scratch-www/webpack.config.js

220 lines
7.4 KiB
JavaScript
Raw Normal View History

const defaults = require('lodash.defaults');
const gitsha = require('git-bundle-sha');
const path = require('path');
const webpack = require('webpack');
2021-02-19 12:51:39 -05:00
// Plugins
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
const CopyWebpackPlugin = require('copy-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const TerserPlugin = require('terser-webpack-plugin');
2021-02-19 12:51:39 -05:00
// PostCss
const autoprefixer = require('autoprefixer');
let routes = require('./src/routes.json');
const templateConfig = require('./src/template-config.js'); // eslint-disable-line global-require
2016-04-12 08:23:43 -04:00
2016-05-11 18:44:54 -04:00
if (process.env.NODE_ENV !== 'production') {
routes = routes.concat(require('./src/routes-dev.json')); // eslint-disable-line global-require
2016-05-11 18:44:54 -04:00
}
2018-03-07 15:16:46 -05:00
routes = routes.filter(route => !process.env.VIEW || process.env.VIEW === route.view);
2021-02-19 12:51:39 -05:00
const pageRoutes = routes.filter(function (route) {
return !route.redirect;
});
let VersionPlugin = function (options) {
2016-04-28 15:40:50 -04:00
this.options = options || {};
return this;
};
2016-04-28 15:40:50 -04:00
VersionPlugin.prototype.apply = function (compiler) {
const addVersion = function (compilation, versionId, callback) {
2016-04-28 15:40:50 -04:00
compilation.assets['version.txt'] = {
source: function () {
return versionId;
},
size: function () {
return versionId.length;
}
2016-04-28 15:40:50 -04:00
};
callback();
};
const options = this.options;
2016-04-28 15:40:50 -04:00
compiler.plugin('emit', function (compilation, callback) {
const sha = process.env.WWW_VERSION;
if (!sha) { // eslint-disable-line no-negated-condition
gitsha(options, function (err, _sha) {
2016-04-28 15:40:50 -04:00
if (err) return callback(err);
return addVersion(compilation, _sha, callback);
2016-04-28 15:40:50 -04:00
});
} else {
return addVersion(compilation, sha, callback);
}
});
};
// Prepare all entry points
2021-02-19 12:51:39 -05:00
let entry = {};
pageRoutes.forEach(function (route) {
entry[route.name] = [
'./src/init.js',
`./src/views/${route.view}.jsx`
];
});
// Config
2015-09-02 15:08:58 -04:00
module.exports = {
entry: entry,
2017-11-27 14:59:45 -05:00
devtool: process.env.NODE_ENV === 'production' ? 'none' : 'eval',
2021-02-19 12:51:39 -05:00
mode: process.env.NODE_ENV === 'production' ? 'production' : 'development',
2015-09-02 15:08:58 -04:00
output: {
2015-11-10 13:38:28 -05:00
path: path.resolve(__dirname, 'build'),
filename: 'js/[name].bundle.js',
publicPath: '/'
2015-09-02 15:08:58 -04:00
},
2021-02-19 10:43:15 -05:00
resolve: {
symlinks: false // Fix local development with `npm link` packages
},
2015-09-02 15:08:58 -04:00
module: {
rules: [
2015-09-02 15:08:58 -04:00
{
test: /\.jsx?$/,
loader: 'babel-loader',
2019-03-07 09:22:53 -05:00
include: [
path.resolve(__dirname, 'src'),
/node_modules[\\/]scratch-[^\\/]+[\\/]src/,
2019-07-12 11:56:34 -04:00
/node_modules[\\/]pify/,
/node_modules[\\/]async/
2019-03-07 09:22:53 -05:00
]
2015-09-02 15:08:58 -04:00
},
{
test: /\.scss$/,
use: [
MiniCssExtractPlugin.loader,
{
loader: 'css-loader',
options: {
url: false
}
},
{
loader: 'postcss-loader',
options: {
postcssOptions: {
plugins: function () {
return [autoprefixer()];
}
}
}
},
'sass-loader'
]
2015-09-08 14:56:28 -04:00
},
2016-06-02 15:25:02 -04:00
{
test: /\.css$/,
use: [
MiniCssExtractPlugin.loader,
{
loader: 'css-loader',
options: {
url: false
}
},
{
loader: 'postcss-loader',
options: {
postcssOptions: {
plugins: function () {
return [autoprefixer()];
}
}
}
}
]
2016-06-02 15:25:02 -04:00
},
2015-09-08 14:56:28 -04:00
{
test: /\.(png|jpg|gif|eot|svg|ttf|woff)$/,
loader: 'url-loader'
2015-09-02 15:08:58 -04:00
}
2016-06-02 15:25:02 -04:00
],
noParse: /node_modules\/google-libphonenumber\/dist/
2015-09-02 16:33:31 -04:00
},
node: {
fs: 'empty'
},
2021-02-19 12:51:39 -05:00
optimization: {
splitChunks: {
cacheGroups: {
common: {
chunks: 'all',
name: 'common',
minChunks: pageRoutes.length // Extract only chunks common to all html pages
}
}
},
minimizer: [
new TerserPlugin({
parallel: 4
})
]
2021-02-19 12:51:39 -05:00
},
2015-09-02 16:33:31 -04:00
plugins: [
new MiniCssExtractPlugin(),
new VersionPlugin({length: 5})
2021-02-19 12:51:39 -05:00
].concat(pageRoutes
.map(function (route) {
return new HtmlWebpackPlugin(defaults({}, {
title: route.title,
filename: route.name + '.html',
route: route,
dynamicMetaTags: route.dynamicMetaTags
}, templateConfig));
})
).concat([
new CopyWebpackPlugin({
patterns: [
{from: 'static'},
{from: 'intl', to: 'js'},
{
from: 'node_modules/scratch-gui/dist/static/blocks-media',
to: 'static/blocks-media'
},
{
from: 'node_modules/scratch-gui/dist/chunks',
to: 'static/chunks'
},
{
from: 'node_modules/scratch-gui/dist/extension-worker.js'
},
{
from: 'node_modules/scratch-gui/dist/extension-worker.js.map'
},
{
from: 'node_modules/scratch-gui/dist/static/assets',
to: 'static/assets'
}
]
}),
2021-02-19 12:51:39 -05:00
new webpack.DefinePlugin({
'process.env.NODE_ENV': '"' + (process.env.NODE_ENV || 'development') + '"',
'process.env.API_HOST': '"' + (process.env.API_HOST || 'https://api.scratch.mit.edu') + '"',
'process.env.RECAPTCHA_SITE_KEY': '"' +
(process.env.RECAPTCHA_SITE_KEY || '6Lf6kK4UAAAAABKTyvdSqgcSVASEnMrCquiAkjVW') + '"',
'process.env.ASSET_HOST': '"' + (process.env.ASSET_HOST || 'https://assets.scratch.mit.edu') + '"',
'process.env.BACKPACK_HOST': '"' + (process.env.BACKPACK_HOST || 'https://backpack.scratch.mit.edu') + '"',
'process.env.CLOUDDATA_HOST': '"' + (process.env.CLOUDDATA_HOST || 'clouddata.scratch.mit.edu') + '"',
'process.env.PROJECT_HOST': '"' + (process.env.PROJECT_HOST || 'https://projects.scratch.mit.edu') + '"',
'process.env.STATIC_HOST': '"' + (process.env.STATIC_HOST || 'https://uploads.scratch.mit.edu') + '"',
'process.env.SCRATCH_ENV': '"' + (process.env.SCRATCH_ENV || 'development') + '"'
2021-02-19 12:51:39 -05:00
})
2018-02-08 12:01:07 -05:00
])
2021-02-19 12:51:39 -05:00
.concat(process.env.ANALYZE_BUNDLE === 'true' ? [
new BundleAnalyzerPlugin()
] : [])
2015-09-02 15:08:58 -04:00
};