mirror of https://github.com/harness/drone.git
119 lines
2.9 KiB
JavaScript
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)
|