-
Notifications
You must be signed in to change notification settings - Fork 57
Expand file tree
/
Copy pathwebpack.dev.ts
More file actions
96 lines (84 loc) · 2.3 KB
/
webpack.dev.ts
File metadata and controls
96 lines (84 loc) · 2.3 KB
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
import { env } from '@twilio/flex-dev-utils';
import { getLocalAndNetworkUrls } from '@twilio/flex-dev-utils/dist/urls';
import { ClientConfiguration, Configuration, Static } from 'webpack-dev-server';
import { getPaths } from '@twilio/flex-dev-utils/dist/fs';
import { WebpackType } from '..';
/**
* Returns the base {@link Configuration}
* @private
*/
// eslint-disable-next-line import/no-unused-modules
export const _getBase = (): Configuration => {
const { local } = getLocalAndNetworkUrls(env.getPort());
return {
compress: true,
static: {},
client: {
logging: 'none',
webSocketURL: {
hostname: local.host,
pathname: local.url,
port: env.getPort(),
},
},
host: env.getHost() || '0.0.0.0', // Keep binding to 0.0.0.0 for network access
port: env.getPort(),
};
};
/**
* Returns the {@link Configuration} for static type
* @private
*/
// eslint-disable-next-line import/no-unused-modules
export const _getStaticConfiguration = (config: Configuration): Configuration => {
config.historyApiFallback = {
disableDotRule: true,
index: '/',
};
config.static = [
{
directory: getPaths().app.publicDir,
publicPath: '/',
watch: true,
},
{
directory: getPaths().scripts.devAssetsDir,
publicPath: '/',
watch: true,
},
];
return config;
};
/**
* Returns the {@link Configuration} for JS type
* @private
*/
// eslint-disable-next-line import/no-unused-modules
export const _getJavaScriptConfiguration = (config: Configuration): Configuration => {
const socket = env.getWSSocket();
(config.static as Static).serveIndex = true;
// We're using native sockjs-node
config.webSocketServer = 'ws';
(config.client as ClientConfiguration).webSocketURL = {
hostname: socket.host,
pathname: socket.path,
port: socket.port,
};
// Hot reload
config.hot = false;
return config;
};
/**
* Generates a webpack-dev configuration
*/
/* c8 ignore next */
export default (type: WebpackType): Configuration => {
const config = _getBase();
if (type === WebpackType.Static) {
return _getStaticConfiguration(config);
}
if (type === WebpackType.JavaScript) {
return _getJavaScriptConfiguration(config);
}
return _getJavaScriptConfiguration(_getStaticConfiguration(config));
};