mirror of
https://github.com/scratchfoundation/scratch-www.git
synced 2025-07-12 04:36:13 -04:00
Upgrade to webpack4
This commit is contained in:
parent
d82307a1a6
commit
fd613f1fff
3 changed files with 2313 additions and 766 deletions
2978
package-lock.json
generated
2978
package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
@ -73,7 +73,7 @@
|
||||||
"chromedriver": "86.0.0",
|
"chromedriver": "86.0.0",
|
||||||
"classnames": "2.2.5",
|
"classnames": "2.2.5",
|
||||||
"cookie": "0.4.1",
|
"cookie": "0.4.1",
|
||||||
"copy-webpack-plugin": "0.2.0",
|
"copy-webpack-plugin": "^4.5.1",
|
||||||
"create-react-class": "15.6.2",
|
"create-react-class": "15.6.2",
|
||||||
"css-loader": "0.23.1",
|
"css-loader": "0.23.1",
|
||||||
"email-validator": "2.0.4",
|
"email-validator": "2.0.4",
|
||||||
|
@ -93,7 +93,7 @@
|
||||||
"git-bundle-sha": "0.0.2",
|
"git-bundle-sha": "0.0.2",
|
||||||
"glob": "5.0.15",
|
"glob": "5.0.15",
|
||||||
"google-libphonenumber": "3.2.6",
|
"google-libphonenumber": "3.2.6",
|
||||||
"html-webpack-plugin": "2.22.0",
|
"html-webpack-plugin": "^3.2.0",
|
||||||
"iso-3166-2": "0.4.0",
|
"iso-3166-2": "0.4.0",
|
||||||
"jest": "^23.6.0",
|
"jest": "^23.6.0",
|
||||||
"json-loader": "0.5.2",
|
"json-loader": "0.5.2",
|
||||||
|
@ -141,7 +141,9 @@
|
||||||
"tap": "14.10.8",
|
"tap": "14.10.8",
|
||||||
"url-loader": "2.3.0",
|
"url-loader": "2.3.0",
|
||||||
"watch": "0.16.0",
|
"watch": "0.16.0",
|
||||||
"webpack": "2.7.0",
|
"webpack": "^4.46.0",
|
||||||
|
"webpack-bundle-analyzer": "^4.4.0",
|
||||||
|
"webpack-cli": "^3.1.0",
|
||||||
"webpack-dev-middleware": "2.0.4",
|
"webpack-dev-middleware": "2.0.4",
|
||||||
"xhr": "2.2.0"
|
"xhr": "2.2.0"
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,11 +1,16 @@
|
||||||
const autoprefixer = require('autoprefixer');
|
|
||||||
const CopyWebpackPlugin = require('copy-webpack-plugin');
|
|
||||||
const defaults = require('lodash.defaults');
|
const defaults = require('lodash.defaults');
|
||||||
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
|
||||||
const gitsha = require('git-bundle-sha');
|
const gitsha = require('git-bundle-sha');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const webpack = require('webpack');
|
const webpack = require('webpack');
|
||||||
|
|
||||||
|
// Plugins
|
||||||
|
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
|
||||||
|
const CopyWebpackPlugin = require('copy-webpack-plugin');
|
||||||
|
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
||||||
|
|
||||||
|
// PostCss
|
||||||
|
const autoprefixer = require('autoprefixer');
|
||||||
|
|
||||||
let routes = require('./src/routes.json');
|
let routes = require('./src/routes.json');
|
||||||
const templateConfig = require('./src/template-config.js'); // eslint-disable-line global-require
|
const templateConfig = require('./src/template-config.js'); // eslint-disable-line global-require
|
||||||
|
|
||||||
|
@ -15,6 +20,9 @@ if (process.env.NODE_ENV !== 'production') {
|
||||||
|
|
||||||
routes = routes.filter(route => !process.env.VIEW || process.env.VIEW === route.view);
|
routes = routes.filter(route => !process.env.VIEW || process.env.VIEW === route.view);
|
||||||
|
|
||||||
|
const pageRoutes = routes.filter(function (route) {
|
||||||
|
return !route.redirect;
|
||||||
|
});
|
||||||
let VersionPlugin = function (options) {
|
let VersionPlugin = function (options) {
|
||||||
this.options = options || {};
|
this.options = options || {};
|
||||||
return this;
|
return this;
|
||||||
|
@ -48,27 +56,20 @@ VersionPlugin.prototype.apply = function (compiler) {
|
||||||
};
|
};
|
||||||
|
|
||||||
// Prepare all entry points
|
// Prepare all entry points
|
||||||
let entry = {
|
let entry = {};
|
||||||
common: [
|
|
||||||
// Vendor
|
pageRoutes.forEach(function (route) {
|
||||||
'react',
|
entry[route.name] = [
|
||||||
'react-dom',
|
'./src/init.js',
|
||||||
'react-intl',
|
`./src/views/${route.view}.jsx`
|
||||||
'redux',
|
];
|
||||||
// Init
|
|
||||||
'./src/init.js'
|
|
||||||
]
|
|
||||||
};
|
|
||||||
routes.forEach(function (route) {
|
|
||||||
if (!route.redirect) {
|
|
||||||
entry[route.name] = `./src/views/${route.view}.jsx`;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Config
|
// Config
|
||||||
module.exports = {
|
module.exports = {
|
||||||
entry: entry,
|
entry: entry,
|
||||||
devtool: process.env.NODE_ENV === 'production' ? 'none' : 'eval',
|
devtool: process.env.NODE_ENV === 'production' ? 'none' : 'eval',
|
||||||
|
mode: process.env.NODE_ENV === 'production' ? 'production' : 'development',
|
||||||
output: {
|
output: {
|
||||||
path: path.resolve(__dirname, 'build'),
|
path: path.resolve(__dirname, 'build'),
|
||||||
filename: 'js/[name].bundle.js'
|
filename: 'js/[name].bundle.js'
|
||||||
|
@ -129,12 +130,20 @@ module.exports = {
|
||||||
node: {
|
node: {
|
||||||
fs: 'empty'
|
fs: 'empty'
|
||||||
},
|
},
|
||||||
|
optimization: {
|
||||||
|
splitChunks: {
|
||||||
|
cacheGroups: {
|
||||||
|
common: {
|
||||||
|
chunks: 'all',
|
||||||
|
name: 'common',
|
||||||
|
minChunks: pageRoutes.length // Extract only chunks common to all html pages
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
plugins: [
|
plugins: [
|
||||||
new VersionPlugin({length: 5})
|
new VersionPlugin({length: 5})
|
||||||
].concat(routes
|
].concat(pageRoutes
|
||||||
.filter(function (route) {
|
|
||||||
return !route.redirect;
|
|
||||||
})
|
|
||||||
.map(function (route) {
|
.map(function (route) {
|
||||||
return new HtmlWebpackPlugin(defaults({}, {
|
return new HtmlWebpackPlugin(defaults({}, {
|
||||||
title: route.title,
|
title: route.title,
|
||||||
|
@ -165,30 +174,22 @@ module.exports = {
|
||||||
new CopyWebpackPlugin([{
|
new CopyWebpackPlugin([{
|
||||||
from: 'node_modules/scratch-gui/dist/static/assets',
|
from: 'node_modules/scratch-gui/dist/static/assets',
|
||||||
to: 'static/assets'
|
to: 'static/assets'
|
||||||
}])
|
}]),
|
||||||
|
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://cdn2.scratch.mit.edu') + '"',
|
||||||
|
'process.env.SCRATCH_ENV': '"' + (process.env.SCRATCH_ENV || 'development') + '"',
|
||||||
|
'process.env.SENTRY_DSN': '"' + (process.env.SENTRY_DSN || '') + '"'
|
||||||
|
})
|
||||||
])
|
])
|
||||||
.concat(process.env.NODE_ENV === 'production' ? [
|
.concat(process.env.ANALYZE_BUNDLE === 'true' ? [
|
||||||
new webpack.optimize.UglifyJsPlugin({
|
new BundleAnalyzerPlugin()
|
||||||
sourceMap: true
|
|
||||||
})
|
|
||||||
] : [])
|
] : [])
|
||||||
.concat([
|
|
||||||
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://cdn2.scratch.mit.edu') + '"',
|
|
||||||
'process.env.SCRATCH_ENV': '"' + (process.env.SCRATCH_ENV || 'development') + '"',
|
|
||||||
'process.env.SENTRY_DSN': '"' + (process.env.SENTRY_DSN || '') + '"'
|
|
||||||
}),
|
|
||||||
new webpack.optimize.CommonsChunkPlugin({
|
|
||||||
name: 'common',
|
|
||||||
filename: 'js/common.bundle.js'
|
|
||||||
})
|
|
||||||
])
|
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue