-
Notifications
You must be signed in to change notification settings - Fork 29
/
webpack.js.js
92 lines (89 loc) · 2.52 KB
/
webpack.js.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
const browsers = require('./browsers')
module.exports = (config, options) => {
config.module.rules[0].oneOf.push({
test: /\.(js|mjs|jsx)$/,
exclude: /(node_modules)/,
use: [{
loader: require.resolve('babel-loader'),
options: {
sourceType: 'unambiguous',
plugins: [
require.resolve('@babel/plugin-syntax-dynamic-import'),
require.resolve('@babel/plugin-proposal-nullish-coalescing-operator'),
require.resolve('@babel/plugin-proposal-optional-chaining')
],
presets: [
[
require.resolve('@babel/preset-env'), {
useBuiltIns: 'usage',
corejs: 3,
modules: false,
targets: {
browsers: browsers.query(options)
}
}
],
[
require.resolve('@babel/preset-react'), {
pragma: options.jsx
}
]
]
}
}]
})
// transpile node_modules
config.module.rules[0].oneOf.push({
test: /\.(js|mjs)$/,
include (filepath) {
if (filepath.startsWith(config.resolve.alias['core-js'])) return false
if (filepath.startsWith(config.resolve.alias['regenerator-runtime'])) return false
if (filepath.includes('node_modules/core-js/')) return false
if (filepath.includes('node_modules/react-hot-loader/')) return false
if (filepath.includes('node_modules/webpack/')) return false
return true
},
use: [{
loader: require.resolve('babel-loader'),
options: {
babelrc: false,
configFile: false,
compact: false,
sourceMaps: false,
sourceType: 'unambiguous',
plugins: [
require.resolve('@babel/plugin-syntax-dynamic-import')
],
presets: [
[
require.resolve('@babel/preset-env'), {
useBuiltIns: 'usage',
corejs: 3,
modules: false,
// Exclude transforms that make all code slower
// Taken from preact/CRA
exclude: ['transform-typeof-symbol']
}
]
]
}
}]
})
if (options.production) {
if (options.minify) {
const Terser = require('terser-webpack-plugin')
config.plugins.push(new Terser({
parallel: true,
terserOptions: {
mangle: true,
compress: true,
output: {
comments: false
}
}
}))
} else {
config.optimization.minimizer = []
}
}
}