-
Notifications
You must be signed in to change notification settings - Fork 25
/
webpack.config.js
executable file
·58 lines (53 loc) · 1.7 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
const HtmlWebpackPlugin = require('html-webpack-plugin')
const CopyWebpackPlugin = require('copy-webpack-plugin')
const webpack = require('webpack')
module.exports = (webpackConfig, env) => {
const production = env === 'production'
// FilenameHash
webpackConfig.output.chunkFilename = '[name].[chunkhash].js'
if (production) {
if (webpackConfig.module) {
// ClassnameHash
webpackConfig.module.rules.map((item) => {
if (String(item.test) === '/\\.less$/' || String(item.test) === '/\\.css/') {
item.use.filter(iitem => iitem.loader === 'css')[0].options.localIdentName = '[hash:base64:5]'
}
return item
})
}
webpackConfig.plugins.push(
new webpack.LoaderOptionsPlugin({
minimize: true,
debug: false,
})
)
}
webpackConfig.plugins = webpackConfig.plugins.concat([
new CopyWebpackPlugin([
{
from: 'src/public',
to: production ? '../' : webpackConfig.output.outputPath,
},
]),
new HtmlWebpackPlugin({
template: `${__dirname}/src/entry.ejs`,
filename: production ? '../index.html' : 'index.html',
minify: production ? {
collapseWhitespace: true,
} : null,
hash: true,
headScripts: production ? null : ['/roadhog.dll.js'],
}),
])
webpackConfig.resolve.alias = {
'@components': `${__dirname}/src/components`,
'@models': `${__dirname}/src/models`,
'@services': `${__dirname}/src/services`,
'@utils': `${__dirname}/src/utils`,
'@config': `${__dirname}/src/config`,
'@ts-types': `${__dirname}/src/ts-types`,
'@enums': `${__dirname}/src/utils/enums`,
themes: `${__dirname}/src/themes`,
}
return webpackConfig
}