From cb790ff741e7ae9cd4a50e9585713713e9d73f1c Mon Sep 17 00:00:00 2001 From: Kenneth Aasan Date: Wed, 24 Apr 2024 11:26:51 +0200 Subject: [PATCH 1/5] feat: upgrades react to v18 --- library/package.json | 16 +- package-lock.json | 309 +++++++------------------------------ package.json | 1 - web-component/package.json | 6 +- 4 files changed, 68 insertions(+), 264 deletions(-) diff --git a/library/package.json b/library/package.json index c9d7b51e3..9344cf2b9 100644 --- a/library/package.json +++ b/library/package.json @@ -76,25 +76,25 @@ "isomorphic-dompurify": "^0.13.0", "marked": "^4.0.14", "openapi-sampler": "^1.2.1", - "use-resize-observer": "^8.0.0" + "use-resize-observer": "^9.1.0" }, "peerDependencies": { - "react": ">=16.8.0", - "react-dom": ">=16.8.0" + "react": ">=18.0.0", + "react-dom": ">=18.0.0" }, "devDependencies": { "@cypress/webpack-preprocessor": "^5.9.0", "@tailwindcss/typography": "^0.4.0", "@testing-library/jest-dom": "^5.17.0", - "@testing-library/react": "^12.1.5", + "@testing-library/react": "^15.0.4", "@testing-library/user-event": "^12.8.3", "@types/dompurify": "^2.0.4", "@types/highlight.js": "^10.1.0", "@types/jest": "^26.0.23", "@types/marked": "^4.0.1", "@types/node": "^12.7.2", - "@types/react": "^16.9.2", - "@types/react-dom": "^17.0.3", + "@types/react": "^18.2.79", + "@types/react-dom": "^18.2.25", "autoprefixer": "^10.2.5", "cross-env": "^7.0.3", "cssnano": "^4.1.11", @@ -105,8 +105,8 @@ "postcss-cli": "^8.3.1", "postcss-import": "^14.0.2", "postcss-scopify": "^0.1.9", - "react": "^16.8.0", - "react-dom": "^16.8.0", + "react": "^18.2.0", + "react-dom": "^18.2.0", "tailwindcss": "^2.1.1", "ts-jest": "^26.4.1", "ts-loader": "9.4.4", diff --git a/package-lock.json b/package-lock.json index 10d2ab96e..0b2fedaca 100644 --- a/package-lock.json +++ b/package-lock.json @@ -26,7 +26,6 @@ "markdown-toc": "^1.2.0", "markdownlint-cli": "^0.17.0", "prettier": "^3.2.5", - "react-split": "^2.0.9", "tslib": "^1.10.0", "typescript": "^5.3.3" }, @@ -48,21 +47,21 @@ "isomorphic-dompurify": "^0.13.0", "marked": "^4.0.14", "openapi-sampler": "^1.2.1", - "use-resize-observer": "^8.0.0" + "use-resize-observer": "^9.1.0" }, "devDependencies": { "@cypress/webpack-preprocessor": "^5.9.0", "@tailwindcss/typography": "^0.4.0", "@testing-library/jest-dom": "^5.17.0", - "@testing-library/react": "^12.1.5", + "@testing-library/react": "^15.0.4", "@testing-library/user-event": "^12.8.3", "@types/dompurify": "^2.0.4", "@types/highlight.js": "^10.1.0", "@types/jest": "^26.0.23", "@types/marked": "^4.0.1", "@types/node": "^12.7.2", - "@types/react": "^16.9.2", - "@types/react-dom": "^17.0.3", + "@types/react": "^18.2.79", + "@types/react-dom": "^18.2.25", "autoprefixer": "^10.2.5", "cross-env": "^7.0.3", "cssnano": "^4.1.11", @@ -73,8 +72,8 @@ "postcss-cli": "^8.3.1", "postcss-import": "^14.0.2", "postcss-scopify": "^0.1.9", - "react": "^16.8.0", - "react-dom": "^16.8.0", + "react": "^18.2.0", + "react-dom": "^18.2.0", "tailwindcss": "^2.1.1", "ts-jest": "^26.4.1", "ts-loader": "9.4.4", @@ -83,72 +82,8 @@ "webpack-cli": "5.1.4" }, "peerDependencies": { - "react": ">=16.8.0", - "react-dom": ">=16.8.0" - } - }, - "library/node_modules/@testing-library/dom": { - "version": "8.20.1", - "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-8.20.1.tgz", - "integrity": "sha512-/DiOQ5xBxgdYRC8LNk7U+RWat0S3qRLeIw3ZIkMQ9kkVlRmwD/Eg8k8CqIpD6GW7u20JIUOfMKbxtiLutpjQ4g==", - "dev": true, - "dependencies": { - "@babel/code-frame": "^7.10.4", - "@babel/runtime": "^7.12.5", - "@types/aria-query": "^5.0.1", - "aria-query": "5.1.3", - "chalk": "^4.1.0", - "dom-accessibility-api": "^0.5.9", - "lz-string": "^1.5.0", - "pretty-format": "^27.0.2" - }, - "engines": { - "node": ">=12" - } - }, - "library/node_modules/@testing-library/react": { - "version": "12.1.5", - "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-12.1.5.tgz", - "integrity": "sha512-OfTXCJUFgjd/digLUuPxa0+/3ZxsQmE7ub9kcbW/wi96Bh3o/p5vrETcBGfP17NWPGqeYYl5LTRpwyGoMC4ysg==", - "dev": true, - "dependencies": { - "@babel/runtime": "^7.12.5", - "@testing-library/dom": "^8.0.0", - "@types/react-dom": "<18.0.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "<18.0.0", - "react-dom": "<18.0.0" - } - }, - "library/node_modules/react": { - "version": "16.14.0", - "resolved": "https://registry.npmjs.org/react/-/react-16.14.0.tgz", - "integrity": "sha512-0X2CImDkJGApiAlcf0ODKIneSwBPhqJawOa5wCtKbu7ZECrmS26NvtSILynQ66cgkT/RJ4LidJOc3bUESwmU8g==", - "dependencies": { - "loose-envify": "^1.1.0", - "object-assign": "^4.1.1", - "prop-types": "^15.6.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "library/node_modules/react-dom": { - "version": "16.14.0", - "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.14.0.tgz", - "integrity": "sha512-1gCeQXDLoIqMgqD3IO2Ah9bnf0w9kzhwN5q4FGnHZ67hBm9yePzB5JJAIQCc8x3pFnNlwFq4RidZggNAAkzWWw==", - "dependencies": { - "loose-envify": "^1.1.0", - "object-assign": "^4.1.1", - "prop-types": "^15.6.2", - "scheduler": "^0.19.1" - }, - "peerDependencies": { - "react": "^16.14.0" + "react": ">=18.0.0", + "react-dom": ">=18.0.0" } }, "library/node_modules/ts-jest": { @@ -193,18 +128,6 @@ "node": ">=4.2.0" } }, - "library/node_modules/use-resize-observer": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/use-resize-observer/-/use-resize-observer-8.0.0.tgz", - "integrity": "sha512-n0iKSeiQpJCyaFh5JA0qsVLBIovsF4EIIR1G6XiBwKJN66ZrD4Oj62bjcuTAATPKiSp6an/2UZZxCf/67fk3sQ==", - "dependencies": { - "@juggle/resize-observer": "^3.3.1" - }, - "peerDependencies": { - "react": ">=16.8.0", - "react-dom": ">=16.8.0" - } - }, "node_modules/@aashutoshrathi/word-wrap": { "version": "1.2.6", "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", @@ -5156,23 +5079,22 @@ } }, "node_modules/@testing-library/dom": { - "version": "9.3.4", - "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-9.3.4.tgz", - "integrity": "sha512-FlS4ZWlp97iiNWig0Muq8p+3rVDjRiYE+YKGbAqXOu9nwJFFOdL00kFpz42M+4huzYi86vAK1sOOfyOG45muIQ==", + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-10.0.0.tgz", + "integrity": "sha512-PmJPnogldqoVFf+EwbHvbBJ98MmqASV8kLrBYgsDNxQcFMeIS7JFL48sfyXvuMtgmWO/wMhh25odr+8VhDmn4g==", "dev": true, - "peer": true, "dependencies": { "@babel/code-frame": "^7.10.4", "@babel/runtime": "^7.12.5", "@types/aria-query": "^5.0.1", - "aria-query": "5.1.3", + "aria-query": "5.3.0", "chalk": "^4.1.0", "dom-accessibility-api": "^0.5.9", "lz-string": "^1.5.0", "pretty-format": "^27.0.2" }, "engines": { - "node": ">=14" + "node": ">=18" } }, "node_modules/@testing-library/jest-dom": { @@ -5210,6 +5132,24 @@ "node": ">=8" } }, + "node_modules/@testing-library/react": { + "version": "15.0.4", + "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-15.0.4.tgz", + "integrity": "sha512-Fw/LM1emOHKfCxv5R0tz+25TOtiMt0o5Np1zJmb4LbSacOagXQX4ooAaHiJfGUMe+OjUk504BX11W+9Z8CvyZA==", + "dev": true, + "dependencies": { + "@babel/runtime": "^7.12.5", + "@testing-library/dom": "^10.0.0", + "@types/react-dom": "^18.0.0" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "react": "^18.0.0", + "react-dom": "^18.0.0" + } + }, "node_modules/@testing-library/user-event": { "version": "12.8.3", "resolved": "https://registry.npmjs.org/@testing-library/user-event/-/user-event-12.8.3.tgz", @@ -5510,42 +5450,24 @@ "dev": true }, "node_modules/@types/react": { - "version": "16.14.58", - "resolved": "https://registry.npmjs.org/@types/react/-/react-16.14.58.tgz", - "integrity": "sha512-F8FNMutMPDU2AitpdmBUZozvli+0oCMdgRXG5dY+01gHxYsw6i+dX7HAoYE7k1inZ0ATNVbsjOfrWptUy+kbvA==", + "version": "18.2.79", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.79.tgz", + "integrity": "sha512-RwGAGXPl9kSXwdNTafkOEuFrTBD5SA2B3iEB96xi8+xu5ddUa/cpvyVCSNn+asgLCTHkb5ZxN8gbuibYJi4s1w==", "dev": true, "dependencies": { "@types/prop-types": "*", - "@types/scheduler": "*", "csstype": "^3.0.2" } }, "node_modules/@types/react-dom": { - "version": "17.0.25", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-17.0.25.tgz", - "integrity": "sha512-urx7A7UxkZQmThYA4So0NelOVjx3V4rNFVJwp0WZlbIK5eM4rNJDiN3R/E9ix0MBh6kAEojk/9YL+Te6D9zHNA==", - "dev": true, - "dependencies": { - "@types/react": "^17" - } - }, - "node_modules/@types/react-dom/node_modules/@types/react": { - "version": "17.0.77", - "resolved": "https://registry.npmjs.org/@types/react/-/react-17.0.77.tgz", - "integrity": "sha512-iDAZD0Oq82JyO/EfLI12s9EgE+qqshyURjJn4o8E3bF0D69ScuQOF2/+KE++Zt09y8nSw3Bb3JWBBh/g5H87cg==", + "version": "18.2.25", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.25.tgz", + "integrity": "sha512-o/V48vf4MQh7juIKZU2QGDfli6p1+OOi5oXx36Hffpc9adsHeXjVp8rHuPkjd8VT8sOJ2Zp05HR7CdpGTIUFUA==", "dev": true, "dependencies": { - "@types/prop-types": "*", - "@types/scheduler": "*", - "csstype": "^3.0.2" + "@types/react": "*" } }, - "node_modules/@types/scheduler": { - "version": "0.16.8", - "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", - "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", - "dev": true - }, "node_modules/@types/semver": { "version": "7.5.8", "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz", @@ -6698,12 +6620,12 @@ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" }, "node_modules/aria-query": { - "version": "5.1.3", - "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.1.3.tgz", - "integrity": "sha512-R5iJ5lkuHybztUfuOAznmboyjWq8O6sqNqtK7CLOqdydi54VNbORp49mb14KbWgG1QD3JFO9hJdZ+y4KutfdOQ==", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.3.0.tgz", + "integrity": "sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==", "dev": true, "dependencies": { - "deep-equal": "^2.0.5" + "dequal": "^2.0.3" } }, "node_modules/arr-diff": { @@ -9842,38 +9764,6 @@ "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", "dev": true }, - "node_modules/deep-equal": { - "version": "2.2.3", - "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-2.2.3.tgz", - "integrity": "sha512-ZIwpnevOurS8bpT4192sqAowWM76JDKSHYzMLty3BZGSswgq6pBaH3DhCSW5xVAZICZyKdOBPjwww5wfgT/6PA==", - "dev": true, - "dependencies": { - "array-buffer-byte-length": "^1.0.0", - "call-bind": "^1.0.5", - "es-get-iterator": "^1.1.3", - "get-intrinsic": "^1.2.2", - "is-arguments": "^1.1.1", - "is-array-buffer": "^3.0.2", - "is-date-object": "^1.0.5", - "is-regex": "^1.1.4", - "is-shared-array-buffer": "^1.0.2", - "isarray": "^2.0.5", - "object-is": "^1.1.5", - "object-keys": "^1.1.1", - "object.assign": "^4.1.4", - "regexp.prototype.flags": "^1.5.1", - "side-channel": "^1.0.4", - "which-boxed-primitive": "^1.0.2", - "which-collection": "^1.0.1", - "which-typed-array": "^1.1.13" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/deep-extend": { "version": "0.5.1", "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.5.1.tgz", @@ -10555,26 +10445,6 @@ "node": ">= 0.4" } }, - "node_modules/es-get-iterator": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/es-get-iterator/-/es-get-iterator-1.1.3.tgz", - "integrity": "sha512-sPZmqHBe6JIiTfN5q2pEi//TwxmAFHwj/XEuYjTuse78i8KxaqMTTzxPoFKuzRpDpTJ+0NAbpfenkmH2rePtuw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "get-intrinsic": "^1.1.3", - "has-symbols": "^1.0.3", - "is-arguments": "^1.1.1", - "is-map": "^2.0.2", - "is-set": "^2.0.2", - "is-string": "^1.0.7", - "isarray": "^2.0.5", - "stop-iteration-iterator": "^1.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/es-iterator-helpers": { "version": "1.0.17", "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.17.tgz", @@ -11217,15 +11087,6 @@ "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" } }, - "node_modules/eslint-plugin-jsx-a11y/node_modules/aria-query": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.3.0.tgz", - "integrity": "sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==", - "dev": true, - "dependencies": { - "dequal": "^2.0.3" - } - }, "node_modules/eslint-plugin-prettier": { "version": "5.1.3", "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.3.tgz", @@ -23079,15 +22940,6 @@ "node": ">=10" } }, - "node_modules/scheduler": { - "version": "0.19.1", - "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.19.1.tgz", - "integrity": "sha512-n/zwRWRYSUj0/3g/otKDRPMh6qv2SYMWNq85IEa8iZyAv8od9zDYpGSnpBEjNgcMNq6Scbu5KfIPxNF72R/2EA==", - "dependencies": { - "loose-envify": "^1.1.0", - "object-assign": "^4.1.1" - } - }, "node_modules/schema-utils": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz", @@ -24034,18 +23886,6 @@ "node": ">= 0.4" } }, - "node_modules/stop-iteration-iterator": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/stop-iteration-iterator/-/stop-iteration-iterator-1.0.0.tgz", - "integrity": "sha512-iCGQj+0l0HOdZ2AEeBADlsRC+vsnDsZsbdSiH1yNSjcfKM7fdpCMfqAL/dwF5BLiw/XhRft/Wax6zQbhq2BcjQ==", - "dev": true, - "dependencies": { - "internal-slot": "^1.0.4" - }, - "engines": { - "node": ">= 0.4" - } - }, "node_modules/stream-browserify": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-3.0.0.tgz", @@ -26369,6 +26209,18 @@ "node": ">=0.10.0" } }, + "node_modules/use-resize-observer": { + "version": "9.1.0", + "resolved": "https://registry.npmjs.org/use-resize-observer/-/use-resize-observer-9.1.0.tgz", + "integrity": "sha512-R25VqO9Wb3asSD4eqtcxk8sJalvIOYBqS8MNZlpDSQ4l4xMQxC/J7Id9HoTqPq8FwULIn0PVW+OAqF2dyYbjow==", + "dependencies": { + "@juggle/resize-observer": "^3.3.1" + }, + "peerDependencies": { + "react": "16.8.0 - 18", + "react-dom": "16.8.0 - 18" + } + }, "node_modules/util": { "version": "0.12.5", "resolved": "https://registry.npmjs.org/util/-/util-0.12.5.tgz", @@ -27325,26 +27177,6 @@ "undici-types": "~5.26.4" } }, - "playground/node_modules/@types/react": { - "version": "18.2.66", - "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.66.tgz", - "integrity": "sha512-OYTmMI4UigXeFMF/j4uv0lBBEbongSgptPrHBxqME44h9+yNov+oL6Z3ocJKo0WyXR84sQUNeyIp9MRfckvZpg==", - "dev": true, - "dependencies": { - "@types/prop-types": "*", - "@types/scheduler": "*", - "csstype": "^3.0.2" - } - }, - "playground/node_modules/@types/react-dom": { - "version": "18.2.22", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.22.tgz", - "integrity": "sha512-fHkBXPeNtfvri6gdsMYyW+dW7RXFo6Ad09nLFK0VQWR7yGLai/Cyvyj696gbwYvBnhGtevUG9cET0pmUbMtoPQ==", - "dev": true, - "dependencies": { - "@types/react": "*" - } - }, "playground/node_modules/object-hash": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", @@ -27511,44 +27343,17 @@ "license": "Apache-2.0", "dependencies": { "@asyncapi/react-component": "^1.4.9", - "react": "^16.8.0", - "react-dom": "^16.8.0", + "react": "^18", + "react-dom": "^18", "web-react-components": "^1.4.2" }, "devDependencies": { - "@types/react": "^16.9.2", + "@types/react": "^18", "node-polyfill-webpack-plugin": "^2.0.1", "ts-loader": "9.4.4", "webpack": "5.88.2", "webpack-cli": "5.1.4" } - }, - "web-component/node_modules/react": { - "version": "16.14.0", - "resolved": "https://registry.npmjs.org/react/-/react-16.14.0.tgz", - "integrity": "sha512-0X2CImDkJGApiAlcf0ODKIneSwBPhqJawOa5wCtKbu7ZECrmS26NvtSILynQ66cgkT/RJ4LidJOc3bUESwmU8g==", - "dependencies": { - "loose-envify": "^1.1.0", - "object-assign": "^4.1.1", - "prop-types": "^15.6.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "web-component/node_modules/react-dom": { - "version": "16.14.0", - "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.14.0.tgz", - "integrity": "sha512-1gCeQXDLoIqMgqD3IO2Ah9bnf0w9kzhwN5q4FGnHZ67hBm9yePzB5JJAIQCc8x3pFnNlwFq4RidZggNAAkzWWw==", - "dependencies": { - "loose-envify": "^1.1.0", - "object-assign": "^4.1.1", - "prop-types": "^15.6.2", - "scheduler": "^0.19.1" - }, - "peerDependencies": { - "react": "^16.14.0" - } } } } diff --git a/package.json b/package.json index bc8e158df..2d2fa9946 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,6 @@ "markdown-toc": "^1.2.0", "markdownlint-cli": "^0.17.0", "prettier": "^3.2.5", - "react-split": "^2.0.9", "tslib": "^1.10.0", "typescript": "^5.3.3" } diff --git a/web-component/package.json b/web-component/package.json index ca8396f7a..9f516dbd7 100644 --- a/web-component/package.json +++ b/web-component/package.json @@ -45,12 +45,12 @@ }, "dependencies": { "@asyncapi/react-component": "^1.4.9", - "react": "^16.8.0", - "react-dom": "^16.8.0", + "react": "^18", + "react-dom": "^18", "web-react-components": "^1.4.2" }, "devDependencies": { - "@types/react": "^16.9.2", + "@types/react": "^18", "node-polyfill-webpack-plugin": "^2.0.1", "ts-loader": "9.4.4", "webpack": "5.88.2", From c4c39840857bf90d0e3dc35143dc4837f99a6c1c Mon Sep 17 00:00:00 2001 From: Kenneth Aasan Date: Wed, 24 Apr 2024 11:37:23 +0200 Subject: [PATCH 2/5] feat: upgrades react to v18 --- library/src/components/Href.tsx | 1 + library/src/components/Markdown.tsx | 4 +++- library/src/containers/Servers/Security.tsx | 6 +++--- library/src/containers/Sidebar/Sidebar.tsx | 1 + 4 files changed, 8 insertions(+), 4 deletions(-) diff --git a/library/src/components/Href.tsx b/library/src/components/Href.tsx index 0399ac498..fd5c3aff5 100644 --- a/library/src/components/Href.tsx +++ b/library/src/components/Href.tsx @@ -4,6 +4,7 @@ interface Props { href: string; title?: string; className?: string; + children: React.ReactNode; } export const Href: React.FunctionComponent = ({ diff --git a/library/src/components/Markdown.tsx b/library/src/components/Markdown.tsx index d05d2d597..c225a5f80 100644 --- a/library/src/components/Markdown.tsx +++ b/library/src/components/Markdown.tsx @@ -3,7 +3,9 @@ import { sanitize } from 'isomorphic-dompurify'; import { renderMarkdown } from '../helpers'; -export const Markdown: React.FunctionComponent = ({ children }) => { +export const Markdown: React.FunctionComponent<{ + children: React.ReactNode; +}> = ({ children }) => { if (!children) { return null; } diff --git a/library/src/containers/Servers/Security.tsx b/library/src/containers/Servers/Security.tsx index 39cb91d19..27b52857f 100644 --- a/library/src/containers/Servers/Security.tsx +++ b/library/src/containers/Servers/Security.tsx @@ -36,7 +36,7 @@ export const Security: React.FunctionComponent = ({ ); } } else { - const securities: React.ReactNodeArray = Object.values(security) + const securities: React.ReactNode[] = Object.values(security) .map((requirement) => { const requirements = requirement.all(); const key = Object.keys(requirements)[0]; @@ -85,8 +85,8 @@ export const Security: React.FunctionComponent = ({ function collectSecuritySchemas( securitySchema: SecuritySchemeInterface | null, requiredScopes: string[] = [], -): React.ReactNodeArray { - const schemas: React.ReactNodeArray = []; +): React.ReactNode[] { + const schemas: React.ReactNode[] = []; if (securitySchema) { if (securitySchema.name()) { schemas.push(Name: {securitySchema.name()}); diff --git a/library/src/containers/Sidebar/Sidebar.tsx b/library/src/containers/Sidebar/Sidebar.tsx index af0900152..a722eea3a 100644 --- a/library/src/containers/Sidebar/Sidebar.tsx +++ b/library/src/containers/Sidebar/Sidebar.tsx @@ -388,6 +388,7 @@ const ServerItem: React.FunctionComponent = ({ interface ItemsByTagItemProps { tagName: string; + children: React.ReactNode; } const ItemsByTagItem: React.FunctionComponent = ({ From f4dc1c962d2a030e78a099f6c1603d0f0a06bc5c Mon Sep 17 00:00:00 2001 From: Kenneth Aasan Date: Wed, 24 Apr 2024 12:54:19 +0200 Subject: [PATCH 3/5] feat: upgrades react to v18 --- library/src/standalone-codebase.ts | 47 +++++++++++------------------- playground/app/page.tsx | 2 +- 2 files changed, 18 insertions(+), 31 deletions(-) diff --git a/library/src/standalone-codebase.ts b/library/src/standalone-codebase.ts index 39fcd2575..b04fd996c 100644 --- a/library/src/standalone-codebase.ts +++ b/library/src/standalone-codebase.ts @@ -1,12 +1,7 @@ import React from 'react'; -import { - // eslint-disable-next-line react/no-deprecated - hydrate as hydrateComponent, - // eslint-disable-next-line react/no-deprecated - render as renderComponent, -} from 'react-dom'; - -function querySelector(selector: string): Element | DocumentFragment | null { +import { hydrateRoot, createRoot } from 'react-dom/client'; + +function querySelector(selector: string): Element | null { if (typeof document !== 'undefined') { return document.querySelector(selector); } @@ -18,20 +13,19 @@ function querySelector(selector: string): Element | DocumentFragment | null { * * @param {Any} component of any kind */ -// eslint-disable-next-line @typescript-eslint/no-explicit-any -export function createRender

(component: any) { - return ( - props: P, - container?: Element | DocumentFragment | null, - callback?: () => void, - ) => { +export function createRender< + Props extends Parameters[1], +>(component: Parameters[0]) { + return (props: Props, container?: Element | DocumentFragment | null) => { container = container ?? querySelector('asyncapi'); + if (container === null) { return; } - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - renderComponent(React.createElement(component, props), container, callback); + const root = createRoot(container); + + root.render(React.createElement(component, props)); }; } @@ -40,23 +34,16 @@ export function createRender

(component: any) { * * @param {Any} component of any kind */ -// eslint-disable-next-line @typescript-eslint/no-explicit-any -export function createHydrate

(component: any) { - return ( - props: P, - container?: Element | DocumentFragment | null, - callback?: () => void, - ) => { +export function createHydrate< + Props extends Parameters[1], +>(component: Parameters[0]) { + return (props: Props, container?: Element | Document | null) => { container = container ?? querySelector('asyncapi'); + if (container === null) { return; } - hydrateComponent( - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - React.createElement(component, props), - container, - callback, - ); + hydrateRoot(container, React.createElement(component, props)); }; } diff --git a/playground/app/page.tsx b/playground/app/page.tsx index a3a9ba62b..b0a1f13a9 100644 --- a/playground/app/page.tsx +++ b/playground/app/page.tsx @@ -17,7 +17,7 @@ import { import { defaultConfig, parse, debounce } from '@/utils'; import * as specs from '@/specs'; -const defaultSchema = specs.streetlights; +const defaultSchema = specs.oneOf; interface State { schema: string; From dc9461d950b76624a316a71e834f9c71eb4a9148 Mon Sep 17 00:00:00 2001 From: Kenneth Aasan Date: Wed, 24 Apr 2024 12:59:46 +0200 Subject: [PATCH 4/5] feat: upgrades react to v18 --- playground/app/page.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/playground/app/page.tsx b/playground/app/page.tsx index b0a1f13a9..a3a9ba62b 100644 --- a/playground/app/page.tsx +++ b/playground/app/page.tsx @@ -17,7 +17,7 @@ import { import { defaultConfig, parse, debounce } from '@/utils'; import * as specs from '@/specs'; -const defaultSchema = specs.oneOf; +const defaultSchema = specs.streetlights; interface State { schema: string; From 2eb5218954f124de9e7319b3baac61dd78179186 Mon Sep 17 00:00:00 2001 From: Kenneth Aasan Date: Thu, 25 Apr 2024 11:44:54 +0200 Subject: [PATCH 5/5] merge fix --- library/src/containers/Servers/Security.tsx | 23 ++++++--------------- 1 file changed, 6 insertions(+), 17 deletions(-) diff --git a/library/src/containers/Servers/Security.tsx b/library/src/containers/Servers/Security.tsx index 27b52857f..3038616aa 100644 --- a/library/src/containers/Servers/Security.tsx +++ b/library/src/containers/Servers/Security.tsx @@ -6,7 +6,6 @@ import { } from '@asyncapi/parser'; import { Href, Markdown } from '../../components'; -import { useSpec } from '../../contexts'; import { ServerHelpers } from '../../helpers'; interface Props { @@ -20,16 +19,8 @@ export const Security: React.FunctionComponent = ({ protocol = '', header = 'Security', }) => { - const asyncapi = useSpec(); - const securitySchemes = - !asyncapi.components().isEmpty() && asyncapi.components().securitySchemes(); - let renderedSecurities; - if ( - !security?.length || - !securitySchemes || - !Object.keys(securitySchemes).length - ) { + if (!security?.length) { if (protocol === 'kafka' || protocol === 'kafka-secure') { renderedSecurities = ( @@ -37,12 +28,11 @@ export const Security: React.FunctionComponent = ({ } } else { const securities: React.ReactNode[] = Object.values(security) + .map((requirements) => requirements.all()) + .flat() .map((requirement) => { - const requirements = requirement.all(); - const key = Object.keys(requirements)[0]; - const def = securitySchemes[Number(key)]; - // eslint-disable-next-line @typescript-eslint/no-explicit-any - const requiredScopes: any = requirements[Number(key)]; + const def = requirement.scheme(); + const requiredScopes = requirement.scopes(); if (!def) { return null; @@ -51,7 +41,6 @@ export const Security: React.FunctionComponent = ({ @@ -125,7 +114,7 @@ const SecurityItem: React.FunctionComponent = ({ protocol, requiredScopes, }) => { - const schemas: React.ReactNodeArray = collectSecuritySchemas( + const schemas: React.ReactNode[] = collectSecuritySchemas( securitySchema, requiredScopes, );