forked from dmkorol/react-hot-reload-simple-starter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
60 lines (55 loc) · 1.41 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
var Path = require('path');
var Clean = require('clean-webpack-plugin');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var Minimist = require('minimist');
var Webpack = require('webpack');
var Rupture = require('rupture');
var AutoPrefixer = require('autoprefixer-stylus');
var argv = Minimist(process.argv);
var plugins = [];
plugins.push(new HtmlWebpackPlugin({
template: 'index.template',
inject: 'body'
}));
plugins.push(new Webpack.EnvironmentPlugin('NODE_ENV'));
if (argv.prod) {
plugins.push(new Webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
}));
plugins.push(new Clean(['build']));
plugins.push(new Webpack.optimize.OccurenceOrderPlugin(true));
}
module.exports = {
entry: {
app: ['webpack/hot/dev-server', './client/style/main.styl', './client/js/app.js']
},
output: {
path: './build',
filename: 'bundle.js'
},
module: {
loaders: [{
test: /\.js$/,
include: [
Path.resolve(process.cwd(), 'client/js')
],
loader: 'babel?optional[]=runtime'
}, {
test: /\.styl$/,
loader: 'style-loader!css-loader!stylus-loader?paths=node_modules/jeet/stylus/'
}, {
test: /\.(ttf|eot|svg|png)$/,
loader: "file"
}]
},
resolve: {
extensions: ['', '.js', '.styl', '.png'],
modulesDirectories: ['node_modules']
},
stylus: {
use: [Rupture(), AutoPrefixer()]
},
plugins: plugins
};