drone/web/config/webpack.dev.js

119 lines
2.9 KiB
JavaScript

/*
* Copyright 2023 Harness, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const path = require('path')
const util = require('util')
const fs = require('fs')
require('dotenv').config()
const { merge } = require('webpack-merge')
const ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin')
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const HTMLWebpackPlugin = require('html-webpack-plugin')
const {
DefinePlugin,
WatchIgnorePlugin,
container: { ModuleFederationPlugin }
} = require('webpack')
const commonConfig = require('./webpack.common')
const API_URL = process.env.API_URL ?? 'http://localhost:3000'
const HOST = 'localhost'
const PORT = process.env.PORT ?? 3020
const STANDALONE = JSON.parse(process.env.STANDALONE ?? 'true')
console.info(`Starting development build... http://${HOST}:${PORT}`)
console.info('Environment variables:')
console.table({ STANDALONE, HOST, PORT, API_URL })
const devConfig = {
mode: 'development',
target: 'web',
entry: './src/index.tsx',
devtool: 'cheap-module-source-map',
cache: { type: 'filesystem' },
output: {
filename: '[name].js',
chunkFilename: '[name].[id].js',
path: path.resolve(process.cwd(), 'dist'),
pathinfo: false
},
...(STANDALONE
? {
optimization: {
runtimeChunk: 'single'
}
}
: {}),
devServer: {
hot: true,
host: HOST,
historyApiFallback: {
disableDotRule: true
},
port: PORT,
proxy: {
'/api': {
target: API_URL,
logLevel: 'debug',
secure: false,
changeOrigin: true
}
},
compress: false
},
plugins: [
new MiniCssExtractPlugin({
filename: '[name].css',
chunkFilename: '[name].[id].css',
ignoreOrder: true
}),
new HTMLWebpackPlugin({
publicPath: '/',
template: 'src/index.html',
filename: 'index.html',
favicon: 'src/favicon.svg',
minify: false,
templateParameters: {
__DEV__: true
}
}),
new DefinePlugin({
'process.env': '{}', // required for @blueprintjs/core
__DEV__: true,
__ENABLE_CDN__: false
})
],
module: {
rules: [
{
test: /\.md$/,
use: [
{
loader: 'raw-loader',
options: {
esModule: false
}
}
]
}
]
}
}
module.exports = merge(commonConfig, devConfig)