-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
62 lines (58 loc) · 1.84 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
/* eslint-disable */ // TODO: Make it proper..
// const dev = process.env.NODE_ENV === 'dev';
// const prod = !dev; // Be more restrictive for dev environment (as firebase buildscripts might not set properly.)
const prod = false; // process.env.NODE_ENV === 'production'; // TODO: There is still a map file..
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin');
module.exports = {
mode: prod ? 'production' : 'development',
entry: './src/index.tsx',
output: {
path: __dirname + '/dist/',
},
resolve: {
// https://www.npmjs.com/package/tsconfig-paths-webpack-plugin
plugins: [new TsconfigPathsPlugin({})],
},
module: {
rules: [
{
test: /\.(ts|tsx)$/,
exclude: /node_modules/,
resolve: {
extensions: ['.ts', '.tsx', '.js', '.json']
},
use: 'ts-loader',
},
{
test: /\.css$/,
use: [MiniCssExtractPlugin.loader, 'css-loader'],
},
]
},
// Catch-All: https://stackoverflow.com/a/34125010/8524651
devServer: {
port: 3000,
// https://github.com/webpack/webpack-dev-server/issues/216
historyApiFallback: { index: '/' },
// https://stackoverflow.com/questions/69901768/webpack-dev-server-enables-features-then-disconnects-twice-when-using-host-op
allowedHosts: ['all']
},
// Only create source maps in dev environment
devtool: prod ? undefined : 'source-map',
plugins: [
new HtmlWebpackPlugin({
template: 'index.html',
}),
new MiniCssExtractPlugin(),
// Copy data.
// https://stackoverflow.com/a/33374807/8524651
new CopyWebpackPlugin({
patterns: [
{ from: 'static' }
]
}),
],
};