mirror of
https://github.com/alibaba/anyproxy.git
synced 2025-04-20 12:14:21 +00:00
115 lines
2.8 KiB
JavaScript
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
|
|
}
|
|
};
|