This repository has been archived by the owner on Jun 13, 2024. It is now read-only.
forked from cryostatio/cryostat-web
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.dev.js
58 lines (55 loc) · 2.15 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
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,
},
plugins: [
new EnvironmentPlugin({
CRYOSTAT_AUTHORITY: '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'],
}));
}