| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 | var webpack = require('webpack');var path = require('path');var TerserPlugin = require('terser-webpack-plugin');var isProd = process.env.NODE_ENV === 'production' || process.env.NODE_ENV === 'production-wip';var VueLoaderPlugin = require('vue-loader/lib/plugin');const ESLintWebpackPlugin = require('eslint-webpack-plugin');module.exports = {    entry: {        'flex-objects': './app/main.js'    },    devtool: isProd ? false : 'eval-source-map',    target: 'web',    output: {        path: path.resolve(__dirname, 'js'),        filename: '[name].js',        chunkFilename: 'flex-objects-vendor.js'    },    optimization: {        minimize: isProd,        minimizer: [            new TerserPlugin({                terserOptions: {                    compress: {                        drop_console: true                    },                    dead_code: true                }            })        ]        /* , splitChunks: {            cacheGroups: {                vendors: {                    test: /[\\/]node_modules[\\/]/,                    priority: 1,                    name: 'vendor',                    enforce: true,                    chunks: 'all'                }            }        }*/    },    plugins: [        new webpack.ProvidePlugin({            'fetch': 'imports-loader?this=>global!exports-loader?global.fetch!whatwg-fetch'        }),        new VueLoaderPlugin(),        new ESLintWebpackPlugin()    ],    externals: {        jquery: 'jQuery',        'grav-config': 'GravConfig'    },    module: {        rules: [            {                test: /\.css$/,                use: [                    'vue-style-loader',                    'css-loader'                ]            },            {                test: /\.js$/,                loader: 'babel-loader',                options: {                    presets: ['@babel/preset-env'],                    plugins: ['@babel/plugin-proposal-object-rest-spread']                }            },            { test: /\.vue$/, use: ['vue-loader'] },            { test: /\.(png|jpg|gif|svg)$/, loader: 'file', options: { name: '[name].[ext]?[hash]' } }        ]    }};
 |