webpack: Upgrade webpack version 4.5.0.

Upgrade webpack to latest version at the time of authoring. This
involves upgrading webpack version and its loaders to compatible
versions. It also involved editing tools/webpack to use the
executable for webpack-cli instead because of a change in how the
webpack package wants you to handle shell execution.
It also fixes the confugration for TypeScript in the webpack config
as that was previously broken. Including TypeScript files in JS
files compiled by webpack now works.
This commit is contained in:
Armaan Ahluwalia 2018-04-18 01:29:17 +05:30 committed by Tim Abbott
parent c4b886d8ae
commit fc7aa1a771
5 changed files with 2144 additions and 350 deletions

View File

@ -6,14 +6,14 @@
"main": "", "main": "",
"dependencies": { "dependencies": {
"@types/node": "8.0.34", "@types/node": "8.0.34",
"@types/webpack": "3.0.13", "@types/webpack": "4.1.3",
"blueimp-md5": "2.10.0", "blueimp-md5": "2.10.0",
"clipboard": "2.0.0", "clipboard": "2.0.0",
"emoji-datasource-apple": "3.0.0", "emoji-datasource-apple": "3.0.0",
"emoji-datasource-emojione": "3.0.0", "emoji-datasource-emojione": "3.0.0",
"emoji-datasource-google": "3.0.0", "emoji-datasource-google": "3.0.0",
"emoji-datasource-twitter": "3.0.0", "emoji-datasource-twitter": "3.0.0",
"expose-loader": "0.7.3", "expose-loader": "0.7.5",
"flatpickr": "4.2.3", "flatpickr": "4.2.3",
"fuzzysearch": "1.0.3", "fuzzysearch": "1.0.3",
"handlebars": "4.0.10", "handlebars": "4.0.10",
@ -35,13 +35,14 @@
"string.prototype.endswith": "0.2.0", "string.prototype.endswith": "0.2.0",
"string.prototype.startswith": "0.2.0", "string.prototype.startswith": "0.2.0",
"to-markdown": "3.1.0", "to-markdown": "3.1.0",
"ts-loader": "2.1.0", "ts-loader": "4.2.0",
"ts-node": "3.3.0", "ts-node": "3.3.0",
"typescript": "2.7.2", "typescript": "2.7.2",
"underscore": "1.8.3", "underscore": "1.8.3",
"webfonts-generator": "0.4.0", "webfonts-generator": "0.4.0",
"webpack": "2.5.1", "webpack": "4.5.0",
"webpack-bundle-tracker": "0.3.0", "webpack-bundle-tracker": "0.3.0",
"webpack-cli": "2.0.14",
"winchan": "0.2.0", "winchan": "0.2.0",
"xdate": "0.8.2", "xdate": "0.8.2",
"zxcvbn": "4.4.2" "zxcvbn": "4.4.2"
@ -60,7 +61,7 @@
"svgo": "0.7.2", "svgo": "0.7.2",
"swagger-parser": "3.4.1", "swagger-parser": "3.4.1",
"tslint": "5.3.2", "tslint": "5.3.2",
"webpack-dev-server": "2.4.1", "webpack-dev-server": "3.1.3",
"xmlhttprequest": "1.5.0" "xmlhttprequest": "1.5.0"
}, },
"scripts": { "scripts": {

View File

@ -1,6 +1,5 @@
{ {
"compilerOptions": { "compilerOptions": {
"outDir": "../webpack-bundles/",
"sourceMap": true, "sourceMap": true,
"emitDecoratorMetadata": true, "emitDecoratorMetadata": true,
"experimentalDecorators": true, "experimentalDecorators": true,
@ -13,6 +12,5 @@
"target": "es5", "target": "es5",
"jsx": "react", "jsx": "react",
"allowJs": false "allowJs": false
}, }
"rootDir": "../.."
} }

View File

@ -21,7 +21,7 @@ STATIC_PATH = 'static/'
def run(): def run():
# type: () -> None # type: () -> None
"""Builds for production, writing the output to disk""" """Builds for production, writing the output to disk"""
subprocess.check_call(['node', 'node_modules/.bin/webpack'] + subprocess.check_call(['node', 'node_modules/.bin/webpack-cli'] +
['--config', 'tools/webpack.config.ts', '-p'] + ['--config', 'tools/webpack.config.ts', '-p'] +
['--env', 'production']) ['--env', 'production'])
@ -29,7 +29,7 @@ def run_watch(host, port, minify):
# type: (str, str, bool) -> None # type: (str, str, bool) -> None
"""watches and rebuilds on changes, serving files from memory via webpack-dev-server""" """watches and rebuilds on changes, serving files from memory via webpack-dev-server"""
webpack_args = ['node', 'node_modules/.bin/webpack-dev-server'] webpack_args = ['node', 'node_modules/.bin/webpack-dev-server']
webpack_args += ['--config', 'tools/webpack.config.ts', '--watch-poll', '--port', port, "--host", host] webpack_args += ['--config', 'tools/webpack.config.ts', '--port', port, "--host", host]
if minify: if minify:
webpack_args.append('--optimize-minimize') webpack_args.append('--optimize-minimize')
subprocess.Popen(webpack_args) subprocess.Popen(webpack_args)

View File

@ -4,16 +4,10 @@ import * as webpack from 'webpack';
const assets = require('./webpack.assets.json'); const assets = require('./webpack.assets.json');
// Only use the Webpack 2.0 Rule definitions. export default (env?: string) : webpack.Configuration => {
interface Config extends webpack.Configuration {
module: {
rules: webpack.NewUseRule[]
}
}
export default (env?: string) : Config => {
const production: boolean = env === "production"; const production: boolean = env === "production";
let config: Config = { let config: webpack.Configuration = {
mode: production ? "production" : "development",
context: resolve(__dirname, "../"), context: resolve(__dirname, "../"),
entry: assets, entry: assets,
module: { module: {
@ -21,20 +15,10 @@ export default (env?: string) : Config => {
// Run the typescript compilier on .ts files before webpack // Run the typescript compilier on .ts files before webpack
{ {
test: /\.tsx?$/, test: /\.tsx?$/,
use: 'ts-loader', loader: 'ts-loader',
}, options: {
// This loads and transforms sourcemap files from other compiliers. configFile: require.resolve('../static/ts/tsconfig.json')
// The typescript comilier will generate a sourcemap and }
// source-map-loader will output the correct sourcemap from that.
{
enforce: 'pre',
test: /\.js$/,
use: "source-map-loader",
},
{
enforce: 'pre',
test: /\.tsx?$/,
use: "source-map-loader",
}, },
// Uses script-loader on minified files so we don't change global variables in them. // Uses script-loader on minified files so we don't change global variables in them.
// Also has the effect of making processing these files fast // Also has the effect of making processing these files fast
@ -94,22 +78,16 @@ export default (env?: string) : Config => {
new BundleTracker({filename: 'webpack-stats-production.json'}), new BundleTracker({filename: 'webpack-stats-production.json'}),
]; ];
} else { } else {
// Built webpack dev asset reloader
config.entry['common'].unshift('webpack/hot/dev-server');
// Use 0.0.0.0 so that we can set a port but still use the host
// the browser is connected to.
config.entry['common'].unshift('webpack-dev-server/client?http://0.0.0.0:9994');
// Out JS debugging tools // Out JS debugging tools
config.entry['common'].push('./static/js/debug.js'); config.entry['common'].push('./static/js/debug.js');
config.output.publicPath = '/webpack/'; config.output.publicPath = '/webpack/';
config.plugins = [ config.plugins = [
new BundleTracker({filename: 'var/webpack-stats-dev.json'}), new BundleTracker({filename: 'var/webpack-stats-dev.json'}),
// Hot Reload of code in development
new webpack.HotModuleReplacementPlugin(),
// Better logging from console for hot reload // Better logging from console for hot reload
new webpack.NamedModulesPlugin(), new webpack.NamedModulesPlugin(),
// Hot Reload of code in development
new webpack.HotModuleReplacementPlugin(),
// script-loader should load sourceURL in dev // script-loader should load sourceURL in dev
new webpack.LoaderOptionsPlugin({debug: true}), new webpack.LoaderOptionsPlugin({debug: true}),
]; ];

2435
yarn.lock

File diff suppressed because it is too large Load Diff