-
Notifications
You must be signed in to change notification settings - Fork 12
/
webpack.config.js
110 lines (109 loc) · 2.34 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
/* eslint-env node */
const webpack = require("webpack");
const path = require("path");
const fs = require("fs");
const ForkTsCheckerWebpackPlugin = require("fork-ts-checker-webpack-plugin");
// const ESLintPlugin = require("eslint-webpack-plugin");
const CopyPlugin = require("copy-webpack-plugin");
const WorkboxPlugin = require("workbox-webpack-plugin");
module.exports = (env) => ({
entry: "./src/index.tsx",
target: "web",
mode: env.WEBPACK_SERVE ? "development" : "production",
devtool: env.WEBPACK_SERVE ? "cheap-source-map" : "source-map",
devServer: {
static: {
directory: path.join(__dirname, "public")
},
port: 8080,
https: env.secure ? {
key: fs.readFileSync("webpack.key"),
cert: fs.readFileSync("webpack.crt"),
} : undefined
},
output: {
path: path.resolve(__dirname, "build"),
filename: "index.js",
assetModuleFilename: "res/[hash][ext][query]",
publicPath: "",
clean: true
},
module: {
rules: [
{
test: /\.ts(x)?$/,
loader: "ts-loader",
exclude: /node_modules/,
options: {
transpileOnly: true
}
},
{
enforce: "pre",
test: /\.js$/,
loader: "source-map-loader"
},
{
test: /\.css$/,
use: [
"style-loader",
"css-loader"
],
exclude: /\.module\.css$/
},
{
test: /\.css$/,
use: [
"style-loader",
{
loader: "css-loader",
options: {
importLoaders: 1,
modules: true
}
}
],
include: /\.module\.css$/
},
{
test: /\.(svg)|(wav)$/,
type: "asset/resource"
},
{
test: /\.md$/,
type: "asset/source"
}
]
},
resolve: {
extensions: [
".tsx",
".ts",
".js"
],
alias: {
"shared": path.resolve(__dirname, "src")
}
},
optimization: {
usedExports: true
},
plugins: [
new ForkTsCheckerWebpackPlugin(),
/* new ESLintPlugin({
files: ["src", "browser", "electron-main", "electron-renderer"],
extensions: ["js", "jsx", "ts", "tsx"]
}), */
new CopyPlugin({
patterns: [
{from: "public"}
]
}),
new webpack.DefinePlugin({
"WPEnv.ENVIRONMENT": JSON.stringify(env.WEBPACK_SERVE ? "development" : "production"),
"WPEnv.PACKAGE_VERSION": JSON.stringify(process.env.npm_package_version),
"WPEnv.RELEASE_HASH": "\"undefined\"",
"WPEnv.BUILD_DATE": Date.now()
}),
].concat(!env.WEBPACK_SERVE ? new WorkboxPlugin.GenerateSW() : [])
});