-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathwebpack.config.ts
61 lines (58 loc) · 1.29 KB
/
webpack.config.ts
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
import path from 'path';
import * as webpack from 'webpack';
import CopyPlugin from 'copy-webpack-plugin';
const config = (env: { [key: string]: string }): webpack.Configuration => {
const platformName = env.hasOwnProperty('firefox') ? 'firefox' : 'chrome';
return {
entry: {
content: './src/content.ts',
popup: './src/popup.tsx',
background: './src/background.ts',
},
mode: 'production',
module: {
rules: [
{
test: /\.tsx?$/,
use: 'ts-loader',
exclude: /node_modules/,
},
{
test: /\.svg$/,
loader: 'svg-inline-loader',
},
],
},
plugins: [
new CopyPlugin({
patterns: [
{
from: path.resolve(__dirname, 'src/resources'),
to: path.resolve(__dirname, 'extension'),
filter: filename =>
!path.parse(filename).name.startsWith('manifest-'),
},
{
from: path.resolve(
__dirname,
`src/resources/manifest-${platformName}.json`,
),
to: path.resolve(__dirname, 'extension/manifest.json'),
},
],
}),
],
resolve: {
extensions: ['.tsx', '.ts', '.js'],
},
target: ['web', 'es2020'],
output: {
filename: '[name].js',
path: path.resolve(__dirname, 'extension'),
},
optimization: {
minimize: env.mode === 'production',
},
};
};
export default config;