mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 22:36:31 +08:00
138 lines
3.0 KiB
JavaScript
138 lines
3.0 KiB
JavaScript
const program = require('commander');
|
|
const majo = require('majo');
|
|
const style = require('ansi-styles');
|
|
|
|
const unified = require('unified');
|
|
const parse = require('remark-parse');
|
|
const stringify = require('remark-stringify');
|
|
|
|
const yamlConfig = require('remark-yaml-config');
|
|
const frontmatter = require('remark-frontmatter');
|
|
|
|
const remarkWithYaml = unified()
|
|
.use(parse)
|
|
.use(stringify, {
|
|
paddedTable: false,
|
|
listItemIndent: 1,
|
|
})
|
|
.use(frontmatter)
|
|
.use(yamlConfig);
|
|
|
|
const stream = majo();
|
|
|
|
function getCellValue(node) {
|
|
return node.children[0].children[0].value;
|
|
}
|
|
|
|
// from small to large
|
|
const sizeBreakPoints = ['xs', 'sm', 'md', 'lg', 'xl'];
|
|
|
|
const groups = {
|
|
isDynamic: val => /^on[A-Z]/.test(val),
|
|
isSize: val => sizeBreakPoints.indexOf(val) > -1,
|
|
};
|
|
|
|
function asciiSort(prev, next) {
|
|
if (prev > next) {
|
|
return 1;
|
|
}
|
|
|
|
if (prev < next) {
|
|
return -1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
// follow the alphabet order
|
|
function alphabetSort(nodes) {
|
|
// use toLowerCase to keep `case insensitive`
|
|
return nodes.sort((...comparison) => {
|
|
return asciiSort(...comparison.map(val => getCellValue(val).toLowerCase()));
|
|
});
|
|
}
|
|
|
|
function sizeSort(nodes) {
|
|
return nodes.sort((...comparison) => {
|
|
return asciiSort(
|
|
...comparison.map(val =>
|
|
sizeBreakPoints.indexOf(getCellValue(val).toLowerCase())
|
|
)
|
|
);
|
|
});
|
|
}
|
|
|
|
function sort(ast) {
|
|
ast.children.forEach((child) => {
|
|
const staticProps = [];
|
|
// prefix with `on`
|
|
const dynamicProps = [];
|
|
// one of ['xs', 'sm', 'md', 'lg', 'xl']
|
|
const sizeProps = [];
|
|
|
|
// find table markdown type
|
|
if (child.type === 'table') {
|
|
// slice will create new array, so sort can affect the original array.
|
|
// slice(1) cut down the thead
|
|
child.children.slice(1).forEach((node) => {
|
|
const value = getCellValue(node);
|
|
if (groups.isDynamic(value)) {
|
|
dynamicProps.push(node);
|
|
} else if (groups.isSize(value)) {
|
|
sizeProps.push(node);
|
|
} else {
|
|
staticProps.push(node);
|
|
}
|
|
});
|
|
|
|
child.children = [
|
|
child.children[0],
|
|
...alphabetSort(staticProps),
|
|
...sizeSort(sizeProps),
|
|
...alphabetSort(dynamicProps),
|
|
];
|
|
}
|
|
});
|
|
|
|
return ast;
|
|
}
|
|
|
|
function sortAPI(md) {
|
|
return remarkWithYaml.stringify(sort(remarkWithYaml.parse(md)));
|
|
}
|
|
|
|
program
|
|
.version('0.1.0')
|
|
.option(
|
|
'-f, --file [file]',
|
|
'Specify which file to be transformed',
|
|
// default value
|
|
'components/**/index.+(zh-CN|en-US).md'
|
|
)
|
|
.parse(process.argv);
|
|
|
|
function sortMiddleware(ctx) {
|
|
Object.keys(ctx.files).forEach((filename) => {
|
|
const content = ctx.fileContents(filename);
|
|
ctx.writeContents(filename, sortAPI(content));
|
|
});
|
|
}
|
|
|
|
// Get the markdown file all need to be transformed
|
|
stream
|
|
.source(program.file)
|
|
.use(sortMiddleware)
|
|
.dest('.')
|
|
.then(() => {
|
|
/* eslint-disable no-console */
|
|
console.log(
|
|
`${style.green.open}sort ant-design api successfully!${style.green.close}`
|
|
);
|
|
/* eslint-enable no-console */
|
|
});
|
|
|
|
module.exports = {
|
|
getCellValue,
|
|
sort,
|
|
};
|