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.
132 lines
4.0 KiB
132 lines
4.0 KiB
/* |
|
* Licensed to the Apache Software Foundation (ASF) under one or more |
|
* contributor license agreements. See the NOTICE file distributed with |
|
* this work for additional information regarding copyright ownership. |
|
* The ASF licenses this file to You under the Apache License, Version 2.0 |
|
* (the "License"); you may not use this file except in compliance with |
|
* the License. You may obtain a copy of the License at |
|
* |
|
* http://www.apache.org/licenses/LICENSE-2.0 |
|
* |
|
* Unless required by applicable law or agreed to in writing, software |
|
* distributed under the License is distributed on an "AS IS" BASIS, |
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
* See the License for the specific language governing permissions and |
|
* limitations under the License. |
|
*/ |
|
const path = require('path') |
|
const webpack = require('webpack') |
|
const merge = require('webpack-merge') |
|
const CopyWebpackPlugin = require('copy-webpack-plugin') |
|
const { baseConfig } = require('./config') |
|
const ExtractTextPlugin = require('extract-text-webpack-plugin') |
|
const UglifyJSPlugin = require('uglifyjs-webpack-plugin') |
|
const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin') |
|
|
|
const resolve = dir => |
|
path.resolve(__dirname, '..', dir) |
|
|
|
const config = merge.smart(baseConfig, { |
|
devtool: 'source-map', |
|
output: { |
|
filename: 'js/[name].[chunkhash:7].js' |
|
}, |
|
module: { |
|
rules: [ |
|
{ |
|
test: /\.vue$/, |
|
loader: 'vue-loader', |
|
options: { |
|
hotReload: false // 开启热重载 |
|
} |
|
}, |
|
{ |
|
test: /\.css$/, |
|
loader: ExtractTextPlugin.extract({ |
|
use: [ |
|
'css-loader', |
|
{ |
|
loader: 'postcss-loader', |
|
options: { |
|
plugins: (loader) => [ |
|
require('autoprefixer')({ |
|
'browsers': [ '> 1%', 'last 3 versions', 'ie >= 9' ] |
|
}), |
|
require('cssnano') |
|
] |
|
} |
|
} |
|
], |
|
fallback: ['vue-style-loader'] |
|
}) |
|
}, |
|
{ |
|
test: /\.scss$/, |
|
loader: ExtractTextPlugin.extract({ |
|
use: [ |
|
'css-loader', |
|
'sass-loader', |
|
{ |
|
loader: 'postcss-loader', |
|
options: { |
|
plugins: (loader) => [ |
|
require('autoprefixer')({ |
|
'browsers': [ '> 1%', 'last 3 versions', 'ie >= 9' ] |
|
}), |
|
require('cssnano') |
|
] |
|
} |
|
} |
|
], |
|
fallback: ['vue-style-loader'] |
|
}) |
|
} |
|
] |
|
}, |
|
plugins: [ |
|
new ExtractTextPlugin({ filename: 'css/[name].[contenthash:7].css', allChunks: true }), |
|
new webpack.optimize.CommonsChunkPlugin({ name: 'common', filename: 'js/[name].[hash:7].js' }), |
|
new webpack.optimize.OccurrenceOrderPlugin(), |
|
new OptimizeCssAssetsPlugin({ |
|
assetNameRegExp: /\.css$/g, |
|
cssProcessor: require('cssnano'), |
|
cssProcessorOptions: { discardComments: { removeAll: true } }, |
|
canPrint: true |
|
}), |
|
new UglifyJSPlugin({ |
|
parallel: true, |
|
sourceMap: true, |
|
uglifyOptions: { |
|
compress: { |
|
warnings: false, |
|
drop_debugger: true, |
|
drop_console: true, |
|
pure_funcs: ['console.log']//移除console |
|
}, |
|
comments: function (n, c) { |
|
/*! IMPORTANT: Please preserve 3rd-party library license info, inspired from @allex/amd-build-worker/config/jsplumb.js */ |
|
var text = c.value, type = c.type |
|
if (type === 'comment2') { |
|
return /^!|@preserve|@license|@cc_on|MIT/i.test(text) |
|
} |
|
} |
|
} |
|
}), |
|
new CopyWebpackPlugin([ |
|
{ |
|
from: resolve('src/combo'), |
|
to: resolve('dist/combo') |
|
}, |
|
{ |
|
from: resolve('src/lib'), |
|
to: resolve('dist/lib') |
|
}, |
|
{ |
|
from: resolve('src/images'), |
|
to: resolve('dist/images') |
|
}, |
|
]), |
|
] |
|
}) |
|
|
|
module.exports = config
|
|
|