-
Notifications
You must be signed in to change notification settings - Fork 15
/
webpack.config.js
82 lines (72 loc) · 2.25 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
const path = require('path');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const WebextensionPlugin = require('webpack-webextension-plugin');
const WebpackShellPlugin = require('webpack-shell-plugin-next');
module.exports = function (env, argv) {
const isProd = argv.mode === 'production';
const vendor = env.vendor || 'firefox';
/**
* @type {import('webpack').Configuration}
*/
const config = {
resolve: {
extensions: ['.js', '.jsx', '.ts', '.tsx', '.json'],
},
devtool: isProd ? false : 'source-map',
watch: !isProd,
performance: {
maxEntrypointSize: 1024000,
},
entry: {
background: './src/background/main.ts',
content: './src/content/main.ts',
options: './src/options/index.tsx',
},
output: {
path: path.resolve(__dirname, 'dist', vendor),
filename: '[name].js',
},
module: {
rules: [{ test: /\.tsx?$/, use: 'ts-loader', exclude: [/node_modules/] }],
},
plugins: [
new CleanWebpackPlugin({
cleanStaleWebpackAssets: false,
cleanAfterEveryBuildPatterns: [],
}),
new WebextensionPlugin({ vendor, autoreload: false }),
new CopyWebpackPlugin({
patterns: [
{ from: './src/_locales/', to: '_locales/', toType: 'dir' },
{ from: './node_modules/spectre.css/dist/spectre.min.css' },
{ from: './node_modules/spectre.css/dist/spectre-icons.min.css' },
{ from: './node_modules/spectre.css/dist/spectre-exp.min.css' },
{ from: './src/icons', to: 'icons' },
{
from: './node_modules/tongwen-dict/dist/*.min.json',
to: 'dictionaries/[name][ext]',
},
],
}),
new HtmlWebpackPlugin({
filename: 'options.html',
template: './src/options/index.html',
chunks: ['options'],
}),
...(isProd
? []
: [
new WebpackShellPlugin({
onBuildEnd: {
scripts: [`npm run we:${vendor}`],
blocking: false,
parallel: true,
},
}),
]),
],
};
return config;
};