-
-
Notifications
You must be signed in to change notification settings - Fork 47
/
webpack.config.js
106 lines (103 loc) · 3.54 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
const path = require("path");
const { WebpackManifestPlugin } = require("webpack-manifest-plugin");
const ForkTsCheckerWebpackPlugin = require("fork-ts-checker-webpack-plugin");
const LessPluginCleanCSS = require("less-plugin-clean-css");
const StylelintPlugin = require("stylelint-webpack-plugin");
const ESLintPlugin = require("eslint-webpack-plugin");
module.exports = function (env, argv) {
const isProd = argv.mode === "production";
const baseDir = "./frontend";
const jsDir = path.join(baseDir, "js");
const distDir = path.join(baseDir, "dist");
const cssDir = path.join(baseDir, "css");
const babelExcludeLibrariesRegexp = new RegExp("node_modules/.*", "");
const plugins = [
new WebpackManifestPlugin(),
new ForkTsCheckerWebpackPlugin({
typescript: {
diagnosticOptions: {
semantic: true,
syntactic: true,
},
mode: "write-references",
memoryLimit: 4096,
},
}),
new StylelintPlugin({
configFile: ".stylelintrc.js",
failOnError: isProd,
files: "**/static/css/**/*.less",
fix: !isProd,
threads: true,
}),
new ESLintPlugin({
files: path.join(jsDir, "src/**/*.{ts,tsx,js,jsx}"),
fix: !isProd,
}),
];
return {
entry: {
// Importing main.less file here so that it gets compiled.
// Otherwise with a standalone entrypoint Webpack would generate a superfluous js file.
// All the Less/CSS will be exported separately to a main.css file and not appear in the main module
main: path.resolve(cssDir, "main.less"),
signupCommercial: path.resolve(jsDir, "src/forms/SignupCommercial.tsx"),
signupNonCommercial: path.resolve(
jsDir,
"src/forms/SignupNonCommercial.tsx"
),
supporterProfileEdit: path.resolve(
jsDir,
"src/forms/SupporterProfileEdit.tsx"
),
createApplication: path.resolve(jsDir, "src/forms/CreateApplication.tsx"),
deleteApplication: path.resolve(jsDir, "src/forms/DeleteApplication.tsx"),
oauthPrompt: path.resolve(jsDir, "src/forms/OAuthPrompt.tsx"),
applications: path.resolve(jsDir, "src/Applications.tsx"),
oauthError: path.resolve(jsDir, "src/OAuthError.tsx"),
},
output: {
filename: isProd ? "[name].[contenthash].js" : "[name].js",
path: path.resolve(distDir),
// This is for the manifest file used by the server. Files end up in /static folder
publicPath: "/static/dist/",
clean: true, // Clean the output directory before emit.
},
devtool: isProd ? "source-map" : "eval-source-map",
module: {
rules: [
{
test: /\.(js|ts)x?$/,
// exclude third-party libraries from ES5 transpilation
exclude: babelExcludeLibrariesRegexp,
// Don't specify the babel configuration here
// Configuration can be found in ./babel.config.js
use: "babel-loader",
},
{
test: /\.less$/i,
type: "asset/resource",
loader: "less-loader",
generator: {
filename: isProd ? "[name].[contenthash].css" : "[name].css",
},
options: {
lessOptions: {
math: "always",
plugins: [new LessPluginCleanCSS({ advanced: true })],
},
},
},
],
},
resolve: {
modules: [
path.resolve("./node_modules"),
"/code/node_modules",
path.resolve(baseDir, "node_modules"),
],
extensions: [".ts", ".tsx", ".js", ".jsx", ".json"],
},
plugins,
};
};