2024-03-22 22:42:22 +01:00
|
|
|
var webpack = require('webpack');
|
|
|
|
|
var path = require('path');
|
2025-11-11 19:27:29 +01:00
|
|
|
var TerserPlugin = require('terser-webpack-plugin');
|
2024-03-22 22:42:22 +01:00
|
|
|
var isProd = process.env.NODE_ENV === 'production' || process.env.NODE_ENV === 'production-wip';
|
2025-11-11 19:27:29 +01:00
|
|
|
var mode = isProd ? 'production' : 'development';
|
2024-03-22 22:42:22 +01:00
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
|
entry: {
|
|
|
|
|
site: './app/main.js'
|
|
|
|
|
},
|
2025-11-11 19:27:29 +01:00
|
|
|
mode: mode,
|
|
|
|
|
devtool: isProd ? false : 'source-map',
|
2024-03-22 22:42:22 +01:00
|
|
|
target: 'web',
|
|
|
|
|
output: {
|
|
|
|
|
path: path.resolve(__dirname, 'assets'),
|
2025-11-11 19:27:29 +01:00
|
|
|
filename: (pathData) => {
|
|
|
|
|
return pathData.chunk && pathData.chunk.name === 'site'
|
|
|
|
|
? 'form.min.js'
|
|
|
|
|
: `form.${pathData.chunk && pathData.chunk.name ? pathData.chunk.name : 'chunk'}.js`;
|
|
|
|
|
},
|
|
|
|
|
chunkFilename: 'form.[name].js'
|
2024-03-22 22:42:22 +01:00
|
|
|
},
|
|
|
|
|
optimization: {
|
|
|
|
|
minimize: isProd,
|
2025-11-11 19:27:29 +01:00
|
|
|
minimizer: isProd ? [
|
|
|
|
|
new TerserPlugin({
|
|
|
|
|
parallel: true,
|
|
|
|
|
extractComments: false,
|
|
|
|
|
terserOptions: {
|
2024-03-22 22:42:22 +01:00
|
|
|
compress: {
|
|
|
|
|
drop_console: true
|
|
|
|
|
},
|
2025-11-11 19:27:29 +01:00
|
|
|
format: {
|
|
|
|
|
comments: false
|
|
|
|
|
}
|
2024-03-22 22:42:22 +01:00
|
|
|
}
|
|
|
|
|
})
|
2025-11-11 19:27:29 +01:00
|
|
|
] : [],
|
2024-03-22 22:42:22 +01:00
|
|
|
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'
|
|
|
|
|
})
|
|
|
|
|
],
|
|
|
|
|
externals: {
|
|
|
|
|
jquery: 'jQuery',
|
|
|
|
|
'grav-form': 'GravForm'
|
|
|
|
|
},
|
|
|
|
|
module: {
|
|
|
|
|
rules: [
|
|
|
|
|
{ enforce: 'pre', test: /\.json$/, loader: 'json-loader' },
|
|
|
|
|
{ enforce: 'pre', test: /\.js$/, loader: 'eslint-loader', exclude: /node_modules/ },
|
2025-11-11 19:27:29 +01:00
|
|
|
{
|
|
|
|
|
test: /\.css$/,
|
|
|
|
|
use: [
|
|
|
|
|
'style-loader',
|
|
|
|
|
'css-loader'
|
|
|
|
|
]
|
|
|
|
|
},
|
2024-03-22 22:42:22 +01:00
|
|
|
{
|
|
|
|
|
test: /\.js$/,
|
|
|
|
|
loader: 'babel-loader',
|
|
|
|
|
exclude: /node_modules/,
|
2025-11-11 19:27:29 +01:00
|
|
|
options: {
|
2024-03-22 22:42:22 +01:00
|
|
|
presets: ['@babel/preset-env']
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
};
|