redux-devtools/packages/redux-devtools-inspector/webpack.config.js
2019-01-10 20:51:14 +02:00

81 lines
2.0 KiB
JavaScript

var path = require('path');
var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var CleanWebpackPlugin = require('clean-webpack-plugin');
var ExportFilesWebpackPlugin = require('export-files-webpack-plugin');
var NyanProgressWebpackPlugin = require('nyan-progress-webpack-plugin');
var pkg = require('./package.json');
var isProduction = process.env.NODE_ENV === 'production';
module.exports = {
mode: process.env.NODE_ENV || 'development',
devtool: 'eval',
entry: isProduction
? ['./demo/src/js/index']
: [
'webpack-dev-server/client?http://localhost:3000',
'webpack/hot/only-dev-server',
'./demo/src/js/index'
],
output: {
path: path.join(__dirname, 'demo/dist'),
filename: 'js/bundle.js'
},
plugins: [
new CleanWebpackPlugin(isProduction ? ['demo/dist'] : []),
new HtmlWebpackPlugin({
inject: true,
template: 'demo/src/index.html',
filename: 'index.html',
package: pkg
}),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify(process.env.NODE_ENV)
}
}),
new NyanProgressWebpackPlugin()
].concat(
isProduction
? [
new webpack.optimize.UglifyJsPlugin({
compress: { warnings: false },
output: { comments: false }
})
]
: [
new ExportFilesWebpackPlugin('demo/dist/index.html'),
new webpack.HotModuleReplacementPlugin()
]
),
resolve: {
extensions: ['*', '.js', '.jsx']
},
module: {
rules: [
{
test: /\.jsx?$/,
loader: 'babel-loader',
include: [
path.join(__dirname, 'src'),
path.join(__dirname, 'demo/src/js')
]
}
]
},
devServer: isProduction
? null
: {
quiet: false,
port: 3000,
hot: true,
stats: {
chunkModules: false,
colors: true
},
historyApiFallback: true
}
};