chore: class link generation in release notes (#30324)

This commit is contained in:
Yury Semikhatsky 2024-04-10 10:05:54 -07:00 коммит произвёл GitHub
Родитель 15b423106f
Коммит 01d4293803
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: B5690EEEBB952194
3 изменённых файлов: 28 добавлений и 9 удалений

Просмотреть файл

@ -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);