mirror of
https://gitee.com/ant-design-vue/ant-design-vue.git
synced 2024-11-30 02:57:50 +08:00
102 lines
3.2 KiB
JavaScript
102 lines
3.2 KiB
JavaScript
const TypeDoc = require('typedoc');
|
|
const fs = require('fs-extra');
|
|
|
|
const getTokenList = (list, source) =>
|
|
list
|
|
.filter(
|
|
item =>
|
|
!item.comment?.blockTags.some(tag => tag.tag === '@internal' || tag.tag === '@private'),
|
|
)
|
|
.map(item => ({
|
|
source,
|
|
token: item.name,
|
|
type: item.type.toString(),
|
|
desc:
|
|
item.comment?.blockTags
|
|
?.find(tag => tag.tag === '@desc')
|
|
?.content.reduce((result, str) => result.concat(str.text), '') || '',
|
|
descEn:
|
|
item.comment?.blockTags
|
|
?.find(tag => tag.tag === '@descEN')
|
|
?.content.reduce((result, str) => result.concat(str.text), '') || '',
|
|
name:
|
|
item.comment?.blockTags
|
|
?.find(tag => tag.tag === '@nameZH')
|
|
?.content.reduce((result, str) => result.concat(str.text), '') || '',
|
|
nameEn:
|
|
item.comment?.blockTags
|
|
?.find(tag => tag.tag === '@nameEN')
|
|
?.content.reduce((result, str) => result.concat(str.text), '') || '',
|
|
}));
|
|
|
|
function main() {
|
|
const app = new TypeDoc.Application();
|
|
|
|
// If you want TypeDoc to load tsconfig.json / typedoc.json files
|
|
app.options.addReader(new TypeDoc.TSConfigReader());
|
|
app.options.addReader(new TypeDoc.TypeDocReader());
|
|
|
|
app.bootstrap({
|
|
// typedoc options here
|
|
entryPoints: ['components/theme/interface/index.ts'],
|
|
});
|
|
|
|
const project = app.convert();
|
|
|
|
if (project) {
|
|
// Project may not have converted correctly
|
|
const output = 'components/version/token-meta.json';
|
|
const tokenMeta = {};
|
|
let presetColors = [];
|
|
project.children.forEach(type => {
|
|
if (type.name === 'SeedToken') {
|
|
tokenMeta.seed = getTokenList(type.children, 'seed');
|
|
} else if (type.name === 'MapToken') {
|
|
tokenMeta.map = getTokenList(type.children, 'map');
|
|
} else if (type.name === 'AliasToken') {
|
|
tokenMeta.alias = getTokenList(type.children, 'alias');
|
|
} else if (type.name === 'PresetColors') {
|
|
presetColors = type.type.target.elements.map(item => item.value);
|
|
}
|
|
});
|
|
|
|
// Exclude preset colors
|
|
tokenMeta.seed = tokenMeta.seed.filter(
|
|
item => !presetColors.some(color => item.token.startsWith(color)),
|
|
);
|
|
tokenMeta.map = tokenMeta.map.filter(
|
|
item => !presetColors.some(color => item.token.startsWith(color)),
|
|
);
|
|
tokenMeta.alias = tokenMeta.alias.filter(
|
|
item => !presetColors.some(color => item.token.startsWith(color)),
|
|
);
|
|
|
|
tokenMeta.alias = tokenMeta.alias.filter(
|
|
item => !tokenMeta.map.some(mapItem => mapItem.token === item.token),
|
|
);
|
|
tokenMeta.map = tokenMeta.map.filter(
|
|
item => !tokenMeta.seed.some(seedItem => seedItem.token === item.token),
|
|
);
|
|
|
|
const finalMeta = Object.entries(tokenMeta).reduce((acc, [key, value]) => {
|
|
value.forEach(item => {
|
|
acc[item.token] = {
|
|
name: item.name,
|
|
nameEn: item.nameEn,
|
|
desc: item.desc,
|
|
descEn: item.descEn,
|
|
type: item.type,
|
|
source: key,
|
|
};
|
|
});
|
|
return acc;
|
|
}, {});
|
|
|
|
fs.writeJsonSync(output, finalMeta, 'utf8');
|
|
// eslint-disable-next-line no-console
|
|
console.log(`✅ Token Meta has been written to ${output}`);
|
|
}
|
|
}
|
|
|
|
main();
|