forked from FortechRomania/react-redux-complete-example
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
81 lines (71 loc) · 2.14 KB
/
webpack.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
const path = require( "path" );
const webpack = require( "webpack" );
const ExtractTextPlugin = require( "extract-text-webpack-plugin" );
const BundleAnalyzerPlugin = require( "webpack-bundle-analyzer" ).BundleAnalyzerPlugin;
const productionEnv = process.env.NODE_ENV === "production";
const plugins = [
new webpack.optimize.CommonsChunkPlugin( {
name: "lib",
minChunks: Infinity,
filename: "lib.bundle.js",
} ),
new ExtractTextPlugin( {
filename: "[name].bundle.css",
allChunks: true,
} ),
new webpack.DefinePlugin( { "process.env.NODE_ENV": JSON.stringify( process.env.NODE_ENV ) } ),
new BundleAnalyzerPlugin( ),
];
if ( productionEnv ) {
plugins.push(
new webpack.optimize.OccurrenceOrderPlugin(),
new webpack.LoaderOptionsPlugin( { minimize: true, debug: false } ),
new webpack.optimize.UglifyJsPlugin( { sourcemap: true } ) );
}
module.exports = {
context: path.resolve( __dirname, "src" ),
devtool: productionEnv ? "source-map" : "cheap-module-source-map",
entry: {
app: "./client/index.js",
lib: [ "react", "react-dom" ],
},
output: {
path: path.resolve( __dirname, "dist" ),
filename: "[name].bundle.js",
},
resolve: {
alias: {
// react: "preact-compat",
// "react-dom": "preact-compat",
},
modules: [
path.resolve( "./src" ),
"node_modules",
],
},
module: {
rules: [
{
test: /(\.jsx|\.js)$/,
enforce: "pre",
exclude: /node_modules/,
use: [
{
loader: "eslint-loader",
options: {
failOnWarning: false,
failOnError: true,
quiet: true,
},
},
],
},
{
test: /(\.jsx|\.js)$/,
exclude: /node_modules/,
use: "babel-loader",
},
],
},
plugins,
};