blob: bed63dc8f838e37db2f800af809c35e63c0c320d [file] [log] [blame]
const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");
const TerserJSPlugin = require('terser-webpack-plugin');
const path = require('path');
const process = require('process');
const srcPath = path.resolve(__dirname, 'src');
const elmPath = path.join(srcPath, "elm");
const dstPath = path.resolve(__dirname, 'dist');
function configVars(mode) {
const production = mode === 'production';
return {
FIDLBOLT_BASE_URL: JSON.stringify(production ? 'go/fidlbolt' : null),
};
}
module.exports = (env, argv) => ({
entry: './src/main.ts',
output: {
path: dstPath,
filename: 'bundle.js',
},
resolve: {
extensions: ['.ts', '.js']
},
plugins: [
new webpack.DefinePlugin(configVars(argv.mode)),
new HtmlWebpackPlugin({
template: 'src/index.html',
favicon: 'src/favicon.ico',
hash: true,
}),
new MiniCssExtractPlugin({
filename: 'style.css',
}),
],
optimization: {
minimizer: [
new TerserJSPlugin({}),
new CssMinimizerPlugin({}),
],
},
module: {
rules: [
{
test: /\.ts$/,
include: srcPath,
use: 'ts-loader',
},
{
test: /\.elm$/,
include: elmPath,
use: {
loader: 'elm-webpack-loader',
options: {
cwd: elmPath,
debug: argv.mode == "development",
optimize: argv.mode == "production",
}
}
},
{
test: /\.css$/,
use: [
MiniCssExtractPlugin.loader,
'css-loader',
],
},
],
},
});