-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.ts
90 lines (84 loc) · 1.93 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
83
84
85
86
87
88
89
90
import * as PATH from 'path'
const { resolve } = PATH
const webpack = require( 'webpack' )
const CopyWebpackPlugin = require( "copy-webpack-plugin" )
const CleanWebpackPlugin = require( 'clean-webpack-plugin' )
import { __DEV__ } from "./server/global"
import { OUTPUT_FILE_NAME, ENTRY, OUTPUT, ENTRY_INDEX_HTML, OUTPUT_INDEX_HTML, ENTRY_STATIC, ENTRY_CODE_VIEWER_COMPANION, OUTPUT_CODE_VIEWER_COMPANION } from './server/constants'
const BundleAnalyzerPlugin = require( "webpack-bundle-analyzer" ).BundleAnalyzerPlugin
const webpackClientConfig = {
mode : __DEV__ ? 'development' : 'production',
entry: {
[ OUTPUT_FILE_NAME ]: [
ENTRY,
].concat(
__DEV__ ? [
`webpack-hot-middleware/client?path=/__webpack_hmr&timeout=20000`,
] : []
)
},
output: {
path : OUTPUT,
filename : '[name]',
publicPath: '/'
},
devtool: __DEV__ ? 'source-map' : false,
module : {
rules: [
{
test: /\.ts|\.tsx$/,
use : {
loader: 'ts-loader',
},
exclude: /node_modules/
},
{
test: /\.css$/,
use : [ "style-loader", "css-loader" ]
},
{
test : /\.(png|woff|woff2|eot|ttf|svg)$/,
loader: "url-loader?limit=100000000"
}
]
},
resolve: {
extensions: [
'.tsx',
'.ts',
'.js'
]
},
externals: {
react : 'React',
'react-dom': 'ReactDOM',
},
plugins: [
new CleanWebpackPlugin( [
OUTPUT
] ),
new CopyWebpackPlugin( [
{
from: ENTRY_INDEX_HTML,
to : OUTPUT_INDEX_HTML
},
{
from: ENTRY_STATIC,
to : OUTPUT
},{
from: ENTRY_CODE_VIEWER_COMPANION,
to : OUTPUT_CODE_VIEWER_COMPANION
}
],
),
].concat(
__DEV__ ?
[
new webpack.HotModuleReplacementPlugin()
] :
[
// new BundleAnalyzerPlugin()
]
)
}
export default webpackClientConfig