You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
buster/webpack.config.js

138 lines
3.6 KiB
JavaScript

const path = require('node:path');
const {lstatSync, readdirSync} = require('node:fs');
const webpack = require('webpack');
const LodashModuleReplacementPlugin = require('lodash-webpack-plugin');
const {VueLoaderPlugin} = require('vue-loader');
const {VuetifyPlugin} = require('webpack-plugin-vuetify');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const storageRevisions = require('./src/storage/config.json').revisions;
const targetEnv = process.env.TARGET_ENV || 'chrome';
const isProduction = process.env.NODE_ENV === 'production';
const enableContributions =
(process.env.ENABLE_CONTRIBUTIONS || 'true') === 'true';
const provideExtApi = !['firefox'].includes(targetEnv);
const provideModules = {};
if (provideExtApi) {
provideModules.browser = 'webextension-polyfill';
}
const plugins = [
new webpack.DefinePlugin({
'process.env': {
TARGET_ENV: JSON.stringify(targetEnv),
STORAGE_REVISION_LOCAL: JSON.stringify(storageRevisions.local.at(-1)),
ENABLE_CONTRIBUTIONS: JSON.stringify(enableContributions.toString())
},
__VUE_OPTIONS_API__: true,
__VUE_PROD_DEVTOOLS__: false
}),
new webpack.ProvidePlugin(provideModules),
new VueLoaderPlugin(),
new VuetifyPlugin(),
new MiniCssExtractPlugin({
filename: '[name]/style.css',
ignoreOrder: true
}),
isProduction ? new LodashModuleReplacementPlugin({shorthands: true}) : null
].filter(Boolean);
const scriptsRootDir = path.join(__dirname, 'src/scripts');
const scripts = readdirSync(scriptsRootDir)
.filter(file => lstatSync(path.join(scriptsRootDir, file)).isFile())
.map(file => file.split('.')[0]);
const entries = Object.fromEntries(
scripts.map(script => [script, `./src/scripts/${script}.js`])
);
if (enableContributions) {
entries.contribute = './src/contribute/main.js';
}
module.exports = {
mode: isProduction ? 'production' : 'development',
entry: {
background: './src/background/main.js',
options: './src/options/main.js',
contribute: './src/contribute/main.js',
solve: './src/solve/main.js',
setup: './src/setup/main.js',
...entries
},
output: {
path: path.resolve(__dirname, 'dist', targetEnv, 'src'),
filename: pathData => {
return scripts.includes(pathData.chunk.name)
? 'scripts/[name].js'
: '[name]/script.js';
},
chunkFilename: '[name]/script.js'
},
optimization: {
splitChunks: {
cacheGroups: {
default: false,
commonsUi: {
name: 'commons-ui',
chunks: chunk => {
return ['options', 'contribute', 'setup'].includes(chunk.name);
},
minChunks: 2
}
}
}
},
module: {
rules: [
{
test: /\.js$/,
use: 'babel-loader',
resolve: {
fullySpecified: false
}
},
{
test: /\.vue$/,
use: [
{
loader: 'vue-loader',
options: {
transformAssetUrls: {img: ''},
compilerOptions: {whitespace: 'preserve'}
}
}
]
},
{
test: /\.(c|sc|sa)ss$/,
use: [
MiniCssExtractPlugin.loader,
'css-loader',
'postcss-loader',
{
loader: 'sass-loader',
options: {
sassOptions: {
includePaths: ['node_modules'],
quietDeps: true
}
}
}
]
}
]
},
resolve: {
modules: [path.resolve(__dirname, 'src'), 'node_modules'],
extensions: ['.js', '.json', '.css', '.scss', '.vue'],
fallback: {fs: false}
},
devtool: false,
plugins
};