You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
2.9 KiB
86 lines
2.9 KiB
// Note: You must restart bin/webpack-dev-server for changes to take effect
|
|
|
|
const { existsSync } = require('fs');
|
|
const webpack = require('webpack');
|
|
const { basename, dirname, join, relative, resolve, sep } = require('path');
|
|
const { sync } = require('glob');
|
|
const ExtractTextPlugin = require('extract-text-webpack-plugin');
|
|
const ManifestPlugin = require('webpack-manifest-plugin');
|
|
const extname = require('path-complete-extname');
|
|
const { env, paths, publicPath, loadersDir } = require('./configuration.js');
|
|
const localePackPaths = require('./generateLocalePacks');
|
|
|
|
const extensionGlob = `**/*{${paths.extensions.join(',')}}*`;
|
|
const packPaths = sync(join(paths.source, paths.entry, extensionGlob));
|
|
const entryPacks = [].concat(packPaths).concat(localePackPaths).filter(path => path !== join(paths.source, paths.entry, 'custom.js'));
|
|
|
|
const customApplicationStyle = resolve(join(paths.source, 'styles/custom.scss'));
|
|
const originalApplicationStyle = resolve(join(paths.source, 'styles/application.scss'));
|
|
|
|
module.exports = {
|
|
entry: entryPacks.reduce(
|
|
(map, entry) => {
|
|
const localMap = map;
|
|
let namespace = relative(join(paths.source, paths.entry), dirname(entry));
|
|
if (namespace === join('..', '..', '..', 'tmp', 'packs')) {
|
|
namespace = ''; // generated by generateLocalePacks.js
|
|
}
|
|
localMap[join(namespace, basename(entry, extname(entry)))] = resolve(entry);
|
|
return localMap;
|
|
}, {}
|
|
),
|
|
|
|
output: {
|
|
filename: '[name].js',
|
|
chunkFilename: '[name]-[chunkhash].js',
|
|
path: resolve(paths.output, paths.entry),
|
|
publicPath,
|
|
},
|
|
|
|
module: {
|
|
rules: sync(join(loadersDir, '*.js')).map(loader => require(loader)),
|
|
},
|
|
|
|
plugins: [
|
|
new webpack.EnvironmentPlugin(JSON.parse(JSON.stringify(env))),
|
|
new ExtractTextPlugin(env.NODE_ENV === 'production' ? '[name]-[hash].css' : '[name].css'),
|
|
new ManifestPlugin({ fileName: paths.manifest, publicPath, writeToFileEmit: true }),
|
|
new webpack.optimize.CommonsChunkPlugin({
|
|
name: 'common',
|
|
minChunks: (module, count) => {
|
|
const reactIntlPathRegexp = new RegExp(`node_modules\\${sep}react-intl`);
|
|
|
|
if (module.resource && reactIntlPathRegexp.test(module.resource)) {
|
|
// skip react-intl because it's useless to put in the common chunk,
|
|
// e.g. because "shared" modules between zh-TW and zh-CN will never
|
|
// be loaded together
|
|
return false;
|
|
}
|
|
|
|
return count >= 2;
|
|
},
|
|
}),
|
|
],
|
|
|
|
resolve: {
|
|
alias: {
|
|
'mastodon-application-style': existsSync(customApplicationStyle) ?
|
|
customApplicationStyle : originalApplicationStyle,
|
|
},
|
|
extensions: paths.extensions,
|
|
modules: [
|
|
resolve(paths.source),
|
|
resolve(paths.node_modules),
|
|
],
|
|
},
|
|
|
|
resolveLoader: {
|
|
modules: [paths.node_modules],
|
|
},
|
|
|
|
node: {
|
|
// Called by http-link-header in an API we never use, increases
|
|
// bundle size unnecessarily
|
|
Buffer: false,
|
|
},
|
|
};
|
|
|