This repository has been archived by the owner on Mar 13, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.make.js
82 lines (75 loc) · 1.91 KB
/
webpack.make.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
var path = require('path');
var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = function makeWebpackConfig(options) {
var BUILD = !!options.BUILD;
return {
// Efficiently evaluate modules with source maps
devtool: 'eval',
// Cache the build
cache: true,
entry: './src/app.js',
/**
* This will not actually create a bundle.js file in ./dist.
* It is used by the dev server for dynamic hot loading.
*/
output: {
publicPath: BUILD ? '/' : 'http://localhost:8080/',
path: path.join(__dirname, '/dist'),
filename: BUILD ? '[name].[hash].js' : '[name].bundle.js',
chunkFilename: BUILD ? '[name].[hash].js' : '[name].bundle.js'
},
plugins: [
new HtmlWebpackPlugin({
template: './src/index.html',
inject: 'body'
})
],
/**
* Transform JS source code using Babel configured to Stage 0, transform CSS
* source code using PostCSS and require binary files with file-loader.
*/
module: {
loaders: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
query: {
presets: ['es2015']
}
},
{
test: /\.css$/,
exclude: /node_modules/,
loaders: ['style-loader', 'css-loader']
},
{
test: /\.woff(2)?(\?.*)?$/,
loader: "url-loader?limit=30000&name=[name]-[hash].[ext]"
},
{
test: /\.(ttf|eot|svg)(\?.*)?$/,
loader: "file"
},
{
test: /\.(png|jpg|jpeg|gif)$/,
loader: 'file'
},
{
test: /\.html$/,
loader: 'raw'
}
]
},
devServer: {
contentBase: './dist',
stats: {
modules: false,
cached: false,
colors: true,
chunk: false
}
}
};
};