naive-ui/build/buildIcon.js
songwanli2025@163.com 74ee9b4f8a create icon
2020-03-13 04:16:22 +08:00

104 lines
2.6 KiB
JavaScript

const fs = require('fs')
const path = require('path')
const rollup = require('rollup')
const { plugins, external } = require('../rollup.config')
const iconPath = path.resolve(__dirname, '..', 'src', '_icons')
const iconNames = fs.readdirSync(iconPath).filter(name => name.endsWith('.vue'))
const iconIndex =
`/** Never import this file! It is automatically generated for building icons fast */\n\n` +
iconNames.map((iconName, index) => `import $${index} from './${iconName}'`).join('\n') +
'\n\nexport default {\n' +
iconNames.map((_, index) => ` $${index},`).join('\n') +
'\n}'
const iconIndexPath = path.resolve(iconPath, 'index.js')
fs.writeFileSync(
iconIndexPath,
iconIndex
)
const cjsIconPath = path.resolve(__dirname, '..', 'lib', 'icons')
const esmIconPath = path.resolve(__dirname, '..', 'es', 'icons')
function createDirIfNotExists (...args) {
if (!fs.existsSync(path.resolve(...args))) {
fs.mkdirSync(path.resolve(...args))
}
}
createDirIfNotExists(__dirname, '../lib')
createDirIfNotExists(__dirname, '../lib', 'icons')
createDirIfNotExists(__dirname, '../es')
createDirIfNotExists(__dirname, '../es', 'icons')
;(async () => {
const bundle = await rollup
.rollup({
input: path.resolve(iconPath),
preserveModules: true,
plugins,
external
})
const vueExtRegex = /\.vue\.js/g
const cjsOutputOptions = {
format: 'cjs',
dir: cjsIconPath
}
const esmOutputOptions = {
format: 'esm',
dir: esmIconPath
}
const { output: cjsOutput } = await bundle.generate(cjsOutputOptions)
cjsOutput.forEach((file, index) => {
const code = file.code.replace(vueExtRegex, '.js')
const fileName = file.fileName.replace(vueExtRegex, '.js')
fs.writeFile(
path.resolve(cjsIconPath, fileName),
code,
(err) => {
if (err) {
console.log(err)
}
}
)
})
const { output: esmOutput } = await bundle.generate(esmOutputOptions)
esmOutput.forEach((file, index) => {
const code = file.code.replace(vueExtRegex, '.js')
const fileName = file.fileName.replace(vueExtRegex, '.js')
fs.writeFile(
path.resolve(esmIconPath, fileName),
code,
(err) => {
if (err) {
console.log(err)
}
}
)
})
let iconNamesCode = `export default {
iconNames: ${JSON.stringify(iconNames)}
}; `
fs.writeFile(
path.resolve(cjsPath, 'iconNames.js'),
iconNamesCode,
(err) => {
if (err) {
console.log(err)
}
}
)
fs.writeFile(
path.resolve(esmPath, 'iconNames.js'),
iconNamesCode,
(err) => {
if (err) {
console.log(err)
}
}
)
})()