renovate/tools/docs/utils.ts
2024-09-08 05:45:43 +00:00

80 lines
2.1 KiB
TypeScript

import { logger } from '../../lib/logger';
import type { ModuleApi } from '../../lib/types';
import { regEx } from '../../lib/util/regex';
import { readFile } from '../utils';
const replaceStart =
'<!-- Autogenerate in https://github.com/renovatebot/renovate -->';
const replaceStop = '<!-- Autogenerate end -->';
const goodUrlRegex = regEx(/\[(.+?)\]\((.+?)\)/);
export function capitalize(input: string): string {
// console.log(input);
return input[0].toUpperCase() + input.slice(1);
}
export function formatName(input: string): string {
return input.split('-').map(capitalize).join(' ');
}
export function getDisplayName(
moduleName: string,
moduleDefinition: ModuleApi,
): string {
return moduleDefinition.displayName ?? formatName(moduleName);
}
export function getNameWithUrl(
moduleName: string,
moduleDefinition: ModuleApi,
): string {
const displayName = getDisplayName(moduleName, moduleDefinition);
if (moduleDefinition.url) {
return `[${displayName}](${moduleDefinition.url})`;
}
return displayName;
}
export function replaceContent(content: string, txt: string): string {
const replaceStartIndex = content.indexOf(replaceStart);
const replaceStopIndex = content.indexOf(replaceStop);
if (replaceStartIndex < 0) {
logger.error('Missing replace placeholder');
return content;
}
return (
content.slice(0, replaceStartIndex) +
txt +
content.slice(replaceStopIndex + replaceStop.length)
);
}
export function formatUrls(urls: string[] | null | undefined): string {
if (Array.isArray(urls) && urls.length) {
return `## References\n\n${urls
.map((url) => {
if (goodUrlRegex.test(url)) {
return ` - ${url}`;
}
return ` - [${url}](${url})`;
})
.join('\n')}\n\n`;
}
return '';
}
export async function formatDescription(
type: string,
name: string,
): Promise<string> {
const content = await readFile(`lib/modules/${type}/${name}/readme.md`);
if (!content) {
return '';
}
return `## Description\n\n${content}\n`;
}
export function getModuleLink(module: string, title?: string): string {
return `[${title ?? module}](${module}/index.md)`;
}