From f4f937dc927a7035229433d9ff2c6e48ba584c58 Mon Sep 17 00:00:00 2001 From: Roman Date: Thu, 20 Jan 2022 14:29:03 +0200 Subject: [PATCH 01/32] attempt to upgrade webpack@5 and all relevant packages to latest version -- part 1 Signed-off-by: Roman --- package.json | 26 +- webpack.extensions.ts | 52 +- webpack.main.ts | 6 +- webpack.renderer.ts | 183 ++-- yarn.lock | 2314 +++++++++++++++-------------------------- 5 files changed, 982 insertions(+), 1599 deletions(-) diff --git a/package.json b/package.json index 2667dea25b9c..e23d50d9387d 100644 --- a/package.json +++ b/package.json @@ -269,7 +269,7 @@ "@material-ui/core": "^4.12.3", "@material-ui/icons": "^4.11.2", "@material-ui/lab": "^4.0.0-alpha.60", - "@pmmmwh/react-refresh-webpack-plugin": "^0.4.3", + "@pmmmwh/react-refresh-webpack-plugin": "^0.5.4", "@sentry/types": "^6.14.1", "@testing-library/jest-dom": "^5.16.1", "@testing-library/react": "^11.2.7", @@ -292,12 +292,11 @@ "@types/lodash": "^4.14.177", "@types/marked": "^4.0.1", "@types/md5-file": "^4.0.2", - "@types/mini-css-extract-plugin": "^0.9.1", + "@types/mini-css-extract-plugin": "^2.4.0", "@types/mock-fs": "^4.13.1", "@types/node": "14.17.33", "@types/node-fetch": "^2.5.12", "@types/npm": "^2.0.32", - "@types/progress-bar-webpack-plugin": "^2.1.2", "@types/proper-lockfile": "^4.1.2", "@types/randomcolor": "^0.5.6", "@types/react": "^17.0.34", @@ -320,10 +319,10 @@ "@types/triple-beam": "^1.3.2", "@types/url-parse": "^1.4.5", "@types/uuid": "^8.3.3", - "@types/webpack": "^4.41.32", - "@types/webpack-dev-server": "^3.11.6", + "@types/webpack": "^5.28.0", + "@types/webpack-dev-server": "^4.7.2", "@types/webpack-env": "^1.16.3", - "@types/webpack-node-externals": "^1.7.1", + "@types/webpack-node-externals": "^2.5.3", "@typescript-eslint/eslint-plugin": "^5.7.0", "@typescript-eslint/parser": "^5.7.0", "ansi_up": "^5.1.0", @@ -348,23 +347,22 @@ "eslint-plugin-unused-imports": "^1.1.5", "file-loader": "^6.2.0", "flex.box": "^3.4.4", - "fork-ts-checker-webpack-plugin": "^5.2.1", + "fork-ts-checker-webpack-plugin": "^6.5.0", "hoist-non-react-statics": "^3.3.2", - "html-webpack-plugin": "^4.5.2", + "html-webpack-plugin": "^5.5.0", "include-media": "^1.4.9", "jest": "26.6.3", "jest-canvas-mock": "^2.3.1", "jest-fetch-mock": "^3.0.3", "jest-mock-extended": "^1.0.18", "make-plural": "^6.2.2", - "mini-css-extract-plugin": "^1.6.2", + "mini-css-extract-plugin": "^2.5.2", "node-gyp": "7.1.2", "node-loader": "^1.0.3", "nodemon": "^2.0.14", "playwright": "^1.17.1", "postcss": "^8.4.5", "postcss-loader": "^4.3.0", - "progress-bar-webpack-plugin": "^2.1.0", "randomcolor": "^0.6.2", "raw-loader": "^4.0.2", "react-beautiful-dnd": "^13.1.0", @@ -390,10 +388,10 @@ "typescript": "^4.5.2", "typescript-plugin-css-modules": "^3.4.0", "url-loader": "^4.1.1", - "webpack": "^4.46.0", - "webpack-cli": "^3.3.12", - "webpack-dev-server": "^3.11.3", - "webpack-node-externals": "^1.7.2", + "webpack": "^5.66.0", + "webpack-cli": "^4.9.1", + "webpack-dev-server": "^4.7.3", + "webpack-node-externals": "^3.0.0", "xterm": "^4.15.0", "xterm-addon-fit": "^0.5.0" } diff --git a/webpack.extensions.ts b/webpack.extensions.ts index a4b06bf9f8d3..9db216d18139 100644 --- a/webpack.extensions.ts +++ b/webpack.extensions.ts @@ -6,9 +6,15 @@ import path from "path"; import type webpack from "webpack"; -import { sassCommonVars, isDevelopment, isProduction } from "./src/common/vars"; +import * as vars from "./src/common/vars"; +import { + cssModulesWebpackRule, + filesAndIconsWebpackRule, + fontsLoaderWebpackRule, +} from "./webpack.renderer"; export default function generateExtensionTypes(): webpack.Configuration { + const { isDevelopment, isProduction } = vars; const entry = "./src/extensions/extension-api.ts"; const outDir = "./src/extensions/npm/extensions/dist"; @@ -48,47 +54,9 @@ export default function generateExtensionTypes(): webpack.Configuration { }, }, }, - // for src/renderer/components/fonts/roboto-mono-nerd.ttf - // in src/renderer/components/dock/terminal.ts 95:25-65 - { - test: /\.(ttf|eot|woff2?)$/, - use: { - loader: "url-loader", - options: { - name: "fonts/[name].[ext]", - }, - }, - }, - { - test: /\.(jpg|png|svg|map|ico)$/, - use: { - loader: "file-loader", - options: { - name: "images/[name]-[hash:6].[ext]", - esModule: false, // handle media imports in