const webpack = require('webpack'); const merge = require('webpack-merge'); const MiniCssExtractPlugin = require("mini-css-extract-plugin"); const vars = require('postcss-simple-vars'); const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin'); const dirs = require('./dirs'); const common = require('./webpack.common.js'); module.exports = merge.smart(common, { mode: 'production', devtool: 'hidden-source-map', entry: { show: ['@babel/polyfill/noConflict', './src/modules/app.ts'], }, output: { path: dirs.DEST, filename: 'connection.min.js' }, plugins: [ new MiniCssExtractPlugin({ path: dirs.DEST, filename: "connection.min.css" }), new webpack.BannerPlugin({ banner: `time: ${new Date().toLocaleString()}` }), new OptimizeCssAssetsPlugin({ assetNameRegExp: /\.css$/g, cssProcessor: require('cssnano'), cssProcessorPluginOptions: { preset: ['default', { discardComments: { removeAll: true, }, normalizeUnicode: false }] }, canPrint: true }) ], module: { rules: [ { test: /\.(css|less)$/, use: [ { loader: 'postcss-loader', options: { plugins: [vars({ variables: { fontUrl: '/webroot/decision/resources?path=/com/fr/web/ui/font', imageUrl: '/webroot/decision/resources?path=/com/fr/web/resources/dist/images/1x', image2xUrl: '/webroot/decision/resources?path=/com/fr/web/resources/dist/images/2x', } })] }, }, ], }, ], }, });