2020-03-27 13:59:38 -07:00
|
|
|
// Note: You must restart bin/webpack-dev-server for changes to take effect
|
|
|
|
|
2022-04-20 11:58:22 -07:00
|
|
|
const fs = require('fs');
|
2020-06-04 15:31:17 -07:00
|
|
|
const { join, resolve } = require('path');
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2021-04-17 11:30:22 -07:00
|
|
|
const CopyPlugin = require('copy-webpack-plugin');
|
2022-02-26 16:13:35 -08:00
|
|
|
const ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin');
|
2022-01-10 14:17:52 -08:00
|
|
|
const HtmlWebpackHarddiskPlugin = require('html-webpack-harddisk-plugin');
|
|
|
|
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
2020-03-27 13:59:38 -07:00
|
|
|
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
|
2022-01-10 14:17:52 -08:00
|
|
|
const webpack = require('webpack');
|
2020-03-27 13:59:38 -07:00
|
|
|
const AssetsManifestPlugin = require('webpack-assets-manifest');
|
2022-04-14 13:22:37 -07:00
|
|
|
const DeadCodePlugin = require('webpack-deadcode-plugin');
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2021-07-21 14:43:41 -07:00
|
|
|
const { env, settings, output } = require('./configuration');
|
2020-03-27 13:59:38 -07:00
|
|
|
const rules = require('./rules');
|
|
|
|
|
2022-03-21 11:09:01 -07:00
|
|
|
const { FE_SUBDIRECTORY, FE_INSTANCE_SOURCE_DIR } = require(join(__dirname, '..', 'app', 'soapbox', 'build_config'));
|
2021-09-03 11:49:18 -07:00
|
|
|
|
2022-04-20 11:58:22 -07:00
|
|
|
// Return file as string, or return empty string
|
|
|
|
const readFile = filename => {
|
|
|
|
try {
|
|
|
|
return fs.readFileSync(filename, 'utf8');
|
|
|
|
} catch {
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-09-05 14:42:48 -07:00
|
|
|
const makeHtmlConfig = (params = {}) => {
|
|
|
|
return Object.assign({
|
|
|
|
template: 'app/index.ejs',
|
|
|
|
chunksSortMode: 'manual',
|
|
|
|
chunks: ['common', 'locale_en', 'application', 'styles'],
|
|
|
|
alwaysWriteToDisk: true,
|
|
|
|
minify: {
|
|
|
|
collapseWhitespace: true,
|
|
|
|
removeComments: false,
|
|
|
|
removeRedundantAttributes: true,
|
|
|
|
removeScriptTypeAttributes: true,
|
|
|
|
removeStyleLinkTypeAttributes: true,
|
|
|
|
useShortDoctype: true,
|
|
|
|
},
|
2022-04-20 11:58:22 -07:00
|
|
|
templateParameters: {
|
|
|
|
snippets: readFile(resolve('custom/snippets.html')),
|
|
|
|
},
|
2021-09-05 14:42:48 -07:00
|
|
|
}, params);
|
2021-08-30 17:17:32 -07:00
|
|
|
};
|
|
|
|
|
2020-03-27 13:59:38 -07:00
|
|
|
module.exports = {
|
2021-09-10 17:30:47 -07:00
|
|
|
entry: {
|
2022-04-15 17:54:40 -07:00
|
|
|
application: resolve('app/application.ts'),
|
2021-09-10 17:30:47 -07:00
|
|
|
},
|
2020-03-27 13:59:38 -07:00
|
|
|
|
|
|
|
output: {
|
2022-09-30 10:03:10 -07:00
|
|
|
filename: 'packs/js/[name].js',
|
|
|
|
chunkFilename: 'packs/js/[name].chunk.js',
|
|
|
|
hotUpdateChunkFilename: 'packs/js/[id].hot-update.js',
|
2021-07-21 14:43:41 -07:00
|
|
|
path: output.path,
|
2021-09-05 11:21:39 -07:00
|
|
|
publicPath: join(FE_SUBDIRECTORY, '/'),
|
2020-03-27 13:59:38 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
optimization: {
|
2021-09-05 14:42:48 -07:00
|
|
|
chunkIds: 'total-size',
|
|
|
|
moduleIds: 'size',
|
2020-03-27 13:59:38 -07:00
|
|
|
runtimeChunk: {
|
|
|
|
name: 'common',
|
|
|
|
},
|
|
|
|
splitChunks: {
|
|
|
|
cacheGroups: {
|
|
|
|
default: false,
|
2021-09-05 14:42:48 -07:00
|
|
|
defaultVendors: false,
|
2020-03-27 13:59:38 -07:00
|
|
|
common: {
|
|
|
|
name: 'common',
|
|
|
|
chunks: 'all',
|
|
|
|
minChunks: 2,
|
|
|
|
minSize: 0,
|
|
|
|
test: /^(?!.*[\\\/]node_modules[\\\/]react-intl[\\\/]).+$/,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
module: {
|
2021-09-09 10:00:42 -07:00
|
|
|
rules,
|
2020-03-27 13:59:38 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
plugins: [
|
|
|
|
new webpack.EnvironmentPlugin(JSON.parse(JSON.stringify(env))),
|
2021-09-05 14:42:48 -07:00
|
|
|
new webpack.ProvidePlugin({
|
|
|
|
process: 'process/browser',
|
|
|
|
}),
|
2022-04-12 10:38:19 -07:00
|
|
|
new ForkTsCheckerWebpackPlugin({ typescript: { memoryLimit: 8192 } }),
|
2020-03-27 13:59:38 -07:00
|
|
|
new MiniCssExtractPlugin({
|
2021-07-21 14:43:41 -07:00
|
|
|
filename: 'packs/css/[name]-[contenthash:8].css',
|
|
|
|
chunkFilename: 'packs/css/[name]-[contenthash:8].chunk.css',
|
2020-03-27 13:59:38 -07:00
|
|
|
}),
|
|
|
|
new AssetsManifestPlugin({
|
|
|
|
integrity: false,
|
|
|
|
entrypoints: true,
|
|
|
|
writeToDisk: true,
|
|
|
|
publicPath: true,
|
|
|
|
}),
|
2022-04-14 13:22:37 -07:00
|
|
|
// https://github.com/MQuy/webpack-deadcode-plugin
|
|
|
|
new DeadCodePlugin({
|
|
|
|
patterns: [
|
|
|
|
'app/**/*',
|
|
|
|
],
|
|
|
|
exclude: [
|
|
|
|
'**/*.test.*',
|
|
|
|
'**/__*__/*',
|
|
|
|
'**/(LICENSE|README|COPYING)(.md|.txt)?',
|
|
|
|
// This file is imported with @preval
|
|
|
|
'app/soapbox/features/emoji/emoji_map.json',
|
|
|
|
],
|
|
|
|
}),
|
2021-08-30 17:17:32 -07:00
|
|
|
// https://github.com/jantimon/html-webpack-plugin#options
|
2021-09-05 14:42:48 -07:00
|
|
|
new HtmlWebpackPlugin(makeHtmlConfig()),
|
|
|
|
new HtmlWebpackPlugin(makeHtmlConfig({ filename: '404.html' })),
|
2021-07-21 14:13:24 -07:00
|
|
|
new HtmlWebpackHarddiskPlugin(),
|
2021-04-17 11:30:22 -07:00
|
|
|
new CopyPlugin({
|
|
|
|
patterns: [{
|
2021-09-12 08:51:58 -07:00
|
|
|
from: join(__dirname, '../node_modules/twemoji/assets/svg'),
|
|
|
|
to: join(output.path, 'packs/emoji'),
|
|
|
|
}, {
|
2022-03-21 11:09:01 -07:00
|
|
|
from: join(__dirname, '..', 'app', FE_INSTANCE_SOURCE_DIR),
|
2021-09-03 11:06:04 -07:00
|
|
|
to: join(output.path, 'instance'),
|
2022-03-05 12:38:21 -08:00
|
|
|
}, {
|
|
|
|
from: join(__dirname, '../custom/instance'),
|
|
|
|
to: join(output.path, 'instance'),
|
|
|
|
noErrorOnMissing: true,
|
|
|
|
globOptions: {
|
|
|
|
ignore: ['**/.gitkeep'],
|
|
|
|
},
|
2021-04-17 11:30:22 -07:00
|
|
|
}],
|
|
|
|
options: {
|
|
|
|
concurrency: 100,
|
|
|
|
},
|
|
|
|
}),
|
2020-03-27 13:59:38 -07:00
|
|
|
],
|
|
|
|
|
|
|
|
resolve: {
|
|
|
|
extensions: settings.extensions,
|
|
|
|
modules: [
|
2022-05-09 15:57:15 -07:00
|
|
|
resolve('custom', 'modules'),
|
2020-03-27 13:59:38 -07:00
|
|
|
resolve(settings.source_path),
|
|
|
|
'node_modules',
|
|
|
|
],
|
2021-09-20 13:33:28 -07:00
|
|
|
alias: {
|
2022-08-31 02:35:06 -07:00
|
|
|
'classnames': 'clsx',
|
2021-09-20 15:05:59 -07:00
|
|
|
'icons': resolve('app', 'icons'),
|
2022-03-03 14:00:43 -08:00
|
|
|
'custom': resolve('custom'),
|
2021-09-20 13:33:28 -07:00
|
|
|
},
|
2021-09-05 14:42:48 -07:00
|
|
|
fallback: {
|
|
|
|
path: require.resolve('path-browserify'),
|
|
|
|
util: require.resolve('util'),
|
|
|
|
},
|
2020-03-27 13:59:38 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
resolveLoader: {
|
|
|
|
modules: ['node_modules'],
|
|
|
|
},
|
|
|
|
};
|