From a02f8d804565880dcf9ee7039469fa41dac3e451 Mon Sep 17 00:00:00 2001 From: Ludovic Levalleux Date: Fri, 30 Sep 2022 15:01:25 +0100 Subject: [PATCH] feat: add rNFT license and contractual agreement (#246) * feat: add rNFT license page and route for a given tokenId (=exchangeId) * add ContractualAgreement route, page and component * Allow the template to be rendered for a non existing offer (during creation process) * Design the ExchangePolicyDetails popup as expected * fix a few bugs * fix jest failure * use generic enum for ProgressStatus of several hooks * add comment to explicit converting the tokenId to exchangeId * add card reference to the TODO for contractual agreement * Chat - exchange context should contain CTA to render contract * clean code * remove 'any' type for useModal returns --- .env.example | 14 +- .github/workflows/ci_reusable.yaml | 8 + config-overrides.js | 5 +- package-lock.json | 2229 +++++++++++++++++ package.json | 3 + .../ContractualAgreement.tsx | 44 + src/components/detail/DetailTable.tsx | 38 +- .../detail/DetailWidget/DetailWidget.tsx | 45 +- .../exchangePolicy/FairExchangePolicy.tsx | 6 +- src/components/license/License.tsx | 43 + src/components/modal/ModalComponents.tsx | 7 +- .../components/ExchangePolicyDetails.tsx | 198 ++ .../Collections/CollectionsCardImage.tsx | 3 +- .../modal/components/ManageFunds.tsx | 8 +- src/components/modal/useModal.ts | 3 + src/components/product/Preview.tsx | 58 +- .../seller/finances/SellerFinances.tsx | 9 +- src/lib/config.ts | 9 +- src/lib/routing/parameters.ts | 3 +- src/lib/routing/routes.tsx | 2 + src/lib/types/progressStatus.ts | 6 + src/lib/utils/hooks/useGetIpfsImage.ts | 20 +- src/lib/utils/hooks/useRenderTemplate.ts | 111 + src/pages/account/funds/useFunds.ts | 15 +- .../chat/components/ExchangeSidePreview.tsx | 43 +- .../ContractualAgreement.tsx | 63 + .../create-product/CreateProductInner.tsx | 30 +- src/pages/license/License.tsx | 74 + src/router/routes.ts | 14 + test/__mocks__/react-markdown.js | 8 + test/__mocks__/rehype-raw.js | 6 + test/__mocks__/remark-gfm.js | 6 + styleMock.js => test/__mocks__/styleMock.js | 0 33 files changed, 3040 insertions(+), 91 deletions(-) create mode 100644 src/components/contractualAgreement/ContractualAgreement.tsx create mode 100644 src/components/license/License.tsx create mode 100644 src/components/modal/components/ExchangePolicyDetails.tsx create mode 100644 src/lib/types/progressStatus.ts create mode 100644 src/lib/utils/hooks/useRenderTemplate.ts create mode 100644 src/pages/contractualAgreement/ContractualAgreement.tsx create mode 100644 src/pages/license/License.tsx create mode 100644 test/__mocks__/react-markdown.js create mode 100644 test/__mocks__/rehype-raw.js create mode 100644 test/__mocks__/remark-gfm.js rename styleMock.js => test/__mocks__/styleMock.js (100%) diff --git a/.env.example b/.env.example index 72b4d21e7..a9cf91d3e 100644 --- a/.env.example +++ b/.env.example @@ -19,4 +19,16 @@ REACT_APP_OFFER_CURATION_LIST= # REACT_APP_ENABLE_CURATION_LISTS=false -REACT_APP_DEFAULT_TOKENS_LIST_TESTING='[{"symbol":"ETH","name":"Ether","address":"0x0000000000000000000000000000000000000000","decimals":"18"}]' \ No newline at end of file +REACT_APP_DEFAULT_TOKENS_LIST_TESTING='[{"symbol":"ETH","name":"Ether","address":"0x0000000000000000000000000000000000000000","decimals":"18"}]' + +REACT_APP_RNFT_LICENSE_TEMPLATE=ipfs://QmZ7GtjENZaSgd9M41DbvWkKWkwFcj3B2Hiw7zWVhUjJVp + +REACT_APP_BUYER_SELLER_AGREEMENT_TEMPLATE=ipfs://QmQKtEcfWSHHbtBfZScZhgHik4MPSqXQafFGfq1ZbsHLjK + +# TESTING +REACT_APP_DEFAULT_DISPUTE_RESOLVER_ID=1 +# STAGING +# REACT_APP_DEFAULT_DISPUTE_RESOLVER_ID=2 + +REACT_APP_DEFAULT_RESOLUTION_PERIOD_DAYS=15 + diff --git a/.github/workflows/ci_reusable.yaml b/.github/workflows/ci_reusable.yaml index ce2168605..6f390530e 100644 --- a/.github/workflows/ci_reusable.yaml +++ b/.github/workflows/ci_reusable.yaml @@ -24,6 +24,12 @@ on: REACT_APP_OFFER_CURATION_LIST: required: false type: string + REACT_APP_RNFT_LICENSE_TEMPLATE: + required: true + type: string + REACT_APP_BUYER_SELLER_AGREEMENT_TEMPLATE: + required: true + type: string secrets: NPM_TOKEN: required: true @@ -59,6 +65,8 @@ jobs: REACT_APP_ENABLE_CURATION_LISTS: ${{ inputs.REACT_APP_ENABLE_CURATION_LISTS }} REACT_APP_SELLER_CURATION_LIST: ${{ inputs.REACT_APP_SELLER_CURATION_LIST }} REACT_APP_OFFER_CURATION_LIST: ${{ inputs.REACT_APP_OFFER_CURATION_LIST }} + REACT_APP_RNFT_LICENSE_TEMPLATE: ${{ inputs.REACT_APP_RNFT_LICENSE_TEMPLATE }} + REACT_APP_BUYER_SELLER_AGREEMENT_TEMPLATE: ${{ inputs.REACT_APP_BUYER_SELLER_AGREEMENT_TEMPLATE }} REACT_APP_INFURA_IPFS_PROJECT_ID: ${{ secrets.REACT_APP_INFURA_IPFS_PROJECT_ID }} REACT_APP_INFURA_IPFS_PROJECT_SECRET: ${{ secrets.REACT_APP_INFURA_IPFS_PROJECT_SECRET }} REACT_APP_DEFAULT_TOKENS_LIST_TESTING: ${{ secrets.REACT_APP_DEFAULT_TOKENS_LIST_TESTING }} diff --git a/config-overrides.js b/config-overrides.js index b2bef034b..a2a558a01 100644 --- a/config-overrides.js +++ b/config-overrides.js @@ -57,7 +57,10 @@ module.exports = { jest: function (config) { // ...add your jest config customisation... config.moduleNameMapper = { - "\\.(css|less|scss|sass)$": "/styleMock.js" + "\\.(css|less|scss|sass)$": "/test/__mocks__/styleMock.js", + "react-markdown": "/test/__mocks__/react-markdown.js", + "remark-gfm": "/test/__mocks__/remark-gfm.js", + "rehype-raw": "/test/__mocks__/rehype-raw.js" }; config.transformIgnorePatterns = [ // '[/\\\\]node_modules[/\\\\].+\\.(js|jsx|mjs|cjs|ts|tsx)$', diff --git a/package-lock.json b/package-lock.json index 72384ef44..f0fa3d3e2 100644 --- a/package-lock.json +++ b/package-lock.json @@ -55,6 +55,7 @@ "react-dom": "^18.2.0", "react-hot-toast": "^2.4.0", "react-infinite-scroll-component": "^6.1.0", + "react-markdown": "^8.0.3", "react-popper": "^2.3.0", "react-query": "^3.39.1", "react-responsive": "^9.0.0-beta.10", @@ -63,6 +64,8 @@ "react-select": "^5.4.0", "react-swipeable": "^7.0.0", "react-table": "^7.8.0", + "rehype-raw": "^6.1.1", + "remark-gfm": "^3.0.1", "stream-browserify": "^3.0.0", "use-resize-observer": "^9.0.2", "util": "^0.12.4", @@ -4986,6 +4989,14 @@ "@types/node": "*" } }, + "node_modules/@types/debug": { + "version": "4.1.7", + "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz", + "integrity": "sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg==", + "dependencies": { + "@types/ms": "*" + } + }, "node_modules/@types/eslint": { "version": "8.4.5", "license": "MIT", @@ -5036,6 +5047,14 @@ "@types/node": "*" } }, + "node_modules/@types/hast": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/@types/hast/-/hast-2.3.4.tgz", + "integrity": "sha512-wLEm0QvaoawEDoTRwzTXp4b4jpwiJDvR5KMnFnVodm3scufTlBOWRD6N1OBf9TZMhjlNsSfcO5V+7AF4+Vy+9g==", + "dependencies": { + "@types/unist": "*" + } + }, "node_modules/@types/hoist-non-react-statics": { "version": "3.3.1", "dev": true, @@ -5129,6 +5148,14 @@ "version": "4.0.2", "license": "MIT" }, + "node_modules/@types/mdast": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-3.0.10.tgz", + "integrity": "sha512-W864tg/Osz1+9f4lrGTZpCSO5/z4608eUp19tbozkq2HJK6i3z1kT0H9tlADXuYIb1YYOBByU4Jsqkk75q48qA==", + "dependencies": { + "@types/unist": "*" + } + }, "node_modules/@types/mime": { "version": "1.3.2", "license": "MIT" @@ -5137,6 +5164,11 @@ "version": "3.0.5", "license": "MIT" }, + "node_modules/@types/ms": { + "version": "0.7.31", + "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", + "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==" + }, "node_modules/@types/node": { "version": "18.0.6", "license": "MIT" @@ -5145,6 +5177,11 @@ "version": "4.0.0", "license": "MIT" }, + "node_modules/@types/parse5": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/@types/parse5/-/parse5-6.0.3.tgz", + "integrity": "sha512-SuT16Q1K51EAVPz1K29DJ/sXjhSQ0zjvsypYJ6tlwVsRV9jwW5Adq2ch8Dq8kDBCkYnELS7N7VNCSB5nC56t/g==" + }, "node_modules/@types/pbkdf2": { "version": "3.1.0", "license": "MIT", @@ -5289,6 +5326,11 @@ "version": "2.0.2", "license": "MIT" }, + "node_modules/@types/unist": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-2.0.6.tgz", + "integrity": "sha512-PBjIUxZHOuj0R15/xuwJYjFi+KZdNFrehocChv4g5hu6aFroHue8m0lBP0POdK2nKzbw0cgV1mws8+V/JAcEkQ==" + }, "node_modules/@types/use-sync-external-store": { "version": "0.0.3", "license": "MIT" @@ -7044,6 +7086,15 @@ "babel-plugin-transform-react-remove-prop-types": "^0.4.24" } }, + "node_modules/bail": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/bail/-/bail-2.0.2.tgz", + "integrity": "sha512-0xO6mYd7JB2YesxDKplafRpsiOzPt9V02ddPCLbY1xYGPOX24NTyN50qnUxgCPcSoYMhKpAuBTjQoRZCAkUDRw==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/balanced-match": { "version": "1.0.2", "license": "MIT" @@ -7566,6 +7617,15 @@ "cborg": "cli.js" } }, + "node_modules/ccount": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/ccount/-/ccount-2.0.1.tgz", + "integrity": "sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/chalk": { "version": "2.4.2", "license": "MIT", @@ -7592,6 +7652,15 @@ "node": ">=10" } }, + "node_modules/character-entities": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-2.0.2.tgz", + "integrity": "sha512-shx7oQ0Awen/BRIdkjkvz54PnEEI/EjwXDSIZp86/KKdbafHh1Df/RYGBhn4hbe2+uKC9FnT5UCEdyPz3ai9hQ==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/chart.js": { "version": "3.8.0", "license": "MIT" @@ -7856,6 +7925,15 @@ "node": ">= 0.8" } }, + "node_modules/comma-separated-tokens": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-2.0.2.tgz", + "integrity": "sha512-G5yTt3KQN4Yn7Yk4ed73hlZ1evrFKXeUW3086p3PRFNp7m2vIjI6Pg+Kgb+oyzhd9F2qdcoj67+y3SdxL5XWsg==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/commander": { "version": "9.4.0", "dev": true, @@ -8651,6 +8729,18 @@ "version": "10.3.1", "license": "MIT" }, + "node_modules/decode-named-character-reference": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/decode-named-character-reference/-/decode-named-character-reference-1.0.2.tgz", + "integrity": "sha512-O8x12RzrUF8xyVcY0KJowWsmaJxQbmy0/EtnNtHRpsOcT7dFk5W598coHqBVpmWo1oQQfsCqfCmkZN5DJrZVdg==", + "dependencies": { + "character-entities": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/decode-uri-component": { "version": "0.2.0", "license": "MIT", @@ -8812,6 +8902,14 @@ "node": ">= 0.8" } }, + "node_modules/dequal": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz", + "integrity": "sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==", + "engines": { + "node": ">=6" + } + }, "node_modules/des.js": { "version": "1.0.1", "license": "MIT", @@ -8892,6 +8990,14 @@ "version": "1.2.2", "license": "Apache-2.0" }, + "node_modules/diff": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-5.1.0.tgz", + "integrity": "sha512-D+mk+qE8VC/PAUrlAU34N+VfXev0ghe5ywmpqrawphmVZc1bEfn56uo9qpyGp1p4xpzOHkSW4ztBd6L7Xx4ACw==", + "engines": { + "node": ">=0.3.1" + } + }, "node_modules/diff-sequences": { "version": "28.1.1", "license": "MIT", @@ -10709,6 +10815,11 @@ ], "license": "MIT" }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" + }, "node_modules/extract-files": { "version": "9.0.0", "license": "MIT", @@ -11693,6 +11804,119 @@ "node": ">=8" } }, + "node_modules/hast-to-hyperscript": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/hast-to-hyperscript/-/hast-to-hyperscript-10.0.1.tgz", + "integrity": "sha512-dhIVGoKCQVewFi+vz3Vt567E4ejMppS1haBRL6TEmeLeJVB1i/FJIIg/e6s1Bwn0g5qtYojHEKvyGA+OZuyifw==", + "dependencies": { + "@types/unist": "^2.0.0", + "comma-separated-tokens": "^2.0.0", + "property-information": "^6.0.0", + "space-separated-tokens": "^2.0.0", + "style-to-object": "^0.3.0", + "unist-util-is": "^5.0.0", + "web-namespaces": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-from-parse5": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/hast-util-from-parse5/-/hast-util-from-parse5-7.1.0.tgz", + "integrity": "sha512-m8yhANIAccpU4K6+121KpPP55sSl9/samzQSQGpb0mTExcNh2WlvjtMwSWFhg6uqD4Rr6Nfa8N6TMypQM51rzQ==", + "dependencies": { + "@types/hast": "^2.0.0", + "@types/parse5": "^6.0.0", + "@types/unist": "^2.0.0", + "hastscript": "^7.0.0", + "property-information": "^6.0.0", + "vfile": "^5.0.0", + "vfile-location": "^4.0.0", + "web-namespaces": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-parse-selector": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-3.1.0.tgz", + "integrity": "sha512-AyjlI2pTAZEOeu7GeBPZhROx0RHBnydkQIXlhnFzDi0qfXTmGUWoCYZtomHbrdrheV4VFUlPcfJ6LMF5T6sQzg==", + "dependencies": { + "@types/hast": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-raw": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/hast-util-raw/-/hast-util-raw-7.2.2.tgz", + "integrity": "sha512-0x3BhhdlBcqRIKyc095lBSDvmQNMY3Eulj2PLsT5XCyKYrxssI5yr3P4Kv/PBo1s/DMkZy2voGkMXECnFCZRLQ==", + "dependencies": { + "@types/hast": "^2.0.0", + "@types/parse5": "^6.0.0", + "hast-util-from-parse5": "^7.0.0", + "hast-util-to-parse5": "^7.0.0", + "html-void-elements": "^2.0.0", + "parse5": "^6.0.0", + "unist-util-position": "^4.0.0", + "unist-util-visit": "^4.0.0", + "vfile": "^5.0.0", + "web-namespaces": "^2.0.0", + "zwitch": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-to-parse5": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/hast-util-to-parse5/-/hast-util-to-parse5-7.0.0.tgz", + "integrity": "sha512-YHiS6aTaZ3N0Q3nxaY/Tj98D6kM8QX5Q8xqgg8G45zR7PvWnPGPP0vcKCgb/moIydEJ/QWczVrX0JODCVeoV7A==", + "dependencies": { + "@types/hast": "^2.0.0", + "@types/parse5": "^6.0.0", + "hast-to-hyperscript": "^10.0.0", + "property-information": "^6.0.0", + "web-namespaces": "^2.0.0", + "zwitch": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-whitespace": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-2.0.0.tgz", + "integrity": "sha512-Pkw+xBHuV6xFeJprJe2BBEoDV+AvQySaz3pPDRUs5PNZEMQjpXJJueqrpcHIXxnWTcAGi/UOCgVShlkY6kLoqg==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hastscript": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-7.0.2.tgz", + "integrity": "sha512-uA8ooUY4ipaBvKcMuPehTAB/YfFLSSzCwFSwT6ltJbocFUKH/GDHLN+tflq7lSRf9H86uOuxOFkh1KgIy3Gg2g==", + "dependencies": { + "@types/hast": "^2.0.0", + "comma-separated-tokens": "^2.0.0", + "hast-util-parse-selector": "^3.0.0", + "property-information": "^6.0.0", + "space-separated-tokens": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/he": { "version": "1.2.0", "license": "MIT", @@ -11805,6 +12029,15 @@ "node": ">= 12" } }, + "node_modules/html-void-elements": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/html-void-elements/-/html-void-elements-2.0.1.tgz", + "integrity": "sha512-0quDb7s97CfemeJAnW9wC0hw78MtW7NU3hqtCD75g2vFlDLt36llsYD7uB7SUzojLMP24N5IatXf7ylGXiGG9A==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/html-webpack-plugin": { "version": "5.5.0", "license": "MIT", @@ -12099,6 +12332,11 @@ "version": "1.3.8", "license": "ISC" }, + "node_modules/inline-style-parser": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/inline-style-parser/-/inline-style-parser-0.1.1.tgz", + "integrity": "sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q==" + }, "node_modules/interface-datastore": { "version": "6.1.1", "license": "MIT", @@ -12304,6 +12542,28 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", + "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "engines": { + "node": ">=4" + } + }, "node_modules/is-callable": { "version": "1.2.4", "license": "MIT", @@ -15755,6 +16015,15 @@ "version": "4.0.0", "license": "Apache-2.0" }, + "node_modules/longest-streak": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/longest-streak/-/longest-streak-3.0.1.tgz", + "integrity": "sha512-cHlYSUpL2s7Fb3394mYxwTYj8niTaNHUCLr0qdiCXQfSjfuA7CKofpX2uSwEfFDQ0EB7JcnMnm+GjbqqoinYYg==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/loose-envify": { "version": "1.4.0", "license": "MIT", @@ -15820,6 +16089,15 @@ "tmpl": "1.0.5" } }, + "node_modules/markdown-table": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/markdown-table/-/markdown-table-3.0.2.tgz", + "integrity": "sha512-y8j3a5/DkJCmS5x4dMCQL+OR0+2EAq3DOtio1COSHsmW2BGXnNCK3v12hJt1LrUz5iZH5g0LmuYOjDdI+czghA==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/match-sorter": { "version": "6.3.1", "license": "MIT", @@ -15844,6 +16122,203 @@ "safe-buffer": "^5.1.2" } }, + "node_modules/mdast-util-definitions": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/mdast-util-definitions/-/mdast-util-definitions-5.1.1.tgz", + "integrity": "sha512-rQ+Gv7mHttxHOBx2dkF4HWTg+EE+UR78ptQWDylzPKaQuVGdG4HIoY3SrS/pCp80nZ04greFvXbVFHT+uf0JVQ==", + "dependencies": { + "@types/mdast": "^3.0.0", + "@types/unist": "^2.0.0", + "unist-util-visit": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-find-and-replace": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/mdast-util-find-and-replace/-/mdast-util-find-and-replace-2.2.1.tgz", + "integrity": "sha512-SobxkQXFAdd4b5WmEakmkVoh18icjQRxGy5OWTCzgsLRm1Fu/KCtwD1HIQSsmq5ZRjVH0Ehwg6/Fn3xIUk+nKw==", + "dependencies": { + "escape-string-regexp": "^5.0.0", + "unist-util-is": "^5.0.0", + "unist-util-visit-parents": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-find-and-replace/node_modules/escape-string-regexp": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz", + "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/mdast-util-from-markdown": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-1.2.0.tgz", + "integrity": "sha512-iZJyyvKD1+K7QX1b5jXdE7Sc5dtoTry1vzV28UZZe8Z1xVnB/czKntJ7ZAkG0tANqRnBF6p3p7GpU1y19DTf2Q==", + "dependencies": { + "@types/mdast": "^3.0.0", + "@types/unist": "^2.0.0", + "decode-named-character-reference": "^1.0.0", + "mdast-util-to-string": "^3.1.0", + "micromark": "^3.0.0", + "micromark-util-decode-numeric-character-reference": "^1.0.0", + "micromark-util-decode-string": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "unist-util-stringify-position": "^3.0.0", + "uvu": "^0.5.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm/-/mdast-util-gfm-2.0.1.tgz", + "integrity": "sha512-42yHBbfWIFisaAfV1eixlabbsa6q7vHeSPY+cg+BBjX51M8xhgMacqH9g6TftB/9+YkcI0ooV4ncfrJslzm/RQ==", + "dependencies": { + "mdast-util-from-markdown": "^1.0.0", + "mdast-util-gfm-autolink-literal": "^1.0.0", + "mdast-util-gfm-footnote": "^1.0.0", + "mdast-util-gfm-strikethrough": "^1.0.0", + "mdast-util-gfm-table": "^1.0.0", + "mdast-util-gfm-task-list-item": "^1.0.0", + "mdast-util-to-markdown": "^1.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-autolink-literal": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-1.0.2.tgz", + "integrity": "sha512-FzopkOd4xTTBeGXhXSBU0OCDDh5lUj2rd+HQqG92Ld+jL4lpUfgX2AT2OHAVP9aEeDKp7G92fuooSZcYJA3cRg==", + "dependencies": { + "@types/mdast": "^3.0.0", + "ccount": "^2.0.0", + "mdast-util-find-and-replace": "^2.0.0", + "micromark-util-character": "^1.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-footnote": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-1.0.1.tgz", + "integrity": "sha512-p+PrYlkw9DeCRkTVw1duWqPRHX6Ywh2BNKJQcZbCwAuP/59B0Lk9kakuAd7KbQprVO4GzdW8eS5++A9PUSqIyw==", + "dependencies": { + "@types/mdast": "^3.0.0", + "mdast-util-to-markdown": "^1.3.0", + "micromark-util-normalize-identifier": "^1.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-strikethrough": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-1.0.1.tgz", + "integrity": "sha512-zKJbEPe+JP6EUv0mZ0tQUyLQOC+FADt0bARldONot/nefuISkaZFlmVK4tU6JgfyZGrky02m/I6PmehgAgZgqg==", + "dependencies": { + "@types/mdast": "^3.0.0", + "mdast-util-to-markdown": "^1.3.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-table": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-table/-/mdast-util-gfm-table-1.0.6.tgz", + "integrity": "sha512-uHR+fqFq3IvB3Rd4+kzXW8dmpxUhvgCQZep6KdjsLK4O6meK5dYZEayLtIxNus1XO3gfjfcIFe8a7L0HZRGgag==", + "dependencies": { + "@types/mdast": "^3.0.0", + "markdown-table": "^3.0.0", + "mdast-util-from-markdown": "^1.0.0", + "mdast-util-to-markdown": "^1.3.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-gfm-task-list-item": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-1.0.1.tgz", + "integrity": "sha512-KZ4KLmPdABXOsfnM6JHUIjxEvcx2ulk656Z/4Balw071/5qgnhz+H1uGtf2zIGnrnvDC8xR4Fj9uKbjAFGNIeA==", + "dependencies": { + "@types/mdast": "^3.0.0", + "mdast-util-to-markdown": "^1.3.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-to-hast": { + "version": "12.2.3", + "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-12.2.3.tgz", + "integrity": "sha512-AN1LP/bYd8GxSljYiu76/kL14Dfi4SJNBbn4XDyzJzZIndVk0vBE4iQhvR1vfhYRK+4XEgmeteDCJriDAhvABg==", + "dependencies": { + "@types/hast": "^2.0.0", + "@types/mdast": "^3.0.0", + "mdast-util-definitions": "^5.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "trim-lines": "^3.0.0", + "unist-builder": "^3.0.0", + "unist-util-generated": "^2.0.0", + "unist-util-position": "^4.0.0", + "unist-util-visit": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-to-markdown": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-markdown/-/mdast-util-to-markdown-1.3.0.tgz", + "integrity": "sha512-6tUSs4r+KK4JGTTiQ7FfHmVOaDrLQJPmpjD6wPMlHGUVXoG9Vjc3jIeP+uyBWRf8clwB2blM+W7+KrlMYQnftA==", + "dependencies": { + "@types/mdast": "^3.0.0", + "@types/unist": "^2.0.0", + "longest-streak": "^3.0.0", + "mdast-util-to-string": "^3.0.0", + "micromark-util-decode-string": "^1.0.0", + "unist-util-visit": "^4.0.0", + "zwitch": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/mdast-util-to-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-string/-/mdast-util-to-string-3.1.0.tgz", + "integrity": "sha512-n4Vypz/DZgwo0iMHLQL49dJzlp7YtAJP+N07MZHpjPf/5XJuHUWstviF4Mn2jEiR/GNmtnRRqnwsXExk3igfFA==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/mdn-data": { "version": "2.0.4", "license": "CC0-1.0" @@ -15905,6 +16380,543 @@ "node": ">= 0.6" } }, + "node_modules/micromark": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/micromark/-/micromark-3.0.10.tgz", + "integrity": "sha512-ryTDy6UUunOXy2HPjelppgJ2sNfcPz1pLlMdA6Rz9jPzhLikWXv/irpWV/I2jd68Uhmny7hHxAlAhk4+vWggpg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "@types/debug": "^4.0.0", + "debug": "^4.0.0", + "decode-named-character-reference": "^1.0.0", + "micromark-core-commonmark": "^1.0.1", + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-chunked": "^1.0.0", + "micromark-util-combine-extensions": "^1.0.0", + "micromark-util-decode-numeric-character-reference": "^1.0.0", + "micromark-util-encode": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-resolve-all": "^1.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "micromark-util-subtokenize": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.1", + "uvu": "^0.5.0" + } + }, + "node_modules/micromark-core-commonmark": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-1.0.6.tgz", + "integrity": "sha512-K+PkJTxqjFfSNkfAhp4GB+cZPfQd6dxtTXnf+RjZOV7T4EEXnvgzOcnp+eSTmpGk9d1S9sL6/lqrgSNn/s0HZA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "decode-named-character-reference": "^1.0.0", + "micromark-factory-destination": "^1.0.0", + "micromark-factory-label": "^1.0.0", + "micromark-factory-space": "^1.0.0", + "micromark-factory-title": "^1.0.0", + "micromark-factory-whitespace": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-chunked": "^1.0.0", + "micromark-util-classify-character": "^1.0.0", + "micromark-util-html-tag-name": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-resolve-all": "^1.0.0", + "micromark-util-subtokenize": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.1", + "uvu": "^0.5.0" + } + }, + "node_modules/micromark-extension-gfm": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm/-/micromark-extension-gfm-2.0.1.tgz", + "integrity": "sha512-p2sGjajLa0iYiGQdT0oelahRYtMWvLjy8J9LOCxzIQsllMCGLbsLW+Nc+N4vi02jcRJvedVJ68cjelKIO6bpDA==", + "dependencies": { + "micromark-extension-gfm-autolink-literal": "^1.0.0", + "micromark-extension-gfm-footnote": "^1.0.0", + "micromark-extension-gfm-strikethrough": "^1.0.0", + "micromark-extension-gfm-table": "^1.0.0", + "micromark-extension-gfm-tagfilter": "^1.0.0", + "micromark-extension-gfm-task-list-item": "^1.0.0", + "micromark-util-combine-extensions": "^1.0.0", + "micromark-util-types": "^1.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-autolink-literal": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-1.0.3.tgz", + "integrity": "sha512-i3dmvU0htawfWED8aHMMAzAVp/F0Z+0bPh3YrbTPPL1v4YAlCZpy5rBO5p0LPYiZo0zFVkoYh7vDU7yQSiCMjg==", + "dependencies": { + "micromark-util-character": "^1.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-footnote": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-1.0.4.tgz", + "integrity": "sha512-E/fmPmDqLiMUP8mLJ8NbJWJ4bTw6tS+FEQS8CcuDtZpILuOb2kjLqPEeAePF1djXROHXChM/wPJw0iS4kHCcIg==", + "dependencies": { + "micromark-core-commonmark": "^1.0.0", + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-strikethrough": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-1.0.4.tgz", + "integrity": "sha512-/vjHU/lalmjZCT5xt7CcHVJGq8sYRm80z24qAKXzaHzem/xsDYb2yLL+NNVbYvmpLx3O7SYPuGL5pzusL9CLIQ==", + "dependencies": { + "micromark-util-chunked": "^1.0.0", + "micromark-util-classify-character": "^1.0.0", + "micromark-util-resolve-all": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-table": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-1.0.5.tgz", + "integrity": "sha512-xAZ8J1X9W9K3JTJTUL7G6wSKhp2ZYHrFk5qJgY/4B33scJzE2kpfRL6oiw/veJTbt7jiM/1rngLlOKPWr1G+vg==", + "dependencies": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-tagfilter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-1.0.1.tgz", + "integrity": "sha512-Ty6psLAcAjboRa/UKUbbUcwjVAv5plxmpUTy2XC/3nJFL37eHej8jrHrRzkqcpipJliuBH30DTs7+3wqNcQUVA==", + "dependencies": { + "micromark-util-types": "^1.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-extension-gfm-task-list-item": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-1.0.3.tgz", + "integrity": "sha512-PpysK2S1Q/5VXi72IIapbi/jliaiOFzv7THH4amwXeYXLq3l1uo8/2Be0Ac1rEwK20MQEsGH2ltAZLNY2KI/0Q==", + "dependencies": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/micromark-factory-destination": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-destination/-/micromark-factory-destination-1.0.0.tgz", + "integrity": "sha512-eUBA7Rs1/xtTVun9TmV3gjfPz2wEwgK5R5xcbIM5ZYAtvGF6JkyaDsj0agx8urXnO31tEO6Ug83iVH3tdedLnw==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-factory-label": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-factory-label/-/micromark-factory-label-1.0.2.tgz", + "integrity": "sha512-CTIwxlOnU7dEshXDQ+dsr2n+yxpP0+fn271pu0bwDIS8uqfFcumXpj5mLn3hSC8iw2MUr6Gx8EcKng1dD7i6hg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "node_modules/micromark-factory-space": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-space/-/micromark-factory-space-1.0.0.tgz", + "integrity": "sha512-qUmqs4kj9a5yBnk3JMLyjtWYN6Mzfcx8uJfi5XAveBniDevmZasdGBba5b4QsvRcAkmvGo5ACmSUmyGiKTLZew==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-character": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-factory-title": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-factory-title/-/micromark-factory-title-1.0.2.tgz", + "integrity": "sha512-zily+Nr4yFqgMGRKLpTVsNl5L4PMu485fGFDOQJQBl2NFpjGte1e86zC0da93wf97jrc4+2G2GQudFMHn3IX+A==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "node_modules/micromark-factory-whitespace": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-whitespace/-/micromark-factory-whitespace-1.0.0.tgz", + "integrity": "sha512-Qx7uEyahU1lt1RnsECBiuEbfr9INjQTGa6Err+gF3g0Tx4YEviPbqqGKNv/NrBaE7dVHdn1bVZKM/n5I/Bak7A==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-util-character": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/micromark-util-character/-/micromark-util-character-1.1.0.tgz", + "integrity": "sha512-agJ5B3unGNJ9rJvADMJ5ZiYjBRyDpzKAOk01Kpi1TKhlT1APx3XZk6eN7RtSz1erbWHC2L8T3xLZ81wdtGRZzg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-util-chunked": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-chunked/-/micromark-util-chunked-1.0.0.tgz", + "integrity": "sha512-5e8xTis5tEZKgesfbQMKRCyzvffRRUX+lK/y+DvsMFdabAicPkkZV6gO+FEWi9RfuKKoxxPwNL+dFF0SMImc1g==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-symbol": "^1.0.0" + } + }, + "node_modules/micromark-util-classify-character": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-classify-character/-/micromark-util-classify-character-1.0.0.tgz", + "integrity": "sha512-F8oW2KKrQRb3vS5ud5HIqBVkCqQi224Nm55o5wYLzY/9PwHGXC01tr3d7+TqHHz6zrKQ72Okwtvm/xQm6OVNZA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-util-combine-extensions": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-combine-extensions/-/micromark-util-combine-extensions-1.0.0.tgz", + "integrity": "sha512-J8H058vFBdo/6+AsjHp2NF7AJ02SZtWaVUjsayNFeAiydTxUwViQPxN0Hf8dp4FmCQi0UUFovFsEyRSUmFH3MA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-chunked": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-util-decode-numeric-character-reference": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-1.0.0.tgz", + "integrity": "sha512-OzO9AI5VUtrTD7KSdagf4MWgHMtET17Ua1fIpXTpuhclCqD8egFWo85GxSGvxgkGS74bEahvtM0WP0HjvV0e4w==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-symbol": "^1.0.0" + } + }, + "node_modules/micromark-util-decode-string": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-decode-string/-/micromark-util-decode-string-1.0.2.tgz", + "integrity": "sha512-DLT5Ho02qr6QWVNYbRZ3RYOSSWWFuH3tJexd3dgN1odEuPNxCngTCXJum7+ViRAd9BbdxCvMToPOD/IvVhzG6Q==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "decode-named-character-reference": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-decode-numeric-character-reference": "^1.0.0", + "micromark-util-symbol": "^1.0.0" + } + }, + "node_modules/micromark-util-encode": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-encode/-/micromark-util-encode-1.0.1.tgz", + "integrity": "sha512-U2s5YdnAYexjKDel31SVMPbfi+eF8y1U4pfiRW/Y8EFVCy/vgxk/2wWTxzcqE71LHtCuCzlBDRU2a5CQ5j+mQA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ] + }, + "node_modules/micromark-util-html-tag-name": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/micromark-util-html-tag-name/-/micromark-util-html-tag-name-1.1.0.tgz", + "integrity": "sha512-BKlClMmYROy9UiV03SwNmckkjn8QHVaWkqoAqzivabvdGcwNGMMMH/5szAnywmsTBUzDsU57/mFi0sp4BQO6dA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ] + }, + "node_modules/micromark-util-normalize-identifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-1.0.0.tgz", + "integrity": "sha512-yg+zrL14bBTFrQ7n35CmByWUTFsgst5JhA4gJYoty4Dqzj4Z4Fr/DHekSS5aLfH9bdlfnSvKAWsAgJhIbogyBg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-symbol": "^1.0.0" + } + }, + "node_modules/micromark-util-resolve-all": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-resolve-all/-/micromark-util-resolve-all-1.0.0.tgz", + "integrity": "sha512-CB/AGk98u50k42kvgaMM94wzBqozSzDDaonKU7P7jwQIuH2RU0TeBqGYJz2WY1UdihhjweivStrJ2JdkdEmcfw==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-types": "^1.0.0" + } + }, + "node_modules/micromark-util-sanitize-uri": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-1.0.0.tgz", + "integrity": "sha512-cCxvBKlmac4rxCGx6ejlIviRaMKZc0fWm5HdCHEeDWRSkn44l6NdYVRyU+0nT1XC72EQJMZV8IPHF+jTr56lAg==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-character": "^1.0.0", + "micromark-util-encode": "^1.0.0", + "micromark-util-symbol": "^1.0.0" + } + }, + "node_modules/micromark-util-subtokenize": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-1.0.2.tgz", + "integrity": "sha512-d90uqCnXp/cy4G881Ub4psE57Sf8YD0pim9QdjCRNjfas2M1u6Lbt+XZK9gnHL2XFhnozZiEdCa9CNfXSfQ6xA==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ], + "dependencies": { + "micromark-util-chunked": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "node_modules/micromark-util-symbol": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-symbol/-/micromark-util-symbol-1.0.1.tgz", + "integrity": "sha512-oKDEMK2u5qqAptasDAwWDXq0tG9AssVwAx3E9bBF3t/shRIGsWIRG+cGafs2p/SnDSOecnt6hZPCE2o6lHfFmQ==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ] + }, + "node_modules/micromark-util-types": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-1.0.2.tgz", + "integrity": "sha512-DCfg/T8fcrhrRKTPjRrw/5LLvdGV7BHySf/1LOZx7TzWZdYRjogNtyNq885z3nNallwr3QUKARjqvHqX1/7t+w==", + "funding": [ + { + "type": "GitHub Sponsors", + "url": "https://github.com/sponsors/unifiedjs" + }, + { + "type": "OpenCollective", + "url": "https://opencollective.com/unified" + } + ] + }, "node_modules/micromatch": { "version": "4.0.5", "license": "MIT", @@ -16074,6 +17086,14 @@ "mkdirp": "bin/cmd.js" } }, + "node_modules/mri": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", + "integrity": "sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==", + "engines": { + "node": ">=4" + } + }, "node_modules/mrmime": { "version": "1.0.1", "dev": true, @@ -20491,6 +21511,15 @@ "version": "2.0.5", "license": "MIT" }, + "node_modules/property-information": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/property-information/-/property-information-6.1.1.tgz", + "integrity": "sha512-hrzC564QIl0r0vy4l6MvRLhafmUowhO/O3KgVSoXIbbA2Sz4j8HGpJc6T2cubRVwMwpdiG/vKGfhT4IixmKN9w==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/protobufjs": { "version": "6.11.3", "hasInstallScript": true, @@ -20967,6 +21996,36 @@ "version": "18.2.0", "license": "MIT" }, + "node_modules/react-markdown": { + "version": "8.0.3", + "resolved": "https://registry.npmjs.org/react-markdown/-/react-markdown-8.0.3.tgz", + "integrity": "sha512-We36SfqaKoVNpN1QqsZwWSv/OZt5J15LNgTLWynwAN5b265hrQrsjMtlRNwUvS+YyR3yDM8HpTNc4pK9H/Gc0A==", + "dependencies": { + "@types/hast": "^2.0.0", + "@types/prop-types": "^15.0.0", + "@types/unist": "^2.0.0", + "comma-separated-tokens": "^2.0.0", + "hast-util-whitespace": "^2.0.0", + "prop-types": "^15.0.0", + "property-information": "^6.0.0", + "react-is": "^18.0.0", + "remark-parse": "^10.0.0", + "remark-rehype": "^10.0.0", + "space-separated-tokens": "^2.0.0", + "style-to-object": "^0.3.0", + "unified": "^10.0.0", + "unist-util-visit": "^4.0.0", + "vfile": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + }, + "peerDependencies": { + "@types/react": ">=16", + "react": ">=16" + } + }, "node_modules/react-native-fetch-api": { "version": "2.0.0", "license": "MIT", @@ -21443,6 +22502,20 @@ "jsesc": "bin/jsesc" } }, + "node_modules/rehype-raw": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/rehype-raw/-/rehype-raw-6.1.1.tgz", + "integrity": "sha512-d6AKtisSRtDRX4aSPsJGTfnzrX2ZkHQLE5kiUuGOeEoLpbEulFF4hj0mLPbsa+7vmguDKOVVEQdHKDSwoaIDsQ==", + "dependencies": { + "@types/hast": "^2.0.0", + "hast-util-raw": "^7.2.0", + "unified": "^10.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/relateurl": { "version": "0.2.7", "license": "MIT", @@ -21461,6 +22534,50 @@ "node": ">=4" } }, + "node_modules/remark-gfm": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/remark-gfm/-/remark-gfm-3.0.1.tgz", + "integrity": "sha512-lEFDoi2PICJyNrACFOfDD3JlLkuSbOa5Wd8EPt06HUdptv8Gn0bxYTdbU/XXQ3swAPkEaGxxPN9cbnMHvVu1Ig==", + "dependencies": { + "@types/mdast": "^3.0.0", + "mdast-util-gfm": "^2.0.0", + "micromark-extension-gfm": "^2.0.0", + "unified": "^10.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/remark-parse": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/remark-parse/-/remark-parse-10.0.1.tgz", + "integrity": "sha512-1fUyHr2jLsVOkhbvPRBJ5zTKZZyD6yZzYaWCS6BPBdQ8vEMBCH+9zNCDA6tET/zHCi/jLqjCWtlJZUPk+DbnFw==", + "dependencies": { + "@types/mdast": "^3.0.0", + "mdast-util-from-markdown": "^1.0.0", + "unified": "^10.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/remark-rehype": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/remark-rehype/-/remark-rehype-10.1.0.tgz", + "integrity": "sha512-EFmR5zppdBp0WQeDVZ/b66CWJipB2q2VLNFMabzDSGR66Z2fQii83G5gTBbgGEnEEA0QRussvrFHxk1HWGJskw==", + "dependencies": { + "@types/hast": "^2.0.0", + "@types/mdast": "^3.0.0", + "mdast-util-to-hast": "^12.1.0", + "unified": "^10.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/remove-accents": { "version": "0.4.2", "license": "MIT" @@ -21785,6 +22902,17 @@ "dev": true, "license": "0BSD" }, + "node_modules/sade": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/sade/-/sade-1.8.1.tgz", + "integrity": "sha512-xal3CZX1Xlo/k4ApwCFrHVACi9fBqJ7V+mwhBsuf/1IOKbBy098Fex+Wa/5QMubw09pSZ/u8EY8PWgevJsXp1A==", + "dependencies": { + "mri": "^1.1.0" + }, + "engines": { + "node": ">=6" + } + }, "node_modules/safe-buffer": { "version": "5.1.2", "license": "MIT" @@ -22260,6 +23388,15 @@ "version": "1.4.8", "license": "MIT" }, + "node_modules/space-separated-tokens": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-2.0.1.tgz", + "integrity": "sha512-ekwEbFp5aqSPKaqeY1PGrlGQxPNaq+Cnx4+bE2D8sciBQrHpbwoBbawqTN2+6jPs9IdWxxiUcN0K2pkczD3zmw==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/spawn-wrap": { "version": "2.0.0", "dev": true, @@ -22589,6 +23726,14 @@ "webpack": "^5.0.0" } }, + "node_modules/style-to-object": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/style-to-object/-/style-to-object-0.3.0.tgz", + "integrity": "sha512-CzFnRRXhzWIdItT3OmF8SQfWyahHhjq3HwcMNCNLn+N7klOOqPjMeG/4JSu77D7ypZdGvSzvkrbyeTMizz2VrA==", + "dependencies": { + "inline-style-parser": "0.1.1" + } + }, "node_modules/styled-components": { "version": "5.3.5", "hasInstallScript": true, @@ -23090,6 +24235,24 @@ "version": "0.0.3", "license": "MIT" }, + "node_modules/trim-lines": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/trim-lines/-/trim-lines-3.0.1.tgz", + "integrity": "sha512-kRj8B+YHZCc9kQYdWfJB2/oUl9rA99qbowYYBtr4ui4mZyAQ2JpvVBd/6U2YloATfqBhBTSMhTpgBHtU0Mf3Rg==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/trough": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/trough/-/trough-2.1.0.tgz", + "integrity": "sha512-AqTiAOLcj85xS7vQ8QkAV41hPDIJ71XJB4RCUrzo/1GM2CQwhkJGaf9Hgr7BOugMRpgGUrqRg/DrBDl4H40+8g==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/tryer": { "version": "1.0.1", "license": "MIT" @@ -23265,6 +24428,35 @@ "node": ">=4" } }, + "node_modules/unified": { + "version": "10.1.2", + "resolved": "https://registry.npmjs.org/unified/-/unified-10.1.2.tgz", + "integrity": "sha512-pUSWAi/RAnVy1Pif2kAoeWNBa3JVrx0MId2LASj8G+7AiHWoKZNTomq6LG326T68U7/e263X6fTdcXIy7XnF7Q==", + "dependencies": { + "@types/unist": "^2.0.0", + "bail": "^2.0.0", + "extend": "^3.0.0", + "is-buffer": "^2.0.0", + "is-plain-obj": "^4.0.0", + "trough": "^2.0.0", + "vfile": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unified/node_modules/is-plain-obj": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-4.1.0.tgz", + "integrity": "sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg==", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/uniq": { "version": "1.0.1", "license": "MIT" @@ -23279,6 +24471,87 @@ "node": ">=8" } }, + "node_modules/unist-builder": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/unist-builder/-/unist-builder-3.0.0.tgz", + "integrity": "sha512-GFxmfEAa0vi9i5sd0R2kcrI9ks0r82NasRq5QHh2ysGngrc6GiqD5CDf1FjPenY4vApmFASBIIlk/jj5J5YbmQ==", + "dependencies": { + "@types/unist": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-generated": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unist-util-generated/-/unist-util-generated-2.0.0.tgz", + "integrity": "sha512-TiWE6DVtVe7Ye2QxOVW9kqybs6cZexNwTwSMVgkfjEReqy/xwGpAXb99OxktoWwmL+Z+Epb0Dn8/GNDYP1wnUw==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-is": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-5.1.1.tgz", + "integrity": "sha512-F5CZ68eYzuSvJjGhCLPL3cYx45IxkqXSetCcRgUXtbcm50X2L9oOWQlfUfDdAf+6Pd27YDblBfdtmsThXmwpbQ==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-position": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/unist-util-position/-/unist-util-position-4.0.3.tgz", + "integrity": "sha512-p/5EMGIa1qwbXjA+QgcBXaPWjSnZfQ2Sc3yBEEfgPwsEmJd8Qh+DSk3LGnmOM4S1bY2C0AjmMnB8RuEYxpPwXQ==", + "dependencies": { + "@types/unist": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-stringify-position": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-3.0.2.tgz", + "integrity": "sha512-7A6eiDCs9UtjcwZOcCpM4aPII3bAAGv13E96IkawkOAW0OhH+yRxtY0lzo8KiHpzEMfH7Q+FizUmwp8Iqy5EWg==", + "dependencies": { + "@types/unist": "^2.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-visit": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-4.1.1.tgz", + "integrity": "sha512-n9KN3WV9k4h1DxYR1LoajgN93wpEi/7ZplVe02IoB4gH5ctI1AaF2670BLHQYbwj+pY83gFtyeySFiyMHJklrg==", + "dependencies": { + "@types/unist": "^2.0.0", + "unist-util-is": "^5.0.0", + "unist-util-visit-parents": "^5.1.1" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-visit-parents": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-5.1.1.tgz", + "integrity": "sha512-gks4baapT/kNRaWxuGkl5BIhoanZo7sC/cUT/JToSRNL1dYoXRFl75d++NkjYk4TAu2uv2Px+l8guMajogeuiw==", + "dependencies": { + "@types/unist": "^2.0.0", + "unist-util-is": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/universalify": { "version": "2.0.0", "license": "MIT", @@ -23505,6 +24778,31 @@ "uuid": "dist/bin/uuid" } }, + "node_modules/uvu": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/uvu/-/uvu-0.5.6.tgz", + "integrity": "sha512-+g8ENReyr8YsOc6fv/NVJs2vFdHBnBNdfE49rshrTzDWOlUx4Gq7KOS2GD8eqhy2j+Ejq29+SbKH8yjkAqXqoA==", + "dependencies": { + "dequal": "^2.0.0", + "diff": "^5.0.0", + "kleur": "^4.0.3", + "sade": "^1.7.3" + }, + "bin": { + "uvu": "bin.js" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/uvu/node_modules/kleur": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", + "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", + "engines": { + "node": ">=6" + } + }, "node_modules/v8-compile-cache": { "version": "2.3.0", "license": "MIT" @@ -23546,6 +24844,47 @@ "node": ">= 0.8" } }, + "node_modules/vfile": { + "version": "5.3.5", + "resolved": "https://registry.npmjs.org/vfile/-/vfile-5.3.5.tgz", + "integrity": "sha512-U1ho2ga33eZ8y8pkbQLH54uKqGhFJ6GYIHnnG5AhRpAh3OWjkrRHKa/KogbmQn8We+c0KVV3rTOgR9V/WowbXQ==", + "dependencies": { + "@types/unist": "^2.0.0", + "is-buffer": "^2.0.0", + "unist-util-stringify-position": "^3.0.0", + "vfile-message": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/vfile-location": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/vfile-location/-/vfile-location-4.0.1.tgz", + "integrity": "sha512-JDxPlTbZrZCQXogGheBHjbRWjESSPEak770XwWPfw5mTc1v1nWGLB/apzZxsx8a0SJVfF8HK8ql8RD308vXRUw==", + "dependencies": { + "@types/unist": "^2.0.0", + "vfile": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/vfile-message": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-3.1.2.tgz", + "integrity": "sha512-QjSNP6Yxzyycd4SVOtmKKyTsSvClqBPJcd00Z0zuPj3hOIjg0rUPG6DbFGPvUKRgYyaIWLPKpuEclcuvb3H8qA==", + "dependencies": { + "@types/unist": "^2.0.0", + "unist-util-stringify-position": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/w3c-hr-time": { "version": "1.0.2", "license": "MIT", @@ -23646,6 +24985,15 @@ "minimalistic-assert": "^1.0.0" } }, + "node_modules/web-namespaces": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/web-namespaces/-/web-namespaces-2.0.1.tgz", + "integrity": "sha512-bKr1DkiNa2krS7qxNtdrtHAmzuYGFQLiQ13TsorsdT6ULTkPLKuu5+GsFpDlg6JFjUTwX2DyhMPG2be8uPrqsQ==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, "node_modules/web-vitals": { "version": "2.1.4", "license": "Apache-2.0" @@ -24638,6 +25986,15 @@ "optional": true } } + }, + "node_modules/zwitch": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/zwitch/-/zwitch-2.0.2.tgz", + "integrity": "sha512-JZxotl7SxAJH0j7dN4pxsTV6ZLXoLdGME+PsjkL/DaBrVryK9kTGq06GfKrwcSOqypP+fdXGoCHE36b99fWVoA==", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } } }, "dependencies": { @@ -27475,6 +28832,14 @@ "@types/node": "*" } }, + "@types/debug": { + "version": "4.1.7", + "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.7.tgz", + "integrity": "sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg==", + "requires": { + "@types/ms": "*" + } + }, "@types/eslint": { "version": "8.4.5", "requires": { @@ -27518,6 +28883,14 @@ "@types/node": "*" } }, + "@types/hast": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/@types/hast/-/hast-2.3.4.tgz", + "integrity": "sha512-wLEm0QvaoawEDoTRwzTXp4b4jpwiJDvR5KMnFnVodm3scufTlBOWRD6N1OBf9TZMhjlNsSfcO5V+7AF4+Vy+9g==", + "requires": { + "@types/unist": "*" + } + }, "@types/hoist-non-react-statics": { "version": "3.3.1", "dev": true, @@ -27590,18 +28963,36 @@ "@types/long": { "version": "4.0.2" }, + "@types/mdast": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-3.0.10.tgz", + "integrity": "sha512-W864tg/Osz1+9f4lrGTZpCSO5/z4608eUp19tbozkq2HJK6i3z1kT0H9tlADXuYIb1YYOBByU4Jsqkk75q48qA==", + "requires": { + "@types/unist": "*" + } + }, "@types/mime": { "version": "1.3.2" }, "@types/minimatch": { "version": "3.0.5" }, + "@types/ms": { + "version": "0.7.31", + "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", + "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==" + }, "@types/node": { "version": "18.0.6" }, "@types/parse-json": { "version": "4.0.0" }, + "@types/parse5": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/@types/parse5/-/parse5-6.0.3.tgz", + "integrity": "sha512-SuT16Q1K51EAVPz1K29DJ/sXjhSQ0zjvsypYJ6tlwVsRV9jwW5Adq2ch8Dq8kDBCkYnELS7N7VNCSB5nC56t/g==" + }, "@types/pbkdf2": { "version": "3.1.0", "requires": { @@ -27724,6 +29115,11 @@ "@types/trusted-types": { "version": "2.0.2" }, + "@types/unist": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-2.0.6.tgz", + "integrity": "sha512-PBjIUxZHOuj0R15/xuwJYjFi+KZdNFrehocChv4g5hu6aFroHue8m0lBP0POdK2nKzbw0cgV1mws8+V/JAcEkQ==" + }, "@types/use-sync-external-store": { "version": "0.0.3" }, @@ -28866,6 +30262,11 @@ "babel-plugin-transform-react-remove-prop-types": "^0.4.24" } }, + "bail": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/bail/-/bail-2.0.2.tgz", + "integrity": "sha512-0xO6mYd7JB2YesxDKplafRpsiOzPt9V02ddPCLbY1xYGPOX24NTyN50qnUxgCPcSoYMhKpAuBTjQoRZCAkUDRw==" + }, "balanced-match": { "version": "1.0.2" }, @@ -29195,6 +30596,11 @@ "cborg": { "version": "1.9.5" }, + "ccount": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/ccount/-/ccount-2.0.1.tgz", + "integrity": "sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==" + }, "chalk": { "version": "2.4.2", "requires": { @@ -29211,6 +30617,11 @@ "char-regex": { "version": "1.0.2" }, + "character-entities": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/character-entities/-/character-entities-2.0.2.tgz", + "integrity": "sha512-shx7oQ0Awen/BRIdkjkvz54PnEEI/EjwXDSIZp86/KKdbafHh1Df/RYGBhn4hbe2+uKC9FnT5UCEdyPz3ai9hQ==" + }, "chart.js": { "version": "3.8.0" }, @@ -29381,6 +30792,11 @@ "delayed-stream": "~1.0.0" } }, + "comma-separated-tokens": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-2.0.2.tgz", + "integrity": "sha512-G5yTt3KQN4Yn7Yk4ed73hlZ1evrFKXeUW3086p3PRFNp7m2vIjI6Pg+Kgb+oyzhd9F2qdcoj67+y3SdxL5XWsg==" + }, "commander": { "version": "9.4.0", "dev": true @@ -29870,6 +31286,14 @@ "decimal.js": { "version": "10.3.1" }, + "decode-named-character-reference": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/decode-named-character-reference/-/decode-named-character-reference-1.0.2.tgz", + "integrity": "sha512-O8x12RzrUF8xyVcY0KJowWsmaJxQbmy0/EtnNtHRpsOcT7dFk5W598coHqBVpmWo1oQQfsCqfCmkZN5DJrZVdg==", + "requires": { + "character-entities": "^2.0.0" + } + }, "decode-uri-component": { "version": "0.2.0" }, @@ -29957,6 +31381,11 @@ "depd": { "version": "2.0.0" }, + "dequal": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz", + "integrity": "sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==" + }, "des.js": { "version": "1.0.1", "requires": { @@ -30008,6 +31437,11 @@ "didyoumean": { "version": "1.2.2" }, + "diff": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-5.1.0.tgz", + "integrity": "sha512-D+mk+qE8VC/PAUrlAU34N+VfXev0ghe5ywmpqrawphmVZc1bEfn56uo9qpyGp1p4xpzOHkSW4ztBd6L7Xx4ACw==" + }, "diff-sequences": { "version": "28.1.1" }, @@ -31206,6 +32640,11 @@ } } }, + "extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" + }, "extract-files": { "version": "9.0.0" }, @@ -31773,6 +33212,91 @@ } } }, + "hast-to-hyperscript": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/hast-to-hyperscript/-/hast-to-hyperscript-10.0.1.tgz", + "integrity": "sha512-dhIVGoKCQVewFi+vz3Vt567E4ejMppS1haBRL6TEmeLeJVB1i/FJIIg/e6s1Bwn0g5qtYojHEKvyGA+OZuyifw==", + "requires": { + "@types/unist": "^2.0.0", + "comma-separated-tokens": "^2.0.0", + "property-information": "^6.0.0", + "space-separated-tokens": "^2.0.0", + "style-to-object": "^0.3.0", + "unist-util-is": "^5.0.0", + "web-namespaces": "^2.0.0" + } + }, + "hast-util-from-parse5": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/hast-util-from-parse5/-/hast-util-from-parse5-7.1.0.tgz", + "integrity": "sha512-m8yhANIAccpU4K6+121KpPP55sSl9/samzQSQGpb0mTExcNh2WlvjtMwSWFhg6uqD4Rr6Nfa8N6TMypQM51rzQ==", + "requires": { + "@types/hast": "^2.0.0", + "@types/parse5": "^6.0.0", + "@types/unist": "^2.0.0", + "hastscript": "^7.0.0", + "property-information": "^6.0.0", + "vfile": "^5.0.0", + "vfile-location": "^4.0.0", + "web-namespaces": "^2.0.0" + } + }, + "hast-util-parse-selector": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-3.1.0.tgz", + "integrity": "sha512-AyjlI2pTAZEOeu7GeBPZhROx0RHBnydkQIXlhnFzDi0qfXTmGUWoCYZtomHbrdrheV4VFUlPcfJ6LMF5T6sQzg==", + "requires": { + "@types/hast": "^2.0.0" + } + }, + "hast-util-raw": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/hast-util-raw/-/hast-util-raw-7.2.2.tgz", + "integrity": "sha512-0x3BhhdlBcqRIKyc095lBSDvmQNMY3Eulj2PLsT5XCyKYrxssI5yr3P4Kv/PBo1s/DMkZy2voGkMXECnFCZRLQ==", + "requires": { + "@types/hast": "^2.0.0", + "@types/parse5": "^6.0.0", + "hast-util-from-parse5": "^7.0.0", + "hast-util-to-parse5": "^7.0.0", + "html-void-elements": "^2.0.0", + "parse5": "^6.0.0", + "unist-util-position": "^4.0.0", + "unist-util-visit": "^4.0.0", + "vfile": "^5.0.0", + "web-namespaces": "^2.0.0", + "zwitch": "^2.0.0" + } + }, + "hast-util-to-parse5": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/hast-util-to-parse5/-/hast-util-to-parse5-7.0.0.tgz", + "integrity": "sha512-YHiS6aTaZ3N0Q3nxaY/Tj98D6kM8QX5Q8xqgg8G45zR7PvWnPGPP0vcKCgb/moIydEJ/QWczVrX0JODCVeoV7A==", + "requires": { + "@types/hast": "^2.0.0", + "@types/parse5": "^6.0.0", + "hast-to-hyperscript": "^10.0.0", + "property-information": "^6.0.0", + "web-namespaces": "^2.0.0", + "zwitch": "^2.0.0" + } + }, + "hast-util-whitespace": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-2.0.0.tgz", + "integrity": "sha512-Pkw+xBHuV6xFeJprJe2BBEoDV+AvQySaz3pPDRUs5PNZEMQjpXJJueqrpcHIXxnWTcAGi/UOCgVShlkY6kLoqg==" + }, + "hastscript": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-7.0.2.tgz", + "integrity": "sha512-uA8ooUY4ipaBvKcMuPehTAB/YfFLSSzCwFSwT6ltJbocFUKH/GDHLN+tflq7lSRf9H86uOuxOFkh1KgIy3Gg2g==", + "requires": { + "@types/hast": "^2.0.0", + "comma-separated-tokens": "^2.0.0", + "hast-util-parse-selector": "^3.0.0", + "property-information": "^6.0.0", + "space-separated-tokens": "^2.0.0" + } + }, "he": { "version": "1.2.0" }, @@ -31859,6 +33383,11 @@ } } }, + "html-void-elements": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/html-void-elements/-/html-void-elements-2.0.1.tgz", + "integrity": "sha512-0quDb7s97CfemeJAnW9wC0hw78MtW7NU3hqtCD75g2vFlDLt36llsYD7uB7SUzojLMP24N5IatXf7ylGXiGG9A==" + }, "html-webpack-plugin": { "version": "5.5.0", "requires": { @@ -32012,6 +33541,11 @@ "ini": { "version": "1.3.8" }, + "inline-style-parser": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/inline-style-parser/-/inline-style-parser-0.1.1.tgz", + "integrity": "sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q==" + }, "interface-datastore": { "version": "6.1.1", "requires": { @@ -32162,6 +33696,11 @@ "has-tostringtag": "^1.0.0" } }, + "is-buffer": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", + "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==" + }, "is-callable": { "version": "1.2.4" }, @@ -34257,6 +35796,11 @@ "long": { "version": "4.0.0" }, + "longest-streak": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/longest-streak/-/longest-streak-3.0.1.tgz", + "integrity": "sha512-cHlYSUpL2s7Fb3394mYxwTYj8niTaNHUCLr0qdiCXQfSjfuA7CKofpX2uSwEfFDQ0EB7JcnMnm+GjbqqoinYYg==" + }, "loose-envify": { "version": "1.4.0", "requires": { @@ -34301,6 +35845,11 @@ "tmpl": "1.0.5" } }, + "markdown-table": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/markdown-table/-/markdown-table-3.0.2.tgz", + "integrity": "sha512-y8j3a5/DkJCmS5x4dMCQL+OR0+2EAq3DOtio1COSHsmW2BGXnNCK3v12hJt1LrUz5iZH5g0LmuYOjDdI+czghA==" + }, "match-sorter": { "version": "6.3.1", "requires": { @@ -34322,6 +35871,151 @@ "safe-buffer": "^5.1.2" } }, + "mdast-util-definitions": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/mdast-util-definitions/-/mdast-util-definitions-5.1.1.tgz", + "integrity": "sha512-rQ+Gv7mHttxHOBx2dkF4HWTg+EE+UR78ptQWDylzPKaQuVGdG4HIoY3SrS/pCp80nZ04greFvXbVFHT+uf0JVQ==", + "requires": { + "@types/mdast": "^3.0.0", + "@types/unist": "^2.0.0", + "unist-util-visit": "^4.0.0" + } + }, + "mdast-util-find-and-replace": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/mdast-util-find-and-replace/-/mdast-util-find-and-replace-2.2.1.tgz", + "integrity": "sha512-SobxkQXFAdd4b5WmEakmkVoh18icjQRxGy5OWTCzgsLRm1Fu/KCtwD1HIQSsmq5ZRjVH0Ehwg6/Fn3xIUk+nKw==", + "requires": { + "escape-string-regexp": "^5.0.0", + "unist-util-is": "^5.0.0", + "unist-util-visit-parents": "^5.0.0" + }, + "dependencies": { + "escape-string-regexp": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz", + "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==" + } + } + }, + "mdast-util-from-markdown": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-1.2.0.tgz", + "integrity": "sha512-iZJyyvKD1+K7QX1b5jXdE7Sc5dtoTry1vzV28UZZe8Z1xVnB/czKntJ7ZAkG0tANqRnBF6p3p7GpU1y19DTf2Q==", + "requires": { + "@types/mdast": "^3.0.0", + "@types/unist": "^2.0.0", + "decode-named-character-reference": "^1.0.0", + "mdast-util-to-string": "^3.1.0", + "micromark": "^3.0.0", + "micromark-util-decode-numeric-character-reference": "^1.0.0", + "micromark-util-decode-string": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "unist-util-stringify-position": "^3.0.0", + "uvu": "^0.5.0" + } + }, + "mdast-util-gfm": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm/-/mdast-util-gfm-2.0.1.tgz", + "integrity": "sha512-42yHBbfWIFisaAfV1eixlabbsa6q7vHeSPY+cg+BBjX51M8xhgMacqH9g6TftB/9+YkcI0ooV4ncfrJslzm/RQ==", + "requires": { + "mdast-util-from-markdown": "^1.0.0", + "mdast-util-gfm-autolink-literal": "^1.0.0", + "mdast-util-gfm-footnote": "^1.0.0", + "mdast-util-gfm-strikethrough": "^1.0.0", + "mdast-util-gfm-table": "^1.0.0", + "mdast-util-gfm-task-list-item": "^1.0.0", + "mdast-util-to-markdown": "^1.0.0" + } + }, + "mdast-util-gfm-autolink-literal": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-1.0.2.tgz", + "integrity": "sha512-FzopkOd4xTTBeGXhXSBU0OCDDh5lUj2rd+HQqG92Ld+jL4lpUfgX2AT2OHAVP9aEeDKp7G92fuooSZcYJA3cRg==", + "requires": { + "@types/mdast": "^3.0.0", + "ccount": "^2.0.0", + "mdast-util-find-and-replace": "^2.0.0", + "micromark-util-character": "^1.0.0" + } + }, + "mdast-util-gfm-footnote": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-1.0.1.tgz", + "integrity": "sha512-p+PrYlkw9DeCRkTVw1duWqPRHX6Ywh2BNKJQcZbCwAuP/59B0Lk9kakuAd7KbQprVO4GzdW8eS5++A9PUSqIyw==", + "requires": { + "@types/mdast": "^3.0.0", + "mdast-util-to-markdown": "^1.3.0", + "micromark-util-normalize-identifier": "^1.0.0" + } + }, + "mdast-util-gfm-strikethrough": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-1.0.1.tgz", + "integrity": "sha512-zKJbEPe+JP6EUv0mZ0tQUyLQOC+FADt0bARldONot/nefuISkaZFlmVK4tU6JgfyZGrky02m/I6PmehgAgZgqg==", + "requires": { + "@types/mdast": "^3.0.0", + "mdast-util-to-markdown": "^1.3.0" + } + }, + "mdast-util-gfm-table": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-table/-/mdast-util-gfm-table-1.0.6.tgz", + "integrity": "sha512-uHR+fqFq3IvB3Rd4+kzXW8dmpxUhvgCQZep6KdjsLK4O6meK5dYZEayLtIxNus1XO3gfjfcIFe8a7L0HZRGgag==", + "requires": { + "@types/mdast": "^3.0.0", + "markdown-table": "^3.0.0", + "mdast-util-from-markdown": "^1.0.0", + "mdast-util-to-markdown": "^1.3.0" + } + }, + "mdast-util-gfm-task-list-item": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-1.0.1.tgz", + "integrity": "sha512-KZ4KLmPdABXOsfnM6JHUIjxEvcx2ulk656Z/4Balw071/5qgnhz+H1uGtf2zIGnrnvDC8xR4Fj9uKbjAFGNIeA==", + "requires": { + "@types/mdast": "^3.0.0", + "mdast-util-to-markdown": "^1.3.0" + } + }, + "mdast-util-to-hast": { + "version": "12.2.3", + "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-12.2.3.tgz", + "integrity": "sha512-AN1LP/bYd8GxSljYiu76/kL14Dfi4SJNBbn4XDyzJzZIndVk0vBE4iQhvR1vfhYRK+4XEgmeteDCJriDAhvABg==", + "requires": { + "@types/hast": "^2.0.0", + "@types/mdast": "^3.0.0", + "mdast-util-definitions": "^5.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "trim-lines": "^3.0.0", + "unist-builder": "^3.0.0", + "unist-util-generated": "^2.0.0", + "unist-util-position": "^4.0.0", + "unist-util-visit": "^4.0.0" + } + }, + "mdast-util-to-markdown": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-markdown/-/mdast-util-to-markdown-1.3.0.tgz", + "integrity": "sha512-6tUSs4r+KK4JGTTiQ7FfHmVOaDrLQJPmpjD6wPMlHGUVXoG9Vjc3jIeP+uyBWRf8clwB2blM+W7+KrlMYQnftA==", + "requires": { + "@types/mdast": "^3.0.0", + "@types/unist": "^2.0.0", + "longest-streak": "^3.0.0", + "mdast-util-to-string": "^3.0.0", + "micromark-util-decode-string": "^1.0.0", + "unist-util-visit": "^4.0.0", + "zwitch": "^2.0.0" + } + }, + "mdast-util-to-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-string/-/mdast-util-to-string-3.1.0.tgz", + "integrity": "sha512-n4Vypz/DZgwo0iMHLQL49dJzlp7YtAJP+N07MZHpjPf/5XJuHUWstviF4Mn2jEiR/GNmtnRRqnwsXExk3igfFA==" + }, "mdn-data": { "version": "2.0.4" }, @@ -34358,6 +36052,305 @@ "methods": { "version": "1.1.2" }, + "micromark": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/micromark/-/micromark-3.0.10.tgz", + "integrity": "sha512-ryTDy6UUunOXy2HPjelppgJ2sNfcPz1pLlMdA6Rz9jPzhLikWXv/irpWV/I2jd68Uhmny7hHxAlAhk4+vWggpg==", + "requires": { + "@types/debug": "^4.0.0", + "debug": "^4.0.0", + "decode-named-character-reference": "^1.0.0", + "micromark-core-commonmark": "^1.0.1", + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-chunked": "^1.0.0", + "micromark-util-combine-extensions": "^1.0.0", + "micromark-util-decode-numeric-character-reference": "^1.0.0", + "micromark-util-encode": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-resolve-all": "^1.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "micromark-util-subtokenize": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.1", + "uvu": "^0.5.0" + } + }, + "micromark-core-commonmark": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-1.0.6.tgz", + "integrity": "sha512-K+PkJTxqjFfSNkfAhp4GB+cZPfQd6dxtTXnf+RjZOV7T4EEXnvgzOcnp+eSTmpGk9d1S9sL6/lqrgSNn/s0HZA==", + "requires": { + "decode-named-character-reference": "^1.0.0", + "micromark-factory-destination": "^1.0.0", + "micromark-factory-label": "^1.0.0", + "micromark-factory-space": "^1.0.0", + "micromark-factory-title": "^1.0.0", + "micromark-factory-whitespace": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-chunked": "^1.0.0", + "micromark-util-classify-character": "^1.0.0", + "micromark-util-html-tag-name": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-resolve-all": "^1.0.0", + "micromark-util-subtokenize": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.1", + "uvu": "^0.5.0" + } + }, + "micromark-extension-gfm": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm/-/micromark-extension-gfm-2.0.1.tgz", + "integrity": "sha512-p2sGjajLa0iYiGQdT0oelahRYtMWvLjy8J9LOCxzIQsllMCGLbsLW+Nc+N4vi02jcRJvedVJ68cjelKIO6bpDA==", + "requires": { + "micromark-extension-gfm-autolink-literal": "^1.0.0", + "micromark-extension-gfm-footnote": "^1.0.0", + "micromark-extension-gfm-strikethrough": "^1.0.0", + "micromark-extension-gfm-table": "^1.0.0", + "micromark-extension-gfm-tagfilter": "^1.0.0", + "micromark-extension-gfm-task-list-item": "^1.0.0", + "micromark-util-combine-extensions": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-extension-gfm-autolink-literal": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-1.0.3.tgz", + "integrity": "sha512-i3dmvU0htawfWED8aHMMAzAVp/F0Z+0bPh3YrbTPPL1v4YAlCZpy5rBO5p0LPYiZo0zFVkoYh7vDU7yQSiCMjg==", + "requires": { + "micromark-util-character": "^1.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-extension-gfm-footnote": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-1.0.4.tgz", + "integrity": "sha512-E/fmPmDqLiMUP8mLJ8NbJWJ4bTw6tS+FEQS8CcuDtZpILuOb2kjLqPEeAePF1djXROHXChM/wPJw0iS4kHCcIg==", + "requires": { + "micromark-core-commonmark": "^1.0.0", + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-normalize-identifier": "^1.0.0", + "micromark-util-sanitize-uri": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-extension-gfm-strikethrough": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-1.0.4.tgz", + "integrity": "sha512-/vjHU/lalmjZCT5xt7CcHVJGq8sYRm80z24qAKXzaHzem/xsDYb2yLL+NNVbYvmpLx3O7SYPuGL5pzusL9CLIQ==", + "requires": { + "micromark-util-chunked": "^1.0.0", + "micromark-util-classify-character": "^1.0.0", + "micromark-util-resolve-all": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-extension-gfm-table": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-1.0.5.tgz", + "integrity": "sha512-xAZ8J1X9W9K3JTJTUL7G6wSKhp2ZYHrFk5qJgY/4B33scJzE2kpfRL6oiw/veJTbt7jiM/1rngLlOKPWr1G+vg==", + "requires": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-extension-gfm-tagfilter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-1.0.1.tgz", + "integrity": "sha512-Ty6psLAcAjboRa/UKUbbUcwjVAv5plxmpUTy2XC/3nJFL37eHej8jrHrRzkqcpipJliuBH30DTs7+3wqNcQUVA==", + "requires": { + "micromark-util-types": "^1.0.0" + } + }, + "micromark-extension-gfm-task-list-item": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-1.0.3.tgz", + "integrity": "sha512-PpysK2S1Q/5VXi72IIapbi/jliaiOFzv7THH4amwXeYXLq3l1uo8/2Be0Ac1rEwK20MQEsGH2ltAZLNY2KI/0Q==", + "requires": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-factory-destination": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-destination/-/micromark-factory-destination-1.0.0.tgz", + "integrity": "sha512-eUBA7Rs1/xtTVun9TmV3gjfPz2wEwgK5R5xcbIM5ZYAtvGF6JkyaDsj0agx8urXnO31tEO6Ug83iVH3tdedLnw==", + "requires": { + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-factory-label": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-factory-label/-/micromark-factory-label-1.0.2.tgz", + "integrity": "sha512-CTIwxlOnU7dEshXDQ+dsr2n+yxpP0+fn271pu0bwDIS8uqfFcumXpj5mLn3hSC8iw2MUr6Gx8EcKng1dD7i6hg==", + "requires": { + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-factory-space": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-space/-/micromark-factory-space-1.0.0.tgz", + "integrity": "sha512-qUmqs4kj9a5yBnk3JMLyjtWYN6Mzfcx8uJfi5XAveBniDevmZasdGBba5b4QsvRcAkmvGo5ACmSUmyGiKTLZew==", + "requires": { + "micromark-util-character": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-factory-title": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-factory-title/-/micromark-factory-title-1.0.2.tgz", + "integrity": "sha512-zily+Nr4yFqgMGRKLpTVsNl5L4PMu485fGFDOQJQBl2NFpjGte1e86zC0da93wf97jrc4+2G2GQudFMHn3IX+A==", + "requires": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-factory-whitespace": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-whitespace/-/micromark-factory-whitespace-1.0.0.tgz", + "integrity": "sha512-Qx7uEyahU1lt1RnsECBiuEbfr9INjQTGa6Err+gF3g0Tx4YEviPbqqGKNv/NrBaE7dVHdn1bVZKM/n5I/Bak7A==", + "requires": { + "micromark-factory-space": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-util-character": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/micromark-util-character/-/micromark-util-character-1.1.0.tgz", + "integrity": "sha512-agJ5B3unGNJ9rJvADMJ5ZiYjBRyDpzKAOk01Kpi1TKhlT1APx3XZk6eN7RtSz1erbWHC2L8T3xLZ81wdtGRZzg==", + "requires": { + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-util-chunked": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-chunked/-/micromark-util-chunked-1.0.0.tgz", + "integrity": "sha512-5e8xTis5tEZKgesfbQMKRCyzvffRRUX+lK/y+DvsMFdabAicPkkZV6gO+FEWi9RfuKKoxxPwNL+dFF0SMImc1g==", + "requires": { + "micromark-util-symbol": "^1.0.0" + } + }, + "micromark-util-classify-character": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-classify-character/-/micromark-util-classify-character-1.0.0.tgz", + "integrity": "sha512-F8oW2KKrQRb3vS5ud5HIqBVkCqQi224Nm55o5wYLzY/9PwHGXC01tr3d7+TqHHz6zrKQ72Okwtvm/xQm6OVNZA==", + "requires": { + "micromark-util-character": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-util-combine-extensions": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-combine-extensions/-/micromark-util-combine-extensions-1.0.0.tgz", + "integrity": "sha512-J8H058vFBdo/6+AsjHp2NF7AJ02SZtWaVUjsayNFeAiydTxUwViQPxN0Hf8dp4FmCQi0UUFovFsEyRSUmFH3MA==", + "requires": { + "micromark-util-chunked": "^1.0.0", + "micromark-util-types": "^1.0.0" + } + }, + "micromark-util-decode-numeric-character-reference": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-1.0.0.tgz", + "integrity": "sha512-OzO9AI5VUtrTD7KSdagf4MWgHMtET17Ua1fIpXTpuhclCqD8egFWo85GxSGvxgkGS74bEahvtM0WP0HjvV0e4w==", + "requires": { + "micromark-util-symbol": "^1.0.0" + } + }, + "micromark-util-decode-string": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-decode-string/-/micromark-util-decode-string-1.0.2.tgz", + "integrity": "sha512-DLT5Ho02qr6QWVNYbRZ3RYOSSWWFuH3tJexd3dgN1odEuPNxCngTCXJum7+ViRAd9BbdxCvMToPOD/IvVhzG6Q==", + "requires": { + "decode-named-character-reference": "^1.0.0", + "micromark-util-character": "^1.0.0", + "micromark-util-decode-numeric-character-reference": "^1.0.0", + "micromark-util-symbol": "^1.0.0" + } + }, + "micromark-util-encode": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-encode/-/micromark-util-encode-1.0.1.tgz", + "integrity": "sha512-U2s5YdnAYexjKDel31SVMPbfi+eF8y1U4pfiRW/Y8EFVCy/vgxk/2wWTxzcqE71LHtCuCzlBDRU2a5CQ5j+mQA==" + }, + "micromark-util-html-tag-name": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/micromark-util-html-tag-name/-/micromark-util-html-tag-name-1.1.0.tgz", + "integrity": "sha512-BKlClMmYROy9UiV03SwNmckkjn8QHVaWkqoAqzivabvdGcwNGMMMH/5szAnywmsTBUzDsU57/mFi0sp4BQO6dA==" + }, + "micromark-util-normalize-identifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-1.0.0.tgz", + "integrity": "sha512-yg+zrL14bBTFrQ7n35CmByWUTFsgst5JhA4gJYoty4Dqzj4Z4Fr/DHekSS5aLfH9bdlfnSvKAWsAgJhIbogyBg==", + "requires": { + "micromark-util-symbol": "^1.0.0" + } + }, + "micromark-util-resolve-all": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-resolve-all/-/micromark-util-resolve-all-1.0.0.tgz", + "integrity": "sha512-CB/AGk98u50k42kvgaMM94wzBqozSzDDaonKU7P7jwQIuH2RU0TeBqGYJz2WY1UdihhjweivStrJ2JdkdEmcfw==", + "requires": { + "micromark-util-types": "^1.0.0" + } + }, + "micromark-util-sanitize-uri": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-1.0.0.tgz", + "integrity": "sha512-cCxvBKlmac4rxCGx6ejlIviRaMKZc0fWm5HdCHEeDWRSkn44l6NdYVRyU+0nT1XC72EQJMZV8IPHF+jTr56lAg==", + "requires": { + "micromark-util-character": "^1.0.0", + "micromark-util-encode": "^1.0.0", + "micromark-util-symbol": "^1.0.0" + } + }, + "micromark-util-subtokenize": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-1.0.2.tgz", + "integrity": "sha512-d90uqCnXp/cy4G881Ub4psE57Sf8YD0pim9QdjCRNjfas2M1u6Lbt+XZK9gnHL2XFhnozZiEdCa9CNfXSfQ6xA==", + "requires": { + "micromark-util-chunked": "^1.0.0", + "micromark-util-symbol": "^1.0.0", + "micromark-util-types": "^1.0.0", + "uvu": "^0.5.0" + } + }, + "micromark-util-symbol": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-symbol/-/micromark-util-symbol-1.0.1.tgz", + "integrity": "sha512-oKDEMK2u5qqAptasDAwWDXq0tG9AssVwAx3E9bBF3t/shRIGsWIRG+cGafs2p/SnDSOecnt6hZPCE2o6lHfFmQ==" + }, + "micromark-util-types": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-1.0.2.tgz", + "integrity": "sha512-DCfg/T8fcrhrRKTPjRrw/5LLvdGV7BHySf/1LOZx7TzWZdYRjogNtyNq885z3nNallwr3QUKARjqvHqX1/7t+w==" + }, "micromatch": { "version": "4.0.5", "requires": { @@ -34455,6 +36448,11 @@ "minimist": "^1.2.6" } }, + "mri": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", + "integrity": "sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==" + }, "mrmime": { "version": "1.0.1", "dev": true @@ -37121,6 +39119,11 @@ "property-expr": { "version": "2.0.5" }, + "property-information": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/property-information/-/property-information-6.1.1.tgz", + "integrity": "sha512-hrzC564QIl0r0vy4l6MvRLhafmUowhO/O3KgVSoXIbbA2Sz4j8HGpJc6T2cubRVwMwpdiG/vKGfhT4IixmKN9w==" + }, "protobufjs": { "version": "6.11.3", "requires": { @@ -37412,6 +39415,28 @@ "react-is": { "version": "18.2.0" }, + "react-markdown": { + "version": "8.0.3", + "resolved": "https://registry.npmjs.org/react-markdown/-/react-markdown-8.0.3.tgz", + "integrity": "sha512-We36SfqaKoVNpN1QqsZwWSv/OZt5J15LNgTLWynwAN5b265hrQrsjMtlRNwUvS+YyR3yDM8HpTNc4pK9H/Gc0A==", + "requires": { + "@types/hast": "^2.0.0", + "@types/prop-types": "^15.0.0", + "@types/unist": "^2.0.0", + "comma-separated-tokens": "^2.0.0", + "hast-util-whitespace": "^2.0.0", + "prop-types": "^15.0.0", + "property-information": "^6.0.0", + "react-is": "^18.0.0", + "remark-parse": "^10.0.0", + "remark-rehype": "^10.0.0", + "space-separated-tokens": "^2.0.0", + "style-to-object": "^0.3.0", + "unified": "^10.0.0", + "unist-util-visit": "^4.0.0", + "vfile": "^5.0.0" + } + }, "react-native-fetch-api": { "version": "2.0.0", "requires": { @@ -37704,6 +39729,16 @@ } } }, + "rehype-raw": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/rehype-raw/-/rehype-raw-6.1.1.tgz", + "integrity": "sha512-d6AKtisSRtDRX4aSPsJGTfnzrX2ZkHQLE5kiUuGOeEoLpbEulFF4hj0mLPbsa+7vmguDKOVVEQdHKDSwoaIDsQ==", + "requires": { + "@types/hast": "^2.0.0", + "hast-util-raw": "^7.2.0", + "unified": "^10.0.0" + } + }, "relateurl": { "version": "0.2.7" }, @@ -37714,6 +39749,38 @@ "es6-error": "^4.0.1" } }, + "remark-gfm": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/remark-gfm/-/remark-gfm-3.0.1.tgz", + "integrity": "sha512-lEFDoi2PICJyNrACFOfDD3JlLkuSbOa5Wd8EPt06HUdptv8Gn0bxYTdbU/XXQ3swAPkEaGxxPN9cbnMHvVu1Ig==", + "requires": { + "@types/mdast": "^3.0.0", + "mdast-util-gfm": "^2.0.0", + "micromark-extension-gfm": "^2.0.0", + "unified": "^10.0.0" + } + }, + "remark-parse": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/remark-parse/-/remark-parse-10.0.1.tgz", + "integrity": "sha512-1fUyHr2jLsVOkhbvPRBJ5zTKZZyD6yZzYaWCS6BPBdQ8vEMBCH+9zNCDA6tET/zHCi/jLqjCWtlJZUPk+DbnFw==", + "requires": { + "@types/mdast": "^3.0.0", + "mdast-util-from-markdown": "^1.0.0", + "unified": "^10.0.0" + } + }, + "remark-rehype": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/remark-rehype/-/remark-rehype-10.1.0.tgz", + "integrity": "sha512-EFmR5zppdBp0WQeDVZ/b66CWJipB2q2VLNFMabzDSGR66Z2fQii83G5gTBbgGEnEEA0QRussvrFHxk1HWGJskw==", + "requires": { + "@types/hast": "^2.0.0", + "@types/mdast": "^3.0.0", + "mdast-util-to-hast": "^12.1.0", + "unified": "^10.0.0" + } + }, "remove-accents": { "version": "0.4.2" }, @@ -37906,6 +39973,14 @@ } } }, + "sade": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/sade/-/sade-1.8.1.tgz", + "integrity": "sha512-xal3CZX1Xlo/k4ApwCFrHVACi9fBqJ7V+mwhBsuf/1IOKbBy098Fex+Wa/5QMubw09pSZ/u8EY8PWgevJsXp1A==", + "requires": { + "mri": "^1.1.0" + } + }, "safe-buffer": { "version": "5.1.2" }, @@ -38217,6 +40292,11 @@ "sourcemap-codec": { "version": "1.4.8" }, + "space-separated-tokens": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/space-separated-tokens/-/space-separated-tokens-2.0.1.tgz", + "integrity": "sha512-ekwEbFp5aqSPKaqeY1PGrlGQxPNaq+Cnx4+bE2D8sciBQrHpbwoBbawqTN2+6jPs9IdWxxiUcN0K2pkczD3zmw==" + }, "spawn-wrap": { "version": "2.0.0", "dev": true, @@ -38411,6 +40491,14 @@ "version": "3.3.1", "requires": {} }, + "style-to-object": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/style-to-object/-/style-to-object-0.3.0.tgz", + "integrity": "sha512-CzFnRRXhzWIdItT3OmF8SQfWyahHhjq3HwcMNCNLn+N7klOOqPjMeG/4JSu77D7ypZdGvSzvkrbyeTMizz2VrA==", + "requires": { + "inline-style-parser": "0.1.1" + } + }, "styled-components": { "version": "5.3.5", "requires": { @@ -38727,6 +40815,16 @@ "tr46": { "version": "0.0.3" }, + "trim-lines": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/trim-lines/-/trim-lines-3.0.1.tgz", + "integrity": "sha512-kRj8B+YHZCc9kQYdWfJB2/oUl9rA99qbowYYBtr4ui4mZyAQ2JpvVBd/6U2YloATfqBhBTSMhTpgBHtU0Mf3Rg==" + }, + "trough": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/trough/-/trough-2.1.0.tgz", + "integrity": "sha512-AqTiAOLcj85xS7vQ8QkAV41hPDIJ71XJB4RCUrzo/1GM2CQwhkJGaf9Hgr7BOugMRpgGUrqRg/DrBDl4H40+8g==" + }, "tryer": { "version": "1.0.1" }, @@ -38826,6 +40924,27 @@ "unicode-property-aliases-ecmascript": { "version": "2.0.0" }, + "unified": { + "version": "10.1.2", + "resolved": "https://registry.npmjs.org/unified/-/unified-10.1.2.tgz", + "integrity": "sha512-pUSWAi/RAnVy1Pif2kAoeWNBa3JVrx0MId2LASj8G+7AiHWoKZNTomq6LG326T68U7/e263X6fTdcXIy7XnF7Q==", + "requires": { + "@types/unist": "^2.0.0", + "bail": "^2.0.0", + "extend": "^3.0.0", + "is-buffer": "^2.0.0", + "is-plain-obj": "^4.0.0", + "trough": "^2.0.0", + "vfile": "^5.0.0" + }, + "dependencies": { + "is-plain-obj": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-4.1.0.tgz", + "integrity": "sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg==" + } + } + }, "uniq": { "version": "1.0.1" }, @@ -38835,6 +40954,59 @@ "crypto-random-string": "^2.0.0" } }, + "unist-builder": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/unist-builder/-/unist-builder-3.0.0.tgz", + "integrity": "sha512-GFxmfEAa0vi9i5sd0R2kcrI9ks0r82NasRq5QHh2ysGngrc6GiqD5CDf1FjPenY4vApmFASBIIlk/jj5J5YbmQ==", + "requires": { + "@types/unist": "^2.0.0" + } + }, + "unist-util-generated": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unist-util-generated/-/unist-util-generated-2.0.0.tgz", + "integrity": "sha512-TiWE6DVtVe7Ye2QxOVW9kqybs6cZexNwTwSMVgkfjEReqy/xwGpAXb99OxktoWwmL+Z+Epb0Dn8/GNDYP1wnUw==" + }, + "unist-util-is": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-5.1.1.tgz", + "integrity": "sha512-F5CZ68eYzuSvJjGhCLPL3cYx45IxkqXSetCcRgUXtbcm50X2L9oOWQlfUfDdAf+6Pd27YDblBfdtmsThXmwpbQ==" + }, + "unist-util-position": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/unist-util-position/-/unist-util-position-4.0.3.tgz", + "integrity": "sha512-p/5EMGIa1qwbXjA+QgcBXaPWjSnZfQ2Sc3yBEEfgPwsEmJd8Qh+DSk3LGnmOM4S1bY2C0AjmMnB8RuEYxpPwXQ==", + "requires": { + "@types/unist": "^2.0.0" + } + }, + "unist-util-stringify-position": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-3.0.2.tgz", + "integrity": "sha512-7A6eiDCs9UtjcwZOcCpM4aPII3bAAGv13E96IkawkOAW0OhH+yRxtY0lzo8KiHpzEMfH7Q+FizUmwp8Iqy5EWg==", + "requires": { + "@types/unist": "^2.0.0" + } + }, + "unist-util-visit": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-4.1.1.tgz", + "integrity": "sha512-n9KN3WV9k4h1DxYR1LoajgN93wpEi/7ZplVe02IoB4gH5ctI1AaF2670BLHQYbwj+pY83gFtyeySFiyMHJklrg==", + "requires": { + "@types/unist": "^2.0.0", + "unist-util-is": "^5.0.0", + "unist-util-visit-parents": "^5.1.1" + } + }, + "unist-util-visit-parents": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-5.1.1.tgz", + "integrity": "sha512-gks4baapT/kNRaWxuGkl5BIhoanZo7sC/cUT/JToSRNL1dYoXRFl75d++NkjYk4TAu2uv2Px+l8guMajogeuiw==", + "requires": { + "@types/unist": "^2.0.0", + "unist-util-is": "^5.0.0" + } + }, "universalify": { "version": "2.0.0" }, @@ -38959,6 +41131,24 @@ "uuid": { "version": "8.3.2" }, + "uvu": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/uvu/-/uvu-0.5.6.tgz", + "integrity": "sha512-+g8ENReyr8YsOc6fv/NVJs2vFdHBnBNdfE49rshrTzDWOlUx4Gq7KOS2GD8eqhy2j+Ejq29+SbKH8yjkAqXqoA==", + "requires": { + "dequal": "^2.0.0", + "diff": "^5.0.0", + "kleur": "^4.0.3", + "sade": "^1.7.3" + }, + "dependencies": { + "kleur": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", + "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==" + } + } + }, "v8-compile-cache": { "version": "2.3.0" }, @@ -38984,6 +41174,35 @@ "vary": { "version": "1.1.2" }, + "vfile": { + "version": "5.3.5", + "resolved": "https://registry.npmjs.org/vfile/-/vfile-5.3.5.tgz", + "integrity": "sha512-U1ho2ga33eZ8y8pkbQLH54uKqGhFJ6GYIHnnG5AhRpAh3OWjkrRHKa/KogbmQn8We+c0KVV3rTOgR9V/WowbXQ==", + "requires": { + "@types/unist": "^2.0.0", + "is-buffer": "^2.0.0", + "unist-util-stringify-position": "^3.0.0", + "vfile-message": "^3.0.0" + } + }, + "vfile-location": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/vfile-location/-/vfile-location-4.0.1.tgz", + "integrity": "sha512-JDxPlTbZrZCQXogGheBHjbRWjESSPEak770XwWPfw5mTc1v1nWGLB/apzZxsx8a0SJVfF8HK8ql8RD308vXRUw==", + "requires": { + "@types/unist": "^2.0.0", + "vfile": "^5.0.0" + } + }, + "vfile-message": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-3.1.2.tgz", + "integrity": "sha512-QjSNP6Yxzyycd4SVOtmKKyTsSvClqBPJcd00Z0zuPj3hOIjg0rUPG6DbFGPvUKRgYyaIWLPKpuEclcuvb3H8qA==", + "requires": { + "@types/unist": "^2.0.0", + "unist-util-stringify-position": "^3.0.0" + } + }, "w3c-hr-time": { "version": "1.0.2", "requires": { @@ -39043,6 +41262,11 @@ "minimalistic-assert": "^1.0.0" } }, + "web-namespaces": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/web-namespaces/-/web-namespaces-2.0.1.tgz", + "integrity": "sha512-bKr1DkiNa2krS7qxNtdrtHAmzuYGFQLiQ13TsorsdT6ULTkPLKuu5+GsFpDlg6JFjUTwX2DyhMPG2be8uPrqsQ==" + }, "web-vitals": { "version": "2.1.4" }, @@ -39699,6 +41923,11 @@ "requires": { "use-sync-external-store": "1.2.0" } + }, + "zwitch": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/zwitch/-/zwitch-2.0.2.tgz", + "integrity": "sha512-JZxotl7SxAJH0j7dN4pxsTV6ZLXoLdGME+PsjkL/DaBrVryK9kTGq06GfKrwcSOqypP+fdXGoCHE36b99fWVoA==" } } } diff --git a/package.json b/package.json index f0d04ba7e..858fe0fc0 100644 --- a/package.json +++ b/package.json @@ -83,6 +83,7 @@ "react-dom": "^18.2.0", "react-hot-toast": "^2.4.0", "react-infinite-scroll-component": "^6.1.0", + "react-markdown": "^8.0.3", "react-popper": "^2.3.0", "react-query": "^3.39.1", "react-responsive": "^9.0.0-beta.10", @@ -91,6 +92,8 @@ "react-select": "^5.4.0", "react-swipeable": "^7.0.0", "react-table": "^7.8.0", + "rehype-raw": "^6.1.1", + "remark-gfm": "^3.0.1", "stream-browserify": "^3.0.0", "use-resize-observer": "^9.0.2", "util": "^0.12.4", diff --git a/src/components/contractualAgreement/ContractualAgreement.tsx b/src/components/contractualAgreement/ContractualAgreement.tsx new file mode 100644 index 000000000..4353cf3f7 --- /dev/null +++ b/src/components/contractualAgreement/ContractualAgreement.tsx @@ -0,0 +1,44 @@ +import { subgraph } from "@bosonprotocol/react-kit"; +import { Loading } from "@bosonprotocol/react-kit"; +import ReactMarkdown from "react-markdown"; +import rehypeRaw from "rehype-raw"; +import remarkGfm from "remark-gfm"; + +import { CONFIG } from "../../lib/config"; +import { ProgressStatus } from "../../lib/types/progressStatus"; +import { useRenderTemplate } from "../../lib/utils/hooks/useRenderTemplate"; +import SimpleError from "../error/SimpleError"; + +interface Props { + offerId: string | undefined; + offerData: subgraph.OfferFieldsFragment | undefined; +} + +export default function ContractualAgreement({ offerId, offerData }: Props) { + // TODO: get the template from the offer metadata (BP390 - https://app.asana.com/0/1200803815983047/1203080300620356) + const templateUrl = CONFIG.buyerSellerAgreementTemplate as string; + const { renderStatus, renderResult } = useRenderTemplate( + offerId, + offerData, + templateUrl + ); + + const isLoading = + renderStatus === ProgressStatus.LOADING || + renderStatus === ProgressStatus.IDLE; + const isError = renderStatus === ProgressStatus.ERROR; + + if (isError) { + return ; + } + if (isLoading) { + return ; + } + return ( + + ); +} diff --git a/src/components/detail/DetailTable.tsx b/src/components/detail/DetailTable.tsx index 1ecbc3a95..de299210b 100644 --- a/src/components/detail/DetailTable.tsx +++ b/src/components/detail/DetailTable.tsx @@ -8,6 +8,7 @@ export interface Data { name?: React.ReactNode | string; info?: React.ReactNode | string; value?: React.ReactNode | string; + nextLine?: React.ReactNode | string; } interface Props { @@ -31,19 +32,30 @@ export default function DetailTable({ {data?.map( ({ hide = false, ...d }: Data, index: number) => !hide && ( - - - - {d.name} - {d.info && } - - - - - {d.value} - - - + <> + + + + {d.name} + {d.info && } + + + + + {d.value} + + + + {d.nextLine ? ( + + + {d.nextLine} + + + ) : ( + <> + )} + ) )} diff --git a/src/components/detail/DetailWidget/DetailWidget.tsx b/src/components/detail/DetailWidget/DetailWidget.tsx index 5290b0935..550f2b730 100644 --- a/src/components/detail/DetailWidget/DetailWidget.tsx +++ b/src/components/detail/DetailWidget/DetailWidget.tsx @@ -6,7 +6,7 @@ import { } from "@bosonprotocol/react-kit"; import dayjs from "dayjs"; import { BigNumber, ethers } from "ethers"; -import { ArrowRight, Check, Question } from "phosphor-react"; +import { ArrowRight, ArrowSquareOut, Check, Question } from "phosphor-react"; import { useMemo, useState } from "react"; import toast from "react-hot-toast"; import styled from "styled-components"; @@ -28,7 +28,7 @@ import { useKeepQueryParamsNavigate } from "../../../lib/utils/hooks/useKeepQuer import { getItemFromStorage } from "../../../lib/utils/hooks/useLocalStorage"; import { useCoreSDK } from "../../../lib/utils/useCoreSdk"; import { poll } from "../../../pages/create-product/utils"; -import { useModal } from "../../modal/useModal"; +import { ModalTypes, ShowModalFn, useModal } from "../../modal/useModal"; import Price from "../../price/index"; import { useConvertedPrice } from "../../price/useConvertedPrice"; import SuccessTransactionToast from "../../toasts/SuccessTransactionToast"; @@ -104,7 +104,9 @@ interface IDetailWidget { export const getOfferDetailData = ( offer: Offer, convertedPrice: IPrice | null, - isModal: boolean + isModal: boolean, + modalTypes?: ModalTypes, + showModal?: ShowModalFn ) => { const redeemableUntil = dayjs( Number(`${offer.voucherRedeemableUntilDate}000`) @@ -115,6 +117,20 @@ export const getOfferDetailData = ( const { buyerCancelationPenalty, convertedBuyerCancelationPenalty } = getBuyerCancelPenalty(offer, convertedPrice); + // if offer is in creation, offer.id does not exist + const handleShowExchangePolicy = () => { + const offerData = offer.id ? undefined : offer; + if (modalTypes && showModal) { + showModal(modalTypes.EXCHANGE_POLICY_DETAILS, { + title: "Exchange Policy Details", + offerId: offer.id, + offerData + }); + } else { + console.error("modalTypes and/or showModal undefined"); + } + }; + return [ { name: "Redeemable until", @@ -177,7 +193,7 @@ export const getOfferDetailData = ( ) }, { - name: "Fair exchange policy", + name: "Exchange policy", info: ( <> @@ -189,7 +205,16 @@ export const getOfferDetailData = ( ), - value: + value: ( + + Fair Exchange Policy{" "} + handleShowExchangePolicy()} + style={{ cursor: "pointer" }} + /> + + ) }, { name: DetailDisputeResolver.name, @@ -262,12 +287,14 @@ const DetailWidget: React.FC = ({ }); const OFFER_DETAIL_DATA = useMemo( - () => getOfferDetailData(offer, convertedPrice, false), - [offer, convertedPrice] + () => + getOfferDetailData(offer, convertedPrice, false, modalTypes, showModal), + [offer, convertedPrice, modalTypes, showModal] ); const OFFER_DETAIL_DATA_MODAL = useMemo( - () => getOfferDetailData(offer, convertedPrice, true), - [offer, convertedPrice] + () => + getOfferDetailData(offer, convertedPrice, true, modalTypes, showModal), + [offer, convertedPrice, modalTypes, showModal] ); const quantity = useMemo( diff --git a/src/components/exchangePolicy/FairExchangePolicy.tsx b/src/components/exchangePolicy/FairExchangePolicy.tsx index f1fceb118..ba0988be4 100644 --- a/src/components/exchangePolicy/FairExchangePolicy.tsx +++ b/src/components/exchangePolicy/FairExchangePolicy.tsx @@ -1,6 +1,7 @@ import { ReactNode } from "react"; import styled, { css, IntrinsicElementsKeys } from "styled-components"; +import { CONFIG } from "../../lib/config"; import { colors } from "../../lib/styles/colors"; import Typography from "../ui/Typography"; @@ -49,6 +50,7 @@ export default function FairExchangePolicy({ titleTag = "p", bulletPointIcon }: Props) { + const disputeResolutionPeriodDays = CONFIG.defaultDisputeResolutionPeriodDays; return ( <> @@ -72,7 +74,9 @@ export default function FairExchangePolicy({ {bulletPointIcon} - 15 days to resolve a raised dispute + + {disputeResolutionPeriodDays} days to resolve a raised dispute + diff --git a/src/components/license/License.tsx b/src/components/license/License.tsx new file mode 100644 index 000000000..b4dec35e5 --- /dev/null +++ b/src/components/license/License.tsx @@ -0,0 +1,43 @@ +import { subgraph } from "@bosonprotocol/react-kit"; +import { Loading } from "@bosonprotocol/react-kit"; +import ReactMarkdown from "react-markdown"; +import rehypeRaw from "rehype-raw"; +import remarkGfm from "remark-gfm"; + +import { CONFIG } from "../../lib/config"; +import { ProgressStatus } from "../../lib/types/progressStatus"; +import { useRenderTemplate } from "../../lib/utils/hooks/useRenderTemplate"; +import SimpleError from "../error/SimpleError"; + +interface Props { + offerId: string | undefined; + offerData: subgraph.OfferFieldsFragment | undefined; +} + +export default function License({ offerId, offerData }: Props) { + const templateUrl = CONFIG.rNFTLicenseTemplate as string; // TODO: get the template from the offer metadata + const { renderStatus, renderResult } = useRenderTemplate( + offerId, + offerData, + templateUrl + ); + + const isLoading = + renderStatus === ProgressStatus.LOADING || + renderStatus === ProgressStatus.IDLE; + const isError = renderStatus === ProgressStatus.ERROR; + + if (isError) { + return ; + } + if (isLoading) { + return ; + } + return ( + + ); +} diff --git a/src/components/modal/ModalComponents.tsx b/src/components/modal/ModalComponents.tsx index 8741238b8..9394cddaa 100644 --- a/src/components/modal/ModalComponents.tsx +++ b/src/components/modal/ModalComponents.tsx @@ -8,6 +8,7 @@ import CreateProductDraft from "./components/CreateProductDraft"; import CustomStore from "./components/CustomStore"; import DetailWidget from "./components/DetailWidget"; import DisputeModal from "./components/DisputeModal/DisputeModal"; +import ExchangePolicyDetailsModal from "./components/ExchangePolicyDetails"; import ManageFunds from "./components/ManageFunds"; import ProductCreateSuccess from "./components/ProductCreateSuccess"; import RedeemModal from "./components/RedeemModal/RedeemModal"; @@ -48,7 +49,8 @@ export const MODAL_TYPES = { RECENT_TRANSACTIONS: "RECENT_TRANSACTIONS", WAITING_FOR_CONFIRMATION: "WAITING_FOR_CONFIRMATION", CONFIRMATION_FAILED: "CONFIRMATION_FAILED", - TRANSACTION_SUBMITTED: "TRANSACTION_SUBMITTED" + TRANSACTION_SUBMITTED: "TRANSACTION_SUBMITTED", + EXCHANGE_POLICY_DETAILS: "EXCHANGE_POLICY_DETAILS" } as const; export const MODAL_COMPONENTS = { @@ -75,5 +77,6 @@ export const MODAL_COMPONENTS = { [MODAL_TYPES.RECENT_TRANSACTIONS]: RecentTransactionsModal, [MODAL_TYPES.WAITING_FOR_CONFIRMATION]: WaitingForConfirmationModal, [MODAL_TYPES.CONFIRMATION_FAILED]: ConfirmationFailedModal, - [MODAL_TYPES.TRANSACTION_SUBMITTED]: TransactionSubmittedModal + [MODAL_TYPES.TRANSACTION_SUBMITTED]: TransactionSubmittedModal, + [MODAL_TYPES.EXCHANGE_POLICY_DETAILS]: ExchangePolicyDetailsModal } as const; diff --git a/src/components/modal/components/ExchangePolicyDetails.tsx b/src/components/modal/components/ExchangePolicyDetails.tsx new file mode 100644 index 000000000..ba4a2221c --- /dev/null +++ b/src/components/modal/components/ExchangePolicyDetails.tsx @@ -0,0 +1,198 @@ +import { subgraph } from "@bosonprotocol/react-kit"; +import { CaretDown, CaretUp } from "phosphor-react"; +import { useState } from "react"; + +import { CONFIG } from "../../../lib/config"; +import ContractualAgreement from "../../contractualAgreement/ContractualAgreement"; +import DetailTable from "../../detail/DetailTable"; +import License from "../../license/License"; +import Grid from "../../ui/Grid"; +import Typography from "../../ui/Typography"; + +interface Props { + offerId?: string; + offerData?: subgraph.OfferFieldsFragment; +} + +export default function ExchangePolicyDetails({ offerId, offerData }: Props) { + const exchangePolicy = { + name: "Fair Exchange Policy", + version: "v1.0", + disputePeriod: 30, + escalationPeriod: CONFIG.defaultDisputeResolutionPeriodDays, + contractualAgreement: { + title: "Commerce Agreement", + version: "v1", + templateUri: CONFIG.buyerSellerAgreementTemplate + }, + rNFTLicense: { + title: "License Agreement", + version: "v1", + templateUri: CONFIG.rNFTLicenseTemplate + } + }; + const [contractualAgreementVisible, setContractualAgreementVisible] = + useState(false); + const [licenseVisible, setLicenseVisible] = useState(false); + + const tableDetails = [ + { + name: "Policy name", + info: undefined, + value: ( + + {exchangePolicy.name} {exchangePolicy.version} + + ) + }, + { + name: "Dispute Period", + info: undefined, + value: ( + + {"Min. "} + {exchangePolicy.disputePeriod} + {" days"} + + ) + }, + { + name: "Escalation Period", + info: undefined, + value: ( + + {"Min. "} + {exchangePolicy.escalationPeriod} + {" days"} + + ) + } + ]; + + const contractualAgreementCollapsed = { + name: "Contractual agreement", + info: ( + <> + + Contractual agreement + + + The Contractual agreement sets out the terms relating to the exchange. + + + ), + value: ( + +
{ + setContractualAgreementVisible(!contractualAgreementVisible); + }} + style={{ cursor: "pointer" }} + > + + {exchangePolicy.contractualAgreement.title}{" "} + {exchangePolicy.contractualAgreement.version}{" "} + +
+ {contractualAgreementVisible ? ( + { + setContractualAgreementVisible(!contractualAgreementVisible); + }} + style={{ cursor: "pointer" }} + size={18} + /> + ) : ( + { + setContractualAgreementVisible(!contractualAgreementVisible); + }} + style={{ cursor: "pointer" }} + size={18} + /> + )} +
+ ) + }; + const contractualAgreementExpanded = { + ...contractualAgreementCollapsed, + nextLine: ( + + ) + }; + const licenseCollapsed = { + name: "Redeemable NFT Terms", + info: ( + <> + + Redeemable NFT Terms + + + Terms for the BOSON Redeemable NFT (rNFT) + + + ), + value: ( + +
{ + setLicenseVisible(!licenseVisible); + }} + style={{ cursor: "pointer" }} + > + + {exchangePolicy.rNFTLicense.title}{" "} + {exchangePolicy.rNFTLicense.version}{" "} + +
+ {licenseVisible ? ( + { + setLicenseVisible(!licenseVisible); + }} + style={{ cursor: "pointer" }} + size={18} + /> + ) : ( + { + setLicenseVisible(!licenseVisible); + }} + style={{ cursor: "pointer" }} + size={18} + /> + )} +
+ ) + }; + const licenseExpanded = { + ...licenseCollapsed, + nextLine: + }; + return ( + <> + + + Boson Exchange Policies combine protocol variables and the underlying + contractual agreement of an exchange into a standardized policy, + ensuring fair terms and protection for both buyer and seller. + + + + + ); +} diff --git a/src/components/modal/components/Explore/Collections/CollectionsCardImage.tsx b/src/components/modal/components/Explore/Collections/CollectionsCardImage.tsx index 6103a166b..e04439141 100644 --- a/src/components/modal/components/Explore/Collections/CollectionsCardImage.tsx +++ b/src/components/modal/components/Explore/Collections/CollectionsCardImage.tsx @@ -4,6 +4,7 @@ import React from "react"; import styled from "styled-components"; import { colors } from "../../../../../lib/styles/colors"; +import { ProgressStatus } from "../../../../../lib/types/progressStatus"; import { useGetIpfsImage } from "../../../../../lib/utils/hooks/useGetIpfsImage"; import { Spinner } from "../../../../loading/Spinner"; @@ -35,7 +36,7 @@ function CollectionsCardImage({ imageSource }: any) { errorIcon: } }; - if (imageStatus === "loading") { + if (imageStatus === ProgressStatus.LOADING) { return ( diff --git a/src/components/modal/components/ManageFunds.tsx b/src/components/modal/components/ManageFunds.tsx index 5d2eec11b..645e00ea9 100644 --- a/src/components/modal/components/ManageFunds.tsx +++ b/src/components/modal/components/ManageFunds.tsx @@ -8,6 +8,7 @@ import { useEffect, useState } from "react"; import styled from "styled-components"; import { colors } from "../../../lib/styles/colors"; +import { ProgressStatus } from "../../../lib/types/progressStatus"; import useFunds from "../../../pages/account/funds/useFunds"; import { useConvertionRate } from "../../convertion-rate/useConvertionRate"; import { Spinner } from "../../loading/Spinner"; @@ -78,12 +79,15 @@ export default function ManageFunds({ id }: Props) { // eslint-disable-next-line react-hooks/exhaustive-deps }, [funds, id]); - if (fundStatus === "error") { + if (fundStatus === ProgressStatus.ERROR) { // TODO: NO FIGMA REPRESENTATIONS return There has been an error...; } - if (fundStatus === "loading" || fundStatus === "idle") { + if ( + fundStatus === ProgressStatus.LOADING || + fundStatus === ProgressStatus.IDLE + ) { return ( diff --git a/src/components/modal/useModal.ts b/src/components/modal/useModal.ts index ce2ac9847..642d488a6 100644 --- a/src/components/modal/useModal.ts +++ b/src/components/modal/useModal.ts @@ -3,6 +3,9 @@ import { useContext } from "react"; import { MODAL_TYPES } from "./ModalComponents"; import ModalContext from "./ModalContext"; +export type ShowModalFn = ReturnType["showModal"]; +export type ModalTypes = ReturnType["modalTypes"]; + export function useModal() { const context = useContext(ModalContext); diff --git a/src/components/product/Preview.tsx b/src/components/product/Preview.tsx index ef59fec96..f827657a3 100644 --- a/src/components/product/Preview.tsx +++ b/src/components/product/Preview.tsx @@ -65,11 +65,10 @@ export default function Preview({ togglePreview, seller }: Props) { const sliderImages = slice(previewImages, 1); const name = values.productInformation.productTitle || "Untitled"; - const weiPrice = parseUnits(`${values.coreTermsOfSale.price}`, 18); - - const sellerDeposit = parseInt(values.termsOfExchange.sellerDeposit) / 100; - const buyerDeposit = - parseInt(values.termsOfExchange.buyerCancellationPenalty) / 100; + const priceBN = parseUnits( + `${values.coreTermsOfSale.price}`, + Number(exchangeToken?.decimals || 18) + ); const validFromDateInMS = Date.parse( values.coreTermsOfSale.offerValidityPeriod[0] @@ -87,30 +86,39 @@ export default function Preview({ togglePreview, seller }: Props) { const exchangeDate = Date.now().toString(); const offer = { - price: weiPrice.toString(), - - sellerDeposit: ethers.utils.formatUnits( - ethers.utils - .parseUnits(values.coreTermsOfSale.price.toString(), 18) - .mul(ethers.utils.parseUnits(sellerDeposit.toString(), 18)) - .toString(), - 18 - ), - buyerCancelPenalty: ethers.utils.formatUnits( - ethers.utils - .parseUnits(values.coreTermsOfSale.price.toString(), 18) - .mul(ethers.utils.parseUnits(buyerDeposit.toString(), 18)) - .toString(), - 18 - ), - validFromDate: validFromDateInMS.toString(), - validUntilDate: validUntilDateInMS.toString(), - voucherRedeemableFromDate: voucherRedeemableFromDateInMS.toString(), + price: priceBN.toString(), + sellerDeposit: priceBN + .mul(parseFloat(values.termsOfExchange.sellerDeposit) * 1000) + .div(100 * 1000) + .toString(), + protocolFee: "0", + agentFee: "0", + agentId: "0", + buyerCancelPenalty: priceBN + .mul(parseFloat(values.termsOfExchange.buyerCancellationPenalty) * 1000) + .div(100 * 1000) + .toString(), + quantityAvailable: values.coreTermsOfSale.quantity.toString(), + quantityInitial: values.coreTermsOfSale.quantity.toString(), + validFromDate: (validFromDateInMS / 1000).toString(), + validUntilDate: (validUntilDateInMS / 1000).toString(), + voucherRedeemableFromDate: ( + voucherRedeemableFromDateInMS / 1000 + ).toString(), voucherRedeemableUntilDate: ( voucherRedeemableUntilDateInMS / 1000 ).toString(), + fulfillmentPeriodDuration: `${ + parseInt(values.termsOfExchange.disputePeriod) * 24 * 3600 + }`, // day to sec + voucherValidDuration: "0", // we use redeemableFrom/redeemableUntil so should be 0 + resolutionPeriodDuration: `${ + parseInt(CONFIG.defaultDisputeResolutionPeriodDays) * 24 * 3600 + }`, // day to sec + metadataUri: "not-uploaded-yet", // can't be empty + metadataHash: "not-uploaded-yet", // can't be empty voidedAt: null, - voucherValidDuration: "21727820", + disputeResolverId: CONFIG.defaultDisputeResolverId, exchanges: [ { committedDate: exchangeDate, diff --git a/src/components/seller/finances/SellerFinances.tsx b/src/components/seller/finances/SellerFinances.tsx index 72ec630f6..b04351daa 100644 --- a/src/components/seller/finances/SellerFinances.tsx +++ b/src/components/seller/finances/SellerFinances.tsx @@ -16,6 +16,7 @@ dayjs.extend(isBetween); import { Currencies, CurrencyDisplay } from "@bosonprotocol/react-kit"; import { colors } from "../../../lib/styles/colors"; +import { ProgressStatus } from "../../../lib/types/progressStatus"; import { useModal } from "../../modal/useModal"; import Tooltip from "../../tooltip/Tooltip"; import Button from "../../ui/Button"; @@ -166,7 +167,7 @@ export default function SellerFinances({ } = sellerDepositData; useEffect(() => { - if (fundStatus === "success" && !isFundsInitialized) { + if (fundStatus === ProgressStatus.SUCCESS && !isFundsInitialized) { setIsFundsInitialized(true); } }, [fundStatus, isFundsInitialized]); @@ -385,7 +386,11 @@ export default function SellerFinances({ return ; } - if (sellerDataIsError || fundStatus === "error" || isErrorExchangesTokens) { + if ( + sellerDataIsError || + fundStatus === ProgressStatus.ERROR || + isErrorExchangesTokens + ) { // TODO: NO FIGMA REPRESENTATIONS } diff --git a/src/lib/config.ts b/src/lib/config.ts index d68ef96a8..5d9f69bc8 100644 --- a/src/lib/config.ts +++ b/src/lib/config.ts @@ -55,11 +55,18 @@ export const CONFIG = { offerCurationList: parseCurationList( process.env.REACT_APP_OFFER_CURATION_LIST ), + rNFTLicenseTemplate: process.env.REACT_APP_RNFT_LICENSE_TEMPLATE, + buyerSellerAgreementTemplate: + process.env.REACT_APP_BUYER_SELLER_AGREEMENT_TEMPLATE, enableCurationLists: stringToBoolean( process.env.REACT_APP_ENABLE_CURATION_LISTS ), defaultTokens: getDefaultTokens(), - mockSellerId: process.env.REACT_APP_MOCK_SELLER_ID + mockSellerId: process.env.REACT_APP_MOCK_SELLER_ID, + defaultDisputeResolverId: + process.env.REACT_APP_DEFAULT_DISPUTE_RESOLVER_ID || "1", + defaultDisputeResolutionPeriodDays: + process.env.REACT_APP_DEFAULT_RESOLUTION_PERIOD_DAYS || "15" }; function stringToBoolean(value?: string) { diff --git a/src/lib/routing/parameters.ts b/src/lib/routing/parameters.ts index a64ea714e..e4e852fcb 100644 --- a/src/lib/routing/parameters.ts +++ b/src/lib/routing/parameters.ts @@ -27,5 +27,6 @@ export const UrlParameters = { page: "page", sellerPage: "sellerPage", buyerId: "id", - sellerId: "id" + sellerId: "id", + tokenId: "id" } as const; diff --git a/src/lib/routing/routes.tsx b/src/lib/routing/routes.tsx index 1474dd8f2..d6325f02e 100644 --- a/src/lib/routing/routes.tsx +++ b/src/lib/routing/routes.tsx @@ -18,6 +18,8 @@ export const BosonRoutes = { DisputeId: `/exchange/:${UrlParameters.exchangeId}/raise-dispute`, BuyerPage: `/buyer/:${UrlParameters.buyerId}`, SellerPage: `/seller/:${UrlParameters.sellerId}`, + License: `/license/:${UrlParameters.tokenId}`, + ContractualAgreement: `/contractualAgreement/:${UrlParameters.offerId}`, Error404: "*" } as const; diff --git a/src/lib/types/progressStatus.ts b/src/lib/types/progressStatus.ts new file mode 100644 index 000000000..dc0ae58ad --- /dev/null +++ b/src/lib/types/progressStatus.ts @@ -0,0 +1,6 @@ +export enum ProgressStatus { + IDLE = "idle", + LOADING = "loading", + SUCCESS = "success", + ERROR = "error" +} diff --git a/src/lib/utils/hooks/useGetIpfsImage.ts b/src/lib/utils/hooks/useGetIpfsImage.ts index 529f4db99..b34b4a428 100644 --- a/src/lib/utils/hooks/useGetIpfsImage.ts +++ b/src/lib/utils/hooks/useGetIpfsImage.ts @@ -1,37 +1,41 @@ import { useEffect, useState } from "react"; +import { ProgressStatus } from "../../types/progressStatus"; import { blobToBase64 } from "../base64ImageConverter"; import { useIpfsStorage } from "./useIpfsStorage"; -type ImageStatus = "idle" | "loading" | "success" | "error"; - export function useGetIpfsImage(src: string) { const ipfsMetadataStorage = useIpfsStorage(); - const [imageStatus, setImageStatus] = useState("idle"); + const [imageStatus, setImageStatus] = useState( + ProgressStatus.IDLE + ); const [imageSrc, setImageSrc] = useState(""); useEffect(() => { async function fetchData(src: string) { if (ipfsMetadataStorage) { - setImageStatus("loading"); + setImageStatus(ProgressStatus.LOADING); const fetchPromises = await ipfsMetadataStorage.get(src, false); const [image] = await Promise.all([fetchPromises]); const base64str = await blobToBase64(new Blob([image as BlobPart])); if (!String(base64str).includes("base64")) { - setImageStatus("error"); + setImageStatus(ProgressStatus.ERROR); } else { setImageSrc(base64str as string); - setImageStatus("success"); + setImageStatus(ProgressStatus.SUCCESS); } } } - if (["idle", "loading"].includes(imageStatus) && !imageSrc) { + if ( + [ProgressStatus.IDLE, ProgressStatus.LOADING].includes(imageStatus) && + !imageSrc + ) { if (src?.includes("ipfs://")) { fetchData(src); } else { setImageSrc(src); - setImageStatus("success"); + setImageStatus(ProgressStatus.SUCCESS); } } }, []); // eslint-disable-line diff --git a/src/lib/utils/hooks/useRenderTemplate.ts b/src/lib/utils/hooks/useRenderTemplate.ts new file mode 100644 index 000000000..9fa0211fc --- /dev/null +++ b/src/lib/utils/hooks/useRenderTemplate.ts @@ -0,0 +1,111 @@ +import { CreateOfferArgs } from "@bosonprotocol/common"; +import { subgraph } from "@bosonprotocol/react-kit"; +import { BigNumber } from "ethers"; +import { useEffect, useState } from "react"; + +import { ProgressStatus } from "../../types/progressStatus"; +import { useCoreSDK } from "../useCoreSdk"; +import { useIpfsStorage } from "./useIpfsStorage"; + +type OfferFieldsFragment = subgraph.OfferFieldsFragment; + +export function useRenderTemplate( + offerId: string | undefined, + offerData: OfferFieldsFragment | undefined, + templateUrl: string +) { + const [renderStatus, setRenderStatus] = useState( + ProgressStatus.IDLE + ); + const [renderResult, setRenderResult] = useState(""); + const ipfsMetadataStorage = useIpfsStorage(); + const coreSDK = useCoreSDK(); + + useEffect(() => { + async function fetchTemplate() { + setRenderStatus(ProgressStatus.LOADING); + if (ipfsMetadataStorage && coreSDK) { + try { + const rawTemplate = await ipfsMetadataStorage.get( + templateUrl, + false + ); + const template = Buffer.from(rawTemplate).toString("utf-8"); + let theOfferData = offerData; + // If the offerData is not specified, retrieve the data from offerId + if (!offerData) { + if (!offerId) { + throw new Error("OfferData or OfferId needs to be defined"); + } + // Get the offer fields from subgraph + theOfferData = await coreSDK.getOfferById(offerId); + } + const result = await coreSDK.renderContractualAgreement( + template, + // Convert offer fields format to offer data format + buildOfferData(theOfferData as OfferFieldsFragment) + ); + setRenderResult(result); + setRenderStatus(ProgressStatus.SUCCESS); + } catch (e) { + console.error(e); + setRenderStatus(ProgressStatus.ERROR); + } + } + } + if ( + renderStatus !== ProgressStatus.SUCCESS && + renderStatus !== ProgressStatus.ERROR + ) { + fetchTemplate(); + } + }, [ + templateUrl, + offerId, + offerData, + renderStatus, + ipfsMetadataStorage, + coreSDK + ]); + return { renderStatus, renderResult }; +} + +function buildOfferData(offerFields: OfferFieldsFragment): CreateOfferArgs { + return { + price: offerFields.price as string, + sellerDeposit: offerFields.sellerDeposit as string, + agentId: offerFields.agentId as string, + buyerCancelPenalty: offerFields.buyerCancelPenalty as string, + quantityAvailable: offerFields.quantityAvailable as string, + validFromDateInMS: BigNumber.from(offerFields.validFromDate) + .mul(1000) + .toString(), + validUntilDateInMS: BigNumber.from(offerFields.validUntilDate) + .mul(1000) + .toString(), + voucherRedeemableFromDateInMS: BigNumber.from( + offerFields.voucherRedeemableFromDate + ) + .mul(1000) + .toString(), + voucherRedeemableUntilDateInMS: BigNumber.from( + offerFields.voucherRedeemableUntilDate + ) + .mul(1000) + .toString(), + fulfillmentPeriodDurationInMS: BigNumber.from( + offerFields.fulfillmentPeriodDuration + ) + .mul(1000) + .toString(), + resolutionPeriodDurationInMS: BigNumber.from( + offerFields.resolutionPeriodDuration + ) + .mul(1000) + .toString(), + exchangeToken: offerFields.exchangeToken.address as string, + disputeResolverId: offerFields.disputeResolverId as string, + metadataHash: offerFields.metadataHash as string, + metadataUri: offerFields.metadataUri as string + }; +} diff --git a/src/pages/account/funds/useFunds.ts b/src/pages/account/funds/useFunds.ts index ee35fac70..f6bca7f8f 100644 --- a/src/pages/account/funds/useFunds.ts +++ b/src/pages/account/funds/useFunds.ts @@ -5,14 +5,13 @@ import { useCallback, useEffect, useReducer, useState } from "react"; import { Token } from "../../../components/convertion-rate/ConvertionRateContext"; import { CONFIG } from "../../../lib/config"; +import { ProgressStatus } from "../../../lib/types/progressStatus"; import { useCoreSDK } from "../../../lib/utils/useCoreSdk"; -type FundStatus = "idle" | "loading" | "error" | "success"; - export interface FundsProps { funds: Array; reload: React.DispatchWithoutAction; - fundStatus: FundStatus; + fundStatus: ProgressStatus; } export default function useFunds( accountId: string, @@ -23,7 +22,9 @@ export default function useFunds( const [funds, setFunds] = useState>( [] ); - const [fundStatus, setFundStatus] = useState("idle"); + const [fundStatus, setFundStatus] = useState( + ProgressStatus.IDLE + ); const handleFunds = useCallback( (funds: Array) => { @@ -67,7 +68,7 @@ export default function useFunds( } return acc; }, []) || []; - setFundStatus("success"); + setFundStatus(ProgressStatus.SUCCESS); setFunds(allTokensParsed); }, [tokens, accountId] @@ -75,14 +76,14 @@ export default function useFunds( const getFunds = useCallback(() => { if (accountId && coreSdk) { - setFundStatus("loading"); + setFundStatus(ProgressStatus.LOADING); coreSdk .getFunds({ fundsFilter: { accountId } }) .then((funds) => handleFunds(funds)) .catch(() => { - setFundStatus("error"); + setFundStatus(ProgressStatus.ERROR); }); } }, [coreSdk, accountId, handleFunds]); diff --git a/src/pages/chat/components/ExchangeSidePreview.tsx b/src/pages/chat/components/ExchangeSidePreview.tsx index 6f464f318..f274e444f 100644 --- a/src/pages/chat/components/ExchangeSidePreview.tsx +++ b/src/pages/chat/components/ExchangeSidePreview.tsx @@ -1,5 +1,6 @@ import { subgraph } from "@bosonprotocol/react-kit"; import dayjs from "dayjs"; +import { ArrowSquareOut } from "phosphor-react"; import { useCallback, useMemo } from "react"; import { generatePath } from "react-router-dom"; import styled from "styled-components"; @@ -7,7 +8,11 @@ import styled from "styled-components"; import DetailTable from "../../../components/detail/DetailTable"; import { DetailDisputeResolver } from "../../../components/detail/DetailWidget/DetailDisputeResolver"; import { DetailSellerDeposit } from "../../../components/detail/DetailWidget/DetailSellerDeposit"; -import { useModal } from "../../../components/modal/useModal"; +import { + ModalTypes, + ShowModalFn, + useModal +} from "../../../components/modal/useModal"; import Price from "../../../components/price"; import MultiSteps from "../../../components/step/MultiSteps"; import Button from "../../../components/ui/Button"; @@ -169,7 +174,24 @@ const HistorySection = styled(Section)` } `; -const getOfferDetailData = (offer: Offer) => { +const getOfferDetailData = ( + offer: Offer, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + modalTypes: ModalTypes, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + showModal: ShowModalFn +) => { + const handleShowExchangePolicy = () => { + if (modalTypes && showModal) { + showModal(modalTypes.EXCHANGE_POLICY_DETAILS, { + title: "Exchange Policy Details", + offerId: offer.id + }); + } else { + console.error("modalTypes and/or showModal undefined"); + } + }; + return [ { name: DetailSellerDeposit.name, @@ -189,7 +211,16 @@ const getOfferDetailData = (offer: Offer) => { ), - value: "Fair exchange policy" + value: ( + + Fair Exchange Policy{" "} + handleShowExchangePolicy()} + style={{ cursor: "pointer" }} + /> + + ) }, { name: DetailDisputeResolver.name, @@ -226,10 +257,10 @@ export default function ExchangeSidePreview({ ? disputes : [{} as subgraph.DisputeFieldsFragment]; const offer = exchange?.offer; - const { showModal } = useModal(); + const { showModal, modalTypes } = useModal(); const OFFER_DETAIL_DATA = useMemo( - () => offer && getOfferDetailData(offer), - [offer] + () => offer && getOfferDetailData(offer, modalTypes, showModal), + [offer, modalTypes, showModal] ); const navigate = useKeepQueryParamsNavigate(); diff --git a/src/pages/contractualAgreement/ContractualAgreement.tsx b/src/pages/contractualAgreement/ContractualAgreement.tsx new file mode 100644 index 000000000..e112891e9 --- /dev/null +++ b/src/pages/contractualAgreement/ContractualAgreement.tsx @@ -0,0 +1,63 @@ +import { useParams } from "react-router-dom"; +import styled from "styled-components"; + +import ContractualAgreementComponent from "../../components/contractualAgreement/ContractualAgreement"; +import Loading from "../../components/ui/Loading"; +import { UrlParameters } from "../../lib/routing/parameters"; +import useOffer from "../../lib/utils/hooks/offer/useOffer"; + +const Container = styled.div` + display: block; + overflow: auto; +`; + +export default function ContractualAgreement() { + const { [UrlParameters.offerId]: offerId } = useParams(); + + const { + data: offer, + isError, + isLoading + } = useOffer( + { + offerId: offerId || "" + }, + { enabled: !!offerId } + ); + + if (isLoading) { + return ; + } + + if (isError) { + return ( +
+ There has been an error, please try again later... +
+ ); + } + + if (!offer) { + return
This exchange does not exist
; + } + + if (!offer.isValid) { + return ( +
+ This offer does not match the expected metadata standard this + application enforces +
+ ); + } + + return ( + <> + + + + + ); +} diff --git a/src/pages/create-product/CreateProductInner.tsx b/src/pages/create-product/CreateProductInner.tsx index b469839a2..8226a3d55 100644 --- a/src/pages/create-product/CreateProductInner.tsx +++ b/src/pages/create-product/CreateProductInner.tsx @@ -121,20 +121,26 @@ function CreateProductInner({ initial }: Props) { id: offerInfo.id, createdAt: offerInfo.createdAt, price: offerInfo.price, - metadataHash: offerInfo.metadataHash, sellerDeposit: offerInfo.sellerDeposit, - resolutionPeriodDuration: offerInfo.resolutionPeriodDuration, - metadataUri: offerInfo.metadataUri, + protocolFee: offerInfo.protocolFee, + agentFee: offerInfo.agentFee, + agentId: offerInfo.agentId, buyerCancelPenalty: offerInfo.buyerCancelPenalty, quantityAvailable: offerInfo.quantityAvailable, quantityInitial: offerInfo.quantityInitial, - fulfillmentPeriodDuration: offerInfo.fulfillmentPeriodDuration, - voucherRedeemableUntilDate: `${offerInfo.voucherRedeemableUntilDate}`, validFromDate: offerInfo.validFromDate, - voidedAt: offerInfo.voidedAt, + validUntilDate: offerInfo.validUntilDate, + voucherRedeemableFromDate: offerInfo.voucherRedeemableFromDate, + voucherRedeemableUntilDate: offerInfo.voucherRedeemableUntilDate, + fulfillmentPeriodDuration: offerInfo.fulfillmentPeriodDuration, voucherValidDuration: offerInfo.voucherValidDuration, - exchangeToken: offerInfo.exchangeToken, - seller: offerInfo.seller + resolutionPeriodDuration: offerInfo.resolutionPeriodDuration, + metadataUri: offerInfo.metadataUri, + metadataHash: offerInfo.metadataHash, + voidedAt: offerInfo.voidedAt, + disputeResolverId: offerInfo.disputeResolverId, + seller: offerInfo.seller, + exchangeToken: offerInfo.exchangeToken }, // these are the ones that we already had before onCreateNewProject: onCreateNewProject, @@ -373,8 +379,10 @@ function CreateProductInner({ initial }: Props) { redemptionPeriod: coreTermsOfSale.redemptionPeriod }); - const resolutionPeriodDurationInMS = + const fulfillmentPeriodDurationInMS = parseInt(termsOfExchange.disputePeriod) * 24 * 3600 * 1000; // day to msec + const resolutionPeriodDurationInMS = + parseInt(CONFIG.defaultDisputeResolutionPeriodDays) * 24 * 3600 * 1000; // day to msec const offerData = { price: priceBN.toString(), sellerDeposit: sellerCancellationPenaltyValue.toString(), @@ -386,10 +394,10 @@ function CreateProductInner({ initial }: Props) { voucherValidDurationInMS: 0, validFromDateInMS: validFromDateInMS.toString(), validUntilDateInMS: validUntilDateInMS.toString(), - fulfillmentPeriodDurationInMS: resolutionPeriodDurationInMS.toString(), + fulfillmentPeriodDurationInMS: fulfillmentPeriodDurationInMS.toString(), resolutionPeriodDurationInMS: resolutionPeriodDurationInMS.toString(), exchangeToken: exchangeToken?.address || ethers.constants.AddressZero, - disputeResolverId: CONFIG.envName === "testing" ? 1 : 2, + disputeResolverId: CONFIG.defaultDisputeResolverId, agentId: 0, // no agent metadataUri: `ipfs://${metadataHash}`, metadataHash: metadataHash diff --git a/src/pages/license/License.tsx b/src/pages/license/License.tsx new file mode 100644 index 000000000..23b7d7b74 --- /dev/null +++ b/src/pages/license/License.tsx @@ -0,0 +1,74 @@ +import { useParams } from "react-router-dom"; +import styled from "styled-components"; + +import LicenseComponent from "../../components/license/License"; +import Loading from "../../components/ui/Loading"; +import { UrlParameters } from "../../lib/routing/parameters"; +import { useExchanges } from "../../lib/utils/hooks/useExchanges"; + +const Container = styled.div` + display: block; + overflow: auto; +`; + +export default function License() { + const { [UrlParameters.tokenId]: tokenId } = useParams(); + // The license is referring to a token (rNFT) identified by a tokenId (NFT convention) + // By convention, Boson Protocol uses the exchangeId as tokenId + const exchangeId = tokenId; + const { + data: exchanges, + isError, + isLoading + } = useExchanges( + { + id: exchangeId, + disputed: null + }, + { + enabled: !!exchangeId + } + ); + const exchange = exchanges?.[0]; + const offer = exchange?.offer; + + if (!exchangeId) { + return null; + } + + if (isLoading) { + return ; + } + + if (isError) { + return ( +
+ There has been an error, please try again later... +
+ ); + } + + if (!offer) { + return
This exchange does not exist
; + } + + if (!offer.isValid) { + return ( +
+ This offer does not match the expected metadata standard this + application enforces +
+ ); + } + + return ( + <> + + + + + ); +} diff --git a/src/router/routes.ts b/src/router/routes.ts index ae5837df2..030f9b6c7 100644 --- a/src/router/routes.ts +++ b/src/router/routes.ts @@ -29,6 +29,10 @@ const ProfilePagePage = lazy(() => import("../pages/profile/ProfilePage")); const PublicOrPrivateAccountPage = lazy( () => import("../pages/account/public/PublicOrPrivateAccount") ); +const LicensePage = lazy(() => import("../pages/license/License")); +const ContractualAgreementPage = lazy( + () => import("../pages/contractualAgreement/ContractualAgreement") +); export const baseAppProps = { withLayout: true, @@ -148,6 +152,16 @@ export default [ withBosonStyles: false } }, + { + ...base, + path: BosonRoutes.License, + component: LicensePage + }, + { + ...base, + path: BosonRoutes.ContractualAgreement, + component: ContractualAgreementPage + }, { ...base, path: BosonRoutes.Exchange, diff --git a/test/__mocks__/react-markdown.js b/test/__mocks__/react-markdown.js new file mode 100644 index 000000000..11d5938d6 --- /dev/null +++ b/test/__mocks__/react-markdown.js @@ -0,0 +1,8 @@ +// File created to fix incompatibility issue between Jest and react-markdown +// source: https://github.com/remarkjs/react-markdown/issues/635#issuecomment-956158474 + +function ReactMarkdown({ children }) { + return <>{children}; +} + +export default ReactMarkdown; diff --git a/test/__mocks__/rehype-raw.js b/test/__mocks__/rehype-raw.js new file mode 100644 index 000000000..25d83c207 --- /dev/null +++ b/test/__mocks__/rehype-raw.js @@ -0,0 +1,6 @@ +// File created to fix incompatibility issue between Jest and react-markdown +// source: https://github.com/remarkjs/react-markdown/issues/635#issuecomment-956158474 + +const rehypeRaw = {}; + +export default rehypeRaw; diff --git a/test/__mocks__/remark-gfm.js b/test/__mocks__/remark-gfm.js new file mode 100644 index 000000000..e3ed837e9 --- /dev/null +++ b/test/__mocks__/remark-gfm.js @@ -0,0 +1,6 @@ +// File created to fix incompatibility issue between Jest and react-markdown +// source: https://github.com/remarkjs/react-markdown/issues/635#issuecomment-956158474 + +const remarkGfm = {}; + +export default remarkGfm; diff --git a/styleMock.js b/test/__mocks__/styleMock.js similarity index 100% rename from styleMock.js rename to test/__mocks__/styleMock.js