chore: class link generation in release notes (#30324)
This commit is contained in:
Родитель
15b423106f
Коммит
01d4293803
|
@ -13,10 +13,14 @@
|
|||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
/** @typedef {'Types'|'ReleaseNotesMd'} OutputType */
|
||||
|
||||
// @ts-check
|
||||
const toKebabCase = require('lodash/kebabCase.js')
|
||||
const Documentation = require('./documentation');
|
||||
|
||||
const createMarkdownLink = (languagePath, member, text) => {
|
||||
function createMarkdownLink(languagePath, member, text) {
|
||||
const className = toKebabCase(member.clazz.name);
|
||||
const memberName = toKebabCase(member.name);
|
||||
let hash = null;
|
||||
|
@ -28,18 +32,33 @@ const createMarkdownLink = (languagePath, member, text) => {
|
|||
};
|
||||
|
||||
/**
|
||||
* @param {string} language
|
||||
* @returns {import('../doclint/documentation').Renderer}
|
||||
* @param {string} languagePath
|
||||
* @param {Documentation.Class} clazz
|
||||
* @returns {string}
|
||||
*/
|
||||
function docsLinkRendererForLanguage(language) {
|
||||
function createClassMarkdownLink(languagePath, clazz) {
|
||||
return `[${clazz.name}](https://playwright.dev${languagePath}/docs/api/class-${clazz.name.toLowerCase()})`;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {string} language
|
||||
* @param {OutputType} outputType
|
||||
* @returns {Documentation.Renderer}
|
||||
*/
|
||||
function docsLinkRendererForLanguage(language, outputType) {
|
||||
const languagePath = languageToRelativeDocsPath(language);
|
||||
return ({ clazz, member, param, option }) => {
|
||||
if (param)
|
||||
return `\`${param}\``;
|
||||
if (option)
|
||||
return `\`${option}\``;
|
||||
if (clazz)
|
||||
return `{@link ${clazz.name}}`;
|
||||
if (clazz) {
|
||||
if (outputType === 'Types')
|
||||
return `{@link ${clazz.name}}`;
|
||||
if (outputType === 'ReleaseNotesMd')
|
||||
return createClassMarkdownLink(languagePath, clazz);
|
||||
throw new Error(`Unexpected output type ${outputType}`);
|
||||
}
|
||||
if (!member || !member.clazz)
|
||||
throw new Error('Internal error');
|
||||
const className = member.clazz.varName === 'playwrightAssertions' ? '' : member.clazz.varName + '.';
|
||||
|
@ -92,7 +111,7 @@ function assertionArgument(className) {
|
|||
}
|
||||
|
||||
/**
|
||||
* @param {import('../doclint/documentation').Member[]} args
|
||||
* @param {Documentation.Member[]} args
|
||||
*/
|
||||
function renderJSSignature(args) {
|
||||
const tokens = [];
|
||||
|
|
|
@ -81,7 +81,7 @@ class TypesGenerator {
|
|||
* @returns {Promise<string>}
|
||||
*/
|
||||
async generateTypes(overridesFile) {
|
||||
this.documentation.setLinkRenderer(docsLinkRendererForLanguage('js'));
|
||||
this.documentation.setLinkRenderer(docsLinkRendererForLanguage('js', 'Types'));
|
||||
this.documentation.setCodeGroupsTransformer('js', tabs => tabs.filter(tab => tab.value === 'ts').map(tab => tab.spec));
|
||||
this.documentation.generateSourceCodeComments();
|
||||
|
||||
|
|
|
@ -40,7 +40,7 @@ if (language === 'js') {
|
|||
.mergeWith(parseApi(path.join(documentationRoot, 'test-reporter-api')));
|
||||
}
|
||||
|
||||
documentation.setLinkRenderer(docsLinkRendererForLanguage(language));
|
||||
documentation.setLinkRenderer(docsLinkRendererForLanguage(language, 'ReleaseNotesMd'));
|
||||
const content = fs.readFileSync(path.join(documentationRoot, `release-notes-${language}.md`)).toString();
|
||||
let nodes = md.parse(content);
|
||||
documentation.renderLinksInNodes(nodes);
|
||||
|
|
Загрузка…
Ссылка в новой задаче