/
webpack.config.dev.js
executable file
路72 lines (68 loc) 路 2.19 KB
/
webpack.config.dev.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
import webpack from 'webpack'
import resolveFrom from 'resolve-from'
import HtmlWebpackPlugin from 'html-webpack-plugin'
import CaseSensitivePathsPlugin from 'case-sensitive-paths-webpack-plugin'
import ExtractCssChunks from 'extract-css-chunks-webpack-plugin'
import path from 'path'
import rules from './rules'
export default function({ config }) {
const { DIST, NODE_MODULES, SRC, HTML_TEMPLATE } = config.paths
process.env.REACT_STATIC_BASE_PATH = config.basePath
process.env.REACT_STATIC_PUBLIC_PATH = config.publicPath
process.env.REACT_STATIC_ASSETS_PATH = config.assetsPath
return {
mode: 'development',
optimization: {
noEmitOnErrors: true,
concatenateModules: true,
},
context: path.resolve(__dirname, '../../../node_modules'),
entry: [
'react-hot-loader/patch',
'webpack/hot/only-dev-server',
...(config.disableRuntime
? []
: [
require.resolve('../../bootstrapPlugins'),
require.resolve('../../bootstrapTemplates'),
]),
config.entry,
].filter(Boolean),
output: {
filename: '[name].js', // never hash dev code
chunkFilename: 'templates/[name].js',
path: DIST,
publicPath: process.env.REACT_STATIC_ASSETS_PATH || '/',
},
module: {
rules: rules({ config, stage: 'dev' }),
strictExportPresence: true,
},
resolve: {
modules: [
NODE_MODULES,
SRC,
DIST,
...[NODE_MODULES, SRC, DIST].map(d => path.relative(__dirname, d)),
'node_modules',
],
extensions: ['.wasm', '.mjs', '.js', '.json', '.jsx'],
alias: {
react: resolveFrom(config.paths.NODE_MODULES, 'react'),
'react-dom': resolveFrom(config.paths.NODE_MODULES, 'react-dom'),
},
},
plugins: [
new webpack.EnvironmentPlugin(process.env),
new HtmlWebpackPlugin({
inject: true,
template: `!!raw-loader!${HTML_TEMPLATE}`,
}),
new webpack.HotModuleReplacementPlugin(),
new webpack.NamedModulesPlugin(),
new CaseSensitivePathsPlugin(),
new ExtractCssChunks({ filename: '[name].css' }), // never hash dev code
],
devtool: 'cheap-module-source-map',
}
}