-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
95 lines (91 loc) · 2.4 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
const util = require('util')
const glob = util.promisify(require('glob'))
const path = require('path')
const webpack = require('webpack')
const baseConfig = require('@instructure/ui-webpack-config')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const TerserWebpackPlugin = require('terser-webpack-plugin')
const { CleanWebpackPlugin } = require('clean-webpack-plugin')
const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin')
const mode = process.env.NODE_ENV || 'production'
const outputPath = path.resolve(__dirname, 'build')
const requires = ['instui-runtime-common', 'instui-vendors-common']
const bannerTemplate = `/**
* @provides instui-[name]
* @requires ${requires.join(' ')}
*/
`
const plugins = []
if (mode === 'production') {
plugins.push(
new CleanWebpackPlugin(),
new webpack.BannerPlugin({
banner: (context) => {
if (requires.includes(`instui-${context.chunk.name}`)) {
return bannerTemplate.replace(` * @requires ${requires.join(' ')}\n`, '')
}
return bannerTemplate
},
raw: true,
}),
)
} else {
plugins.push(
new ReactRefreshWebpackPlugin(),
new HtmlWebpackPlugin({
filename: 'index.html',
template: './src/index.html',
}),
)
}
module.exports = {
...baseConfig,
entry: () => glob('./src/*/entry.js').then(matches => matches.reduce((entry, entryPath) => {
const appName = entryPath.split('/')[2]
const entryName = appName.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()
return { ...entry, [entryName]:entryPath }
}, {})),
optimization: {
...baseConfig.optimization,
runtimeChunk: {
name: 'runtime-common',
},
splitChunks: {
...baseConfig.optimization.splitChunks,
name: 'vendors-common',
},
minimizer: [
new TerserWebpackPlugin({
cache: true,
parallel: true,
sourceMap: mode !== 'production',
terserOptions: {
mangle: false,
output: {
semicolons: false,
comments: /@provides/,
},
},
extractComments: 'some',
})
],
},
output: {
path: outputPath,
filename: '[name].js',
},
devServer: {
disableHostCheck: true,
contentBase: false,
host: '0.0.0.0',
hot: true,
},
node: {
...baseConfig.node,
__filename: true,
},
plugins: [
...baseConfig.plugins,
...plugins,
],
}