-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
73 lines (71 loc) · 1.77 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
const path = require("path");
const SRC_DIR = path.join(__dirname, "/client/source");
const PUBLIC_DIR = path.join(__dirname, "/client/public");
// const BundleAnalyzerPlugin =
// require("webpack-bundle-analyzer").BundleAnalyzerPlugin;
const BrotliPlugin = require("brotli-webpack-plugin"); //brotli
const CompressionPlugin = require("compression-webpack-plugin"); //gzip
module.exports = {
entry: `${SRC_DIR}/index.jsx`,
output: {
filename: "bundle.js",
path: PUBLIC_DIR,
},
devtool: "",
mode: "production",
module: {
rules: [
{
test: /\.m?js|jsx$/,
exclude: /node_modules/,
use: {
loader: "babel-loader",
options: {
presets: ["@babel/preset-env", "@babel/preset-react"],
},
},
},
],
},
plugins: [
// new BundleAnalyzerPlugin(),
// new CompressionPlugin({
// //gzip plugin
// filename: "[path].gz[query]",
// algorithm: "gzip",
// test: /\.(js|css|html|svg)$/,
// threshold: 8192,
// minRatio: 0.8,
// }),
// new BrotliPlugin({
// asset: "[path].br[query]",
// test: /\.(js|css|html|svg)$/,
// threshold: 10240,
// minRatio: 0.8,
// }),
new CompressionPlugin({
// asset: "[path].gz[query]",
algorithm: "gzip",
test: /\.js$|\.css$|\.html$/,
threshold: 10240,
minRatio: 0.7,
}),
new BrotliPlugin({
asset: "[path].br[query]",
test: /\.js$|\.css$|\.html$/,
threshold: 10240,
minRatio: 0.7,
}),
],
// optimization: {
// splitChunks: {
// cacheGroups: {
// commons: {
// test: /[\\/]node_modules[\\/]/,
// name: "vendors",
// chunks: "all",
// },
// },
// },
// },
};