webpack.prod.config.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. const path = require('path');
  2. //const webpack = require('webpack');
  3. const { merge } = require('webpack-merge');
  4. const baseWpConfig = require('./webpack.base.config');
  5. const TerserPlugin = require('terser-webpack-plugin');
  6. const CssMinimizerWebpackPlugin = require('css-minimizer-webpack-plugin');
  7. const MiniCssExtractPlugin = require('mini-css-extract-plugin');
  8. const CleanWebpackPlugin = require('clean-webpack-plugin');
  9. const HtmlWebpackPlugin = require('html-webpack-plugin');
  10. const CopyWebpackPlugin = require('copy-webpack-plugin');
  11. const {GenerateSW} = require('workbox-webpack-plugin');
  12. const publicDir = path.resolve(__dirname, '../dist/tmp/public');
  13. const clientDir = path.resolve(__dirname, '../client');
  14. module.exports = merge(baseWpConfig, {
  15. mode: 'production',
  16. output: {
  17. path: `${publicDir}/app_new`,
  18. filename: 'bundle.[contenthash].js'
  19. },
  20. module: {
  21. rules: [
  22. {
  23. test: /\.css$/,
  24. use: [
  25. MiniCssExtractPlugin.loader,
  26. 'css-loader'
  27. ]
  28. }
  29. ]
  30. },
  31. optimization: {
  32. minimizer: [
  33. new TerserPlugin({
  34. cache: true,
  35. parallel: true,
  36. terserOptions: {
  37. output: {
  38. comments: false,
  39. },
  40. },
  41. }),
  42. new CssMinimizerWebpackPlugin()
  43. ]
  44. },
  45. plugins: [
  46. new CleanWebpackPlugin([publicDir], {root: path.resolve(__dirname, '..')}),
  47. new MiniCssExtractPlugin({
  48. filename: "[name].[contenthash].css"
  49. }),
  50. new HtmlWebpackPlugin({
  51. template: `${clientDir}/index.html.template`,
  52. filename: `${publicDir}/index.html`
  53. }),
  54. new CopyWebpackPlugin([{from: `${clientDir}/assets/*`, to: `${publicDir}/`}]),
  55. new GenerateSW({
  56. cacheId: 'liberama',
  57. swDest: `${publicDir}/service-worker.js`,
  58. navigateFallback: '/index.html',
  59. navigateFallbackDenylist: [new RegExp('^/api'), new RegExp('^/ws'), new RegExp('^/tmp'),],
  60. skipWaiting: true,
  61. }),
  62. ]
  63. });