| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 | 
							- const CompressionWebpackPlugin = require('compression-webpack-plugin')
 
- const VueFilenameInjector = require('@d2-projects/vue-filename-injector')
 
- const ThemeColorReplacer = require('webpack-theme-color-replacer')
 
- const forElementUI = require('webpack-theme-color-replacer/forElementUI')
 
- const cdnDependencies = require('./dependencies-cdn')
 
- const { chain, set, each } = require('lodash')
 
- const resolve = dir => require('path').join(__dirname, dir)
 
- process.env.VUE_APP_VERSION = require('./package.json').version
 
- process.env.VUE_APP_BUILD_TIME = require('dayjs')().format('YYYY-M-D HH:mm:ss')
 
- const publicPath = process.env.VUE_APP_PUBLIC_PATH || '/'
 
- const externals = {}
 
- cdnDependencies.forEach(pkg => { externals[pkg.name] = pkg.library })
 
- const cdn = {
 
-   css: cdnDependencies.map(e => e.css).filter(e => e),
 
-   js: cdnDependencies.map(e => e.js).filter(e => e)
 
- }
 
- const pages = undefined
 
- module.exports = {
 
-   
 
-   publicPath,
 
-   lintOnSave: true,
 
-   devServer: {
 
-     publicPath, 
 
-     disableHostCheck: process.env.NODE_ENV === 'development' 
 
-   },
 
-   css: {
 
-     loaderOptions: {
 
-       
 
-       sass: {
 
-         prependData: '@import \'~@/assets/style/public.scss\';'
 
-       }
 
-     }
 
-   },
 
-   pages,
 
-   configureWebpack: config => {
 
-     const configNew = {}
 
-     if (process.env.NODE_ENV === 'production') {
 
-       configNew.externals = externals
 
-       configNew.plugins = [
 
-         
 
-         new CompressionWebpackPlugin({
 
-           filename: '[path].gz[query]',
 
-           test: new RegExp('\\.(' + ['js', 'css'].join('|') + ')$'),
 
-           threshold: 10240,
 
-           minRatio: 0.8,
 
-           deleteOriginalAssets: false
 
-         })
 
-       ]
 
-     }
 
-     return configNew
 
-   },
 
-   
 
-   chainWebpack: config => {
 
-     
 
-     const htmlPluginNames = chain(pages).keys().map(page => 'html-' + page).value()
 
-     const targetHtmlPluginNames = htmlPluginNames.length ? htmlPluginNames : ['html']
 
-     each(targetHtmlPluginNames, name => {
 
-       config.plugin(name).tap(options => {
 
-         set(options, '[0].cdn', process.env.NODE_ENV === 'production' ? cdn : [])
 
-         return options
 
-       })
 
-     })
 
-     
 
-     config.plugins
 
-       .delete('prefetch')
 
-       .delete('preload')
 
-     
 
-     config.resolve
 
-       .symlinks(true)
 
-     config
 
-       .plugin('theme-color-replacer')
 
-       .use(ThemeColorReplacer, [{
 
-         fileName: 'css/theme-colors.[contenthash:8].css',
 
-         matchColors: [
 
-           ...forElementUI.getElementUISeries(process.env.VUE_APP_ELEMENT_COLOR) 
 
-         ],
 
-         externalCssFiles: ['./node_modules/element-ui/lib/theme-chalk/index.css'], 
 
-         changeSelector: forElementUI.changeSelector
 
-       }])
 
-     config
 
-       
 
-       .when(process.env.NODE_ENV === 'development',
 
-         config => config.devtool('cheap-source-map')
 
-       )
 
-       
 
-       .when(
 
-         process.env.VUE_APP_SCOURCE_LINK === 'TRUE',
 
-         config => VueFilenameInjector(config, {
 
-           propName: process.env.VUE_APP_SOURCE_VIEWER_PROP_NAME
 
-         })
 
-       )
 
-     
 
-     config.module
 
-       .rule('md')
 
-       .test(/\.md$/)
 
-       .use('text-loader')
 
-       .loader('text-loader')
 
-       .end()
 
-     
 
-     const svgRule = config.module.rule('svg')
 
-     svgRule.uses.clear()
 
-     svgRule
 
-       .include
 
-       .add(resolve('src/assets/svg-icons/icons'))
 
-       .end()
 
-       .use('svg-sprite-loader')
 
-       .loader('svg-sprite-loader')
 
-       .options({
 
-         symbolId: 'd2-[name]'
 
-       })
 
-       .end()
 
-     
 
-     const imagesRule = config.module.rule('images')
 
-     imagesRule
 
-       .test(/\.(png|jpe?g|gif|webp|svg)(\?.*)?$/)
 
-       .exclude
 
-       .add(resolve('src/assets/svg-icons/icons'))
 
-       .end()
 
-     
 
-     config.resolve.alias
 
-       .set('@api', resolve('src/api'))
 
-     
 
-     if (process.env.npm_config_report) {
 
-       config
 
-         .plugin('webpack-bundle-analyzer')
 
-         .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)
 
-     }
 
-   },
 
-   
 
-   productionSourceMap: false,
 
-   
 
-   pluginOptions: {
 
-     i18n: {
 
-       locale: 'zh-chs',
 
-       fallbackLocale: 'en',
 
-       localeDir: 'locales',
 
-       enableInSFC: true
 
-     }
 
-   }
 
- }
 
 
  |