|
@@ -1,46 +1,17 @@
|
|
|
const path = require('path')
|
|
|
const webpack = require('webpack')
|
|
|
-const ThemeColorReplacer = require('webpack-theme-color-replacer')
|
|
|
-const generate = require('@ant-design/colors/lib/generate').default
|
|
|
+const createThemeColorReplacerPlugin = require('./config/plugin.config')
|
|
|
|
|
|
function resolve (dir) {
|
|
|
return path.join(__dirname, dir)
|
|
|
}
|
|
|
|
|
|
// vue.config.js
|
|
|
-module.exports = {
|
|
|
+const vueConfig = {
|
|
|
configureWebpack: {
|
|
|
plugins: [
|
|
|
// Ignore all locale files of moment.js
|
|
|
- new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/),
|
|
|
- // 生成仅包含颜色的替换样式(主题色等)
|
|
|
- // TODO 需要增加根据环境不开启主题需求
|
|
|
- new ThemeColorReplacer({
|
|
|
- fileName: 'css/theme-colors-[contenthash:8].css',
|
|
|
- matchColors: getAntdSerials('#1890ff'), // 主色系列
|
|
|
- // 改变样式选择器,解决样式覆盖问题
|
|
|
- changeSelector (selector) {
|
|
|
- switch (selector) {
|
|
|
- case '.ant-calendar-today .ant-calendar-date':
|
|
|
- return ':not(.ant-calendar-selected-date):not(.ant-calendar-selected-day)' + selector
|
|
|
- case '.ant-btn:focus,.ant-btn:hover':
|
|
|
- return '.ant-btn:focus:not(.ant-btn-primary),.ant-btn:hover:not(.ant-btn-primary)'
|
|
|
- case '.ant-steps-item-process .ant-steps-item-icon > .ant-steps-icon':
|
|
|
- return ':not(.ant-steps-item-process)' + selector
|
|
|
- case '.ant-btn.active,.ant-btn:active':
|
|
|
- return '.ant-btn.active:not(.ant-btn-primary),.ant-btn:active:not(.ant-btn-primary)'
|
|
|
- case '.ant-menu-horizontal>.ant-menu-item-active,.ant-menu-horizontal>.ant-menu-item-open,.ant-menu-horizontal>.ant-menu-item-selected,.ant-menu-horizontal>.ant-menu-item:hover,.ant-menu-horizontal>.ant-menu-submenu-active,.ant-menu-horizontal>.ant-menu-submenu-open,.ant-menu-horizontal>.ant-menu-submenu-selected,.ant-menu-horizontal>.ant-menu-submenu:hover':
|
|
|
- case '.ant-menu-horizontal > .ant-menu-item-active,.ant-menu-horizontal > .ant-menu-item-open,.ant-menu-horizontal > .ant-menu-item-selected,.ant-menu-horizontal > .ant-menu-item:hover,.ant-menu-horizontal > .ant-menu-submenu-active,.ant-menu-horizontal > .ant-menu-submenu-open,.ant-menu-horizontal > .ant-menu-submenu-selected,.ant-menu-horizontal > .ant-menu-submenu:hover':
|
|
|
- return '.ant-menu-horizontal > .ant-menu-item-active,.ant-menu-horizontal > .ant-menu-item-open,.ant-menu-horizontal > .ant-menu-item-selected,.ant-menu-horizontal:not(.ant-menu-dark) > .ant-menu-item:hover,.ant-menu-horizontal > .ant-menu-submenu-active,.ant-menu-horizontal > .ant-menu-submenu-open,.ant-menu-horizontal:not(.ant-menu-dark) > .ant-menu-submenu-selected,.ant-menu-horizontal:not(.ant-menu-dark) > .ant-menu-submenu:hover'
|
|
|
- case '.ant-menu-horizontal > .ant-menu-item-selected > a':
|
|
|
- return ':not(.ant-menu-horizontal)' + selector
|
|
|
- case '.ant-menu-horizontal > .ant-menu-item > a:hover':
|
|
|
- return ':not(.ant-menu-horizontal)' + selector
|
|
|
- default :
|
|
|
- return selector
|
|
|
- }
|
|
|
- }
|
|
|
- })
|
|
|
+ new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/)
|
|
|
]
|
|
|
},
|
|
|
|
|
@@ -63,32 +34,17 @@ module.exports = {
|
|
|
.options({
|
|
|
name: 'assets/[name].[hash:8].[ext]'
|
|
|
})
|
|
|
- /* svgRule.oneOf('inline')
|
|
|
- .resourceQuery(/inline/)
|
|
|
- .use('vue-svg-loader')
|
|
|
- .loader('vue-svg-loader')
|
|
|
- .end()
|
|
|
- .end()
|
|
|
- .oneOf('external')
|
|
|
- .use('file-loader')
|
|
|
- .loader('file-loader')
|
|
|
- .options({
|
|
|
- name: 'assets/[name].[hash:8].[ext]'
|
|
|
- })
|
|
|
- */
|
|
|
},
|
|
|
|
|
|
css: {
|
|
|
loaderOptions: {
|
|
|
less: {
|
|
|
modifyVars: {
|
|
|
- /* less 变量覆盖,用于自定义 ant design 主题 */
|
|
|
+ // less vars,customize ant design theme
|
|
|
|
|
|
- /*
|
|
|
- 'primary-color': '#F5222D',
|
|
|
- 'link-color': '#F5222D',
|
|
|
- 'border-radius-base': '4px',
|
|
|
- */
|
|
|
+ // 'primary-color': '#F5222D',
|
|
|
+ // 'link-color': '#F5222D',
|
|
|
+ // 'border-radius-base': '4px'
|
|
|
},
|
|
|
javascriptEnabled: true
|
|
|
}
|
|
@@ -98,9 +54,9 @@ module.exports = {
|
|
|
devServer: {
|
|
|
// development server port 8000
|
|
|
port: 8000
|
|
|
+ // If you want to turn on the proxy, please remove the mockjs /src/main.jsL11
|
|
|
// proxy: {
|
|
|
// '/api': {
|
|
|
- // // target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro',
|
|
|
// target: 'https://mock.ihx.me/mock/5baf3052f7da7e07e04a5116/antd-pro',
|
|
|
// ws: false,
|
|
|
// changeOrigin: true
|
|
@@ -115,11 +71,10 @@ module.exports = {
|
|
|
transpileDependencies: []
|
|
|
}
|
|
|
|
|
|
-function getAntdSerials (color) {
|
|
|
- // 淡化(即less的tint)
|
|
|
- const lightens = new Array(9).fill().map((t, i) => {
|
|
|
- return ThemeColorReplacer.varyColor.lighten(color, i / 10)
|
|
|
- })
|
|
|
- const colorPalettes = generate(color)
|
|
|
- return lightens.concat(colorPalettes)
|
|
|
+// preview.pro.loacg.com only do not use in your production;
|
|
|
+if (process.env.NODE_ENV !== 'production' || process.env.VUE_APP_PREVIEW === 'true') {
|
|
|
+ // add `ThemeColorReplacer` plugin to webpack plugins
|
|
|
+ vueConfig.configureWebpack.plugins.push(createThemeColorReplacerPlugin())
|
|
|
}
|
|
|
+
|
|
|
+module.exports = vueConfig
|