-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.production.config.js
109 lines (103 loc) · 2.5 KB
/
webpack.production.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/**
* Created by jonlazarini on 06/03/17.
*/
var webpack = require('webpack');
var path = require('path');
var loaders = require('./webpack.loaders');
var WebpackCleanupPlugin = require('webpack-cleanup-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var ManifestPlugin = require('webpack-manifest-plugin');
const extractSass = new ExtractTextPlugin({
filename: "[name].[hash].css",
disable: process.env.NODE_ENV === "development",
allChunks: true
});
loaders.push({
rules: [{
test: /\.scss$/,
loader: extractSass.extract({
use: [{
loader: "css-loader"
}, {
loader: "sass-loader"
}],
fallback: "style-loader"
})
}]
});
loaders.push({
include: /\.pug/,
test: /\.pug/,
exclude: /(node_modules|bower_components)/,
use: [
{loader: 'raw-loader'},
{loader: 'pug-html-loader'}
]
});
// ** old **
// loaders.push({
// test: /\.scss$/,
// loader: extractSass.extract({
// use : 'css-loader?sourceMap&localIdentName=[local]___[hash:base64:5]!sass-loader?outputStyle=expanded',
// fallback: 'style-loader'
// }),
// exclude: ['node_modules']
// });
module.exports = {
entry: {
bundle: './src/index.js', // entry point will be named bundle
style: './src/sass/main.scss',
vendors: ['jquery', 'bootstrap']
},
output: {
publicPath: '/',
path: path.join(__dirname, 'public'),
filename: '[name].[hash].js'
},
resolve: {
extensions: ['.js', '.jsx']
},
externals:[{
xmlhttprequest: '{XMLHttpRequest:XMLHttpRequest}'
}],
module: {
loaders
},
plugins: [
new WebpackCleanupPlugin(),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: '"production"'
}
}),
//TODO IMPORTANT Fix break js bundle
new webpack.optimize.UglifyJsPlugin({
// }),
compress: {
warnings: false,
screw_ie8: true,
drop_console: true,
drop_debugger: true
}
}),
new webpack.optimize.OccurrenceOrderPlugin(),
/*new HtmlWebpackPlugin({
template: './src/views/index.pug',
files: {
style: ['[name].[hash].css'], // will be css.hashkey.css (entry point)
js: [ '[name].[hash].js'] // will be app.hashkey.js & vendor.hashley.js (entry point)
}
}),*/
// Provides jQuery on global scope can be called using $ or jQuery no need to do scope scope binding
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
Bootstrap: 'bootstrap'
}),
// creates CSS file
extractSass,
new ManifestPlugin({
fileName: 'build-manifest.json'
})
]
};