-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathwebpack.config.production.js
138 lines (121 loc) · 3.5 KB
/
webpack.config.production.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/**
* Build config for electron 'Renderer Process' file
*/
import path from "path";
import webpack from "webpack";
import ExtractTextPlugin from "extract-text-webpack-plugin";
import merge from "webpack-merge";
import HtmlWebpackPlugin from "html-webpack-plugin";
import baseConfig from "./webpack.config.base";
const config = merge(baseConfig, {
devtool: "cheap-module-source-map",
entry: [
"babel-polyfill",
"./app/index"
],
output: {
path: path.join(__dirname, "app/dist"),
publicPath: "../dist/"
},
module: {
rules: [
// Extract all .global.css to style.css as is
{
test: /\.global\.css$/,
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: "css-loader"
})
},
// Pipe other styles through css modules and append to style.css
{
test: /^((?!\.global).)*\.css$/,
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: [{
loader: "css-loader",
options: {
modules: true,
importLoaders: 1,
localIdentName: "[name]__[local]___[hash:base64:5]"
}
}]
})
},
{
test: /\.less$/,
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: [{
loader: "css-loader",
options: {
modules: true,
importLoaders: 1,
localIdentName: "[local]"
}
}, {
loader: "less-loader",
options: {
noIeCompat: true,
strictMath: true
}
}]
})
},
{
test: [ /\.woff(\?v=\d+\.\d+\.\d+)?$/, /\.woff2(\?v=\d+\.\d+\.\d+)?$/ ],
use: [{
loader: "url-loader",
options: { limit: 10000, mimetype: "application/font-woff" }
}]
},
{
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
use: [{
loader: "url-loader",
options: { limit: 10000, mimetype: "application/octet-stream" }
}]
},
{
test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: "file-loader" }]
},
{
test: /\.gif(\?v=\d+\.\d+\.\d+)?$/,
use: [{ loader: "file-loader" }]
},
{
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
use: [{
loader: "url-loader",
options: { limit: 10000, mimetype: "image/svg+xml"}
}]
}
]
},
plugins: [
// https://webpack.github.io/docs/list-of-plugins.html#occurrenceorderplugin
// https://github.com/webpack/webpack/issues/864
new webpack.optimize.OccurrenceOrderPlugin(),
// NODE_ENV should be production so that modules do not perform certain development checks
new webpack.DefinePlugin({
"process.env.NODE_ENV": JSON.stringify("production")
}),
// Minify without warning messages and IE8 support
new webpack.optimize.UglifyJsPlugin({
compressor: {
screw_ie8: true,
warnings: false
}
}),
new ExtractTextPlugin({ filename: "style.css", allChunks: true }),
new HtmlWebpackPlugin({
filename: "../app.html",
template: "app/app.html",
inject: false
})
],
// https://github.com/chentsulin/webpack-target-electron-renderer#how-this-module-works
target: "electron-renderer"
});
export default config;