From bba6716cf7af625644e96c1742d63c55686272e4 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Mon, 30 Aug 2021 17:17:32 -0700 Subject: [PATCH] Webpack: generate 404.html during build --- .gitlab-ci.yml | 1 - webpack/shared.js | 33 ++++++++++++++++++--------------- 2 files changed, 18 insertions(+), 16 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 34e101953..c4c7800ba 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -88,7 +88,6 @@ pages: script: - yarn build - mv static public - - cp public/{index.html,404.html} variables: NODE_ENV: production artifacts: diff --git a/webpack/shared.js b/webpack/shared.js index 4322ad3b6..df3861563 100644 --- a/webpack/shared.js +++ b/webpack/shared.js @@ -11,6 +11,21 @@ const { UnusedFilesWebpackPlugin } = require('unused-files-webpack-plugin'); const { env, settings, output } = require('./configuration'); const rules = require('./rules'); +const htmlWebpackPluginConfig = { + template: 'app/index.ejs', + chunksSortMode: 'manual', + chunks: ['common', 'locale_en', 'application', 'styles'], + alwaysWriteToDisk: true, + minify: { + collapseWhitespace: true, + removeComments: false, + removeRedundantAttributes: true, + removeScriptTypeAttributes: true, + removeStyleLinkTypeAttributes: true, + useShortDoctype: true, + }, +}; + module.exports = { entry: Object.assign( { application: resolve('app/application.js') }, @@ -75,21 +90,9 @@ module.exports = { ignore: ['node_modules/**/*', '**/__*__/**/*'], }, }), - // https://github.com/ampedandwired/html-webpack-plugin - new HtmlWebpackPlugin({ - template: 'app/index.ejs', - chunksSortMode: 'manual', - chunks: ['common', 'locale_en', 'application', 'styles'], - alwaysWriteToDisk: true, - minify: { - collapseWhitespace: true, - removeComments: false, - removeRedundantAttributes: true, - removeScriptTypeAttributes: true, - removeStyleLinkTypeAttributes: true, - useShortDoctype: true, - }, - }), + // https://github.com/jantimon/html-webpack-plugin#options + new HtmlWebpackPlugin(htmlWebpackPluginConfig), + new HtmlWebpackPlugin(Object.assign(htmlWebpackPluginConfig, { filename: '404.html' })), new HtmlWebpackHarddiskPlugin(), new CopyPlugin({ patterns: [{