-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathconfig-overrides.js
52 lines (49 loc) · 1.82 KB
/
config-overrides.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
const webpack = require('webpack');
const ImageMinimizerPlugin = require("image-minimizer-webpack-plugin");
/**
* Edit webpack config...
*/
module.exports = function override(config, env) {
const fallback = config.resolve.fallback || {};
Object.assign(fallback, {
"crypto": require.resolve("crypto-browserify"),
"stream": require.resolve("stream-browserify"),
"assert": require.resolve("assert"),
"http": require.resolve("stream-http"),
"https": require.resolve("https-browserify"),
"os": require.resolve("os-browserify"),
"url": require.resolve("url"),
"vm": require.resolve("vm-browserify")
})
config.resolve.fallback = fallback;
config.plugins = (config.plugins || []).concat([
new webpack.ProvidePlugin({
process: 'process/browser',
Buffer: ['buffer', 'Buffer']
}),
])
// Add Babel plugin to remove console logs in production
if (env === 'production') {
const babelLoader = config.module.rules.find(rule => rule.oneOf)
.oneOf.find(rule => rule.loader && rule.loader.includes('babel-loader'));
if (babelLoader) {
babelLoader.options.plugins = (babelLoader.options.plugins || []).concat(
"babel-plugin-transform-remove-console"
);
}
config.optimization.minimizer.push(
new ImageMinimizerPlugin({
minimizer: {
implementation: ImageMinimizerPlugin.imageminMinify,
options: {
plugins: [
["mozjpeg", { quality: 75 }],
["pngquant", { quality: [0.6, 0.8] }],
],
}
},
})
);
}
return config;
}