-
-
Notifications
You must be signed in to change notification settings - Fork 433
/
Copy pathwebpack.config.js
66 lines (65 loc) · 1.68 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
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin');
// To improve build times for large projects enable fork-ts-checker-webpack-plugin
// const ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin');
module.exports = {
"mode": "development",
"entry": "src/index.tsx",
"output": {
"path": __dirname+'/dist',
"filename": "[name].js"
},
"watch": false,
"context": __dirname, // to automatically find tsconfig.json
"module": {
"rules": [
{
"test": /\.([cm]?ts|tsx)$/,
"exclude": /node_modules/,
"use": {
"loader": "ts-loader",
"options": {
"projectReferences": true
}
}
}
]
},
resolve: {
modules: [
"node_modules",
path.resolve(__dirname)
],
// TsconfigPathsPlugin will automatically add this
// alias: {
// packages: path.resolve(__dirname, 'packages/'),
// },
extensions: [".js", ".ts", ".tsx"],
extensionAlias: {
".js": [".js", ".ts"],
".cjs": [".cjs", ".cts"],
".mjs": [".mjs", ".mts"]
},
plugins: [
new TsconfigPathsPlugin({
logLevel: "info",
mainFields: "module",
extensions: [".js", ".ts", ".tsx"]
})
]
},
plugins: [
new HtmlWebpackPlugin({
templateContent: `
<html>
<body>
<h1>Project Reference Demo App</h1>
<div id='react-content'></div>
</body>
</html>
`
}),
// new ForkTsCheckerWebpackPlugin()
]
}