-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
92 lines (77 loc) · 2.65 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
82
83
84
85
86
87
88
89
90
91
92
import path from "path";
import webpack from "webpack";
import ExtractTextPlugin from "extract-text-webpack-plugin";
export default (DEBUG, PATH, PORT=3000) => ({
entry: (DEBUG ? [
`webpack-dev-server/client?http://localhost:${PORT}`,
] : []).concat([
'./src/main.less',
'babel-polyfill',
'./src/main',
]),
output: {
path: path.resolve(__dirname, PATH, "generated"),
filename: DEBUG ? "main.js" : "main-[hash].js",
publicPath: "/generated/"
},
cache: DEBUG,
debug: DEBUG,
// For options, see http://webpack.github.io/docs/configuration.html#devtool
devtool: DEBUG && "eval",
module: {
loaders: [
// Load ES6/JSX
{ test: /\.jsx?$/,
include: [
path.resolve(__dirname, "src"),
],
loader: "babel-loader",
query: {
plugins: ['transform-runtime'],
presets: ['es2015', 'stage-0', 'react'],
}
},
// Load styles
{ test: /\.less$/,
loader: DEBUG
? "style!css!autoprefixer!less"
: ExtractTextPlugin.extract("style-loader", "css-loader!autoprefixer-loader!less-loader")
},
// Load images
{ test: /\.jpg/, loader: "url-loader?limit=10000&mimetype=image/jpg" },
{ test: /\.gif/, loader: "url-loader?limit=10000&mimetype=image/gif" },
{ test: /\.png/, loader: "url-loader?limit=10000&mimetype=image/png" },
{ test: /\.svg/, loader: "url-loader?limit=10000&mimetype=image/svg" },
// Load fonts
{ test: /\.woff(\?v=[0-9]\.[0-9]\.[0-9])?$/, loader: "url-loader?limit=10000&mimetype=application/font-woff" },
{ test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/, loader: "file-loader" },
]
},
plugins: DEBUG
? []
: [
new webpack.DefinePlugin({'process.env.NODE_ENV': '"production"'}),
new ExtractTextPlugin("style.css", {allChunks: false}),
new webpack.optimize.DedupePlugin(),
new webpack.optimize.UglifyJsPlugin({
compressor: {screw_ie8: true, keep_fnames: true, warnings: false},
mangle: {screw_ie8: true, keep_fnames: true}
}),
new webpack.optimize.OccurenceOrderPlugin(),
new webpack.optimize.AggressiveMergingPlugin(),
],
resolveLoader: {
root: path.join(__dirname, "node_modules"),
},
resolve: {
root: path.join(__dirname, "node_modules"),
modulesDirectories: ['node_modules'],
alias: {
environment: DEBUG
? path.resolve(__dirname, 'config', 'environments', 'development.js')
: path.resolve(__dirname, 'config', 'environments', 'production.js')
},
// Allow to omit extensions when requiring these files
extensions: ["", ".js", ".jsx"],
}
});