const path = require('node:path') const webpack = require('webpack') const MiniCssExtractPlugin = require('mini-css-extract-plugin') const RemoveEmptyScriptsPlugin = require('webpack-remove-empty-scripts') const CopyPlugin = require('copy-webpack-plugin') const mode = process.env.NODE_ENV === 'development' ? 'development' : 'production' const publicPath = process.env.RAILS_RELATIVE_URL_ROOT ?? '' module.exports = { mode, devtool: 'source-map', entry: { application: [ './app/frontend/application.js' ] }, module: { rules: [ { test: /\.(js|ts)$/, include: [ path.resolve(__dirname, 'node_modules/@hotwired/stimulus'), path.resolve(__dirname, 'node_modules/@stimulus/polyfills'), path.resolve(__dirname, 'node_modules/@rails/actioncable'), path.resolve(__dirname, 'app/frontend') ], use: ['babel-loader'] }, { test: /\.(png|jpe?g|gif|eot|woff|woff2|ttf|svg|ico)$/i, type: 'asset/resource' }, { test: /\.(scss|css)/i, use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader'] } ] }, resolve: { alias: { 'govuk-frontend-styles': path.resolve(__dirname, 'node_modules/govuk-frontend/govuk/all.scss'), 'govuk-prototype-styles': path.resolve(__dirname, 'node_modules/@x-govuk/govuk-prototype-components/x-govuk/all.scss') }, modules: ['node_modules', 'node_modules/govuk-frontend/govuk'] }, output: { filename: '[name].js', // we must set publicPath to an empty value to override the default of // auto which doesn't work in IE11 publicPath: publicPath, path: path.resolve(__dirname, 'app/assets/builds') }, plugins: [ new RemoveEmptyScriptsPlugin(), new MiniCssExtractPlugin(), new webpack.optimize.LimitChunkCountPlugin({ maxChunks: 1 }), new CopyPlugin({ patterns: [ { from: 'node_modules/govuk-frontend/govuk/assets/images', to: 'images' }, { from: 'node_modules/govuk-frontend/govuk/assets/fonts', to: 'fonts' }, { from: 'node_modules/html5shiv/dist/html5shiv.min.js', to: 'vendor' }, { from: 'app/frontend/vendor/outerHTML.js', to: 'vendor' }, { from: 'app/frontend/vendor/polyfill-output-value.js', to: 'vendor' } ] }) ] }