vuecssuiant-designantdreactantantd-vueenterprisefrontendui-designvue-antdvue-antd-uivue3vuecomponent
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
4.2 KiB
146 lines
4.2 KiB
#!/usr/bin/env node |
|
|
|
/* eslint-disable */ |
|
'use strict'; |
|
|
|
const fs = require('fs'); |
|
const path = require('path'); |
|
const packageInfo = require('../package.json'); |
|
const defaultVars = require('./default-vars'); |
|
const darkVars = require('./dark-vars'); |
|
|
|
function generateVersionFile() { |
|
if (fs.existsSync(path.join(__dirname, '../lib'))) { |
|
// Build package.json version to lib/version/index.js |
|
// prevent json-loader needing in user-side |
|
const versionFilePath = path.join(process.cwd(), 'lib', 'version', 'index.js'); |
|
const versionFileContent = fs.readFileSync(versionFilePath).toString(); |
|
fs.writeFileSync( |
|
versionFilePath, |
|
versionFileContent.replace( |
|
`require('../../package.json')`, |
|
`{ version: '${packageInfo.version}' }`, |
|
), |
|
); |
|
console.log('Wrote version into lib/version/index.js'); |
|
} |
|
} |
|
|
|
function generateThemeFileContent(theme) { |
|
return `const { ${theme}ThemeSingle } = require('./theme');\nconst defaultTheme = require('./default-theme');\n |
|
module.exports = { |
|
...defaultTheme, |
|
...${theme}ThemeSingle |
|
}`; |
|
} |
|
|
|
// We need compile additional content for antd user |
|
function finalizeCompile() { |
|
if (fs.existsSync(path.join(__dirname, '../lib'))) { |
|
// Build a entry less file to dist/antd.less |
|
const componentsPath = path.join(process.cwd(), 'components'); |
|
let componentsLessContent = ''; |
|
// Build components in one file: lib/style/components.less |
|
fs.readdir(componentsPath, (err, files) => { |
|
files.forEach(file => { |
|
if (fs.existsSync(path.join(componentsPath, file, 'style', 'index.less'))) { |
|
componentsLessContent += `@import "../${path.join(file, 'style', 'index.less')}";\n`; |
|
} |
|
}); |
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'lib', 'style', 'components.less'), |
|
componentsLessContent, |
|
); |
|
}); |
|
} |
|
} |
|
|
|
function buildThemeFile(theme, vars) { |
|
// Build less entry file: dist/antd.${theme}.less |
|
if (theme !== 'default') { |
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', `antd.${theme}.less`), |
|
`@import "../lib/style/${theme}.less";\n@import "../lib/style/components.less";`, |
|
); |
|
// eslint-disable-next-line no-console |
|
console.log(`Built a entry less file to dist/antd.${theme}.less`); |
|
} else { |
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', `default-theme.js`), |
|
`module.exports = ${JSON.stringify(vars, null, 2)};\n`, |
|
); |
|
return; |
|
} |
|
|
|
// Build ${theme}.js: dist/${theme}-theme.js, for less-loader |
|
|
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', `theme.js`), |
|
`const ${theme}ThemeSingle = ${JSON.stringify(vars, null, 2)};\n`, |
|
{ |
|
flag: 'a', |
|
}, |
|
); |
|
|
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', `${theme}-theme.js`), |
|
generateThemeFileContent(theme), |
|
); |
|
|
|
// eslint-disable-next-line no-console |
|
console.log(`Built a ${theme} theme js file to dist/${theme}-theme.js`); |
|
} |
|
|
|
function finalizeDist() { |
|
if (fs.existsSync(path.join(__dirname, '../dist'))) { |
|
// Build less entry file: dist/antd.less |
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', 'antd.less'), |
|
'@import "../lib/style/index.less";\n@import "../lib/style/components.less";', |
|
); |
|
// eslint-disable-next-line no-console |
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', 'theme.js'), |
|
`const defaultTheme = require('./default-theme.js');\n`, |
|
); |
|
// eslint-disable-next-line no-console |
|
console.log('Built a entry less file to dist/antd.less'); |
|
buildThemeFile('default', defaultVars); |
|
buildThemeFile('dark', darkVars); |
|
// buildThemeFile('compact', compactVars); |
|
fs.writeFileSync( |
|
path.join(process.cwd(), 'dist', `theme.js`), |
|
` |
|
function getThemeVariables(options = {}) { |
|
let themeVar = { |
|
'hack': \`true;@import "\${require.resolve('ant-design-vue/lib/style/color/colorPalette.less')}";\`, |
|
...defaultTheme |
|
}; |
|
if(options.dark) { |
|
themeVar = { |
|
...themeVar, |
|
...darkThemeSingle |
|
} |
|
} |
|
if(options.compact){ |
|
themeVar = { |
|
...themeVar |
|
} |
|
} |
|
return themeVar; |
|
} |
|
|
|
module.exports = { |
|
darkThemeSingle, |
|
getThemeVariables |
|
}`, |
|
{ |
|
flag: 'a', |
|
}, |
|
); |
|
} |
|
} |
|
|
|
generateVersionFile(); |
|
finalizeCompile(); |
|
finalizeDist();
|
|
|