const path = require('path') const MiniCssExtractPlugin = require('mini-css-extract-plugin') const CopyPlugin = require('copy-webpack-plugin') //__dirname, module.exports = { ignoreWarnings: [ { module: /module2\.js\?[34]/ // A RegExp }, { module: /[13]/, message: /homepage/ }, /warning from compiler/, (warning) => true ], plugins: [ new MiniCssExtractPlugin({ filename: '[name].css', chunkFilename: '[id].css' }), new CopyPlugin({ patterns: [ { from: './app/Views/kewilayahan/dist/*.*', to: path.resolve('./public/kpdl/dist/[name][ext]') } ] }) ], entry: { kpdl: './app/Views/kewilayahan/kytp/kpdl.js', monitoring: './app/Views/kewilayahan/monitoring/index.js', 'monitoring-perubahan-perilaku': './app/Views/kewilayahan/monitoringPerubahanPerilaku/index.js', peta: './app/Views/kewilayahan/peta/peta.js' }, output: { publicPath: '/engineN/public/kpdl/dist/', path: path.resolve('./app/Views/kewilayahan/dist'), filename: '[name].js' }, optimization: { minimize: false }, module: { rules: [ { exclude: /node_modules/, use: { loader: 'babel-loader', options: { presets: ['@babel/preset-react'], plugins: ['@babel/plugin-proposal-optional-chaining', '@babel/plugin-proposal-nullish-coalescing-operator'] } } }, { test: /\.s[ac]ss$/i, use: [ { loader: MiniCssExtractPlugin.loader, options: { publicPath: '' } }, 'css-loader', 'sass-loader' ] }, { test: /\.css$/i, // use: ['style-loader', 'css-loader'] use: [ { loader: MiniCssExtractPlugin.loader, options: { publicPath: '' } }, { loader: 'css-loader', options: { url: { filter: (url) => { if (/^data:(application\/font-woff|image|font)/i.test(url)) { return false } return true } } } } ] }, { test: /Image\.(png|jpe?g|gif)$/i, use: [ { loader: 'file-loader' } ] } ] }, // mode: 'production' mode: 'development' // devServer: { // static: { // directory: path.join(__dirname, './public/kpdl/dist'), // serveIndex: false // }, // compress: false, // hot: true, // port: 9000, // proxy: [ // { // context: ['/engineN/geoserver'], // target: 'http://localhost', // changeOrigin: false // } // ] // } }