-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
110 lines (104 loc) · 2.31 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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
var path = require('path')
var webpack = require('webpack')
var ExtractTextPlugin = require("extract-text-webpack-plugin")
var isProd = process.env.NODE_ENV == 'production'
var cssLoaderOptions = JSON.stringify({
autoprefixer: {
add: true // overwrite cssnano
}
})
var config = module.exports = {
context: path.join(__dirname, 'theme', 'mindcrack', 'assets'),
entry: {
main: ['./javascripts/main.js', './stylesheets/style.scss'],
polyfill: ['core-js/es6/promise.js']
},
output: {
filename: '[name].js',
path: path.join(__dirname, 'public', 'theme', 'mindcrack', 'assets'),
publicPath: '/theme/mindcrack/assets/',
chunkFilename: '[name].[id].js'
},
module: {
loaders: [
{
// Provide bootstrap with jQuery
test: path.join(__dirname, 'node_modules', 'bootstrap'),
exclude: /\.scss$/,
loaders: [
{
loader: 'imports',
query: {
jQuery: 'jquery',
define: '>false'
}
}
]
},
{
// Don't let moment load extra locales
test: path.join(__dirname, 'node_modules', 'moment'),
loaders: [
{
loader: 'imports',
query: {
require: '>false',
define: '>false'
}
}
]
},
{
// ES6
test: /\.js$/,
exclude: /(node_modules)/,
loader: 'babel',
query: {
presets: ['es2015-webpack']
}
},
{
// Sass
test: /\.scss$/,
// Disable sass minification so css-loader handles it
loader: ExtractTextPlugin.extract(['css?' + cssLoaderOptions, 'sass?outputStyle=nested'])
},
{
// Images
test: /\.(png|jpe?g|gif|svg|woff2?|eot|ttf|otf)(\?.*)?$/,
loader: 'url',
query: {
limit: 10000,
name: '[name].[hash:7].[ext]'
}
}
]
},
plugins: [
new ExtractTextPlugin(isProd ? "[name].[hash].css" : "[name].css")
]
}
// Production settings
if (isProd) {
var ManifestPlugin = require('webpack-manifest-plugin')
// Versioning
config.output.filename = '[name].[chunkhash].bundle.js'
config.output.chunkFilename = '[name].[id].[chunkhash].js'
// Plugins
config.plugins.push(
new ManifestPlugin({
basePath: '/theme/mindcrack/assets/',
fileName: '../../../manifest.json'
}),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: '"production"'
}
}),
new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
})
);
}