const path = require('path'); const TerserPlugin = require("terser-webpack-plugin"); const CssMinimizerPlugin = require('css-minimizer-webpack-plugin'); const HtmlWebpackPlugin = require('html-webpack-plugin'); const MiniCssExtractPlugin = require("mini-css-extract-plugin"); module.exports = { mode: "production", cache: false, entry: './src/main.tsx', output: { path: path.resolve(__dirname, 'dist'), filename: 'bundle.js', }, stats: { colors: true, timings: true, }, performance: { hints: false, }, plugins: [ new HtmlWebpackPlugin({ title: "chaos's Food Likes/Dislikes", aseUrl: './', meta: { 'og:title': { property: 'og:title', content: "chaos's Food Likes/Dislikes" }, 'og:description': { property: 'og:description', content: "A list for all the foods I like, dislike and find myself unable to eat due to sensory difficulties." }, }, }), new MiniCssExtractPlugin(), ], devServer: { historyApiFallback: true, }, resolve: { modules: ['node_modules'], extensions: ['.tsx', '.ts', '.js', ".mjs"], alias: { os: false } }, module: { rules: [ { test: /\.(scss)$/, use: [MiniCssExtractPlugin.loader, { loader: 'css-loader', }, { loader: 'postcss-loader', options: { postcssOptions: { options: function () { return [ require('precss'), require('autoprefixer') ]; } } } }, { loader: 'sass-loader' }] }, { test: /\.ts(x?)$/, exclude: /node_modules/, use: [ { loader: 'ts-loader' } ] }, ], }, optimization: { minimize: true, minimizer: [ `...`, new TerserPlugin({ terserOptions: { ecma: "2015" } }), new CssMinimizerPlugin(), ], }, };