forked from cryostatio/cryostat-web
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.dev.js
71 lines (68 loc) · 2.64 KB
/
webpack.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
const path = require('path');
const { merge } = require('webpack-merge');
const common = require('./webpack.common.js');
const ESLintPlugin = require('eslint-webpack-plugin');
const { EnvironmentPlugin } = require('webpack');
const HOST = process.env.HOST || "localhost";
const PORT = process.env.PORT || "9000";
module.exports = merge(common('development'), {
mode: 'development',
devtool: 'eval-source-map',
devServer: {
compress: true,
historyApiFallback: true,
host: HOST,
hot: true,
open: true,
port: PORT,
// In preview mode, requests are intercepted with miragejs
proxy: process.env.PREVIEW? undefined: [
{
context: ['/api', '/health', '/grafana'],
target: process.env.CRYOSTAT_PROXY_URL ?? 'https://localhost:8443',
secure: false, // ignore insecure tls
auth: 'user:pass',
ws: true,
followRedirects: true,
}
]
},
plugins: [
new EnvironmentPlugin({
// Requests are proxied by dev-server
// In preview mode, a base url is required.
CRYOSTAT_AUTHORITY: process.env.PREVIEW? 'http://localhost:8181': '',
PREVIEW: process.env.PREVIEW || 'false'
})
],
module: {
rules: [
{
test: /\.css$/,
include: [
path.resolve(__dirname, 'src'),
path.resolve(__dirname, 'node_modules/patternfly'),
path.resolve(__dirname, 'node_modules/@patternfly/patternfly'),
path.resolve(__dirname, 'node_modules/@patternfly/react-styles/css'),
path.resolve(__dirname, 'node_modules/@patternfly/react-core/dist/styles/base.css'),
path.resolve(__dirname, 'node_modules/@patternfly/react-core/dist/esm/@patternfly/patternfly'),
path.resolve(__dirname, 'node_modules/@patternfly/react-core/node_modules/@patternfly/react-styles/css'),
path.resolve(__dirname, 'node_modules/@patternfly/react-table/node_modules/@patternfly/react-styles/css'),
path.resolve(__dirname, 'node_modules/@patternfly/react-inline-edit-extension/node_modules/@patternfly/react-styles/css'),
path.resolve(__dirname, 'node_modules/@patternfly/quickstarts/dist/quickstarts.css'),
path.resolve(__dirname, 'node_modules/@patternfly/react-topology/node_modules/@patternfly/react-styles/css')
],
use: ['style-loader', 'css-loader']
}
]
}
});
if (process.env.ESLINT_ENABLE === 'true') {
console.log('ESLint webpack-plugin enabled...');
module.exports.plugins.push(new ESLintPlugin({
cache: true,
cacheLocation: path.resolve(__dirname, '.eslintcache'),
extensions: ['js', 'jsx', 'ts', 'tsx'],
exclude: ['node_modules', 'dist'],
}));
}