mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-06 12:17:13 +08:00
6d2c60bd68
in the future i will focus on vicons, move the logic outside the ui core
90 lines
2.5 KiB
JavaScript
90 lines
2.5 KiB
JavaScript
// build icon is deprecated
|
|
// it is kept for backward compitability
|
|
// it will be removed in next major version
|
|
// warning info should be added
|
|
// using `vicons` is a recommend way for users to use icons
|
|
|
|
const fs = require('fs')
|
|
const path = require('path')
|
|
const rollup = require('rollup')
|
|
const { plugins, external } = require('../rollup.config')
|
|
const { camelCase, upperFirst } = require('lodash')
|
|
|
|
const iconPath = path.resolve(__dirname, '..', 'src', '_deprecated', 'icons')
|
|
const iconNames = fs.readdirSync(iconPath).filter(name => name.endsWith('.vue'))
|
|
|
|
const iconIndex =
|
|
iconNames.map((iconName) => `import ${upperFirst(camelCase(iconName.match(/.*(?=.vue)/)[0]))} from './${iconName}'`).join('\n') +
|
|
'\n\nexport {\n' +
|
|
iconNames.map((iconName) => ` ${upperFirst(camelCase(iconName.match(/.*(?=.vue)/)[0]))},`).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,
|
|
exports: 'auto'
|
|
}
|
|
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)
|
|
}
|
|
}
|
|
)
|
|
})
|
|
})()
|