geojs/webpack-examples.config.js
David Manthey 6ed307e8dc build: Speed up building tutorials and examples
Use swc-minify-webpack-plugin rather than terser.  Keep terser for the
main build so as not to possible affect compatibility.
2025-11-11 15:09:57 -05:00

63 lines
1.4 KiB
JavaScript

const WebpackStringReplacer = require('webpack-string-replacer');
const { SwcMinifyWebpackPlugin } = require('swc-minify-webpack-plugin');
var path = require('path');
var base = require('./webpack.config');
var rules = base.module.rules.concat([{
test: /\.pug$/,
use: ['pug-load']
}, {
test: /\.(woff|woff2|eot|ttf|svg)(\?v=\d+\.\d+\.\d+)?$/,
type: 'asset/inline'
}, {
test: require.resolve('codemirror'),
use: [{
loader: 'expose-loader',
options: {exposes: 'CodeMirror'}
}]
}]);
var plugins = base.plugins;
plugins.push(new WebpackStringReplacer({
rules:[{
fileInclude: /bootstrap.css$/,
replacements: [{
pattern: /@import.*fonts.googleapis.com\/css\?family=Lato[^;]*;/g,
replacement: () => '@import url(../../@fontsource/lato/index.css);'
}]
}]
}));
var resolve = {
extensions: ['.js', '.css', '.pug', '...'],
alias: base.resolve.alias
};
module.exports = {
mode: 'production',
performance: {hints: false},
devtool: 'source-map',
context: path.join(__dirname),
entry: {
bundle: './examples/index.js'
},
output: {
path: path.join(__dirname, 'dist', 'examples'),
publicPath: '/examples/',
filename: '[name].js'
},
optimization: {
// minimize: false
minimizer: [
new SwcMinifyWebpackPlugin()
]
},
module: {
rules: rules
},
resolve: resolve,
plugins: plugins
};