-
Notifications
You must be signed in to change notification settings - Fork 85
Expand file tree
/
Copy pathwebpack.config.js
More file actions
95 lines (85 loc) · 2.45 KB
/
webpack.config.js
File metadata and controls
95 lines (85 loc) · 2.45 KB
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
/* eslint import/no-extraneous-dependencies: ["error", {"devDependencies": true}] */
const CopyWebpackPlugin = require('copy-webpack-plugin');
const OpenBrowserPlugin = require('open-browser-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const SplitByPathPlugin = require('webpack-split-by-path');
const path = require('path');
const { argv } = require('optimist');
const { NODE_ENV } = process.env;
const entry = {
app: []
};
const plugins = [
new HtmlWebpackPlugin({
template: 'index.html',
chunksSortMode: (a, b) => {
const order = ['manifest', 'vendor', 'app'];
const nameA = a.names[0];
const nameB = b.names[0];
return order.indexOf(nameA) - order.indexOf(nameB);
}
}),
new SplitByPathPlugin([{
name: 'vendor',
path: path.join(__dirname, 'node_modules/'),
}]),
function saveChunksPlugin() {
this.plugin('emit', (compilation, callback) => {
const chunks = [];
for (const { files: [jsName] } of compilation.chunks) {
chunks.push(jsName);
}
const chunksJSON = JSON.stringify(chunks);
// eslint-disable-next-line no-param-reassign
compilation.assets['chunks.json'] = {
source: () => chunksJSON,
size: () => chunksJSON.length
};
callback();
});
}
];
if (NODE_ENV === 'development') {
const { port } = argv;
entry.app.push(`webpack-dev-server/client?http://localhost:${port}`);
plugins.push(new OpenBrowserPlugin({
url: `http://localhost:${port}`,
ignoreErrors: true
}));
}
let filename;
let chunkFilename;
if (NODE_ENV === 'development') {
filename = 'js/[name].js';
chunkFilename = 'js/[id].[name].chunk.js';
} else {
filename = 'js/[name]-[chunkhash].js';
chunkFilename = 'js/[id]-[chunkhash].[name].chunk.js';
}
entry.app.push(
'babel-polyfill',
'./js/index'
);
plugins.push(new CopyWebpackPlugin([
{ from: 'static', to: '.' },
]));
module.exports = {
entry,
plugins,
context: __dirname,
output: {
filename,
chunkFilename,
path: path.resolve('dist/'),
library: 'app',
libraryTarget: 'var'
},
module: {
rules: [{
test: /.js?$/,
use: ['babel-loader'],
include: path.resolve('js/')
}]
},
devtool: 'source-map'
};