forked from zendesk/zendesk_app_framework_sdk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
125 lines (112 loc) · 2.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
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
const path = require('path')
const webpackMerge = require('webpack-merge')
const TerserPlugin = require('terser-webpack-plugin')
const Visualizer = require('webpack-visualizer-plugin')
const fs = require('fs')
const _resolveCache = new Map()
const resolve = (__path = '.') => {
if (_resolveCache.has(__path)) {
return _resolveCache.get(__path)
}
const resolved = path.resolve(__dirname, __path)
if (fs.existsSync(resolved)) {
const followed = fs.realpathSync(resolved)
_resolveCache.set(__path, followed)
return followed
}
_resolveCache.set(__path, resolved)
return resolved
}
const optimization = {
minimize: true,
minimizer: [new TerserPlugin()]
}
const commonConfig = {
devtool: 'source-map',
entry: {
'zaf_sdk': [
'native-promise-only',
'./lib/index.js'
],
'zaf_sdk.min': [
'native-promise-only',
'./lib/index.js'
]
},
output: {
library: {
name: 'ZAFClient',
type: 'umd',
export: 'default'
},
filename: '[name].js',
sourceMapFilename: '[name].js.map',
path: path.resolve(__dirname, 'build')
},
// Note: devServer does not serve from build/, but from cache. It also doesn't respect mode
// so outputed files are very different from server/build/build:dev
devServer: {
contentBase: path.join(__dirname, 'build'),
hot: false,
inline: false,
compress: true,
port: 9001
},
module: {
rules: [
{
test: /\.ts$/,
enforce: 'pre',
include: [resolve('lib'), resolve('spec'), resolve('node_modules')],
use: [
{
loader: 'babel-loader',
options: {
extends: resolve('.babelrc')
}
},
{
loader: 'ts-loader',
options: {
configFile: resolve('tsconfig.json')
}
}
]
},
{
test: /\.js$/,
include: [resolve('lib'), resolve('spec')],
exclude: [
resolve('spec/factories') // Factories are included raw in Lotus
],
enforce: 'post',
loader: 'babel-loader',
options: {
cacheDirectory: true,
babelrc: true
}
}
]
},
optimization,
resolve: {
modules: [resolve('lib'), resolve('spec'), resolve('node_modules')],
extensions: ['.ts', '.js', '.hdbs', '.scss', '.css']
}
}
const statsConfig = {
plugins: [
new Visualizer({
filename: './statistics.html'
})
]
}
module.exports = function (env = {}) {
let config = webpackMerge(commonConfig, {
mode: env.production ? 'production' : 'development'
})
if (env.stats) {
config = webpackMerge(config, statsConfig)
}
return config
}