-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.common.js
82 lines (79 loc) · 2.34 KB
/
webpack.common.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
const path = require("path");
const CopyWebpackPlugin = require("copy-webpack-plugin");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const ReactRefreshTypeScript = require("react-refresh-typescript");
const ReactRefreshPlugin = require("@pmmmwh/react-refresh-webpack-plugin");
const CrxLoadScriptWebpackPlugin = require("@cooby/crx-load-script-webpack-plugin");
const { ProvidePlugin } = require("webpack");
const isDev = process.env.NODE !== "production";
const getHtmlPlugins = (chunks) => {
return chunks.map(
(chunk) =>
new HtmlWebpackPlugin({
filename: `${chunk}.html`,
chunks: [chunk],
})
);
};
module.exports = {
resolve: {
extensions: [".tsx", ".ts", ".js"],
alias: {
"@api": path.resolve(__dirname, "./src/api"),
"@assets": path.resolve(__dirname, "./src/assets"),
"@utils": path.resolve(__dirname, "./src/utils"),
"@background": path.resolve(__dirname, "./src/background"),
"@content": path.resolve(__dirname, "./src/content"),
"@popup": path.resolve(__dirname, "./src/popup"),
},
},
entry: {
popup: path.resolve("./src/popup/Popup.tsx"),
background: path.resolve("./src/background/background.ts"),
content: path.resolve("./src/content/index.tsx"),
},
output: {
filename: "[name].js",
clean: true,
},
module: {
rules: [
{
use: {
loader: "ts-loader",
options: {
transpileOnly: isDev,
getCustomTransformers: () => ({
before: [isDev && ReactRefreshTypeScript()].filter(Boolean),
}),
},
},
test: /\.(ts|tsx)$/,
exclude: /node_modules/,
},
{
use: ["style-loader", "css-loader", "postcss-loader"],
test: /\.css$/i,
},
{
test: /\.(png|jpg|jpeg|gif|woff|woff2|tff|eot|svg)$/i,
type: "asset/inline",
},
],
},
plugins: [
isDev && new ReactRefreshPlugin({ overlay: false }),
isDev && new CrxLoadScriptWebpackPlugin(),
new CopyWebpackPlugin({
patterns: [
{ from: path.resolve("src/static"), to: path.resolve("dist") },
{
from: path.resolve("src/assets/images"),
to: path.resolve("dist/"),
},
],
}),
new ProvidePlugin({ React: "react" }),
...getHtmlPlugins(["popup"]),
].filter(Boolean),
};