-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
123 lines (107 loc) · 3.03 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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
const path = require('path');
const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const Dotenv = require('dotenv-webpack');
const SriPlugin = require('webpack-subresource-integrity');
const TerserPlugin = require('terser-webpack-plugin');
const GenerateJsonPlugin = require('generate-json-webpack-plugin');
// import generateManifest from './resources/webextensions/generateManifest'
const generateManifest = require('./resources/webextensions/generateManifest');
const extensionName = 'ExtensionStarter';
const parseArgs = (env) =>
env
? Object.keys(env).reduce((acc, cur) => {
const [key, value] = cur.split('=');
acc[key] = value || env[key];
return acc;
}, {})
: null;
module.exports = (env) => {
const args = parseArgs(env);
if (!args || !args.browser) {
console.warn('Must submit browser argument to webpack command');
return undefined;
}
const { browser } = parseArgs(env);
return {
mode: 'development',
entry: {
bg: './src/bg/index.js',
popup: './src/popup/index.js',
options: './src/options/index.js',
cs: './src/cs/index.js',
},
output: {
path: path.resolve(__dirname, `build/${browser}`),
filename: `${extensionName}.[name].js`,
},
plugins: [
new webpack.ProgressPlugin(),
new HtmlWebpackPlugin({
inject: true,
chunks: ['popup'],
filename: `${extensionName}.popup.html`,
template: './src/popup/index.html',
}),
new HtmlWebpackPlugin({
inject: true,
chunks: ['bg'],
filename: `${extensionName}.bg.html`,
template: './src/bg/index.html',
}),
new HtmlWebpackPlugin({
inject: true,
chunks: ['options'],
filename: `${extensionName}.options.html`,
template: './src/options/index.html',
}),
new Dotenv({
path: './.env',
safe: true,
}),
new SriPlugin({
hashFuncNames: ['sha256'],
enabled: true,
}),
new GenerateJsonPlugin('manifest.json', generateManifest(browser)),
],
module: {
rules: [
{
test: /\.jsx?$/,
include: [path.resolve(__dirname, './extensions/src')],
loader: 'babel-loader',
},
{
test: /\.(ico|eot|otf|webp|ttf|woff|woff2)(\?.*)?$/,
use: 'file-loader?limit=100000',
},
{
test: /\.(jpe?g|png|gif|svg)$/i,
use: 'file-loader?limit=100000',
},
{
test: /\.css$/,
use: ['style-loader', 'css-loader'],
},
],
},
optimization: {
minimizer: [new TerserPlugin()],
splitChunks: false,
// {
// cacheGroups: {
// vendors: {
// priority: -10,
// test: /[\\/]node_modules[\\/]/,
// },
// },
// chunks: 'async',
// minChunks: 1,
// minSize: 30000,
// name: true,
// },
},
};
};