2021-03-01 23:11:12 +08:00
|
|
|
import path from 'path';
|
|
|
|
import fs from 'fs-extra';
|
|
|
|
import inquirer from 'inquirer';
|
|
|
|
import chalk from 'chalk';
|
|
|
|
import pkg from '../../package.json';
|
|
|
|
|
|
|
|
async function generateIcon() {
|
|
|
|
const dir = path.resolve(process.cwd(), 'node_modules/@iconify/json');
|
|
|
|
|
|
|
|
const raw = await fs.readJSON(path.join(dir, 'collections.json'));
|
|
|
|
|
|
|
|
const collections = Object.entries(raw).map(([id, v]) => ({
|
|
|
|
...(v as any),
|
|
|
|
id,
|
|
|
|
}));
|
|
|
|
|
|
|
|
const choices = collections.map((item) => ({ key: item.id, value: item.id, name: item.name }));
|
|
|
|
|
|
|
|
inquirer
|
|
|
|
.prompt([
|
|
|
|
{
|
2021-03-02 20:54:15 +08:00
|
|
|
type: 'list',
|
|
|
|
name: 'useType',
|
|
|
|
choices: [
|
|
|
|
{ key: 'local', value: 'local', name: 'Local' },
|
|
|
|
{ key: 'onLine', value: 'onLine', name: 'OnLine' },
|
|
|
|
],
|
|
|
|
message: 'How to use icons?',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'list',
|
2021-03-01 23:11:12 +08:00
|
|
|
name: 'iconSet',
|
|
|
|
choices: choices,
|
|
|
|
message: 'Select the icon set that needs to be generated?',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'input',
|
|
|
|
name: 'output',
|
|
|
|
message: 'Select the icon set that needs to be generated?',
|
2021-03-02 20:54:15 +08:00
|
|
|
default: 'src/components/Icon/data',
|
2021-03-01 23:11:12 +08:00
|
|
|
},
|
|
|
|
])
|
|
|
|
.then(async (answers) => {
|
2021-03-02 20:54:15 +08:00
|
|
|
const { iconSet, output, useType } = answers;
|
2021-03-01 23:11:12 +08:00
|
|
|
const outputDir = path.resolve(process.cwd(), output);
|
|
|
|
fs.ensureDir(outputDir);
|
2021-03-02 20:54:15 +08:00
|
|
|
const genCollections = collections.filter((item) => [iconSet].includes(item.id));
|
2021-03-01 23:11:12 +08:00
|
|
|
const prefixSet: string[] = [];
|
|
|
|
for (const info of genCollections) {
|
|
|
|
const data = await fs.readJSON(path.join(dir, 'json', `${info.id}.json`));
|
|
|
|
if (data) {
|
|
|
|
const { prefix } = data;
|
2021-03-02 20:54:15 +08:00
|
|
|
const isLocal = useType === 'local';
|
|
|
|
const icons = Object.keys(data.icons).map(
|
|
|
|
(item) => `${isLocal ? prefix + ':' : ''}${item}`
|
|
|
|
);
|
|
|
|
|
|
|
|
await fs.writeFileSync(
|
|
|
|
path.join(output, `icons.data.ts`),
|
|
|
|
`export default ${isLocal ? JSON.stringify(icons) : JSON.stringify({ prefix, icons })}`
|
|
|
|
);
|
2021-03-01 23:11:12 +08:00
|
|
|
prefixSet.push(prefix);
|
|
|
|
}
|
|
|
|
}
|
2021-03-02 20:54:15 +08:00
|
|
|
fs.emptyDir(path.join(process.cwd(), 'node_modules/.vite'));
|
2021-03-01 23:11:12 +08:00
|
|
|
console.log(
|
|
|
|
`✨ ${chalk.cyan(`[${pkg.name}]`)}` + ' - Icon generated successfully:' + `[${prefixSet}]`
|
|
|
|
);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
generateIcon();
|