forked from hsdt/checkin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.ts
82 lines (78 loc) · 1.97 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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import path from 'path';
import webpack from 'webpack';
import nodeExternals from 'webpack-node-externals';
import NodemonPlugin from 'nodemon-webpack-plugin';
import statements from 'tsx-control-statements';
import MiniCssExtractPlugin from 'mini-css-extract-plugin';
import OptimizeCSSAssetsPlugin from 'optimize-css-assets-webpack-plugin';
import TerserJSPlugin from 'terser-webpack-plugin';
const config = {
mode: 'development',
optimization: {
minimizer: [new TerserJSPlugin({}), new OptimizeCSSAssetsPlugin({})],
},
module: {
rules: [{
test: /\.tsx?$/,
use: 'ts-loader',
exclude: /node_modules/,
}],
},
resolve: {
extensions: ['.tsx', '.ts', '.js'],
modules: ['src', 'node_modules'],
},
};
const client = Object.assign({}, config, {
name: 'client',
target: 'web',
entry: path.resolve(__dirname, 'client/src/app.tsx'),
output: {
filename: 'app.js',
path: path.resolve(__dirname, 'build/client'),
},
plugins: [
new webpack.HotModuleReplacementPlugin(),
new MiniCssExtractPlugin({
filename: '[name].css',
chunkFilename: '[id].css',
}),
],
module: {
rules: [{
test: /\.tsx?$/,
loader: 'ts-loader',
// loader: 'awesome-typescript-loader',
options: {
getCustomTransformers: () => ({ before: [statements()] }),
},
}, {
test: /\.(ttf|eot|woff|woff2|svg|png)$/,
use: {
loader: 'file-loader',
options: {
name: 'fonts/[name].[ext]',
},
},
}, {
test: /\.css$/,
use: [MiniCssExtractPlugin.loader, 'css-loader'],
},
],
},
});
const server = Object.assign({}, config, {
name: 'server',
target: 'node',
externals: [nodeExternals()],
entry: path.resolve(__dirname, 'app.ts'),
output: {
filename: 'app.js',
path: path.resolve(__dirname, 'build/server'),
},
plugins: [
new webpack.HotModuleReplacementPlugin(),
new NodemonPlugin(),
],
});
module.exports = [client, server];