anyproxy/web/webpack.config.js

115 lines
2.8 KiB
JavaScript

const webpack = require('webpack');
const path = require('path');
const autoprefixer = require('autoprefixer');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const UglifyJsPlugin = webpack.optimize.UglifyJsPlugin;
const extractCss = new ExtractTextPlugin('[name].css', {
disable: false,
allChunks: true
});
// a plugin to set the environment
const defineProperty = new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify(process.env.NODE_ENV || 'test')
}
});
module.exports = {
entry: ['whatwg-fetch', 'babel-polyfill', path.join(__dirname, './src/index.jsx')],
output: {
path: path.join(__dirname, 'dist'),
filename: 'main.js'
},
resolve: {
modules: [
'node_modules',
path.join(__dirname, 'src')
],
extensions: ['.', '.js', '.jsx']
},
module: {
rules: [{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
presets: ['es2015', 'stage-0']
}
},
{
test: /\.jsx$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
presets: ['es2015', 'stage-0', 'react'],
plugins: [['import', { libraryName: 'antd', style: true }]]
}
}
},
{
test: function (filePath) {
return (/antd\/.*\.less$/.test(filePath) || /\.global\.less$/.test(filePath));
},
use: ExtractTextPlugin.extract({use: 'css-loader!postcss-loader!less-loader'})
},
{
test: function (filePath) {
return (/\.less$/.test(filePath) && !/\.global\.less$/.test(filePath) && !/antd\/.*\.less$/.test(filePath));
},
use: ExtractTextPlugin.extract({use: 'css-loader?modules&localIdentName=[local]___[hash:base64:5]!postcss-loader!less-loader'})
},
{
test: /\.css$/,
use: ExtractTextPlugin.extract({use:'css-loader'})
},
{
test: /\.png(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: 'url-loader?limit=10000&mimetype=image/png'
}
},
{
test: /\.woff(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: 'url-loader?limit=10000&mimetype=application/font-woff'
}
},
{
test: /\.woff2(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: 'url-loader?limit=10000&mimetype=application/font-woff'
}
},
{
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: 'url-loader?limit=10000&mimetype=application/octet-stream'
}
},
{
test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: 'url-loader?limit=10000&mimetype=application/octet-stream'
}
},
{
test: /font\.svg(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: 'url-loader?limit=10000&mimetype=image/svg+xml'
}
}]
},
plugins: [
extractCss,
defineProperty,
new UglifyJsPlugin()
],
stats: {
children: false
}
};