123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- const path = require('path');
- //const webpack = require('webpack');
- const { merge } = require('webpack-merge');
- const baseWpConfig = require('./webpack.base.config');
- const TerserPlugin = require('terser-webpack-plugin');
- const CssMinimizerWebpackPlugin = require('css-minimizer-webpack-plugin');
- const MiniCssExtractPlugin = require('mini-css-extract-plugin');
- const CleanWebpackPlugin = require('clean-webpack-plugin');
- const HtmlWebpackPlugin = require('html-webpack-plugin');
- const CopyWebpackPlugin = require('copy-webpack-plugin');
- const {GenerateSW} = require('workbox-webpack-plugin');
- const publicDir = path.resolve(__dirname, '../dist/tmp/public');
- const clientDir = path.resolve(__dirname, '../client');
- module.exports = merge(baseWpConfig, {
- mode: 'production',
- output: {
- path: `${publicDir}/app_new`,
- filename: 'bundle.[contenthash].js'
- },
- module: {
- rules: [
- {
- test: /\.css$/,
- use: [
- MiniCssExtractPlugin.loader,
- 'css-loader'
- ]
- }
- ]
- },
- optimization: {
- minimizer: [
- new TerserPlugin({
- cache: true,
- parallel: true,
- terserOptions: {
- output: {
- comments: false,
- },
- },
- }),
- new CssMinimizerWebpackPlugin()
- ]
- },
- plugins: [
- new CleanWebpackPlugin([publicDir], {root: path.resolve(__dirname, '..')}),
- new MiniCssExtractPlugin({
- filename: "[name].[contenthash].css"
- }),
- new HtmlWebpackPlugin({
- template: `${clientDir}/index.html.template`,
- filename: `${publicDir}/index.html`
- }),
- new CopyWebpackPlugin([{from: `${clientDir}/assets/*`, to: `${publicDir}/`}]),
- new GenerateSW({
- cacheId: 'liberama',
- swDest: `${publicDir}/service-worker.js`,
- navigateFallback: '/index.html',
- navigateFallbackDenylist: [new RegExp('^/api'), new RegExp('^/ws'), new RegExp('^/tmp'),],
- skipWaiting: true,
- }),
- ]
- });
|