From c26d3e48447fe6851f01ccab419a864f428ace28 Mon Sep 17 00:00:00 2001 From: Iveta Date: Wed, 21 Aug 2024 17:06:27 -0400 Subject: [PATCH] Lab v2 release (#963) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Next.js and other config * Add git-info * Static build * V2 Layout and basic page setup (#740) * Layout mostly done * Cleanup * Updated next.config.js * Delete extra folders * Remove trailingSlash config * Add console.log for testing * V2 Basic demo setup for state management (#741) * Layout mostly done * Cleanup * Updated next.config.js * Delete extra folders * Remove trailingSlash config * Add console.log for testing * Basic demo setup for state management * V2 Network selector (#742) * Network selector functional * Improved network dropdown functionality * Network selector done * Updated network links * Test PR to trigger PR preview for testing (#743) ### What Test PR to trigger PR preview for testing ### Why I need a way to test PR previews for laboratory-v2 ### Issue addressed by this PR https://github.com/stellar/ops/issues/2846 * V2 Intro page + some page placeholders (#744) * V2 Maintenance banner (#745) * V2 Add Playwright testing framework with initial tests (#748) * Updated dependencies * Playwright config + initial tests * Disable missingSuspenseWithCSRBailout * Replace class selector with testId * V2 Explore Endpoints: Horizon navigation and routes (#764) * V2 Explore Endpoints: routes + side navigation * Explore Endpoints landing page * Privacy Policy and Terms of Service links (#770) * Privacy Policy and Terms of Service links * Update font size * [wip] create account * [Account Routes] add routes for Account * updating styles * rename Account 'routes' * fix routes * updating scss to use 'gap' * fix * remove unused styling * Network switch update (#778) * Update network order * Fix test * Upgrade SDS * Add warning for futurenet * Explore Endpoints: Basic tabs view setup (#772) * Explore Endpoints: Params tab view * Picker components (#777) * RadioPicker * OrderPicker * IncludeFailedPicker * AssetPicker + PubKeyPicker * Update hover color + expand transition speed * Cleanup * Tweaks and cleanup * Cleanup * add component (#779) * Run `eslint:recommended` when committing (#787) * Creat and Fund Account Page (#788) * Explore Endpoints: Accounts Params view + template rendering setup (#789) * Explore Endpoints: data flow functional * Accounts endpoint done * Cleanup * Remove none option + update anim transition * Clean up input onChange methods * Require code and issuer for non-native assets * Text updates * Fix tests * use @stellar/stellar-sdk (#795) * Explore Endpoints submit and response (#797) * Explore Endpoints: submit + json response * Cleanup * Fix reset query on change and submit + PrettyJson unique keys * Box component + tweak ExpandBox (#800) * Use Node v20 + updated dependencies (#803) * Minor dep updates * Use Node v20 * [Account] create and parse muxed account (#794) * Explore Endpoints: pages part 1 (#805) * All Assets * Claimable Balances * Effects + refactor endpoint URL template * Fee Stats * Ledgers * Offers * Operations * Fix positiveInt validation when changing routes * update husky's lintstagedrc and linting rule (#804) * Explore Endpoints: pages part 2 (#807) * All Assets * Claimable Balances * Effects + refactor endpoint URL template * Fee Stats * Ledgers * Offers * Operations * Payments * Transactions * Update SDS * Order book + asset object params * Trade aggregations * Fix PrettyJson records rendering * Trades * Cleanup * Cleanup * Fix linting * Explore Endpoints: pages part 3 (#809) * All Assets * Claimable Balances * Effects + refactor endpoint URL template * Fee Stats * Ledgers * Offers * Operations * Payments * Transactions * Update SDS * Order book + asset object params * Trade aggregations * Fix PrettyJson records rendering * Trades * Cleanup * Paths * Liquidity pools * Fix URL validation * Cleanup * Update reserves asset type * Cleanup * Don't hard-code component IDs * Endpoints tests (#811) * All Assets * Claimable Balances * Effects + refactor endpoint URL template * Fee Stats * Ledgers * Offers * Operations * Payments * Transactions * Update SDS * Order book + asset object params * Trade aggregations * Fix PrettyJson records rendering * Trades * Cleanup * Paths * Liquidity pools * Fix URL validation * Cleanup * Update reserves asset type * Cleanup * Endpoints tests * Update asset validation * openUrl helper * Renamed Explore Endpoints to Endpoints (#813) * Renamed Explore Endpoints to Endpoints * Rename View XDR to XDR * adding tests for create and fund account (#808) * [Build Transaction] Attributes view UI only (without input values and validation) (#825) * Build transaction: basic tabs setup * Attributes UI done * Update button label * Rename Attributes to Params * [Sign TX] Input Overview View (#826) * PrettyJson theme + updated network accent colors (#830) * Update network accent colors * PrettyJson theme updated * [Create Account] Fund account with Friend button behavior (#827) * [Build Transaction] Params input and validation + encode JSON to XDR (#832) * Transaction: build params validation + XDR * Add temp Stellar XDR package locally * Moved temp into src * Fix build * XDR works * Cleanup * Rename GH Action + remove BigNumber.js * Rename GH action job to build * [Build Transaction] Basic Operations layout + button actions (#836) * Clear params btn + extended Box component * Basic operations layout + buttons with action * [Build Transaction] Operations setup + create account op (#840) * [Build Transaction] Added operations (#843) * Operation type description + docs URL * Payment operation * Manage buy and sell operations * Create Passive Sell Offer operation * Update maintenance banner (#846) * [Build Transaction] Add more operations (#844) * Operation type description + docs URL * Payment operation * Manage buy and sell operations * Create Passive Sell Offer operation * Account Merge operation * Manage Data operation * Bump Sequence operation * Claim Claimable Balance operation * Begin and End Sponsoring Future Reserves operations * [sign tx] add signing with secrets and ValidationResponseCard (#839) * [Build Transaction] More operations pt. 4 (#847) * Operation type description + docs URL * Payment operation * Manage buy and sell operations * Create Passive Sell Offer operation * Account Merge operation * Manage Data operation * Bump Sequence operation * Claim Claimable Balance operation * Begin and End Sponsoring Future Reserves operations * Clawback operation * Clawback Claimable Balance operation * Path Payment Strict Send operation * Path Payment Strict Receive operation * [Sign Transaction] Enable persisting data on page refresh (#850) * [Build Transaction] Set Options operation (#851) * Operation type description + docs URL * Payment operation * Manage buy and sell operations * Create Passive Sell Offer operation * Account Merge operation * Manage Data operation * Bump Sequence operation * Claim Claimable Balance operation * Begin and End Sponsoring Future Reserves operations * Clawback operation * Clawback Claimable Balance operation * Path Payment Strict Send operation * Path Payment Strict Receive operation * Set Options operation * Fix signer key encoding * [Sign Tx] Integrate with 'stellar-wallets-kit' (#852) * Update GitHub Action packages (#854) * [Build Transaction] Change Trust operation (#853) * Change Trust operation * Use string value * [Build Transaction] Allow Trust operation (#856) * Allow Trust operation * Cleanup * Use @stellar/stellar-xdr-json-web package and remove temp files (#863) * [Sign Tx] Add a sign with hardware wallets (trezor, ledger) (#859) * [Build Transaction] Liquidity Pool Deposit and Withdraw (#857) * Change Trust operation * Allow Trust operation * Cleanup * Liquidity Pool Deposit and Withdraw * [Build Transaction] Set Trust Line Flags + Revoke Sponsorship operations (#858) * Set Trust Line Flags operation * Revoke Sponsorship operation * [Build Transaction] Create Claimable Balance operation (#861) * Create Claimable Balance operation * Cleanup * Cleanup * [UI] Display commit hash + 404 page design (#865) * Display commit hash * 404 page design * Save commit hash in env var instead of file * Use .env.local * Update scripts * Another test * Another experiment * Tweak Docker config * Cleanup * [View XDR] UI + decoded JSON (#876) * Link "Sign in Transaction Signer" button to "Sign Transaction" page (#875) * Update XDR validation + show error message on View XDR page (#877) * Update XDR validation + show error message on View XDR page * Update XDR validation + show error message on View XDR page * [Submit Tx] Add a Submit Tx Page (#879) * Updated dependencies + CSP middleware configuration (#884) * Minor updates * Configure CSP * Tweaks * [View XDR] XDR Type dropdown with search + remove custom key for zustand-querystring (#882) * XDR type search select * Use default key in zustand-querystring * Update test * Text update + copy JSON button * Fix clawback claimable balance operation (#887) * [XDR] JSON To XDR (#886) * XDR type search select * Use default key in zustand-querystring * Update test * Text update + copy JSON button * To XDR * Add Fee Bump Tx (#888) * [Endpoints] Saved Endpoints (#892) * Wider content + updated transaction base fee note (#896) * Make content width wider * Update txn base fee note text * Fix assetMulti validation * [Transactions] Saved Transactions (#895) * Saved Horizon Endpoints * XDR: prettify copy JSON * Fix tests * Save transactions * Temp disable tests in pre-push * Some cleanup * Enable prefetch for links * Put back pre-push test * Update saved endpoints layout * Update src/app/(sidebar)/transaction/saved/page.tsx Co-authored-by: jeesun 지선 --------- Co-authored-by: jeesun 지선 * Maintenance banner: update loading state (#898) * Maintenance banner: update loading state * Replace loader * Temp: test beta website (#902) * Small tweaks (#901) * Small tweaks * Update button variant * [RPC Endpoints] (#897) * enable Rpc Url input in network selector * Fix design issues 737 (#914) * Update src/components/NetworkSelector/index.tsx Co-authored-by: Nando Vieira * Rename validate methods function (#919) * [Fund Account] switch network page on mainnet (#917) * V2: undo beta test (#905) * ThemeSwitch: fix state on page load (#931) * [Navigation] Utilize vertical space and add subnavigation for endpoints (#930) * enable switch button when rpc url is different on mainnet (#920) * UI tweaks (#932) * Action button tooltip * Remove main nav link underline * Upgrade SDS * Use custom icon + CSS cleanup * [Rpc endpoint] Bug fixes (#911) * Simulate Transaction page (#934) * Network: persist mainnet RPC URL * XDR: fix large number parsing in JSON (#953) * XDR: update labels (#954) * UI tweaks (#945) * Updated readme * Added GitHub links * Update main nav link order + allow Wallet Kit img source in CSP * Don't show nothing scheduled maintenance banner * Adjust Network selector max-width * Rename nav items + endpoints expand by default * MultiPicker: delete function + button variant update * Fix test * Update link + rename Stellar RPC * Fix test * Fix another test * Submit Transaction using RPC (#941) * Submit Transaction using RPC * Reset response on input change * Add diagnosticEvents output * Remove unused file * Submit Transaction: Simulate and Save transaction buttons (#943) * Submit Transaction using RPC * Reset response on input change * Add diagnosticEvents output * Submit Transaction: Simulate transaction button * Update Payments for Transaction info link * delayedAction helper + XDR type const + Sign Tx View XDR button * Sign tx Fee Bump button * Updated saved transaction logic + save tx on Submit Transaction page * Resolved merge conflicts * Update SEO + rename laboratory to lab (#955) * Resolve conflicts with master branch (#960) * correct a link on the endpoint explorer to Horizon API documentation * Improve Soroban XDR rendering (#746) * Upgrade to TypeScript v5 (#760) * XDR: fix contract ID and type rendering (#761) * XDR: fix scvVec rendering (#763) * display the correct soroban network (#796) * Add option to sign transaction hash with Ledger device (#838) * Upgrade @stellar/stellar-sdk to v12.0.0-rc.1 (#841) * Upgrade stellar/stellar-sdk to v12.0.0-rc.1 * Use Node v18 in GH action * Dependency updates (#878) * Temp: beta test v1 (#903) * V1: undo beta test (#904) * Remove CLA reference from contributing document (#958) * Remove CLA reference from contributing document * Update CONTRIBUTING.md --------- Co-authored-by: Elliot Voris Co-authored-by: jeesun 지선 Co-authored-by: Leigh McCulloch <351529+leighmcculloch@users.noreply.github.com> * Endpoints: handle JSON response links (#956) * Endpoints: JSON response account + XDR custom links * JSON response links * Do not reset Endpoints for XDR links * No need to clear errors * Use href instead onClick * Use href instead onClick * Trigger PR preview * Cleanup test * Final tweaks (#962) * correct a link on the endpoint explorer to Horizon API documentation * Improve Soroban XDR rendering (#746) * Upgrade to TypeScript v5 (#760) * XDR: fix contract ID and type rendering (#761) * XDR: fix scvVec rendering (#763) * display the correct soroban network (#796) * Add option to sign transaction hash with Ledger device (#838) * Upgrade @stellar/stellar-sdk to v12.0.0-rc.1 (#841) * Upgrade stellar/stellar-sdk to v12.0.0-rc.1 * Use Node v18 in GH action * Dependency updates (#878) * Temp: beta test v1 (#903) * V1: undo beta test (#904) * Remove CLA reference from contributing document (#958) * Remove CLA reference from contributing document * Update CONTRIBUTING.md * Final tweaks --------- Co-authored-by: Elliot Voris Co-authored-by: jeesun 지선 Co-authored-by: Leigh McCulloch <351529+leighmcculloch@users.noreply.github.com> --------- Co-authored-by: jacekn Co-authored-by: Jeesun Kim Co-authored-by: Jeesun Kim Co-authored-by: jeesun 지선 Co-authored-by: Nando Vieira Co-authored-by: Jane Wang Co-authored-by: Elliot Voris Co-authored-by: Leigh McCulloch <351529+leighmcculloch@users.noreply.github.com> --- .babelrc | 14 - .eslintignore | 6 - .eslintrc.js | 75 - .eslintrc.json | 15 + .github/workflows/build.yml | 19 + .github/workflows/test-build.yml | 13 - .gitignore | 31 +- .husky/post-merge | 1 + .husky/pre-commit | 1 + .husky/pre-push | 1 + .lintstagedrc.js | 14 + .nvmrc | 2 +- .prettierignore | 5 + .prettierrc.json | 12 + Dockerfile | 33 +- Makefile | 6 +- README.md | 46 +- babel.config.js | 22 - docs.md | 40 - jest.config.js | 6 - next.config.js | 9 + nginx.conf | 23 + nginx_default.conf | 17 - package.json | 163 +- playwright.config.ts | 86 + prettier.config.js | 3 - public/favicon.ico | Bin 7406 -> 0 bytes public/logo192.png | Bin 3843 -> 0 bytes public/logo512.png | Bin 11240 -> 0 bytes public/manifest.json | 25 - public/robots.txt | 3 - public/settings/env-config.js | 3 - setupJest.js | 1 - src/App.tsx | 17 - src/actions/accountCreator.js | 132 - src/actions/endpointExplorer.js | 98 - src/actions/network.js | 46 - src/actions/routing.js | 16 - src/actions/transactionBuilder.js | 132 - src/actions/transactionSigner.js | 204 - src/actions/xdrViewer.js | 158 - src/app/(sidebar)/account/create/page.tsx | 153 + .../account/fund/components/SwitchNetwork.tsx | 60 + src/app/(sidebar)/account/fund/page.tsx | 151 + src/app/(sidebar)/account/layout.tsx | 39 + .../(sidebar)/account/muxed-create/page.tsx | 184 + .../(sidebar)/account/muxed-parse/page.tsx | 145 + src/app/(sidebar)/account/styles.scss | 77 + .../(sidebar)/endpoints/[[...pages]]/page.tsx | 928 ++ .../components/EndpointsJsonResponse.tsx | 393 + .../components/EndpointsLandingPage.tsx | 68 + .../components/SavedEndpointsPage.tsx | 265 + src/app/(sidebar)/endpoints/layout.tsx | 50 + src/app/(sidebar)/layout.tsx | 6 + src/app/(sidebar)/smart-contracts/layout.tsx | 21 + src/app/(sidebar)/smart-contracts/page.tsx | 5 + .../build/components/Operations.tsx | 1112 ++ .../transaction/build/components/Params.tsx | 414 + .../build/components/TransactionXdr.tsx | 594 + src/app/(sidebar)/transaction/build/page.tsx | 39 + .../(sidebar)/transaction/fee-bump/page.tsx | 310 + src/app/(sidebar)/transaction/layout.tsx | 56 + src/app/(sidebar)/transaction/saved/page.tsx | 248 + .../transaction/sign/components/Import.tsx | 109 + .../transaction/sign/components/Overview.tsx | 476 + .../sign/components/SignWithWallet.tsx | 87 + src/app/(sidebar)/transaction/sign/page.tsx | 17 + .../(sidebar)/transaction/simulate/page.tsx | 164 + .../submit/components/ErrorResponse.tsx | 132 + src/app/(sidebar)/transaction/submit/page.tsx | 223 + src/app/(sidebar)/xdr/layout.tsx | 31 + src/app/(sidebar)/xdr/to/page.tsx | 134 + src/app/(sidebar)/xdr/view/page.tsx | 187 + src/app/apple-icon.png | Bin 0 -> 2580 bytes src/app/favicon.ico | Bin 0 -> 4286 bytes src/app/icon.svg | 8 + src/app/icon1.png | Bin 0 -> 2667 bytes src/app/icon2.png | Bin 0 -> 7608 bytes src/app/layout.tsx | 39 + src/app/not-found.tsx | 45 + src/app/page.tsx | 127 + src/assets/suisseintl-regular-webfont.woff | Bin 27840 -> 0 bytes src/assets/suisseintl-regular-webfont.woff2 | Bin 21740 -> 0 bytes src/assets/suisseintl-semibold-webfont.woff | Bin 27948 -> 0 bytes src/assets/suisseintl-semibold-webfont.woff2 | Bin 21888 -> 0 bytes .../suisseintlmono-regular-webfont.woff | Bin 25480 -> 0 bytes .../suisseintlmono-regular-webfont.woff2 | Bin 19068 -> 0 bytes src/components/CodeBlock.tsx | 37 - src/components/Collapsible.js | 24 - src/components/EasySelect.tsx | 20 - src/components/EndpointPicker.tsx | 120 - src/components/EndpointResult.tsx | 57 - src/components/EndpointSetup.tsx | 120 - src/components/ExpandBox/index.tsx | 46 + src/components/ExpandBox/styles.scss | 57 + src/components/Footer.tsx | 21 - src/components/FormComponents/AmountPicker.js | 21 - .../FormComponents/AssetMultiPicker.js | 73 - src/components/FormComponents/AssetPicker.js | 293 - .../FormComponents/BipPathPicker.tsx | 29 - .../FormComponents/BooleanPicker.js | 17 - .../FormComponents/CheckboxButtonPicker.js | 59 - .../FormComponents/ClaimantPicker.js | 344 - .../FormComponents/FlagfieldPicker.js | 81 - src/components/FormComponents/LedgerPicker.js | 11 - .../LiquidityPoolAssetPicker.tsx | 76 - .../FormComponents/LiquidityPoolId.tsx | 15 - .../FormComponents/ManualMultiPicker.js | 77 - src/components/FormComponents/MemoPicker.js | 94 - src/components/FormComponents/MultiPicker.tsx | 94 - .../FormComponents/MuxedKeyPicker.tsx | 54 - .../FormComponents/NumberFractionPicker.tsx | 86 - .../FormComponents/OperationPicker.js | 14 - .../FormComponents/OperationTypePicker.tsx | 25 - src/components/FormComponents/OrderPicker.js | 17 - src/components/FormComponents/PickerError.js | 13 - .../FormComponents/PositiveIntPicker.js | 21 - .../FormComponents/PositiveNumberPicker.js | 21 - .../FormComponents/PubKeyPicker.tsx | 58 - .../FormComponents/RadioButtonPicker.js | 42 - .../FormComponents/RevokeSponsorshipPicker.js | 196 - .../FormComponents/SecretKeyPicker.js | 28 - .../FormComponents/SelectPicker.tsx | 67 - .../FormComponents/SequencePicker.js | 14 - src/components/FormComponents/SignerPicker.js | 90 - .../FormComponents/StroopsPicker.js | 14 - src/components/FormComponents/TextPicker.js | 33 - .../FormComponents/TimeBoundsPicker.js | 34 - .../FormComponents/TimestampPicker.js | 14 - .../FormComponents/TransactionPicker.js | 31 - src/components/FormComponents/TxTypePicker.js | 24 - .../FormComponents/Unsigned8bitIntPicker.js | 16 - src/components/FormComponents/XdrPicker.js | 28 - .../FormElements/AssetMultiPicker.tsx | 235 + src/components/FormElements/AssetPicker.tsx | 234 + .../FormElements/AuthorizePicker.tsx | 33 + .../FormElements/ClaimantsPicker.tsx | 642 + src/components/FormElements/CursorPicker.tsx | 35 + src/components/FormElements/FiltersPicker.tsx | 98 + .../FormElements/FlagFieldPicker.tsx | 88 + .../FormElements/IncludeFailedPicker.tsx | 28 + src/components/FormElements/LimitPicker.tsx | 35 + .../FormElements/LiquidityPoolShares.tsx | 77 + src/components/FormElements/MemoPicker.tsx | 97 + src/components/FormElements/MultiPicker.tsx | 98 + .../FormElements/NumberFractionPicker.tsx | 131 + src/components/FormElements/OrderPicker.tsx | 28 + .../FormElements/PositiveIntPicker.tsx | 43 + src/components/FormElements/PubKeyPicker.tsx | 40 + .../FormElements/RevokeSponsorshipPicker.tsx | 294 + src/components/FormElements/SignerPicker.tsx | 129 + src/components/FormElements/TextPicker.tsx | 41 + .../FormElements/TimeBoundsPicker.tsx | 100 + src/components/FormElements/XdrPicker.tsx | 50 + src/components/FriendBot/ErrorMsg.tsx | 21 + src/components/FriendBot/SuccessMsg.tsx | 39 + src/components/GenerateKeypair.tsx | 40 + src/components/Header.tsx | 28 - src/components/HelpMark.js | 36 - src/components/Hydration.tsx | 14 + src/components/ImportMark.js | 17 - src/components/InfoCards/index.tsx | 32 + src/components/InfoCards/styles.scss | 20 + src/components/InputSideElement/index.tsx | 67 + src/components/InputSideElement/styles.scss | 52 + src/components/LoadingView.tsx | 43 - src/components/MainNav.tsx | 78 + src/components/MaintenanceBanner.tsx | 151 +- src/components/MuxedAccountResult.tsx | 50 + src/components/Navigation.tsx | 63 - src/components/NetworkIndicator/index.tsx | 20 + src/components/NetworkIndicator/styles.scss | 34 + src/components/NetworkSelector/index.tsx | 398 + src/components/NetworkSelector/styles.scss | 149 + src/components/NextLink.tsx | 28 + src/components/NotFoundPage.tsx | 9 - src/components/OperationPanes/AccountMerge.js | 17 - src/components/OperationPanes/AllowTrust.js | 44 - .../BeginSponsoringFutureReserves.js | 17 - src/components/OperationPanes/BumpSequence.js | 17 - src/components/OperationPanes/ChangeTrust.js | 33 - .../OperationPanes/ClaimClaimableBalance.js | 17 - src/components/OperationPanes/Clawback.js | 36 - .../ClawbackClaimableBalance.js | 17 - .../OperationPanes/CreateAccount.js | 26 - .../OperationPanes/CreateClaimableBalance.js | 39 - .../EndSponsoringFutureReserves.js | 3 - src/components/OperationPanes/GenericOffer.js | 56 - .../OperationPanes/LiquidityPoolDeposit.tsx | 68 - .../OperationPanes/LiquidityPoolWithdraw.tsx | 51 - .../OperationPanes/ManageBuyOffer.js | 23 - src/components/OperationPanes/ManageData.js | 45 - .../OperationPanes/ManageSellOffer.js | 23 - .../PathPaymentStrictReceive.js | 73 - .../OperationPanes/PathPaymentStrictSend.js | 69 - src/components/OperationPanes/Payment.js | 35 - .../OperationPanes/RevokeSponsorship.js | 13 - src/components/OperationPanes/SetOptions.js | 234 - .../OperationPanes/SetTrustLineFlags.js | 69 - src/components/OptionsTable/Pair.js | 21 - src/components/PrettyJson/index.tsx | 256 + src/components/PrettyJson/styles.scss | 47 + src/components/RadioPicker/index.tsx | 86 + src/components/RadioPicker/styles.scss | 114 + src/components/SaveTransactionModal.tsx | 153 + src/components/SdsLink.tsx | 14 + src/components/SetupPanes/Accounts.js | 70 - src/components/SetupPanes/All.js | 42 - src/components/SetupPanes/AllAssets.js | 32 - .../SetupPanes/AllLiquidityPools.tsx | 59 - src/components/SetupPanes/AllOffers.js | 82 - src/components/SetupPanes/AllWithFailed.js | 53 - .../SetupPanes/ClaimableBalances.js | 70 - src/components/SetupPanes/FindPaymentPaths.js | 45 - .../FindStrictReceivePaymentPaths.js | 53 - .../SetupPanes/FindStrictSendPaymentPaths.js | 54 - src/components/SetupPanes/For.js | 57 - src/components/SetupPanes/ForAccount.js | 21 - .../SetupPanes/ForAccountWithFailed.js | 21 - src/components/SetupPanes/ForLedger.js | 18 - .../SetupPanes/ForLedgerWithFailed.js | 21 - .../SetupPanes/ForLiquidityPool.tsx | 23 - .../SetupPanes/ForLiquidityPoolWithFailed.tsx | 25 - src/components/SetupPanes/ForOffer.js | 19 - src/components/SetupPanes/ForOperation.js | 18 - src/components/SetupPanes/ForTransaction.js | 18 - src/components/SetupPanes/OrderBookDetails.js | 26 - src/components/SetupPanes/PostTransaction.js | 19 - src/components/SetupPanes/SingleAccount.js | 18 - .../SetupPanes/SingleClaimableBalance.js | 18 - src/components/SetupPanes/SingleLedger.js | 18 - .../SetupPanes/SingleLiquidityPool.tsx | 21 - src/components/SetupPanes/SingleOffer.js | 17 - src/components/SetupPanes/SingleOperation.js | 18 - .../SetupPanes/SingleTransaction.js | 18 - .../SetupPanes/TradeAggregations.js | 69 - src/components/SetupPanes/Trades.js | 61 - src/components/SorobanBanner.tsx | 23 - src/components/TabView/index.tsx | 115 + src/components/TabView/styles.scss | 20 + src/components/TabbedButtons/index.tsx | 45 + src/components/TabbedButtons/styles.scss | 39 + src/components/Tabs/index.tsx | 31 + src/components/Tabs/styles.scss | 37 + src/components/TransactionImporter.js | 75 - src/components/TreeView.tsx | 284 - src/components/TxResponse/index.tsx | 18 + src/components/TxResponse/styles.scss | 7 + src/components/TxSubmitterResult.tsx | 277 - .../ValidationResponseCard/index.tsx | 98 + .../ValidationResponseCard/styles.scss | 39 + src/components/ViewInXdrButton.tsx | 25 + src/components/WithInfoText/index.tsx | 58 + src/components/WithInfoText/styles.scss | 34 + src/components/XdrTypeSelect/index.tsx | 137 + src/components/XdrTypeSelect/styles.scss | 68 + .../formComponentTemplateEndpoints.tsx | 730 + .../formComponentTemplateTxnOps.tsx | 664 + src/components/layout/Box/index.tsx | 46 + src/components/layout/Box/styles.scss | 34 + .../layout/LayoutContentContainer.tsx | 11 + src/components/layout/LayoutMain.tsx | 40 + .../layout/LayoutSidebarContent.tsx | 200 + src/components/layout/LayoutWithSidebar.tsx | 7 + src/config/store.ts | 49 - src/constants/endpointsPages.ts | 998 ++ src/constants/fetched_signers.ts | 9 - src/constants/network.js | 20 - src/constants/routes.ts | 83 + src/constants/settings.ts | 119 +- src/constants/signTransactionPage.ts | 62 + src/constants/signature.ts | 7 - src/constants/slug.js | 12 - src/constants/transactionOperations.tsx | 430 + src/constants/transaction_types.js | 10 - src/constants/xdr.ts | 4 + src/data/endpoints.ts | 602 - src/data/operations.ts | 232 - src/helpers/Libify.js | 939 -- src/helpers/StellarXdr.ts | 17 + src/helpers/arrayItem.ts | 82 + src/helpers/buildRequest.ts | 41 - src/helpers/buildRequestUrl.ts | 101 - src/helpers/capitalizeString.ts | 2 + src/helpers/claimantHelpers.js | 258 - src/helpers/clickToSelect.ts | 15 - .../convertMuxedAccountToEd25519Account.js | 11 - src/helpers/delay.ts | 3 + src/helpers/delayedAction.ts | 12 + src/helpers/detectXdrType.js | 0 src/helpers/dispatchInNewStack.js | 9 - src/helpers/extrapolateFromXdr.js | 238 - src/helpers/fetchMaintenanceData.ts | 12 - src/helpers/formatTimestamp.ts | 14 + src/helpers/getEndpointTemplate.ts | 11 - src/helpers/getRelevantMaintenanceMsg.ts | 20 + src/helpers/getResourceEndpoints.ts | 11 - src/helpers/getSaveItemNetwork.ts | 22 + src/helpers/horizonUrlParser.js | 145 - src/helpers/hydration.js | 18 - src/helpers/inputNumberValue.ts | 7 + src/helpers/isEmptyObject.ts | 5 + src/helpers/isMaintenanceRelevant.ts | 20 - src/helpers/isValidUrl.ts | 12 + src/helpers/linkBuilder.js | 97 - src/helpers/linkHighlighterRules.js | 35 - .../localStorageSavedEndpointsHorizon.ts | 22 + src/helpers/localStorageSavedNetwork.ts | 22 + src/helpers/localStorageSavedTransactions.ts | 22 + src/helpers/metrics.js | 64 - src/helpers/muxedAccount.ts | 57 + src/helpers/networkLocalStorage.ts | 22 - src/helpers/openUrl.ts | 3 + src/helpers/optionsFlagDetails.ts | 18 + src/helpers/parseJsonString.ts | 11 + src/helpers/parseToLosslessJson.ts | 12 + src/helpers/prism-jsonLinkHighlighter.js | 94 - src/helpers/prism.js | 473 - src/helpers/sanitizeArray.ts | 3 + src/helpers/sanitizeHtml.ts | 12 +- src/helpers/sanitizeObject.ts | 19 + src/helpers/scrollOnAnchorOpen.js | 43 - src/helpers/shortenStellarAddress.ts | 7 + src/helpers/simpleRouter.js | 87 - src/helpers/sorobanXdrUtils.ts | 78 - src/helpers/stateSerializer.js | 149 - src/helpers/testHelpers.tsx | 377 - src/helpers/trim.ts | 3 + src/helpers/txHelper.ts | 285 + src/helpers/useFreighter.js | 26 - src/helpers/validateBase64.ts | 19 - src/helpers/validateTxXdr.ts | 27 - src/helpers/xdr/fraction.ts | 42 + src/helpers/xdr/utils.ts | 36 + src/hooks/useIsSoroban.ts | 19 - src/hooks/useIsTestingNetwork.ts | 7 + src/hooks/useIsXdrInit.ts | 18 + src/hooks/usePrevious.ts | 11 + src/hooks/useRedux.ts | 29 - src/index.html | 21 - src/index.tsx | 4 - src/localStorage.js | 20 - src/metricsHandlers/README.md | 92 - src/metricsHandlers/accountCreator.js | 49 - src/metricsHandlers/endpointExplorer.js | 81 - src/metricsHandlers/network.js | 17 - src/metricsHandlers/routing.js | 17 - src/metricsHandlers/transactionBuilder.js | 69 - src/metricsHandlers/transactionSigner.js | 68 - src/metricsHandlers/xdrViewer.js | 17 - src/middleware.ts | 68 + src/middleware/metrics.js | 8 - src/query/QueryProvider.tsx | 23 + src/query/useAccountSequenceNumber.ts | 46 + src/query/useEndpoint.ts | 55 + src/query/useFriendBot.ts | 59 + src/query/useLatestTxn.ts | 24 + src/query/useMaintenanceData.ts | 22 + src/query/useSimulateTx.ts | 62 + src/query/useSubmitRpcTx.ts | 73 + src/react-app-env.d.ts | 1 - src/reducers/accountCreator.js | 111 - src/reducers/endpointExplorer.js | 137 - src/reducers/network.js | 68 - src/reducers/routing.js | 21 - src/reducers/transactionBuilder.js | 235 - src/reducers/transactionSigner.js | 155 - src/reducers/xdrViewer.js | 64 - src/setupTests.ts | 6 - src/store/StoreProvider.tsx | 23 + src/store/createStore.ts | 529 + src/store/useStore.ts | 13 + src/styles/_AccountCreator.scss | 31 - src/styles/_ClaimantPicker.scss | 41 - src/styles/_CodeBlock.scss | 6 - src/styles/_Collapsible.scss | 9 - src/styles/_EasySelect.scss | 7 - src/styles/_EndpointExplorer.scss | 14 - src/styles/_EndpointPicker.scss | 24 - src/styles/_EndpointResult.scss | 67 - src/styles/_EndpointSetup.scss | 23 - src/styles/_HelpMark.scss | 15 - src/styles/_Introduction.scss | 10 - src/styles/_LaboratoryChrome.scss | 43 - src/styles/_ManualMultiPicker.scss | 29 - src/styles/_MultiPicker.scss | 5 - src/styles/_NetworkPicker.scss | 89 - src/styles/_PubKeyPicker.scss | 19 - src/styles/_Reskin.scss | 142 - src/styles/_ReskinColors.scss | 6 - src/styles/_SimplePage.scss | 4 - src/styles/_TransactionBuilder.scss | 110 - src/styles/_TransactionSigner.scss | 27 - src/styles/_TreeView.scss | 18 - src/styles/_TxFreighterSign.scss | 23 - src/styles/_TxSignerImport.scss | 10 - src/styles/_TxSignerKeys.scss | 14 - src/styles/_TxSignerOverview.scss | 22 - src/styles/_TxSignerResult.scss | 19 - src/styles/_XdrViewer.scss | 35 - src/styles/_optionsTable.scss | 54 - src/styles/_pageIntro.scss | 11 - src/styles/_picker.scss | 26 - src/styles/_simpleTable.scss | 41 - src/styles/_xdrInput.scss | 28 - src/styles/globals.scss | 627 + src/styles/main.scss | 58 - src/styles/prism.css | 236 - src/styles/solar-css/lib/_index.scss | 12 - src/styles/solar-css/lib/_layout.flex.scss | 57 - src/styles/solar-css/lib/_respond.media.scss | 31 - src/styles/solar-css/lib/_scale.scss | 161 - src/styles/solar-css/lib/_theme.colors.scss | 54 - .../solar-css/lib/_theme.variables.scss | 5 - src/styles/solar-css/lib/_webapp.base.scss | 45 - .../styles/_base.basic-elements.scss | 8 - .../solar-css/styles/_base.border-box.scss | 6 - .../solar-css/styles/_base.normalize.scss | 424 - src/styles/solar-css/styles/_base.page.scss | 6 - .../solar-css/styles/_components.alerts.scss | 43 - .../solar-css/styles/_elements.links.scss | 5 - src/styles/solar-css/styles/_forms.base.scss | 23 - .../solar-css/styles/_forms.buttonGroup.scss | 108 - .../solar-css/styles/_forms.buttons.scss | 24 - .../solar-css/styles/_forms.inputGroup.scss | 49 - src/styles/solar-css/styles/_index.scss | 33 - src/styles/solar-css/styles/_layout.flex.scss | 45 - .../solar-css/styles/_lists.buttonList.scss | 27 - .../solar-css/styles/_lists.inlineList.scss | 17 - .../styles/_theme-starter.index.scss | 153 - .../solar-css/styles/_typography.base.scss | 21 - .../solar-css/styles/_webapp.index.scss | 23 - src/styles/utils.scss | 12 + src/types/types.ts | 350 +- src/validate/index.ts | 51 + .../methods/getAccountThresholdError.ts | 15 + src/validate/methods/getAmountError.ts | 11 + .../methods/getArrayOfStringsError.ts | 22 + src/validate/methods/getAssetCodeError.ts | 36 + src/validate/methods/getAssetError.ts | 60 + src/validate/methods/getAssetMultiError.ts | 35 + src/validate/methods/getBipPathError.ts | 10 + .../methods/getClaimableBalanceIdError.ts | 8 + src/validate/methods/getClaimaintsError.ts | 72 + src/validate/methods/getContractIdError.ts | 11 + src/validate/methods/getDataNameError.ts | 7 + src/validate/methods/getDataValueError.ts | 9 + src/validate/methods/getEventsFiltersError.ts | 43 + src/validate/methods/getMemoError.ts | 53 + .../methods/getNumberFractionError.ts | 27 + src/validate/methods/getOptionsSignerError.ts | 41 + src/validate/methods/getPositiveIntError.ts | 9 + .../methods/getPositiveNumberError.ts | 9 + src/validate/methods/getPublicKeyError.ts | 21 + .../methods/getRevokeSponsorshipError.ts | 68 + src/validate/methods/getSecretKeyError.ts | 15 + src/validate/methods/getTimeBoundsError.ts | 17 + .../methods/getTransactionHashError.ts | 11 + src/validate/methods/getXdrError.ts | 44 + src/views/AccountCreator.tsx | 21 - src/views/AppContent.tsx | 104 - src/views/EndpointExplorer.tsx | 77 - src/views/FriendbotFundAccount.tsx | 106 - src/views/Introduction.tsx | 35 - src/views/KeypairGenerator.tsx | 83 - src/views/MuxedAccount.tsx | 211 - src/views/NetworkPicker.js | 152 - src/views/OperationsBuilder.js | 193 - src/views/TransactionBuilder.js | 105 - src/views/TransactionSigner.tsx | 516 - src/views/TransactionSubmitter.tsx | 116 - src/views/TxBuilderAttributes.js | 352 - src/views/TxBuilderResult.js | 168 - src/views/XdrViewer.tsx | 149 - src/views/__tests__/AccountCreator.test.tsx | 138 - src/views/__tests__/AppContent.test.tsx | 63 - src/views/__tests__/EndpointExplorer.test.tsx | 2128 --- src/views/__tests__/Introduction.test.tsx | 12 - .../__tests__/TransactionSigner.test.tsx | 265 - .../__tests__/TransactionSubmitter.test.tsx | 419 - src/views/__tests__/XdrViewer.test.tsx | 76 - src/views/__tests__/__mocks__/transactions.ts | 9 - test/mocha.opts | 1 - test/smoke/routingRoundTrip.js | 142 - test/test-helper.js | 6 - test/unit/Libify.js | 401 - .../convertMuxedAccountToEd25519Account.js | 12 - test/unit/hydration.js | 22 - test/unit/linkBuilder.js | 80 - tests/createAccountPage.test.ts | 70 + tests/createMuxedAccountPage.test.ts | 72 + tests/endpointsPage.test.ts | 187 + tests/fundAccountPage.test.ts | 226 + tests/introductionPage.test.ts | 20 + tests/networkSelector.test.ts | 180 + tests/parseMuxedAccountPage.test.ts | 32 + tsconfig.json | 56 +- webpack.common.js | 162 - webpack.dev.js | 15 - webpack.prod.js | 7 - yarn.lock | 11733 ++++------------ 501 files changed, 23086 insertions(+), 30643 deletions(-) delete mode 100644 .babelrc delete mode 100644 .eslintignore delete mode 100644 .eslintrc.js create mode 100644 .eslintrc.json create mode 100644 .github/workflows/build.yml delete mode 100644 .github/workflows/test-build.yml create mode 100755 .husky/post-merge create mode 100755 .husky/pre-commit create mode 100644 .husky/pre-push create mode 100644 .lintstagedrc.js create mode 100644 .prettierignore create mode 100644 .prettierrc.json delete mode 100644 babel.config.js delete mode 100644 docs.md delete mode 100644 jest.config.js create mode 100644 next.config.js create mode 100644 nginx.conf delete mode 100644 nginx_default.conf create mode 100644 playwright.config.ts delete mode 100644 prettier.config.js delete mode 100644 public/favicon.ico delete mode 100644 public/logo192.png delete mode 100644 public/logo512.png delete mode 100644 public/manifest.json delete mode 100644 public/robots.txt delete mode 100644 public/settings/env-config.js delete mode 100644 setupJest.js delete mode 100644 src/App.tsx delete mode 100644 src/actions/accountCreator.js delete mode 100644 src/actions/endpointExplorer.js delete mode 100644 src/actions/network.js delete mode 100644 src/actions/routing.js delete mode 100644 src/actions/transactionBuilder.js delete mode 100644 src/actions/transactionSigner.js delete mode 100644 src/actions/xdrViewer.js create mode 100644 src/app/(sidebar)/account/create/page.tsx create mode 100644 src/app/(sidebar)/account/fund/components/SwitchNetwork.tsx create mode 100644 src/app/(sidebar)/account/fund/page.tsx create mode 100644 src/app/(sidebar)/account/layout.tsx create mode 100644 src/app/(sidebar)/account/muxed-create/page.tsx create mode 100644 src/app/(sidebar)/account/muxed-parse/page.tsx create mode 100644 src/app/(sidebar)/account/styles.scss create mode 100644 src/app/(sidebar)/endpoints/[[...pages]]/page.tsx create mode 100644 src/app/(sidebar)/endpoints/components/EndpointsJsonResponse.tsx create mode 100644 src/app/(sidebar)/endpoints/components/EndpointsLandingPage.tsx create mode 100644 src/app/(sidebar)/endpoints/components/SavedEndpointsPage.tsx create mode 100644 src/app/(sidebar)/endpoints/layout.tsx create mode 100644 src/app/(sidebar)/layout.tsx create mode 100644 src/app/(sidebar)/smart-contracts/layout.tsx create mode 100644 src/app/(sidebar)/smart-contracts/page.tsx create mode 100644 src/app/(sidebar)/transaction/build/components/Operations.tsx create mode 100644 src/app/(sidebar)/transaction/build/components/Params.tsx create mode 100644 src/app/(sidebar)/transaction/build/components/TransactionXdr.tsx create mode 100644 src/app/(sidebar)/transaction/build/page.tsx create mode 100644 src/app/(sidebar)/transaction/fee-bump/page.tsx create mode 100644 src/app/(sidebar)/transaction/layout.tsx create mode 100644 src/app/(sidebar)/transaction/saved/page.tsx create mode 100644 src/app/(sidebar)/transaction/sign/components/Import.tsx create mode 100644 src/app/(sidebar)/transaction/sign/components/Overview.tsx create mode 100644 src/app/(sidebar)/transaction/sign/components/SignWithWallet.tsx create mode 100644 src/app/(sidebar)/transaction/sign/page.tsx create mode 100644 src/app/(sidebar)/transaction/simulate/page.tsx create mode 100644 src/app/(sidebar)/transaction/submit/components/ErrorResponse.tsx create mode 100644 src/app/(sidebar)/transaction/submit/page.tsx create mode 100644 src/app/(sidebar)/xdr/layout.tsx create mode 100644 src/app/(sidebar)/xdr/to/page.tsx create mode 100644 src/app/(sidebar)/xdr/view/page.tsx create mode 100644 src/app/apple-icon.png create mode 100644 src/app/favicon.ico create mode 100644 src/app/icon.svg create mode 100644 src/app/icon1.png create mode 100644 src/app/icon2.png create mode 100644 src/app/layout.tsx create mode 100644 src/app/not-found.tsx create mode 100644 src/app/page.tsx delete mode 100644 src/assets/suisseintl-regular-webfont.woff delete mode 100644 src/assets/suisseintl-regular-webfont.woff2 delete mode 100644 src/assets/suisseintl-semibold-webfont.woff delete mode 100644 src/assets/suisseintl-semibold-webfont.woff2 delete mode 100644 src/assets/suisseintlmono-regular-webfont.woff delete mode 100644 src/assets/suisseintlmono-regular-webfont.woff2 delete mode 100644 src/components/CodeBlock.tsx delete mode 100644 src/components/Collapsible.js delete mode 100644 src/components/EasySelect.tsx delete mode 100644 src/components/EndpointPicker.tsx delete mode 100644 src/components/EndpointResult.tsx delete mode 100644 src/components/EndpointSetup.tsx create mode 100644 src/components/ExpandBox/index.tsx create mode 100644 src/components/ExpandBox/styles.scss delete mode 100644 src/components/Footer.tsx delete mode 100644 src/components/FormComponents/AmountPicker.js delete mode 100644 src/components/FormComponents/AssetMultiPicker.js delete mode 100644 src/components/FormComponents/AssetPicker.js delete mode 100644 src/components/FormComponents/BipPathPicker.tsx delete mode 100644 src/components/FormComponents/BooleanPicker.js delete mode 100644 src/components/FormComponents/CheckboxButtonPicker.js delete mode 100644 src/components/FormComponents/ClaimantPicker.js delete mode 100644 src/components/FormComponents/FlagfieldPicker.js delete mode 100644 src/components/FormComponents/LedgerPicker.js delete mode 100644 src/components/FormComponents/LiquidityPoolAssetPicker.tsx delete mode 100644 src/components/FormComponents/LiquidityPoolId.tsx delete mode 100644 src/components/FormComponents/ManualMultiPicker.js delete mode 100644 src/components/FormComponents/MemoPicker.js delete mode 100644 src/components/FormComponents/MultiPicker.tsx delete mode 100644 src/components/FormComponents/MuxedKeyPicker.tsx delete mode 100644 src/components/FormComponents/NumberFractionPicker.tsx delete mode 100644 src/components/FormComponents/OperationPicker.js delete mode 100644 src/components/FormComponents/OperationTypePicker.tsx delete mode 100644 src/components/FormComponents/OrderPicker.js delete mode 100644 src/components/FormComponents/PickerError.js delete mode 100644 src/components/FormComponents/PositiveIntPicker.js delete mode 100644 src/components/FormComponents/PositiveNumberPicker.js delete mode 100644 src/components/FormComponents/PubKeyPicker.tsx delete mode 100644 src/components/FormComponents/RadioButtonPicker.js delete mode 100644 src/components/FormComponents/RevokeSponsorshipPicker.js delete mode 100644 src/components/FormComponents/SecretKeyPicker.js delete mode 100644 src/components/FormComponents/SelectPicker.tsx delete mode 100644 src/components/FormComponents/SequencePicker.js delete mode 100644 src/components/FormComponents/SignerPicker.js delete mode 100644 src/components/FormComponents/StroopsPicker.js delete mode 100644 src/components/FormComponents/TextPicker.js delete mode 100644 src/components/FormComponents/TimeBoundsPicker.js delete mode 100644 src/components/FormComponents/TimestampPicker.js delete mode 100644 src/components/FormComponents/TransactionPicker.js delete mode 100644 src/components/FormComponents/TxTypePicker.js delete mode 100644 src/components/FormComponents/Unsigned8bitIntPicker.js delete mode 100644 src/components/FormComponents/XdrPicker.js create mode 100644 src/components/FormElements/AssetMultiPicker.tsx create mode 100644 src/components/FormElements/AssetPicker.tsx create mode 100644 src/components/FormElements/AuthorizePicker.tsx create mode 100644 src/components/FormElements/ClaimantsPicker.tsx create mode 100644 src/components/FormElements/CursorPicker.tsx create mode 100644 src/components/FormElements/FiltersPicker.tsx create mode 100644 src/components/FormElements/FlagFieldPicker.tsx create mode 100644 src/components/FormElements/IncludeFailedPicker.tsx create mode 100644 src/components/FormElements/LimitPicker.tsx create mode 100644 src/components/FormElements/LiquidityPoolShares.tsx create mode 100644 src/components/FormElements/MemoPicker.tsx create mode 100644 src/components/FormElements/MultiPicker.tsx create mode 100644 src/components/FormElements/NumberFractionPicker.tsx create mode 100644 src/components/FormElements/OrderPicker.tsx create mode 100644 src/components/FormElements/PositiveIntPicker.tsx create mode 100644 src/components/FormElements/PubKeyPicker.tsx create mode 100644 src/components/FormElements/RevokeSponsorshipPicker.tsx create mode 100644 src/components/FormElements/SignerPicker.tsx create mode 100644 src/components/FormElements/TextPicker.tsx create mode 100644 src/components/FormElements/TimeBoundsPicker.tsx create mode 100644 src/components/FormElements/XdrPicker.tsx create mode 100644 src/components/FriendBot/ErrorMsg.tsx create mode 100644 src/components/FriendBot/SuccessMsg.tsx create mode 100644 src/components/GenerateKeypair.tsx delete mode 100644 src/components/Header.tsx delete mode 100644 src/components/HelpMark.js create mode 100644 src/components/Hydration.tsx delete mode 100644 src/components/ImportMark.js create mode 100644 src/components/InfoCards/index.tsx create mode 100644 src/components/InfoCards/styles.scss create mode 100644 src/components/InputSideElement/index.tsx create mode 100644 src/components/InputSideElement/styles.scss delete mode 100644 src/components/LoadingView.tsx create mode 100644 src/components/MainNav.tsx create mode 100644 src/components/MuxedAccountResult.tsx delete mode 100644 src/components/Navigation.tsx create mode 100644 src/components/NetworkIndicator/index.tsx create mode 100644 src/components/NetworkIndicator/styles.scss create mode 100644 src/components/NetworkSelector/index.tsx create mode 100644 src/components/NetworkSelector/styles.scss create mode 100644 src/components/NextLink.tsx delete mode 100644 src/components/NotFoundPage.tsx delete mode 100644 src/components/OperationPanes/AccountMerge.js delete mode 100644 src/components/OperationPanes/AllowTrust.js delete mode 100644 src/components/OperationPanes/BeginSponsoringFutureReserves.js delete mode 100644 src/components/OperationPanes/BumpSequence.js delete mode 100644 src/components/OperationPanes/ChangeTrust.js delete mode 100644 src/components/OperationPanes/ClaimClaimableBalance.js delete mode 100644 src/components/OperationPanes/Clawback.js delete mode 100644 src/components/OperationPanes/ClawbackClaimableBalance.js delete mode 100644 src/components/OperationPanes/CreateAccount.js delete mode 100644 src/components/OperationPanes/CreateClaimableBalance.js delete mode 100644 src/components/OperationPanes/EndSponsoringFutureReserves.js delete mode 100644 src/components/OperationPanes/GenericOffer.js delete mode 100644 src/components/OperationPanes/LiquidityPoolDeposit.tsx delete mode 100644 src/components/OperationPanes/LiquidityPoolWithdraw.tsx delete mode 100644 src/components/OperationPanes/ManageBuyOffer.js delete mode 100644 src/components/OperationPanes/ManageData.js delete mode 100644 src/components/OperationPanes/ManageSellOffer.js delete mode 100644 src/components/OperationPanes/PathPaymentStrictReceive.js delete mode 100644 src/components/OperationPanes/PathPaymentStrictSend.js delete mode 100644 src/components/OperationPanes/Payment.js delete mode 100644 src/components/OperationPanes/RevokeSponsorship.js delete mode 100644 src/components/OperationPanes/SetOptions.js delete mode 100644 src/components/OperationPanes/SetTrustLineFlags.js delete mode 100644 src/components/OptionsTable/Pair.js create mode 100644 src/components/PrettyJson/index.tsx create mode 100644 src/components/PrettyJson/styles.scss create mode 100644 src/components/RadioPicker/index.tsx create mode 100644 src/components/RadioPicker/styles.scss create mode 100644 src/components/SaveTransactionModal.tsx create mode 100644 src/components/SdsLink.tsx delete mode 100644 src/components/SetupPanes/Accounts.js delete mode 100644 src/components/SetupPanes/All.js delete mode 100644 src/components/SetupPanes/AllAssets.js delete mode 100644 src/components/SetupPanes/AllLiquidityPools.tsx delete mode 100644 src/components/SetupPanes/AllOffers.js delete mode 100644 src/components/SetupPanes/AllWithFailed.js delete mode 100644 src/components/SetupPanes/ClaimableBalances.js delete mode 100644 src/components/SetupPanes/FindPaymentPaths.js delete mode 100644 src/components/SetupPanes/FindStrictReceivePaymentPaths.js delete mode 100644 src/components/SetupPanes/FindStrictSendPaymentPaths.js delete mode 100644 src/components/SetupPanes/For.js delete mode 100644 src/components/SetupPanes/ForAccount.js delete mode 100644 src/components/SetupPanes/ForAccountWithFailed.js delete mode 100644 src/components/SetupPanes/ForLedger.js delete mode 100644 src/components/SetupPanes/ForLedgerWithFailed.js delete mode 100644 src/components/SetupPanes/ForLiquidityPool.tsx delete mode 100644 src/components/SetupPanes/ForLiquidityPoolWithFailed.tsx delete mode 100644 src/components/SetupPanes/ForOffer.js delete mode 100644 src/components/SetupPanes/ForOperation.js delete mode 100644 src/components/SetupPanes/ForTransaction.js delete mode 100644 src/components/SetupPanes/OrderBookDetails.js delete mode 100644 src/components/SetupPanes/PostTransaction.js delete mode 100644 src/components/SetupPanes/SingleAccount.js delete mode 100644 src/components/SetupPanes/SingleClaimableBalance.js delete mode 100644 src/components/SetupPanes/SingleLedger.js delete mode 100644 src/components/SetupPanes/SingleLiquidityPool.tsx delete mode 100644 src/components/SetupPanes/SingleOffer.js delete mode 100644 src/components/SetupPanes/SingleOperation.js delete mode 100644 src/components/SetupPanes/SingleTransaction.js delete mode 100644 src/components/SetupPanes/TradeAggregations.js delete mode 100644 src/components/SetupPanes/Trades.js delete mode 100644 src/components/SorobanBanner.tsx create mode 100644 src/components/TabView/index.tsx create mode 100644 src/components/TabView/styles.scss create mode 100644 src/components/TabbedButtons/index.tsx create mode 100644 src/components/TabbedButtons/styles.scss create mode 100644 src/components/Tabs/index.tsx create mode 100644 src/components/Tabs/styles.scss delete mode 100644 src/components/TransactionImporter.js delete mode 100644 src/components/TreeView.tsx create mode 100644 src/components/TxResponse/index.tsx create mode 100644 src/components/TxResponse/styles.scss delete mode 100644 src/components/TxSubmitterResult.tsx create mode 100644 src/components/ValidationResponseCard/index.tsx create mode 100644 src/components/ValidationResponseCard/styles.scss create mode 100644 src/components/ViewInXdrButton.tsx create mode 100644 src/components/WithInfoText/index.tsx create mode 100644 src/components/WithInfoText/styles.scss create mode 100644 src/components/XdrTypeSelect/index.tsx create mode 100644 src/components/XdrTypeSelect/styles.scss create mode 100644 src/components/formComponentTemplateEndpoints.tsx create mode 100644 src/components/formComponentTemplateTxnOps.tsx create mode 100644 src/components/layout/Box/index.tsx create mode 100644 src/components/layout/Box/styles.scss create mode 100644 src/components/layout/LayoutContentContainer.tsx create mode 100644 src/components/layout/LayoutMain.tsx create mode 100644 src/components/layout/LayoutSidebarContent.tsx create mode 100644 src/components/layout/LayoutWithSidebar.tsx delete mode 100644 src/config/store.ts create mode 100644 src/constants/endpointsPages.ts delete mode 100644 src/constants/fetched_signers.ts delete mode 100644 src/constants/network.js create mode 100644 src/constants/routes.ts create mode 100644 src/constants/signTransactionPage.ts delete mode 100644 src/constants/signature.ts delete mode 100644 src/constants/slug.js create mode 100644 src/constants/transactionOperations.tsx delete mode 100644 src/constants/transaction_types.js create mode 100644 src/constants/xdr.ts delete mode 100644 src/data/endpoints.ts delete mode 100644 src/data/operations.ts delete mode 100644 src/helpers/Libify.js create mode 100644 src/helpers/StellarXdr.ts create mode 100644 src/helpers/arrayItem.ts delete mode 100644 src/helpers/buildRequest.ts delete mode 100644 src/helpers/buildRequestUrl.ts create mode 100644 src/helpers/capitalizeString.ts delete mode 100644 src/helpers/claimantHelpers.js delete mode 100644 src/helpers/clickToSelect.ts delete mode 100644 src/helpers/convertMuxedAccountToEd25519Account.js create mode 100644 src/helpers/delay.ts create mode 100644 src/helpers/delayedAction.ts delete mode 100644 src/helpers/detectXdrType.js delete mode 100644 src/helpers/dispatchInNewStack.js delete mode 100644 src/helpers/extrapolateFromXdr.js delete mode 100644 src/helpers/fetchMaintenanceData.ts create mode 100644 src/helpers/formatTimestamp.ts delete mode 100644 src/helpers/getEndpointTemplate.ts create mode 100644 src/helpers/getRelevantMaintenanceMsg.ts delete mode 100644 src/helpers/getResourceEndpoints.ts create mode 100644 src/helpers/getSaveItemNetwork.ts delete mode 100644 src/helpers/horizonUrlParser.js delete mode 100644 src/helpers/hydration.js create mode 100644 src/helpers/inputNumberValue.ts create mode 100644 src/helpers/isEmptyObject.ts delete mode 100644 src/helpers/isMaintenanceRelevant.ts create mode 100644 src/helpers/isValidUrl.ts delete mode 100644 src/helpers/linkBuilder.js delete mode 100644 src/helpers/linkHighlighterRules.js create mode 100644 src/helpers/localStorageSavedEndpointsHorizon.ts create mode 100644 src/helpers/localStorageSavedNetwork.ts create mode 100644 src/helpers/localStorageSavedTransactions.ts delete mode 100644 src/helpers/metrics.js create mode 100644 src/helpers/muxedAccount.ts delete mode 100644 src/helpers/networkLocalStorage.ts create mode 100644 src/helpers/openUrl.ts create mode 100644 src/helpers/optionsFlagDetails.ts create mode 100644 src/helpers/parseJsonString.ts create mode 100644 src/helpers/parseToLosslessJson.ts delete mode 100644 src/helpers/prism-jsonLinkHighlighter.js delete mode 100644 src/helpers/prism.js create mode 100644 src/helpers/sanitizeArray.ts create mode 100644 src/helpers/sanitizeObject.ts delete mode 100644 src/helpers/scrollOnAnchorOpen.js create mode 100644 src/helpers/shortenStellarAddress.ts delete mode 100644 src/helpers/simpleRouter.js delete mode 100644 src/helpers/sorobanXdrUtils.ts delete mode 100644 src/helpers/stateSerializer.js delete mode 100644 src/helpers/testHelpers.tsx create mode 100644 src/helpers/trim.ts create mode 100644 src/helpers/txHelper.ts delete mode 100644 src/helpers/useFreighter.js delete mode 100644 src/helpers/validateBase64.ts delete mode 100644 src/helpers/validateTxXdr.ts create mode 100644 src/helpers/xdr/fraction.ts create mode 100644 src/helpers/xdr/utils.ts delete mode 100644 src/hooks/useIsSoroban.ts create mode 100644 src/hooks/useIsTestingNetwork.ts create mode 100644 src/hooks/useIsXdrInit.ts create mode 100644 src/hooks/usePrevious.ts delete mode 100644 src/hooks/useRedux.ts delete mode 100644 src/index.html delete mode 100644 src/index.tsx delete mode 100644 src/localStorage.js delete mode 100644 src/metricsHandlers/README.md delete mode 100644 src/metricsHandlers/accountCreator.js delete mode 100644 src/metricsHandlers/endpointExplorer.js delete mode 100644 src/metricsHandlers/network.js delete mode 100644 src/metricsHandlers/routing.js delete mode 100644 src/metricsHandlers/transactionBuilder.js delete mode 100644 src/metricsHandlers/transactionSigner.js delete mode 100644 src/metricsHandlers/xdrViewer.js create mode 100644 src/middleware.ts delete mode 100644 src/middleware/metrics.js create mode 100644 src/query/QueryProvider.tsx create mode 100644 src/query/useAccountSequenceNumber.ts create mode 100644 src/query/useEndpoint.ts create mode 100644 src/query/useFriendBot.ts create mode 100644 src/query/useLatestTxn.ts create mode 100644 src/query/useMaintenanceData.ts create mode 100644 src/query/useSimulateTx.ts create mode 100644 src/query/useSubmitRpcTx.ts delete mode 100644 src/react-app-env.d.ts delete mode 100644 src/reducers/accountCreator.js delete mode 100644 src/reducers/endpointExplorer.js delete mode 100644 src/reducers/network.js delete mode 100644 src/reducers/routing.js delete mode 100644 src/reducers/transactionBuilder.js delete mode 100644 src/reducers/transactionSigner.js delete mode 100644 src/reducers/xdrViewer.js delete mode 100644 src/setupTests.ts create mode 100644 src/store/StoreProvider.tsx create mode 100644 src/store/createStore.ts create mode 100644 src/store/useStore.ts delete mode 100644 src/styles/_AccountCreator.scss delete mode 100644 src/styles/_ClaimantPicker.scss delete mode 100644 src/styles/_CodeBlock.scss delete mode 100644 src/styles/_Collapsible.scss delete mode 100644 src/styles/_EasySelect.scss delete mode 100644 src/styles/_EndpointExplorer.scss delete mode 100644 src/styles/_EndpointPicker.scss delete mode 100644 src/styles/_EndpointResult.scss delete mode 100644 src/styles/_EndpointSetup.scss delete mode 100644 src/styles/_HelpMark.scss delete mode 100644 src/styles/_Introduction.scss delete mode 100644 src/styles/_LaboratoryChrome.scss delete mode 100644 src/styles/_ManualMultiPicker.scss delete mode 100644 src/styles/_MultiPicker.scss delete mode 100644 src/styles/_NetworkPicker.scss delete mode 100644 src/styles/_PubKeyPicker.scss delete mode 100644 src/styles/_Reskin.scss delete mode 100644 src/styles/_ReskinColors.scss delete mode 100644 src/styles/_SimplePage.scss delete mode 100644 src/styles/_TransactionBuilder.scss delete mode 100644 src/styles/_TransactionSigner.scss delete mode 100644 src/styles/_TreeView.scss delete mode 100644 src/styles/_TxFreighterSign.scss delete mode 100644 src/styles/_TxSignerImport.scss delete mode 100644 src/styles/_TxSignerKeys.scss delete mode 100644 src/styles/_TxSignerOverview.scss delete mode 100644 src/styles/_TxSignerResult.scss delete mode 100644 src/styles/_XdrViewer.scss delete mode 100644 src/styles/_optionsTable.scss delete mode 100644 src/styles/_pageIntro.scss delete mode 100644 src/styles/_picker.scss delete mode 100644 src/styles/_simpleTable.scss delete mode 100644 src/styles/_xdrInput.scss create mode 100644 src/styles/globals.scss delete mode 100644 src/styles/main.scss delete mode 100644 src/styles/prism.css delete mode 100644 src/styles/solar-css/lib/_index.scss delete mode 100644 src/styles/solar-css/lib/_layout.flex.scss delete mode 100644 src/styles/solar-css/lib/_respond.media.scss delete mode 100644 src/styles/solar-css/lib/_scale.scss delete mode 100644 src/styles/solar-css/lib/_theme.colors.scss delete mode 100644 src/styles/solar-css/lib/_theme.variables.scss delete mode 100644 src/styles/solar-css/lib/_webapp.base.scss delete mode 100644 src/styles/solar-css/styles/_base.basic-elements.scss delete mode 100644 src/styles/solar-css/styles/_base.border-box.scss delete mode 100644 src/styles/solar-css/styles/_base.normalize.scss delete mode 100644 src/styles/solar-css/styles/_base.page.scss delete mode 100644 src/styles/solar-css/styles/_components.alerts.scss delete mode 100644 src/styles/solar-css/styles/_elements.links.scss delete mode 100644 src/styles/solar-css/styles/_forms.base.scss delete mode 100644 src/styles/solar-css/styles/_forms.buttonGroup.scss delete mode 100644 src/styles/solar-css/styles/_forms.buttons.scss delete mode 100644 src/styles/solar-css/styles/_forms.inputGroup.scss delete mode 100644 src/styles/solar-css/styles/_index.scss delete mode 100644 src/styles/solar-css/styles/_layout.flex.scss delete mode 100644 src/styles/solar-css/styles/_lists.buttonList.scss delete mode 100644 src/styles/solar-css/styles/_lists.inlineList.scss delete mode 100644 src/styles/solar-css/styles/_theme-starter.index.scss delete mode 100644 src/styles/solar-css/styles/_typography.base.scss delete mode 100644 src/styles/solar-css/styles/_webapp.index.scss create mode 100644 src/styles/utils.scss create mode 100644 src/validate/index.ts create mode 100644 src/validate/methods/getAccountThresholdError.ts create mode 100644 src/validate/methods/getAmountError.ts create mode 100644 src/validate/methods/getArrayOfStringsError.ts create mode 100644 src/validate/methods/getAssetCodeError.ts create mode 100644 src/validate/methods/getAssetError.ts create mode 100644 src/validate/methods/getAssetMultiError.ts create mode 100644 src/validate/methods/getBipPathError.ts create mode 100644 src/validate/methods/getClaimableBalanceIdError.ts create mode 100644 src/validate/methods/getClaimaintsError.ts create mode 100644 src/validate/methods/getContractIdError.ts create mode 100644 src/validate/methods/getDataNameError.ts create mode 100644 src/validate/methods/getDataValueError.ts create mode 100644 src/validate/methods/getEventsFiltersError.ts create mode 100644 src/validate/methods/getMemoError.ts create mode 100644 src/validate/methods/getNumberFractionError.ts create mode 100644 src/validate/methods/getOptionsSignerError.ts create mode 100644 src/validate/methods/getPositiveIntError.ts create mode 100644 src/validate/methods/getPositiveNumberError.ts create mode 100644 src/validate/methods/getPublicKeyError.ts create mode 100644 src/validate/methods/getRevokeSponsorshipError.ts create mode 100644 src/validate/methods/getSecretKeyError.ts create mode 100644 src/validate/methods/getTimeBoundsError.ts create mode 100644 src/validate/methods/getTransactionHashError.ts create mode 100644 src/validate/methods/getXdrError.ts delete mode 100644 src/views/AccountCreator.tsx delete mode 100644 src/views/AppContent.tsx delete mode 100644 src/views/EndpointExplorer.tsx delete mode 100644 src/views/FriendbotFundAccount.tsx delete mode 100644 src/views/Introduction.tsx delete mode 100644 src/views/KeypairGenerator.tsx delete mode 100644 src/views/MuxedAccount.tsx delete mode 100644 src/views/NetworkPicker.js delete mode 100644 src/views/OperationsBuilder.js delete mode 100644 src/views/TransactionBuilder.js delete mode 100644 src/views/TransactionSigner.tsx delete mode 100644 src/views/TransactionSubmitter.tsx delete mode 100644 src/views/TxBuilderAttributes.js delete mode 100644 src/views/TxBuilderResult.js delete mode 100644 src/views/XdrViewer.tsx delete mode 100644 src/views/__tests__/AccountCreator.test.tsx delete mode 100644 src/views/__tests__/AppContent.test.tsx delete mode 100644 src/views/__tests__/EndpointExplorer.test.tsx delete mode 100644 src/views/__tests__/Introduction.test.tsx delete mode 100644 src/views/__tests__/TransactionSigner.test.tsx delete mode 100644 src/views/__tests__/TransactionSubmitter.test.tsx delete mode 100644 src/views/__tests__/XdrViewer.test.tsx delete mode 100644 src/views/__tests__/__mocks__/transactions.ts delete mode 100644 test/mocha.opts delete mode 100644 test/smoke/routingRoundTrip.js delete mode 100644 test/test-helper.js delete mode 100644 test/unit/Libify.js delete mode 100644 test/unit/convertMuxedAccountToEd25519Account.js delete mode 100644 test/unit/hydration.js delete mode 100644 test/unit/linkBuilder.js create mode 100644 tests/createAccountPage.test.ts create mode 100644 tests/createMuxedAccountPage.test.ts create mode 100644 tests/endpointsPage.test.ts create mode 100644 tests/fundAccountPage.test.ts create mode 100644 tests/introductionPage.test.ts create mode 100644 tests/networkSelector.test.ts create mode 100644 tests/parseMuxedAccountPage.test.ts delete mode 100644 webpack.common.js delete mode 100644 webpack.dev.js delete mode 100644 webpack.prod.js diff --git a/.babelrc b/.babelrc deleted file mode 100644 index 2e7f9c6a..00000000 --- a/.babelrc +++ /dev/null @@ -1,14 +0,0 @@ -{ - "presets": [ - ["@babel/preset-env", { "targets": "> 1%" }], - [ - "@babel/preset-react", - // Needed to handle new JSX transform in React 17+ - { - "runtime": "automatic" - } - ], - "@babel/preset-flow", - "@babel/preset-typescript" - ] -} diff --git a/.eslintignore b/.eslintignore deleted file mode 100644 index 3d20c357..00000000 --- a/.eslintignore +++ /dev/null @@ -1,6 +0,0 @@ -babel.config.js -webpack.common.js -webpack.dev.js -webpack.prod.js -.eslintrc.js -prettier.config.js diff --git a/.eslintrc.js b/.eslintrc.js deleted file mode 100644 index 762bab11..00000000 --- a/.eslintrc.js +++ /dev/null @@ -1,75 +0,0 @@ -module.exports = { - extends: ["@stellar/eslint-config", "plugin:import/typescript"], - rules: { - "no-console": "off", - "import/no-unresolved": "off", - "react/jsx-filename-extension": ["error", { extensions: [".tsx", ".jsx"] }], - "no-plusplus": "off", - "jsdoc/check-indentation": "off", - "@typescript-eslint/naming-convention": [ - "error", - { - selector: "typeProperty", - format: ["PascalCase", "UPPER_CASE", "camelCase", "snake_case"], - leadingUnderscore: "allow", - trailingUnderscore: "allow", - }, - ], - // Disabled for now - "prefer-const": "off", - "no-var": "off", - "prefer-template": "off", - "@typescript-eslint/restrict-plus-operands": "off", - "@typescript-eslint/unbound-method": "off", - "new-cap": "off", - "one-var": "off", - "max-len": "off", - "no-param-reassign": "off", - "@typescript-eslint/no-shadow": "off", - "no-shadow": "off", - eqeqeq: "off", - "no-return-assign": "off", - "@typescript-eslint/prefer-for-of": "off", - "vars-on-top": "off", - "default-case": "off", - "no-case-declarations": "off", - "react/jsx-filename-extension": "off", - "no-else-return": "off", - "consistent-return": "off", - "object-shorthand": "off", - "no-restricted-globals": "off", - radix: "off", - "no-restricted-properties": "off", - "arrow-body-style": "off", - "no-bitwise": "off", - "@typescript-eslint/dot-notation": "off", - "dot-notation": "off", - "no-lonely-if": "off", - "no-useless-escape": "off", - "no-buffer-constructor": "off", - "react/prefer-stateless-function": "off", - "jsx-a11y/anchor-is-valid": "off", - "no-new": "off", - "max-classes-per-file": "off", - "no-useless-constructor": "off", - "import/named": "off", - "no-fallthrough": "off", - "no-useless-return": "off", - "import/no-mutable-exports": "off", - camelcase: "off", - "no-nested-ternary": "off", - "func-names": "off", - "prefer-arrow-callback": "off", - "react/no-array-index-key": "off", - "no-unused-vars": "off", - "@typescript-eslint/no-unused-vars": "off", - "react-hooks/exhaustive-deps": "off", - "prefer-object-spread": "off", - "no-alert": "off", - "react/sort-comp": "off", - "valid-jsdoc": "off", - "@typescript-eslint/no-unsafe-argument": "off", - "@typescript-eslint/no-unnecessary-type-constraint": "off", - "jsdoc/newline-after-description": "off", - }, -}; diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 00000000..cc457e6a --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,15 @@ +{ + "extends": [ + "eslint:recommended", + "plugin:react-hooks/recommended", + "plugin:@typescript-eslint/recommended", + "next/core-web-vitals", + "prettier" + ], + "rules": { + // @TODO: ideally, these should be removed + "@typescript-eslint/no-explicit-any": "off", + "import/named": "off" + }, + "ignorePatterns": ["./src/temp/stellar-xdr-web/*"] +} diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml new file mode 100644 index 00000000..8f7e7ada --- /dev/null +++ b/.github/workflows/build.yml @@ -0,0 +1,19 @@ +name: Build the app and run Playwright Tests +on: [push, pull_request] +jobs: + build: + timeout-minutes: 60 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: 20 + - name: Install dependencies + run: npm install -g yarn && yarn + - name: Install Playwright Browsers + run: yarn playwright install --with-deps + - name: Build app + run: yarn build + - name: Run Playwright tests + run: yarn test diff --git a/.github/workflows/test-build.yml b/.github/workflows/test-build.yml deleted file mode 100644 index fc72b6a3..00000000 --- a/.github/workflows/test-build.yml +++ /dev/null @@ -1,13 +0,0 @@ -name: Test and build -on: [push, pull_request] -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: actions/setup-node@v3 - with: - node-version: 18 - - run: yarn install - # - run: yarn test:jest - - run: yarn build diff --git a/.gitignore b/.gitignore index d82fb886..50d2e64e 100644 --- a/.gitignore +++ b/.gitignore @@ -4,23 +4,40 @@ /node_modules /.pnp .pnp.js +.yarn/install-state.gz +package-lock.json # testing /coverage +# next.js +/.next/ +/out/ + # production /build -/dist # misc .DS_Store -.env -.env.local -.env.development.local -.env.test.local -.env.production.local +*.pem +# debug npm-debug.log* yarn-debug.log* yarn-error.log* -.eslintcache + +# local env files +.env*.local + +# vercel +.vercel + +# typescript +*.tsbuildinfo +next-env.d.ts + +# test files +/test-results/ +/playwright-report/ +/blob-report/ +/playwright/.cache/ diff --git a/.husky/post-merge b/.husky/post-merge new file mode 100755 index 00000000..a2c24131 --- /dev/null +++ b/.husky/post-merge @@ -0,0 +1 @@ +yarn install-if-package-changed diff --git a/.husky/pre-commit b/.husky/pre-commit new file mode 100755 index 00000000..c4778ab5 --- /dev/null +++ b/.husky/pre-commit @@ -0,0 +1 @@ +yarn pre-commit diff --git a/.husky/pre-push b/.husky/pre-push new file mode 100644 index 00000000..b0019253 --- /dev/null +++ b/.husky/pre-push @@ -0,0 +1 @@ +yarn pre-push \ No newline at end of file diff --git a/.lintstagedrc.js b/.lintstagedrc.js new file mode 100644 index 00000000..b559cfd8 --- /dev/null +++ b/.lintstagedrc.js @@ -0,0 +1,14 @@ +const path = require("path"); + +const buildEslintCommand = (filenames) => + `next lint --fix --file ${filenames + .map((f) => path.relative(process.cwd(), f)) + .join(" --file ")}`; + +const ignoredFiles = ["./src/temp/stellar-xdr-web/**/*"]; + +const eslintPattern = `!(${ignoredFiles.join(",")})*.{js,ts,jsx,tsx}`; + +module.exports = { + "*.{js,jsx,ts,tsx}": [buildEslintCommand], +}; diff --git a/.nvmrc b/.nvmrc index 3f430af8..9a2a0e21 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -v18 +v20 diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 00000000..1149ded4 --- /dev/null +++ b/.prettierignore @@ -0,0 +1,5 @@ +.prettierignore +public/ +.gitignore +.husky/ +src/temp/stellar-xdr-web/ diff --git a/.prettierrc.json b/.prettierrc.json new file mode 100644 index 00000000..d90ebd47 --- /dev/null +++ b/.prettierrc.json @@ -0,0 +1,12 @@ +{ + "arrowParens:": "always", + "bracketSpacing": true, + "jsxBracketSameLine": false, + "printWidth": 80, + "proseWrap": "always", + "semi": true, + "singleQuote": false, + "tabWidth": 2, + "trailingComma": "all", + "useTabs": false +} diff --git a/Dockerfile b/Dockerfile index 71566c74..dc0cdaed 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,29 +1,14 @@ -FROM ubuntu:22.04 as build +FROM node:20 -MAINTAINER SDF Ops Team - -RUN mkdir -p /app +ENV NEXT_TELEMETRY_DISABLED 1 +ENV PORT 80 WORKDIR /app - -ENV DEBIAN_FRONTEND=noninteractive -# https://create-react-app.dev/docs/advanced-configuration/ -ENV INLINE_RUNTIME_CHUNK=false -RUN apt-get update && apt-get install --no-install-recommends -y gpg curl git make ca-certificates apt-transport-https && \ - curl -sSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key|gpg --dearmor >/etc/apt/trusted.gpg.d/nodesource-key.gpg && \ - echo "deb https://deb.nodesource.com/node_18.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list && \ - curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg |gpg --dearmor >/etc/apt/trusted.gpg.d/yarnpkg.gpg && \ - echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list && \ - apt-get update && apt-get install -y nodejs yarn && apt-get clean - -COPY . /app/ +COPY . . +# Passing env var to be used on client side +ARG NEXT_PUBLIC_COMMIT_HASH RUN yarn install - RUN yarn build -FROM nginx:1.17 - -COPY --from=build /app/build/ /usr/share/nginx/html/ - -# We're removing /laboratory/ prefix. To allow for transition -# period we'll support /laboratory/ links using rewrites -COPY nginx_default.conf /etc/nginx/conf.d/default.conf +# Run on port 80 for compatibility with laboratory v1 +EXPOSE 80 +CMD ["npm", "start"] diff --git a/Makefile b/Makefile index a2e06989..26d3bc9f 100644 --- a/Makefile +++ b/Makefile @@ -1,13 +1,15 @@ # Check if we need to prepend docker commands with sudo SUDO := $(shell docker version >/dev/null 2>&1 || echo "sudo") +# If LABEL is not provided set default value +LABEL ?= $(shell git rev-parse --short HEAD)$(and $(shell git status -s),-dirty-$(shell id -u -n)) # If TAG is not provided set default value -TAG ?= stellar/laboratory:$(shell git rev-parse --short HEAD)$(and $(shell git status -s),-dirty-$(shell id -u -n)) +TAG ?= stellar/laboratory:$(LABEL) # https://github.com/opencontainers/image-spec/blob/master/annotations.md BUILD_DATE := $(shell date -u +%FT%TZ) docker-build: - $(SUDO) docker build --pull --label org.opencontainers.image.created="$(BUILD_DATE)" -t $(TAG) . + $(SUDO) docker build --pull --label org.opencontainers.image.created="$(BUILD_DATE)" -t $(TAG) --build-arg=NEXT_PUBLIC_COMMIT_HASH="$(shell git rev-parse --short HEAD)" . docker-push: $(SUDO) docker push $(TAG) diff --git a/README.md b/README.md index f0c9163c..985d05b0 100644 --- a/README.md +++ b/README.md @@ -1,19 +1,31 @@ -# laboratory +# Lab -The Stellar Laboratory is a suite of tools to help one learn about exploring the +The Stellar Lab is a suite of tools to help one learn about exploring the Stellar network. See it in action: -[https://laboratory.stellar.org/](https://laboratory.stellar.org/). +[https://lab.stellar.org/](https://lab.stellar.org/). + +## Tech stack + +- [Next.js](https://nextjs.org/) framework (React) +- [TypeScript](https://www.typescriptlang.org/) +- [Stellar Design System](https://design-system.stellar.org/) for UI +- [Sass](https://sass-lang.com/) for CSS styling +- [TanStack (React) Query](https://tanstack.com/query/latest) for API queries +- [Zustand](https://docs.pmnd.rs/zustand/getting-started/introduction) for state + management +- [Playwright](https://playwright.dev/) for e2e tests +- [Yarn Classic (v1)](https://classic.yarnpkg.com/lang/en/docs/install/) ## Developing ```sh -yarn start +yarn dev ``` Testing hardware wallets requires an HTTPS connection to enable U2F. The recommended way to do this is with [`ngrok`](https://ngrok.com/). Once -downloaded and authenticated, start ngrok, and tell the laboratory to start with -a public URL. +downloaded and authenticated, start ngrok, and tell the Lab to start with a +public URL. ```bash ./ngrok http 3000 @@ -28,26 +40,12 @@ yarn start --public randomsubdomain.ngrok.io yarn build ``` -To build a production docker image using a clean docker build environment: - -```sh -make docker-build -# or directly with docker -docker build -t lab:localbuild . -``` - To build and run production build locally: ```sh -yarn production -# or -yarn prod:build -yarn prod:serve +yarn start ``` -Production uses Amplitude to emit metrics, so to fully emulate a production build, you'll need to set an `AMPLITUDE_API_KEY` variable in `/public/settings/env-config.js` file. - -## Internal documentation - -The [docs.md](./docs.md) file contains code documentation on the laboratory. The -docs.md is only relevant for developing the laboratory. +Production uses [Amplitude](https://amplitude.com/) to emit metrics, so to fully +emulate a production build, you’ll need to set an +`NEXT_PUBLIC_AMPLITUDE_API_KEY` variable in `.env.local` file. diff --git a/babel.config.js b/babel.config.js deleted file mode 100644 index c742e964..00000000 --- a/babel.config.js +++ /dev/null @@ -1,22 +0,0 @@ -module.exports = { - presets: [ - "@babel/preset-react", - "@babel/preset-typescript", - [ - "@babel/preset-env", - { - targets: { - browsers: "last 2 versions", - }, - modules: false, - loose: false, - }, - ], - ], - plugins: ["transform-class-properties", "react-hot-loader/babel"], - env: { - test: { - plugins: ["transform-es2015-modules-commonjs"], - }, - }, -}; diff --git a/docs.md b/docs.md deleted file mode 100644 index 3eb51ef8..00000000 --- a/docs.md +++ /dev/null @@ -1,40 +0,0 @@ -This file contains information about the laboratory itself and design choices inside. - -# Simple Router -The laboratory uses a simple routing system with no outside dependencies. The simple router is stateless. Components do not need to know about the router since everything is handled. - -## Dataflow: Two possible events -### Outbound changes: Changes from updated redux store -When the redux state changes, we can then serialize it and save it in the url. This is handled by a middleware called `routerMiddleware`. - -This is reactive and won't change the redux store. - -#### Triggers -1. An action happened (LOAD_STATE actions are ignored). - -### Inbound changes: Changes from url hash updates -The a component uses the `routerListener` to provide access to dispatching actions. It will perform a diff to see if an the store needs to be updated. If so, it will dispatch an event. - -If save data is not specified, the redux store should not be cleared. - -#### Two results: -1. Load the state from the query string and navigate -2. Only navigate. Don't load state - -#### Triggers -1. Page initially loads: Result 1 -2. Hash change with query present: Result 1 -3. Hash change with empty query: Result 2 - -## User navigation via clicks on plain hash links -User navigation should always occur through hash links. This is so that users can open links in new tabs as well as right clicking to copy the link. - -Although these events are user initiated, these are considered "inbound" changes since it is changing the hash which is outside of redux. - -## Routing actions and reducer -The only code creating actions for routing.js should be the routerListener. - -## Link builder -Within the laboratory, tools are interconnected and will want to link to each other. For example, in Transaction Builder, it is convenient to have a button to sign the built transaction. - -The linkBuilder interface provides simple functions that build the desired url using the storeSerializer. Components that want to link to others don't need knowledge of how the storeSerializer works. They only need to use the simple functions that the linkBuilder provides. diff --git a/jest.config.js b/jest.config.js deleted file mode 100644 index 465952bc..00000000 --- a/jest.config.js +++ /dev/null @@ -1,6 +0,0 @@ -module.exports = { - testPathIgnorePatterns: ["__mocks__"], - moduleDirectories: ["node_modules", "src/"], - setupFiles: ["./setupJest.js"], - setupFilesAfterEnv: ["@testing-library/jest-dom"], -}; diff --git a/next.config.js b/next.config.js new file mode 100644 index 00000000..d8eba3eb --- /dev/null +++ b/next.config.js @@ -0,0 +1,9 @@ +/** @type {import('next').NextConfig} */ +const nextConfig = { + distDir: "build", + experimental: { + missingSuspenseWithCSRBailout: false, + }, +}; + +module.exports = nextConfig; diff --git a/nginx.conf b/nginx.conf new file mode 100644 index 00000000..2c513fb3 --- /dev/null +++ b/nginx.conf @@ -0,0 +1,23 @@ +server { + listen 80; + server_name localhost; + + gzip on; + gzip_disable "msie6"; + gzip_vary on; + gzip_proxied any; + gzip_comp_level 6; + gzip_buffers 16 8k; + gzip_types application/javascript application/rss+xml application/vnd.ms-fontobject application/x-font application/x-font-opentype application/x-font-otf application/x-font-truetype application/x-font-ttf application/x-javascript application/xhtml+xml application/xml font/opentype font/otf font/ttf image/svg+xml image/x-icon text/css text/javascript text/plain text/xml; + + location / { + root /usr/share/nginx/html; + try_files $uri /index.html index.htm; + gzip_static on; + } + + error_page 500 502 503 504 /50x.html; + location = /50x.html { + root /usr/share/nginx/html; + } +} diff --git a/nginx_default.conf b/nginx_default.conf deleted file mode 100644 index 0ed5e499..00000000 --- a/nginx_default.conf +++ /dev/null @@ -1,17 +0,0 @@ -server { - listen 80; - server_name localhost; - - location / { - root /usr/share/nginx/html; - index index.html index.htm; - } - - error_page 500 502 503 504 /50x.html; - location = /50x.html { - root /usr/share/nginx/html; - } - - rewrite ^/laboratory$ /laboratory/ permanent; - rewrite ^/laboratory/(.*)$ /$1 break; -} diff --git a/package.json b/package.json index 201670e2..c07ca39f 100644 --- a/package.json +++ b/package.json @@ -1,128 +1,65 @@ { "name": "stellar-laboratory", - "version": "0.0.1", - "private": true, - "description": "", + "version": "0.1.0", "author": "Stellar Development Foundation ", "license": "Apache-2.0", - "scripts": { - "start": "webpack serve --open --config webpack.dev.js", - "build": "NODE_ENV=production webpack --config webpack.prod.js", - "build:netlify": "yarn build; mkdir out; mkdir out/laboratory; mv build/* out/laboratory; cp _redirects out/_redirects", - "test": "mocha './test/**/*.js'", - "test:jest": "jest", - "prod:build": "docker image build -t lab:localbuild .", - "prod:serve": "docker run -p 8000:80 lab:localbuild", - "production": "yarn prod:build && yarn prod:serve" - }, - "eslintConfig": { - "extends": "react-app" + "engines": { + "node": ">=20.0.0" }, - "browserslist": { - "production": [ - ">0.2%", - "not dead", - "not op_mini all" - ], - "development": [ - "last 1 chrome version", - "last 1 firefox version", - "last 1 safari version" - ] + "scripts": { + "dev": "export NEXT_PUBLIC_COMMIT_HASH=$(git rev-parse --short HEAD) && next dev", + "build": "next build", + "start": "next start", + "lint": "next lint", + "lint:ts": "tsc --noEmit", + "test": "playwright test", + "install-if-package-changed": "git diff-tree -r --name-only --no-commit-id ORIG_HEAD HEAD | grep --quiet yarn.lock && yarn install || exit 0", + "prepare": "husky", + "pre-commit": "yarn lint-staged", + "pre-push": "yarn lint:ts && yarn test" }, "dependencies": { - "@albedo-link/intent": "^0.11.2", - "@babel/register": "^7.24.6", + "@creit.tech/stellar-wallets-kit": "^0.8.2", "@ledgerhq/hw-app-str": "^6.28.6", "@ledgerhq/hw-transport-webusb": "^6.28.6", - "@reduxjs/toolkit": "^1.7.2", - "@stellar/freighter-api": "^1.4.0", - "@stellar/prettier-config": "^1.2.0", - "@stellar/stellar-sdk": "^12.0.1", - "@stellar/tsconfig": "^1.0.2", + "@stellar/design-system": "^2.0.0-beta.15", + "@stellar/stellar-sdk": "^12.2.0", + "@stellar/stellar-xdr-json-web": "^0.0.1", + "@tanstack/react-query": "^5.45.1", + "@tanstack/react-query-devtools": "^5.45.1", "@trezor/connect-plugin-stellar": "^9.0.3", - "@trezor/connect-web": "^9.2.4", - "assert": "^2.1.0", - "axios": "^1.7.2", - "babel-plugin-transform-class-properties": "^6.24.1", - "babel-plugin-transform-es2015-modules-commonjs": "^6.26.2", - "browser-sync": "^3.0.2", - "buffer": "^6.0.3", - "chai": "^4.3.6", - "classnames": "^2.5.1", - "crypto-browserify": "^3.12.0", - "dompurify": "^2.3.5", - "html-react-parser": "^1.4.8", - "https-browserify": "^1.0.0", - "json-loader": "^0.5.7", - "lodash": "^4.17.5", - "mocha": "^9.2.0", - "msw": "^2.3.1", - "os-browserify": "^0.3.0", - "prettier": "^2.5.1", - "prop-types": "^15.8.1", - "querystring-es3": "^0.2.1", - "react": "^17.0.2", - "react-dom": "^17.0.2", - "react-hot-loader": "^4.13.1", - "react-loadable": "^5.5.0", - "react-redux": "^7.2.6", - "redux": "^4.1.2", - "redux-thunk": "^2.4.1", - "regenerator-runtime": "^0.13.9", - "route-recognizer": "^0.3.4", - "solar-stellarorg": "git+https://github.com/stellar/solar-stellarorg#master", - "stream-browserify": "^3.0.0", - "stream-http": "^3.2.0", - "typescript": "^5.3.3", - "uri-templates": "^0.2.0", - "urijs": "^1.19.11", - "url": "^0.11.1" + "@trezor/connect-web": "^9.2.2", + "@typescript-eslint/eslint-plugin": "^7.13.1", + "bignumber.js": "^9.1.2", + "dompurify": "^3.1.2", + "html-react-parser": "^5.1.10", + "immer": "^10.1.1", + "lodash": "^4.17.21", + "lossless-json": "^4.0.1", + "next": "14.2.4", + "react": "^18.3.1", + "react-dom": "^18.3.1", + "tslib": "^2.6.2", + "zustand": "^4.5.2", + "zustand-querystring": "^0.0.19" }, "devDependencies": { - "@babel/core": "^7.24.7", - "@babel/preset-env": "^7.24.7", - "@babel/preset-flow": "^7.24.7", - "@babel/preset-react": "^7.24.7", - "@babel/preset-typescript": "^7.24.7", - "@stellar/eslint-config": "^2.1.2", - "@testing-library/jest-dom": "^5.16.2", - "@testing-library/react": "^12.1.2", - "@testing-library/user-event": "^13.5.0", - "@types/dompurify": "^2.3.3", - "@types/jest": "^27.4.0", - "@types/lodash": "^4.17.5", - "@types/node": "^16.0.1", - "@types/react": "^17.0.39", - "@types/react-dom": "^17.0.11", - "@types/react-loadable": "^5.5.11", - "@types/react-redux": "^7.1.33", - "@types/uri-templates": "^0.1.34", - "@typescript-eslint/eslint-plugin": "^5.60.1", - "@typescript-eslint/parser": "^5.60.1", - "babel-loader": "^9.1.2", - "clean-webpack-plugin": "^4.0.0", - "copy-webpack-plugin": "^11.0.0", - "css-loader": "^6.8.1", - "eslint": "^7.31.0", - "eslint-config-prettier": "^8.3.0", - "eslint-config-react": "^1.1.7", - "eslint-config-react-app": "^7.0.1", - "eslint-plugin-jsdoc": "^46.9.0", - "eslint-plugin-prefer-arrow": "^1.2.3", - "eslint-webpack-plugin": "^4.2.0", - "fork-ts-checker-webpack-plugin": "^8.0.0", - "html-webpack-plugin": "^5.6.0", - "jest-fetch-mock": "^3.0.3", - "mini-css-extract-plugin": "^2.9.0", - "node-sass": "^9.0.0", + "@next/eslint-plugin-next": "^14.2.4", + "@playwright/test": "^1.43.1", + "@stellar/tsconfig": "^1.0.2", + "@types/dompurify": "^3.0.5", + "@types/lodash": "^4.17.0", + "@types/node": "^20.12.7", + "@types/react": "^18.3.1", + "@types/react-dom": "^18.3.0", + "eslint": "^8.57.0", + "eslint-config-next": "14.2.4", + "eslint-config-prettier": "^9.1.0", + "eslint-plugin-react-hooks": "^4.6.2", + "husky": "^9.0.11", + "lint-staged": "^15.2.7", + "prettier": "^3.3.2", "sass": "^1.77.5", - "sass-loader": "^13.3.2", - "style-loader": "^3.3.3", - "ts-loader": "^9.4.3", - "tsconfig-paths-webpack-plugin": "^4.0.1", - "webpack": "^5.92.0", - "webpack-cli": "^5.1.4", - "webpack-dev-server": "^4.15.1" + "typescript": "^5.4.5" } } diff --git a/playwright.config.ts b/playwright.config.ts new file mode 100644 index 00000000..17a564df --- /dev/null +++ b/playwright.config.ts @@ -0,0 +1,86 @@ +import { defineConfig, devices } from "@playwright/test"; + +/** + * Read environment variables from file. + * https://github.com/motdotla/dotenv + */ +// require('dotenv').config(); + +// Use process.env.PORT by default and fallback to port 3000 +const PORT = process.env.PORT || 3000; +// Set webServer.url and use.baseURL with the location of the WebServer respecting the correct set port +const baseURL = `http://localhost:${PORT}`; + +/** + * See https://playwright.dev/docs/test-configuration. + */ +export default defineConfig({ + /* Timeout per test */ + timeout: 30 * 1000, + /* Tests directory */ + testDir: "./tests", + /* Run tests in files in parallel */ + fullyParallel: true, + /* Fail the build on CI if you accidentally left test.only in the source code. */ + forbidOnly: !!process.env.CI, + /* Retry on CI only */ + retries: process.env.CI ? 2 : 0, + /* Opt out of parallel tests on CI. */ + workers: process.env.CI ? 1 : undefined, + /* Reporter to use. See https://playwright.dev/docs/test-reporters */ + reporter: "list", + /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ + use: { + /* Base URL to use in actions like `await page.goto('/')`. */ + baseURL, + /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ + trace: "on-first-retry", + }, + + /* Run your local dev server before starting the tests */ + webServer: { + command: "yarn dev", + url: baseURL, + timeout: 120 * 1000, + reuseExistingServer: !process.env.CI, + }, + + /* Configure projects for major browsers */ + projects: [ + { + name: "chromium", + use: { ...devices["Desktop Chrome"] }, + }, + + // TODO: enable these later if needed + // { + // name: "firefox", + // use: { ...devices["Desktop Firefox"] }, + // }, + + // { + // name: "webkit", + // use: { ...devices["Desktop Safari"] }, + // }, + + /* Test against mobile viewports. */ + // { + // name: 'Mobile Chrome', + // use: { ...devices['Pixel 5'] }, + // }, + // { + // name: 'Mobile Safari', + // use: { ...devices['iPhone 12'] }, + // }, + + /* Test against branded browsers. */ + // { + // name: 'Microsoft Edge', + // use: { ...devices['Desktop Edge'], channel: 'msedge' }, + // }, + // { + // name: 'Google Chrome', + // use: { ...devices['Desktop Chrome'], channel: 'chrome' }, + // }, + ], +}); diff --git a/prettier.config.js b/prettier.config.js deleted file mode 100644 index 4603b615..00000000 --- a/prettier.config.js +++ /dev/null @@ -1,3 +0,0 @@ -module.exports = { - ...require("@stellar/prettier-config"), -}; diff --git a/public/favicon.ico b/public/favicon.ico deleted file mode 100644 index 4f17c94a834735ea04cf72bff9589bf3f0a8bbcd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7406 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 diff --git a/public/logo192.png b/public/logo192.png deleted file mode 100644 index 476ff8d02ec31c87b274f5e06efa3d8df9d56b9e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3843 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 bHzj~oZVvw)4Y`!F6o8(#k=APs`-uMm+|?z~ diff --git a/public/logo512.png b/public/logo512.png deleted file mode 100644 index 41427a2f0ee6dae7d1a19bde8b4699badc7022e9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11240 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 XUl6;W%L%0-RRF4rnhKS2AA|o7lzflw diff --git a/public/manifest.json b/public/manifest.json deleted file mode 100644 index 7360e52a..00000000 --- a/public/manifest.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "short_name": "Laboratory", - "name": "Stellar Laboratory", - "icons": [ - { - "src": "favicon.ico", - "sizes": "64x64 32x32 24x24 16x16", - "type": "image/x-icon" - }, - { - "src": "logo192.png", - "type": "image/png", - "sizes": "192x192" - }, - { - "src": "logo512.png", - "type": "image/png", - "sizes": "512x512" - } - ], - "start_url": ".", - "display": "standalone", - "theme_color": "#000000", - "background_color": "#ffffff" -} diff --git a/public/robots.txt b/public/robots.txt deleted file mode 100644 index e9e57dc4..00000000 --- a/public/robots.txt +++ /dev/null @@ -1,3 +0,0 @@ -# https://www.robotstxt.org/robotstxt.html -User-agent: * -Disallow: diff --git a/public/settings/env-config.js b/public/settings/env-config.js deleted file mode 100644 index 2960edc6..00000000 --- a/public/settings/env-config.js +++ /dev/null @@ -1,3 +0,0 @@ -window._env_ = { - AMPLITUDE_API_KEY: "", -}; diff --git a/setupJest.js b/setupJest.js deleted file mode 100644 index d36d1111..00000000 --- a/setupJest.js +++ /dev/null @@ -1 +0,0 @@ -require('jest-fetch-mock').enableMocks(); diff --git a/src/App.tsx b/src/App.tsx deleted file mode 100644 index 150a3354..00000000 --- a/src/App.tsx +++ /dev/null @@ -1,17 +0,0 @@ -import * as StellarSdk from "@stellar/stellar-sdk"; -import { Provider } from "react-redux"; -import { store } from "config/store"; -import { AppContent } from "views/AppContent"; - -import "styles/main.scss"; - -if (typeof window !== "undefined") { - // @ts-ignore - window.StellarSdk = StellarSdk; -} - -export const App = () => ( - - - -); diff --git a/src/actions/accountCreator.js b/src/actions/accountCreator.js deleted file mode 100644 index 69d2c701..00000000 --- a/src/actions/accountCreator.js +++ /dev/null @@ -1,132 +0,0 @@ -import axios from "axios"; -import { Keypair, Account, MuxedAccount } from "@stellar/stellar-sdk"; -import dispatchInNewStack from "../helpers/dispatchInNewStack"; - -export const GENERATE_NEW_KEYPAIR = "GENERATE_NEW_KEYPAIR"; -export function generateNewKeypair() { - let keypair = Keypair.random(); - return { - type: GENERATE_NEW_KEYPAIR, - pubKey: keypair.publicKey(), - secretKey: keypair.secret(), - }; -} - -export const UPDATE_FRIENDBOT_TARGET = "UPDATE_FRIENDBOT_TARGET"; -export function updateFriendbotTarget(target) { - return { - type: UPDATE_FRIENDBOT_TARGET, - target, - }; -} - -export const START_FRIENDBOT_REQUEST = "START_FRIENDBOT_REQUEST"; -export const FINISH_FRIENDBOT_REQUEST = "FINISH_FRIENDBOT_REQUEST"; -export function startFriendbotRequest(target, isFuturenet = false) { - const friendbotURL = isFuturenet - ? "https://friendbot-futurenet.stellar.org" - : "https://friendbot.stellar.org"; - return (dispatch) => { - dispatch({ - type: START_FRIENDBOT_REQUEST, - message: "Loading...", - status: "loading", - }); - - axios - .get(friendbotURL + "/?addr=" + target) - .then(() => { - dispatchInNewStack(dispatch, { - type: FINISH_FRIENDBOT_REQUEST, - target, - message: `Successfully funded ${target} on the test network`, - status: "success", - code: "", - }); - }) - .catch((e) => { - let code, message; - if (e.response.status === 0) { - code = ""; - message = "Unable to reach Friendbot server at " + friendbotURL; - } else { - code = JSON.stringify(e.response.data, null, 2); - message = `Failed to fund ${target} on the test network`; - } - - dispatchInNewStack(dispatch, { - type: FINISH_FRIENDBOT_REQUEST, - target, - message, - status: "failure", - code, - }); - }); - }; -} - -export const GENERATE_MUXED_ACCOUNT = "GENERATE_MUXED_ACCOUNT"; -export function generateMuxedAccount(publicKey, muxedAccountId) { - try { - const muxedAccount = new MuxedAccount( - new Account(publicKey, "0"), - muxedAccountId, - ); - - return { - type: GENERATE_MUXED_ACCOUNT, - mAddress: muxedAccount.accountId(), - }; - } catch (e) { - return { - type: GENERATE_MUXED_ACCOUNT, - errorMessage: `Something went wrong. ${e.toString()}`, - }; - } -} - -export const UPDATE_GENERATE_MUXED_ACCOUNT_INPUT = - "UPDATE_GENERATE_MUXED_ACCOUNT_INPUT"; -export function updateGenerateMuxedAccountInput(input) { - return { - type: UPDATE_GENERATE_MUXED_ACCOUNT_INPUT, - input, - }; -} - -export const PARSE_MUXED_ACCOUNT = "PARSE_MUXED_ACCOUNT"; -export function parseMuxedAccount(muxedAccountAddress) { - try { - const muxedAccount = new MuxedAccount.fromAddress(muxedAccountAddress, "0"); - const gAddress = muxedAccount.baseAccount().accountId(); - const mAccountId = muxedAccount.id(); - - if (!gAddress) { - throw new Error("Base account for this muxed account was not found."); - } - - if (!mAccountId) { - throw new Error("Muxed account ID for this muxed account was not found."); - } - - return { - type: PARSE_MUXED_ACCOUNT, - gAddress, - mAccountId, - }; - } catch (e) { - return { - type: PARSE_MUXED_ACCOUNT, - errorMessage: `Something went wrong. ${e.toString()}`, - }; - } -} - -export const UPDATE_PARSE_MUXED_ACCOUNT_INPUT = - "UPDATE_PARSE_MUXED_ACCOUNT_INPUT"; -export function updateParseMuxedAccountInput(mAddress) { - return { - type: UPDATE_PARSE_MUXED_ACCOUNT_INPUT, - mAddress, - }; -} diff --git a/src/actions/endpointExplorer.js b/src/actions/endpointExplorer.js deleted file mode 100644 index e2828972..00000000 --- a/src/actions/endpointExplorer.js +++ /dev/null @@ -1,98 +0,0 @@ -import axios from "axios"; -import { CallBuilder } from "@stellar/stellar-sdk"; -import URI from "urijs"; -import dispatchInNewStack from "../helpers/dispatchInNewStack"; - -export const CHOOSE_ENDPOINT = "CHOOSE_ENDPOINT"; -export function chooseEndpoint(resource, endpoint) { - return { - type: CHOOSE_ENDPOINT, - resource, - endpoint, - }; -} -export const CHANGE_PENDING_REQUEST_PROPS = "CHANGE_PENDING_REQUEST_PROPS"; -export function changePendingRequestProps(props) { - return { - type: CHANGE_PENDING_REQUEST_PROPS, - props, - }; -} - -export const UPDATE_VALUE = "UPDATE_VALUE"; -export function updateValue(param, value) { - return { - type: UPDATE_VALUE, - param, - value, - }; -} - -export const START_REQUEST = "START_REQUEST"; -export const ERROR_REQUEST = "ERROR_REQUEST"; -export const UPDATE_REQUEST = "UPDATE_REQUEST"; -let resultIdNonce = 0; -let closeStreamFn; -export function submitRequest(request) { - return (dispatch) => { - // Close old stream if it exists - if (typeof closeStreamFn === "function") { - closeStreamFn(); - closeStreamFn = null; - } - - let id = resultIdNonce++; - dispatch({ - type: START_REQUEST, - id, - isStreaming: Boolean(request.streaming), - }); - - if (request.streaming) { - closeStreamFn = streamingRequest(request.url, (message) => { - // dispatchInNewStack is not needed for streaming since there is no catch here - dispatch({ - type: UPDATE_REQUEST, - id, - body: message, - isStreaming: true, - }); - }); - } else { - // dispatchInNewStack will only be called at most one time. - httpRequest(request) - .then((r) => { - dispatchInNewStack(dispatch, { - type: UPDATE_REQUEST, - id, - body: r.data, - }); - }) - .catch((e) => { - dispatchInNewStack(dispatch, { - type: ERROR_REQUEST, - id, - errorStatus: e.response.status, - body: e.response.data, - }); - }); - } - }; -} - -function httpRequest(request) { - if (request.method === "POST") { - if (typeof request.formData !== "string") { - throw new Error( - "Network POST requests require the form data to be in string format.", - ); - } - return axios.post(request.url, request.formData); - } - return axios.get(request.url); -} - -function streamingRequest(url, onmessage) { - var callBuilder = new CallBuilder(URI(url)); - return callBuilder.stream({ onmessage }); -} diff --git a/src/actions/network.js b/src/actions/network.js deleted file mode 100644 index 6228d5b1..00000000 --- a/src/actions/network.js +++ /dev/null @@ -1,46 +0,0 @@ -import NETWORK from "../constants/network"; - -export const SET_NETWORKS = "SET_NETWORKS"; -export function setNetworks(networks) { - return { - type: SET_NETWORKS, - networks, - }; -} - -export const SHOW_MODAL = "SHOW_MODAL"; -export const HIDE_MODAL = "HIDE_MODAL"; -export function setModalVisibility(visible) { - return { - type: visible ? SHOW_MODAL : HIDE_MODAL, - }; -} - -export const UPDATE_MODAL = "UPDATE_MODAL"; -export function updateModal(key, value) { - return { - type: UPDATE_MODAL, - key, - value, - }; -} - -export const SET_PARAMS = "SET_PARAMS"; -export function chooseNetwork(name) { - return { - type: SET_PARAMS, - params: { - name, - horizonURL: NETWORK.available[name].horizonURL, - networkPassphrase: NETWORK.available[name].networkPassphrase, - }, - }; -} - -export function setCustomParams(params) { - params.name = "custom"; - return { - type: SET_PARAMS, - params, - }; -} diff --git a/src/actions/routing.js b/src/actions/routing.js deleted file mode 100644 index b88b7707..00000000 --- a/src/actions/routing.js +++ /dev/null @@ -1,16 +0,0 @@ -export const UPDATE_LOCATION = "UPDATE_LOCATION"; -export function updateLocation(slug) { - return { - type: UPDATE_LOCATION, - slug, - }; -} - -export const LOAD_STATE = "LOAD_STATE"; -export function loadState(slug, queryObj) { - return { - type: LOAD_STATE, - slug, - queryObj, - }; -} diff --git a/src/actions/transactionBuilder.js b/src/actions/transactionBuilder.js deleted file mode 100644 index 42f21e1c..00000000 --- a/src/actions/transactionBuilder.js +++ /dev/null @@ -1,132 +0,0 @@ -import axios from "axios"; - -// Resets everything to it's default state -export const RESET_TXBUILDER = "RESET_TXBUILDER"; -export function resetTxbuilder() { - return { - type: RESET_TXBUILDER, - }; -} - -// Attributes -export const UPDATE_ATTRIBUTES = "UPDATE_ATTRIBUTES"; -export function updateAttributes(newAttributes) { - return { - type: UPDATE_ATTRIBUTES, - newAttributes, - }; -} - -// Operations -export const ADD_OPERATION = "ADD_OPERATION"; -export let addOperation = (() => { - return () => { - return { - type: ADD_OPERATION, - opId: Date.now(), - }; - }; -})(); - -export const DUPLICATE_OPERATION = "DUPLICATE_OPERATION"; -export function duplicateOperation(sourceOpId) { - return { - type: DUPLICATE_OPERATION, - sourceOpId: sourceOpId, - opId: Date.now(), - }; -} - -export const REMOVE_OPERATION = "REMOVE_OPERATION"; -export function removeOperation(opId) { - return { - type: REMOVE_OPERATION, - opId, - }; -} - -export const UPDATE_OPERATION_TYPE = "UPDATE_OPERATION_TYPE"; -export function updateOperationType(opId, newType) { - return { - type: UPDATE_OPERATION_TYPE, - opId, - newType, - }; -} - -export const UPDATE_OPERATION_ATTRIBUTES = "UPDATE_OPERATION_ATTRIBUTES"; -export function updateOperationAttributes(opId, newAttributes) { - return { - type: UPDATE_OPERATION_ATTRIBUTES, - opId, - newAttributes, - }; -} - -export const REORDER_OPERATION = "REORDER_OPERATION"; -export function reorderOperation(opId, toNth) { - return { - type: REORDER_OPERATION, - opId, - toNth, - }; -} - -export const FETCH_SEQUENCE = "FETCH_SEQUENCE"; -export const FETCH_SEQUENCE_START = "FETCH_SEQUENCE_START"; -export const FETCH_SEQUENCE_FAIL = "FETCH_SEQUENCE_FAIL"; -export const FETCH_SEQUENCE_SUCCESS = "FETCH_SEQUENCE_SUCCESS"; -// This is only meant to be used for fetching *next* sequence number for txbuilder -export function fetchSequence(accountId, horizonBaseUrl) { - return (dispatch) => { - dispatch({ - type: FETCH_SEQUENCE_START, - }); - axios - .get(horizonBaseUrl + "/accounts/" + accountId) - .then((r) => - dispatch({ - type: FETCH_SEQUENCE_SUCCESS, - sequence: (BigInt(r.data.sequence) + BigInt(1)).toString(), - }), - ) - .catch((r) => dispatch({ type: FETCH_SEQUENCE_FAIL, payload: r })); - }; -} - -export const FETCH_BASE_FEE = "FETCH_BASE_FEE"; -export const FETCH_BASE_FEE_FAIL = "FETCH_BASE_FEE_FAIL"; -export const FETCH_BASE_FEE_SUCCESS = "FETCH_BASE_FEE_SUCCESS"; -export function fetchBaseFee(horizonBaseUrl) { - return (dispatch) => { - dispatch({ - type: FETCH_BASE_FEE, - }); - axios - .get(horizonBaseUrl + "/fee_stats") - .then((r) => - dispatch({ - type: FETCH_BASE_FEE_SUCCESS, - min_fee: r.data.fee_charged.min, - base_fee: r.data.last_ledger_base_fee, - }), - ) - .catch((r) => dispatch({ type: FETCH_BASE_FEE_FAIL, payload: r })); - }; -} - -export const UPDATE_TX_TYPE = "UPDATE_TX_TYPE"; -export function updateTxType(txType) { - return { - type: UPDATE_TX_TYPE, - txType, - }; -} - -export const UPDATE_FEE_BUMP_ATTRIBUTE = "UPDATE_FEE_BUMP_ATTRIBUTE"; -export function updateFeeBumpAttribute(newAttribute) { - return { - type: UPDATE_FEE_BUMP_ATTRIBUTE, - newAttribute, - }; -} diff --git a/src/actions/transactionSigner.js b/src/actions/transactionSigner.js deleted file mode 100644 index 478b486f..00000000 --- a/src/actions/transactionSigner.js +++ /dev/null @@ -1,204 +0,0 @@ -import LedgerTransportWebUSB from "@ledgerhq/hw-transport-webusb"; -import LedgerStr from "@ledgerhq/hw-app-str"; -import TrezorConnect from "@trezor/connect-web"; -import transformTransaction from "@trezor/connect-plugin-stellar"; -import { TransactionBuilder, Keypair, xdr, StrKey } from "@stellar/stellar-sdk"; -import { signTransaction } from "@stellar/freighter-api"; -import albedo from "@albedo-link/intent"; - -export const IMPORT_FROM_XDR = "IMPORT_FROM_XDR"; -export function importFromXdr(xdr) { - return { - type: IMPORT_FROM_XDR, - xdr, - }; -} - -export const CLEAR_TRANSACTION = "CLEAR_TRANSACTION"; -export function clearTransaction() { - return { - type: CLEAR_TRANSACTION, - }; -} - -export const SET_SECRETS = "SET_SECRETS"; -export function setSecrets(secrets) { - return { - type: SET_SECRETS, - secrets, - }; -} - -export const SET_BIP_PATH = "SET_BIP_PATH"; -export function setBIPPath(bipPath) { - return { - type: SET_BIP_PATH, - bipPath, - }; -} - -export const LEDGER_WALLET_SIGN_START = "LEDGER_WALLET_SIGN_START"; -export const LEDGER_WALLET_SIGN_SUCCESS = "LEDGER_WALLET_SIGN_SUCCESS"; -export const LEDGER_WALLET_SIGN_ERROR = "LEDGER_WALLET_SIGN_ERROR"; -export const TREZOR_WALLET_SIGN_START = "TREZOR_WALLET_SIGN_START"; -export const TREZOR_WALLET_SIGN_SUCCESS = "TREZOR_WALLET_SIGN_SUCCESS"; -export const TREZOR_WALLET_SIGN_ERROR = "TREZOR_WALLET_SIGN_ERROR"; -export const FREIGHTER_WALLET_SIGN_START = "FREIGHTER_WALLET_SIGN_START"; -export const FREIGHTER_WALLET_SIGN_SUCCESS = "FREIGHTER_WALLET_SIGN_SUCCESS"; -export const FREIGHTER_WALLET_SIGN_ERROR = "FREIGHTER_WALLET_SIGN_ERROR"; -export const ALBEDO_WALLET_SIGN_START = "ALBEDO_WALLET_SIGN_START"; -export const ALBEDO_WALLET_SIGN_SUCCESS = "ALBEDO_WALLET_SIGN_SUCCESS"; -export const ALBEDO_WALLET_SIGN_ERROR = "ALBEDO_WALLET_SIGN_ERROR"; - -export function signWithLedger(txXDR, bipPath, networkPassphrase, isHash) { - return (dispatch) => { - dispatch({ type: LEDGER_WALLET_SIGN_START }); - - let transaction = TransactionBuilder.fromXDR(txXDR, networkPassphrase); - - let onError = (err) => { - if (err.message) { - err = err.message; - } else if (err.errorCode == 2) { - err = `Couldn't connect to Ledger device. Connection can only be established using a secure connection.`; - } else if (err.errorCode == 5) { - err = `Connection timeout.`; - } - - dispatch({ - type: LEDGER_WALLET_SIGN_ERROR, - error: err, - }); - }; - - let onConnect = (ledgerApi) => { - let publicKey; - - ledgerApi - .getPublicKey(bipPath) - .then((result) => (publicKey = result.publicKey)) - .then(() => { - if (isHash) { - return ledgerApi.signHash(bipPath, transaction.hash()); - } - return ledgerApi.signTransaction( - bipPath, - transaction.signatureBase(), - ); - }) - .then((result) => { - let { signature } = result; - let keyPair = Keypair.fromPublicKey(publicKey); - let hint = keyPair.signatureHint(); - let decorated = new xdr.DecoratedSignature({ hint, signature }); - - dispatch({ - type: LEDGER_WALLET_SIGN_SUCCESS, - signature: decorated, - }); - }) - .catch(onError); - }; - - LedgerTransportWebUSB.request() - .then((transport) => { - onConnect(new LedgerStr(transport)); - }) - .catch(onError); - }; -} - -export function signWithTrezor(txXDR, bipPath, networkPassphrase) { - return (dispatch) => { - dispatch({ type: TREZOR_WALLET_SIGN_START }); - - let transaction = TransactionBuilder.fromXDR(txXDR, networkPassphrase); - const path = `m/${bipPath}`; - - let onError = (err) => { - err = err || "Couldn't sign transaction with Trezor device."; - - dispatch({ - type: TREZOR_WALLET_SIGN_ERROR, - error: err, - }); - }; - - let onConnect = (trezorResponse) => { - if (trezorResponse.success) { - const signature = Buffer.from(trezorResponse.payload.signature, "hex"); - const publicKeyBytes = Buffer.from( - trezorResponse.payload.publicKey, - "hex", - ); - const encodedPublicKey = StrKey.encodeEd25519PublicKey(publicKeyBytes); - - let keyPair = Keypair.fromPublicKey(encodedPublicKey); - let hint = keyPair.signatureHint(); - let decorated = new xdr.DecoratedSignature({ hint, signature }); - - dispatch({ - type: TREZOR_WALLET_SIGN_SUCCESS, - signature: decorated, - }); - } else { - onError(trezorResponse.payload.error); - } - }; - - TrezorConnect.manifest({ - email: "accounts+trezor@stellar.org", - appUrl: "https://laboratory.stellar.org/", - }); - - const trezorParams = transformTransaction(path, transaction); - - TrezorConnect.stellarSignTransaction(trezorParams) - .then(onConnect) - .catch(onError); - }; -} - -export function signWithFreighter(txXDR, txNetwork) { - return (dispatch) => { - dispatch({ type: FREIGHTER_WALLET_SIGN_START }); - - signTransaction(txXDR, txNetwork) - .then((signedTx) => { - dispatch({ - type: FREIGHTER_WALLET_SIGN_SUCCESS, - signedTx, - }); - }) - .catch((e) => { - dispatch({ - type: FREIGHTER_WALLET_SIGN_ERROR, - error: e, - }); - }); - }; -} - -export function signWithAlbedo(txXDR, txNetwork) { - return (dispatch) => { - dispatch({ type: ALBEDO_WALLET_SIGN_START }); - - albedo - .tx({ - xdr: txXDR, - network: txNetwork, - }) - .then((result) => { - dispatch({ - type: ALBEDO_WALLET_SIGN_SUCCESS, - signedTx: result.signed_envelope_xdr, - }); - }) - .catch((e) => { - dispatch({ - type: ALBEDO_WALLET_SIGN_ERROR, - error: e.message, - }); - }); - }; -} diff --git a/src/actions/xdrViewer.js b/src/actions/xdrViewer.js deleted file mode 100644 index 49bba358..00000000 --- a/src/actions/xdrViewer.js +++ /dev/null @@ -1,158 +0,0 @@ -import * as StellarSdk from "@stellar/stellar-sdk"; -import axios from "axios"; -import { FETCH_SEQUENCE_FAIL } from "actions/transactionBuilder.js"; -import { SIGNATURE } from "../constants/signature"; -import { FETCHED_SIGNERS } from "../constants/fetched_signers"; -import convertMuxedAccountToEd25519Account from "../helpers/convertMuxedAccountToEd25519Account"; - -export const UPDATE_XDR_INPUT = "UPDATE_XDR_INPUT"; -export function updateXdrInput(input) { - return { - type: UPDATE_XDR_INPUT, - input, - }; -} - -export const UPDATE_XDR_TYPE = "UPDATE_XDR_TYPE"; -export function updateXdrType(xdrType) { - return { - type: UPDATE_XDR_TYPE, - xdrType, - }; -} - -export const FETCH_LATEST_TX = "FETCH_LATEST_TX"; -export function fetchLatestTx(horizonBaseUrl, networkPassphrase) { - return (dispatch) => { - dispatch({ type: FETCH_LATEST_TX }); - axios - .get(horizonBaseUrl + "/transactions?limit=1&order=desc") - .then((r) => { - const xdr = r.data._embedded.records[0].envelope_xdr; - dispatch(updateXdrInput(xdr)); - dispatch(updateXdrType("TransactionEnvelope")); - dispatch(fetchSigners(xdr, horizonBaseUrl, networkPassphrase)); - }) - .catch((r) => dispatch({ type: FETCH_SEQUENCE_FAIL, payload: r })); - }; -} - -export function fetchSigners(input, horizonBaseUrl, networkPassphrase) { - return (dispatch) => { - dispatch({ type: FETCHED_SIGNERS.PENDING }); - try { - let tx = new StellarSdk.TransactionBuilder.fromXDR( - input, - networkPassphrase, - ); - - // Extract all source accounts from transaction (base transaction, and all operations) - let sourceAccounts = {}; - - // tuple of signatures and transaction hash. This is needed to handle - // inner signatures in a fee bump transaction - let groupedSignatures = []; - - if (tx instanceof StellarSdk.FeeBumpTransaction) { - sourceAccounts[ - convertMuxedAccountToEd25519Account(tx.feeSource) - ] = true; - groupedSignatures.push([ - tx.signatures.map((x) => ({ sig: x.signature() })), - tx.hash(), - ]); - - tx = tx.innerTransaction; - } - - sourceAccounts[convertMuxedAccountToEd25519Account(tx.source)] = true; - tx.operations.forEach((op) => { - if (op.source) { - sourceAccounts[convertMuxedAccountToEd25519Account(op.source)] = true; - } - }); - - groupedSignatures.push([ - tx.signatures.map((x) => ({ sig: x.signature() })), - tx.hash(), - ]); - - // Get all signers per source account - array of promises - sourceAccounts = Object.keys(sourceAccounts).map((accountID) => - axios.get(horizonBaseUrl + "/accounts/" + accountID), - ); - const signatures = []; - - Promise.all(sourceAccounts) - .then((response) => { - let allSigners = {}; - response.forEach((r) => - r.data.signers.forEach( - (signer) => (allSigners[signer.key] = signer), - ), - ); - - allSigners = Object.values(allSigners); - - groupedSignatures.forEach((group) => { - const sigs = group[0]; - const txHash = group[1]; - - // We are only interested in checking if each of the signatures can be verified for some valid - // signer for any of the source accounts in the transaction -- we are not taking into account - // weights, or even if this signer makes sense. - for (var i = 0; i < sigs.length; i++) { - const sigObj = sigs[i]; - let isValid = false; - - for (var j = 0; j < allSigners.length; j++) { - const signer = allSigners[j]; - - // By nature of pre-authorized transaction, we won't ever receive a pre-auth - // tx hash in signatures array, so we can ignore pre-authorized transactions here. - switch (signer.type) { - case "sha256_hash": - const hashXSigner = StellarSdk.StrKey.decodeSha256Hash( - signer.key, - ); - const hashXSignature = StellarSdk.hash(sigObj.sig); - isValid = hashXSigner.equals(hashXSignature); - break; - case "ed25519_public_key": - const keypair = StellarSdk.Keypair.fromPublicKey( - signer.key, - ); - isValid = keypair.verify(txHash, sigObj.sig); - break; - } - - if (isValid) { - break; - } - } - - sigObj.isValid = isValid ? SIGNATURE.VALID : SIGNATURE.INVALID; - - signatures.push(sigObj); - } - }); - - dispatch({ - type: FETCHED_SIGNERS.SUCCESS, - result: signatures, - }); - }) - .catch((e) => { - console.error(e); - if (e.response.status == 404) { - dispatch({ type: FETCHED_SIGNERS.NOT_EXIST }); - } else { - dispatch({ type: FETCHED_SIGNERS.FAIL }); - } - }); - } catch (e) { - console.error(e); - dispatch({ type: FETCHED_SIGNERS.FAIL }); - } - }; -} diff --git a/src/app/(sidebar)/account/create/page.tsx b/src/app/(sidebar)/account/create/page.tsx new file mode 100644 index 00000000..a2676323 --- /dev/null +++ b/src/app/(sidebar)/account/create/page.tsx @@ -0,0 +1,153 @@ +"use client"; + +import { useCallback, useEffect, useRef, useState } from "react"; +import { Card, Text, Button } from "@stellar/design-system"; +import { Keypair } from "@stellar/stellar-sdk"; + +import { useStore } from "@/store/useStore"; +import { useFriendBot } from "@/query/useFriendBot"; +import { useQueryClient } from "@tanstack/react-query"; + +import { useIsTestingNetwork } from "@/hooks/useIsTestingNetwork"; + +import { GenerateKeypair } from "@/components/GenerateKeypair"; +import { ExpandBox } from "@/components/ExpandBox"; +import { SuccessMsg } from "@/components/FriendBot/SuccessMsg"; +import { ErrorMsg } from "@/components/FriendBot/ErrorMsg"; + +import "../styles.scss"; + +export default function CreateAccount() { + const { account, network } = useStore(); + const { reset } = account; + + const [secretKey, setSecretKey] = useState(""); + const [showAlert, setShowAlert] = useState(false); + + const queryClient = useQueryClient(); + const IS_TESTING_NETWORK = useIsTestingNetwork(); + const IS_CUSTOM_NETWORK_WITH_HORIZON = + network.id === "custom" && network.horizonUrl; + + const networkRef = useRef(network); + + const resetQuery = useCallback( + () => + queryClient.resetQueries({ + queryKey: ["friendBot", { type: "create" }], + }), + [queryClient], + ); + + const resetStates = useCallback(() => { + reset(); + resetQuery(); + }, [reset, resetQuery]); + + const { error, isError, isFetching, isLoading, isSuccess, refetch } = + useFriendBot({ + network, + publicKey: account.publicKey!, + key: { type: "create" }, + }); + + useEffect(() => { + if (isError || isSuccess) { + setShowAlert(true); + } + }, [isError, isSuccess]); + + useEffect(() => { + if (networkRef.current.id !== network.id) { + networkRef.current = network; + resetStates(); + } + }, [networkRef.current.id, network.id]); + + const generateKeypair = () => { + resetStates(); + + const keypair = Keypair.random(); + + if (IS_TESTING_NETWORK) { + account.updateKeypair(keypair.publicKey(), keypair.secret()); + } else { + account.updateKeypair(keypair.publicKey()); + } + + setSecretKey(keypair.secret()); + }; + + return ( +
+ +
+
+ + Keypair Generator + + + + These keypairs can be used on the Stellar network where one is + required. For example, it can be used as an account master key, + account signer, and/or as a stellar-core node key. + +
+
+ + + {IS_TESTING_NETWORK || IS_CUSTOM_NETWORK_WITH_HORIZON ? ( + + ) : null} +
+ + {Boolean(account.publicKey) && ( + +
+ +
+
+ )} +
+
+ + { + setShowAlert(false); + }} + /> + + { + setShowAlert(false); + }} + /> +
+ ); +} diff --git a/src/app/(sidebar)/account/fund/components/SwitchNetwork.tsx b/src/app/(sidebar)/account/fund/components/SwitchNetwork.tsx new file mode 100644 index 00000000..0df1c3be --- /dev/null +++ b/src/app/(sidebar)/account/fund/components/SwitchNetwork.tsx @@ -0,0 +1,60 @@ +"use client"; + +import { Card, Text, Button } from "@stellar/design-system"; + +import { NetworkOptions } from "@/constants/settings"; +import { useStore } from "@/store/useStore"; + +import { NetworkType } from "@/types/types"; + +import "../../styles.scss"; + +export const SwitchNetwork = () => { + const { selectNetwork, updateIsDynamicNetworkSelect } = useStore(); + const onSwitchNetwork = (network: NetworkType) => { + const selectedNetwork = NetworkOptions.find((n) => n.id === network); + if (selectedNetwork) { + updateIsDynamicNetworkSelect(true); + selectNetwork(selectedNetwork); + } + }; + + return ( + +
+
+ + Friendbot: fund a Futurenet or Testnet network account + + + + You must switch your network to Futurenet or Testnet in order to + fund keypairs. The friendbot is a horizon API endpoint that will + fund an account with 10,000 lumens on the futurenet network. + +
+
+ + + +
+
+
+ ); +}; diff --git a/src/app/(sidebar)/account/fund/page.tsx b/src/app/(sidebar)/account/fund/page.tsx new file mode 100644 index 00000000..a9d9c10e --- /dev/null +++ b/src/app/(sidebar)/account/fund/page.tsx @@ -0,0 +1,151 @@ +"use client"; + +import { useCallback, useEffect, useRef, useState } from "react"; +import { Card, Input, Text, Button } from "@stellar/design-system"; +import { useQueryClient } from "@tanstack/react-query"; + +import { useFriendBot } from "@/query/useFriendBot"; +import { useStore } from "@/store/useStore"; + +import { validate } from "@/validate"; + +import { SuccessMsg } from "@/components/FriendBot/SuccessMsg"; +import { ErrorMsg } from "@/components/FriendBot/ErrorMsg"; + +import { SwitchNetwork } from "./components/SwitchNetwork"; + +import "../styles.scss"; + +export default function FundAccount() { + const { account, network } = useStore(); + const { reset } = account; + + const [showAlert, setShowAlert] = useState(false); + const [generatedPublicKey, setGeneratedPublicKey] = useState(""); + const [inlineErrorMessage, setInlineErrorMessage] = useState(""); + + const networkRef = useRef(network); + + const { + error, + isError, + isFetching, + isLoading, + isSuccess, + refetch, + isFetchedAfterMount, + } = useFriendBot({ + network, + publicKey: generatedPublicKey, + key: { type: "fund" }, + }); + + const queryClient = useQueryClient(); + + const resetQuery = useCallback( + () => + queryClient.resetQueries({ + queryKey: ["friendBot", { type: "fund" }], + }), + [queryClient], + ); + + const resetStates = useCallback(() => { + reset(); + resetQuery(); + }, [reset, resetQuery]); + + useEffect(() => { + // when switching network, reset the state + if (networkRef.current.id !== network.id) { + networkRef.current = network; + resetStates(); + } + }, [networkRef.current.id, network.id]); + + useEffect(() => { + if (isError || isSuccess) { + setShowAlert(true); + } + }, [isError, isSuccess]); + + if (network.id === "mainnet") { + return ; + } + return ( +
+ +
+
+ + Friendbot: fund a {network.id} network account + + + + The friendbot is a horizon API endpoint that will fund an account + with 10,000 lumens on the {network.id} network. + +
+ + { + setGeneratedPublicKey(e.target.value); + const error = validate.getPublicKeyError(e.target.value); + setInlineErrorMessage(error || ""); + }} + placeholder="Ex: GCEXAMPLE5HWNK4AYSTEQ4UWDKHTCKADVS2AHF3UI2ZMO3DPUSM6Q4UG" + error={inlineErrorMessage} + /> + +
+ + + +
+
+
+ + { + setShowAlert(false); + }} + /> + + { + setShowAlert(false); + }} + /> +
+ ); +} diff --git a/src/app/(sidebar)/account/layout.tsx b/src/app/(sidebar)/account/layout.tsx new file mode 100644 index 00000000..e28d4942 --- /dev/null +++ b/src/app/(sidebar)/account/layout.tsx @@ -0,0 +1,39 @@ +"use client"; + +import React from "react"; + +import { LayoutSidebarContent } from "@/components/layout/LayoutSidebarContent"; +import { Routes } from "@/constants/routes"; + +export default function AccountTemplate({ + children, +}: { + children: React.ReactNode; +}) { + return ( + + {children} + + ); +} diff --git a/src/app/(sidebar)/account/muxed-create/page.tsx b/src/app/(sidebar)/account/muxed-create/page.tsx new file mode 100644 index 00000000..4e015c13 --- /dev/null +++ b/src/app/(sidebar)/account/muxed-create/page.tsx @@ -0,0 +1,184 @@ +"use client"; + +import { useState } from "react"; +import { Alert, Button, Card, Input, Text } from "@stellar/design-system"; + +import { useStore } from "@/store/useStore"; + +import { ExpandBox } from "@/components/ExpandBox"; +import { MuxedAccountResult } from "@/components/MuxedAccountResult"; +import { PubKeyPicker } from "@/components/FormElements/PubKeyPicker"; +import { SdsLink } from "@/components/SdsLink"; + +import { muxedAccount } from "@/helpers/muxedAccount"; + +import { validate } from "@/validate"; + +import "../styles.scss"; + +export default function CreateMuxedAccount() { + const { account } = useStore(); + + const [baseAddress, setBaseAddress] = useState( + account.generatedMuxedAccountInput?.baseAddress || "", + ); + const [muxedId, setMuxedId] = useState( + account.generatedMuxedAccountInput?.id || "", + ); + const [baseFieldErrorMessage, setBaseFieldErrorMessage] = + useState(""); + const [muxedFieldError, setMuxedFieldError] = useState(""); + const [sdkError, setSdkError] = useState(""); + + const [isReset, setReset] = useState(false); + + const generateMuxedAccount = () => { + const result = muxedAccount.generate({ + baseAddress, + muxedAccountId: muxedId, + }); + + const { error, muxedAddress } = result; + + if (muxedAddress) { + setReset(false); + account.updateGeneratedMuxedAccount({ + id: muxedId, + baseAddress, + muxedAddress, + }); + + account.updateGeneratedMuxedAccountInput({ + id: muxedId, + baseAddress, + }); + + setSdkError(""); + return; + } + + if (error) { + setSdkError(error); + return; + } + }; + + return ( +
+ +
+
+ + Create Multiplexed Account + + + + A muxed (or multiplexed) account (defined in{" "} + + CAP-27 + {" "} + and briefly{" "} + + SEP-23 + + ) is one that resolves a single Stellar G...account to many + different underlying IDs. + +
+ + { + setReset(true); + setBaseAddress(e.target.value); + + let error = ""; + + if (!e.target.value.startsWith("G")) { + error = "Base account address should start with G"; + } else { + error = validate.getPublicKeyError(e.target.value) || ""; + } + + setBaseFieldErrorMessage(error); + }} + error={baseFieldErrorMessage} + copyButton={{ + position: "right", + }} + /> + + { + setReset(true); + setMuxedId(e.target.value); + + const error = validate.getPositiveIntError(e.target.value); + setMuxedFieldError(error || ""); + }} + error={muxedFieldError} + copyButton={{ + position: "right", + }} + /> + +
+ +
+ + + + +
+
+ + + Don’t use in a production environment unless you know what you’re doing. + + + {Boolean(sdkError) && ( + { + setSdkError(""); + }} + title={sdkError} + > + {""} + + )} +
+ ); +} diff --git a/src/app/(sidebar)/account/muxed-parse/page.tsx b/src/app/(sidebar)/account/muxed-parse/page.tsx new file mode 100644 index 00000000..511eea6a --- /dev/null +++ b/src/app/(sidebar)/account/muxed-parse/page.tsx @@ -0,0 +1,145 @@ +"use client"; + +import { useState } from "react"; +import { Alert, Card, Text, Button } from "@stellar/design-system"; + +import { useStore } from "@/store/useStore"; + +import { ExpandBox } from "@/components/ExpandBox"; +import { PubKeyPicker } from "@/components/FormElements/PubKeyPicker"; +import { MuxedAccountResult } from "@/components/MuxedAccountResult"; + +import { muxedAccount } from "@/helpers/muxedAccount"; + +import { validate } from "@/validate"; + +import "../styles.scss"; + +export default function ParseMuxedAccount() { + const { account } = useStore(); + const parsedMuxedAccount = account.parsedMuxedAccount; + + const [muxedAddress, setMuxedAddress] = useState( + account.parsedMuxedAccountInput || "", + ); + + const [muxedFieldError, setMuxedFieldError] = useState(""); + const [sdkError, setSdkError] = useState(""); + + const [isReset, setReset] = useState(false); + + const parseMuxedAccount = () => { + const result = muxedAccount.parse({ + muxedAddress, + }); + + const { error, id, baseAddress } = result; + + if (baseAddress && id) { + setReset(false); + account.updateParsedMuxedAccount({ + id, + baseAddress, + muxedAddress, + }); + account.updateParsedMuxedAccountInput(muxedAddress); + + setSdkError(""); + return; + } + + if (error) { + setSdkError(error); + return; + } + }; + + return ( +
+ +
+
+ + Get Muxed Account from M address + +
+ + { + setReset(true); + setMuxedAddress(e.target.value); + + let error = ""; + + if (!e.target.value.startsWith("M")) { + error = "Muxed account address should start with M"; + } else { + error = validate.getPublicKeyError(e.target.value) || ""; + } + + setMuxedFieldError(error); + }} + /> + +
+ +
+ + + + +
+
+ + + Don’t use in a production environment unless you know what you’re doing. + + + {Boolean(sdkError) && ( + { + setSdkError(""); + }} + title={sdkError} + > + {""} + + )} +
+ ); +} diff --git a/src/app/(sidebar)/account/styles.scss b/src/app/(sidebar)/account/styles.scss new file mode 100644 index 00000000..18fc5e2a --- /dev/null +++ b/src/app/(sidebar)/account/styles.scss @@ -0,0 +1,77 @@ +@use "../../../styles/utils.scss" as *; + +.Account { + display: flex; + flex-direction: column; + gap: pxToRem(12px); + + &__card { + display: flex; + flex-direction: column; + gap: pxToRem(24px); + } + + .CardText__button { + align-self: flex-start; + } + + &__CTA { + display: flex; + gap: pxToRem(18px) pxToRem(8px); + } + + &__keypair { + display: flex; + align-items: flex-start; + flex-direction: column; + gap: pxToRem(16px); + + .Input__side-element--right { + cursor: pointer; + } + } + + &__result { + display: flex; + flex-direction: column; + gap: pxToRem(16px); + background-color: var(--sds-clr-gray-03); + border-radius: pxToRem(8px); + padding: pxToRem(16px); + } + + // TODO: temp fix until SDS is fixed (tooltip overlap) + // Adjusting form element z-index to fix "Copied" tooltip overlap + .Input { + // Keypair Generator response + &:has(#generate-keypair-publickey) { + z-index: 2; + } + + &:has(#generate-keypair-secretkey) { + z-index: 1; + } + + // Create Multiplexed Account main form + &:has(#muxed-public-key) { + z-index: 2; + } + + &:has(#muxed-account-id) { + z-index: 1; + } + + // Create Multiplexed Account results + &:has(#muxed-public-key-result) { + z-index: 3; + } + + &:has(#muxed-account-id-result) { + z-index: 2; + } + + &:has(#muxed-account-address-result) { + z-index: 1; + } + } +} diff --git a/src/app/(sidebar)/endpoints/[[...pages]]/page.tsx b/src/app/(sidebar)/endpoints/[[...pages]]/page.tsx new file mode 100644 index 00000000..167264d9 --- /dev/null +++ b/src/app/(sidebar)/endpoints/[[...pages]]/page.tsx @@ -0,0 +1,928 @@ +"use client"; + +import React, { useCallback, useEffect, useRef, useState } from "react"; +import { usePathname } from "next/navigation"; +import { + Alert, + Button, + Card, + CopyText, + Icon, + Input, + Text, + Textarea, +} from "@stellar/design-system"; +import { useQueryClient } from "@tanstack/react-query"; +import { stringify } from "lossless-json"; + +import { SdsLink } from "@/components/SdsLink"; +import { formComponentTemplateEndpoints } from "@/components/formComponentTemplateEndpoints"; +import { InputSideElement } from "@/components/InputSideElement"; + +import { useStore } from "@/store/useStore"; +import { isEmptyObject } from "@/helpers/isEmptyObject"; +import { sanitizeArray } from "@/helpers/sanitizeArray"; +import { sanitizeObject } from "@/helpers/sanitizeObject"; +import { parseJsonString } from "@/helpers/parseJsonString"; +import { getSaveItemNetwork } from "@/helpers/getSaveItemNetwork"; +import { localStorageSavedEndpointsHorizon } from "@/helpers/localStorageSavedEndpointsHorizon"; +import { arrayItem } from "@/helpers/arrayItem"; +import { delayedAction } from "@/helpers/delayedAction"; + +import { Routes } from "@/constants/routes"; +import { + ENDPOINTS_PAGES_HORIZON, + ENDPOINTS_PAGES_RPC, +} from "@/constants/endpointsPages"; +import { useEndpoint } from "@/query/useEndpoint"; +import { + AnyObject, + AssetObject, + AssetObjectValue, + Network, + FiltersObject, +} from "@/types/types"; + +import { EndpointsLandingPage } from "../components/EndpointsLandingPage"; +import { SavedEndpointsPage } from "../components/SavedEndpointsPage"; +import { EndpointsJsonResponse } from "../components/EndpointsJsonResponse"; + +export default function Endpoints() { + const pathname = usePathname(); + const isRpcEndpoint = pathname.includes(Routes.ENDPOINTS_RPC); + const currentPage = pathname.split(Routes.ENDPOINTS)?.[1]; + + const horizonPage = ENDPOINTS_PAGES_HORIZON.navItems + .find((page) => pathname.includes(page.route)) + ?.nestedItems?.find((i) => i.route === pathname); + + const rpcPage = ENDPOINTS_PAGES_RPC.navItems.find( + (page) => pathname === page.route, + ); + + const page = isRpcEndpoint ? rpcPage : horizonPage; + const pageData = isRpcEndpoint ? rpcPage?.form : horizonPage?.form; + + const requiredFields = sanitizeArray( + pageData?.requiredParams?.split(",") || [], + ); + + const { endpoints, network, isDynamicNetworkSelect } = useStore(); + const { + params, + currentEndpoint, + network: endpointNetwork, + updateParams, + updateCurrentEndpoint, + updateNetwork, + resetParams, + } = endpoints; + + const REGEX_TEMPLATE_SEARCH_PARAMS = /\{\?.+?\}/; + const REGEX_TEMPLATE_SEARCH_PARAMS_VALUE = /(?<=\{\?).+?(?=\})/; + const REGEX_TEMPLATE_PATH_PARAM_VALUE = /(?<=\{).+?(?=\})/; + + // Parse page URL from the template to get path and search params + const parseTemplate = useCallback((templateString: string | undefined) => { + let template = templateString; + let templateParams = ""; + + if (template) { + const matchSearchParams = template.match( + REGEX_TEMPLATE_SEARCH_PARAMS, + )?.[0]; + + if (matchSearchParams) { + template = template.replace(matchSearchParams, ""); + templateParams = + matchSearchParams.match(REGEX_TEMPLATE_SEARCH_PARAMS_VALUE)?.[0] ?? + ""; + } + } + + // Getting path params + if (template) { + const urlPathParamArr: string[] = []; + + template.split("/").forEach((p) => { + const param = p.match(REGEX_TEMPLATE_PATH_PARAM_VALUE)?.[0]; + + if (param) { + urlPathParamArr.push(param); + } + }); + + setUrlPathparams(urlPathParamArr.join(",")); + } + + return { + templatePath: template ?? "", + templateParams: templateParams ?? "", + }; + // Not including RegEx const + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + const [formError, setFormError] = useState({}); + const [requestUrl, setRequestUrl] = useState(""); + const [urlPath, setUrlPath] = useState(""); + const [urlPathParams, setUrlPathparams] = useState(""); + const [urlParams, setUrlParams] = useState(""); + + const getRpcPostPayloadProps = (endpoint: string) => { + const defaultRpcRequestBody: AnyObject = { + jsonrpc: "2.0", + id: 8675309, + method: pageData?.rpcMethod, + }; + + switch (endpoint) { + case Routes.ENDPOINTS_GET_EVENTS: { + const filteredParams = params.filters ? JSON.parse(params.filters) : {}; + + // do not display the empty string unless its field is filled + const filteredContractIds = filteredParams.contract_ids + ? filteredParams.contract_ids.filter((topic: string) => topic.length) + : []; + // [filter] do not display the empty string unless its field is filled + // [map] Parse the JSON string to JSON + const filteredTopics = filteredParams.topics + ? filteredParams.topics + .filter((topic: string) => topic.length) + .map((item: string) => JSON.parse(item)) + : []; + + return { + ...defaultRpcRequestBody, + params: { + startLedger: Number(params.startLedger), + pagination: { + cursor: params.cursor, + limit: Number(params.limit) || undefined, + }, + filters: [ + { + type: filteredParams.type ?? "", + contractIds: filteredContractIds ?? [], + topics: filteredTopics ?? [], + }, + ], + }, + }; + } + + case Routes.ENDPOINTS_GET_LEDGER_ENTRIES: { + return { + ...defaultRpcRequestBody, + params: { + keys: params.tx ?? "", + }, + }; + } + + case Routes.ENDPOINTS_GET_TRANSACTION: { + return { + ...defaultRpcRequestBody, + params: { + hash: params.transaction ?? "", + }, + }; + } + + case Routes.ENDPOINTS_GET_TRANSACTIONS: { + return { + ...defaultRpcRequestBody, + params: { + startLedger: Number(params.startLedger), + pagination: { + cursor: params.cursor, + limit: Number(params.limit) || undefined, + }, + }, + }; + } + + case Routes.ENDPOINTS_SEND_TRANSACTION: { + return { + ...defaultRpcRequestBody, + params: { + transaction: params.tx ?? "", + }, + }; + } + + case Routes.ENDPOINTS_SIMULATE_TRANSACTION: { + return { + ...defaultRpcRequestBody, + params: { + transaction: params.tx ?? "", + resourceConfig: { + instructionLeeway: Number(params.resourceConfig) || undefined, + }, + }, + }; + } + + default: { + return defaultRpcRequestBody; + } + } + }; + + const getPostPayload = () => { + let payload; + + if (pageData?.requestMethod === "POST") { + if (pathname === Routes.ENDPOINTS_TRANSACTIONS_POST) { + payload = { tx: params.tx ?? "" }; + } + + if (isRpcEndpoint) { + payload = getRpcPostPayloadProps(pathname); + } + } + + return payload; + }; + + const queryClient = useQueryClient(); + const { + data: endpointData, + isLoading, + isFetching, + error: endpointError, + refetch, + isSuccess, + isError, + } = useEndpoint( + requestUrl, + // There is only one endpoint request for POST, using params directly for + // simplicity. + pageData?.requestMethod === "POST" ? getPostPayload() : undefined, + ); + + const responseEl = useRef(null); + + const isSubmitEnabled = () => { + let isValidReqFields = true; + let isValidReqAssetFields = true; + let isValid = true; + + // Checking if all required fields have values + const missingReqFields = requiredFields.reduce((res, cur) => { + if (!params[cur]) { + return [...res, cur]; + } + + return res; + }, [] as string[]); + + isValidReqFields = missingReqFields.length === 0; + + // Checking if there are any errors + isValid = isEmptyObject(formError); + + // Asset components + const assetParams = [ + params.asset, + params.selling_asset, + params.buying_asset, + params.base_asset, + params.counter_asset, + params.destination_asset, + params.source_asset, + ]; + + assetParams.forEach((aParam) => { + // No need to keep checking if one field is invalid + if (!isValidReqAssetFields) { + return; + } + + // When non-native asset is selected, code and issuer fields are required + if (aParam) { + const assetObj = parseJsonString(aParam); + isValidReqAssetFields = validateAssetObj(assetObj); + } + }); + + const isAssetMultiValid = true; + + const assetMulti = [ + params.source_assets, + params.destination_assets, + params.reserves, + ]; + + assetMulti.forEach((a) => { + if (a) { + const saParams = parseJsonString(a); + + saParams.forEach((sa: AssetObjectValue) => { + if (!isAssetMultiValid) { + return; + } + + isValidReqAssetFields = validateAssetObj(sa); + }); + } + }); + + return ( + isValidReqAssetFields && isValidReqFields && isValid && isAssetMultiValid + ); + }; + + const validateAssetObj = (asset: AssetObjectValue) => { + if ( + ["issued", "credit_alphanum4", "credit_alphanum12"].includes( + asset.type as string, + ) + ) { + return Boolean(asset.code && asset.issuer); + } + + return true; + }; + + const resetQuery = useCallback( + () => + queryClient.resetQueries({ + queryKey: ["endpoint", "response"], + }), + [queryClient], + ); + + const resetStates = useCallback(() => { + resetParams(); + setFormError({}); + resetQuery(); + }, [resetParams, resetQuery]); + + useEffect(() => { + // Validate saved params when the page loads + const paramErrors = () => { + return Object.keys(params).reduce((res, param) => { + const error = formComponentTemplateEndpoints(param)?.validate?.( + parseJsonString(params[param]), + requiredFields.includes(param), + ); + + if (error) { + return { ...res, [param]: error }; + } + + return res; + }, {}); + }; + + setFormError(paramErrors()); + + // We want to check this only when the page mounts for the first time + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + const mapParamToValue = (key: string, value: string) => { + const [param, prop] = (value as string)?.split(".") || []; + const mappedValue = parseJsonString(params?.[param])?.[prop]; + + return mappedValue ? { [key]: mappedValue } : {}; + }; + + // Persist mapped custom template props to params + useEffect(() => { + const paramMapping = pageData?.custom?.paramMapping; + + if (paramMapping) { + const mappedParams = Object.entries(paramMapping).reduce( + (res, [key, value]) => { + const mappedVal = mapParamToValue(key, value as string); + + return { ...res, ...mappedVal }; + }, + {} as AnyObject, + ); + + if (!isEmptyObject(mappedParams)) { + updateParams(mappedParams); + } + } + // Run this only once when page loads + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + useEffect(() => { + if (currentPage) { + updateCurrentEndpoint(currentPage); + } + + // Clear form and errors if navigating to another endpoint page. We don't + // want to keep previous form values. + if (currentEndpoint && ![currentPage, "/saved"].includes(currentEndpoint)) { + resetStates(); + } + }, [currentEndpoint, currentPage, resetStates, updateCurrentEndpoint]); + + useEffect(() => { + const { templatePath, templateParams } = parseTemplate( + pageData?.endpointUrlTemplate, + ); + setUrlPath(templatePath); + setUrlParams(templateParams); + }, [pageData?.endpointUrlTemplate, parseTemplate]); + + useEffect(() => { + // Save network for endpoints if we don't have it yet. + if (network.id && !endpointNetwork.id) { + updateNetwork(network as Network); + // When network changes, clear saved params and errors. + } else if ( + network.id && + network.id !== endpointNetwork.id && + !isDynamicNetworkSelect + ) { + resetStates(); + updateNetwork(network as Network); + } + }, [ + endpointNetwork.id, + isDynamicNetworkSelect, + network, + resetStates, + updateNetwork, + ]); + + // Scroll to response + useEffect(() => { + if (isSuccess || isError) { + responseEl?.current?.scrollIntoView({ behavior: "smooth" }); + } + }, [isSuccess, isError]); + + const createAssetString = (asset: AssetObjectValue) => { + if (asset.type === "native") { + return "native"; + } + + return `${asset.code}:${asset.issuer}`; + }; + + const buildUrl = useCallback(() => { + const parseUrlPath = (path: string) => { + const pathArr: string[] = []; + + path.split("/").forEach((p) => { + const param = p.match(REGEX_TEMPLATE_PATH_PARAM_VALUE)?.[0]; + + if (param) { + return pathArr.push(params[param] ?? ""); + } + + return pathArr.push(p); + }); + + return pathArr.join("/"); + }; + + const baseUrl = isRpcEndpoint + ? `${endpointNetwork.rpcUrl}${parseUrlPath(urlPath)}` + : `${endpointNetwork.horizonUrl}${parseUrlPath(urlPath)}`; + + if (pageData?.requestMethod === "POST") { + return baseUrl; + } + + const searchParams = new URLSearchParams(); + const templateParams = urlParams?.split(","); + + const getParamRequestValue = (param: string) => { + const value = parseJsonString(params[param]); + + // Boolean values + if (!value && typeof value !== "boolean") { + return false; + } + + // Asset string + if (["asset", "selling", "buying"].includes(param)) { + return createAssetString(value); + } + + // Comma separated assets string + if (["source_assets", "destination_assets", "reserves"].includes(param)) { + return sanitizeArray( + value.map((v: AssetObjectValue) => + isEmptyObject(sanitizeObject(v)) ? undefined : createAssetString(v), + ), + ).join(","); + } + + return `${value}`; + }; + + // Build search params keeping the same params order + templateParams?.forEach((p) => { + const paramVal = getParamRequestValue(p); + + if (paramVal) { + searchParams.set(p, paramVal); + } + }); + + const searchParamString = searchParams.toString(); + + return `${baseUrl}${searchParamString ? `?${searchParamString}` : ""}`; + // Not including RegEx const + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [endpointNetwork.horizonUrl, params, urlParams, urlPath]); + + useEffect(() => { + setRequestUrl(buildUrl()); + }, [buildUrl]); + + const handleSubmit = (event: React.FormEvent) => { + event.preventDefault(); + + // Adding a bit of a delay to make sure reset doesn't affect refetch + const delay = isError || isSuccess ? 100 : 0; + + if (delay) { + resetQuery(); + } + + delayedAction({ + action: () => { + refetch(); + }, + delay, + }); + }; + + const renderPostPayload = () => { + let renderedProps = getPostPayload(); + const defaultRowsLength = 5; + + if (pageData?.requestMethod === "POST") { + if (pathname === Routes.ENDPOINTS_TRANSACTIONS_POST) { + renderedProps = { tx: params.tx ?? "" }; + } + + if (isRpcEndpoint) { + renderedProps = getRpcPostPayloadProps(pathname); + } + } + + if (renderedProps) { + const requiredParams = renderedProps.params + ? Object.values(renderedProps.params).filter((val) => val !== undefined) + : undefined; + + const rows = requiredParams + ? requiredParams.length + defaultRowsLength + 2 + : defaultRowsLength; + + return ( +
+ + + + + <> + {!xdr.jsonString || !xdr.type ? ( + + {!xdr.blob + ? "Enter a JSON string to encode." + : "Please select a XDR type"} + + ) : null} + + + + + + + <> + {jsonXdrEncoded?.xdrString ? ( + + ) : null} + + + + + + You can use use this tool to encode JSON into XDR.{" "} + + External Data Representation + {" "} + (XDR) is a standardized protocol that the Stellar network uses to encode + data. The XDR Viewer is a tool that displays contents of a Stellar XDR + blob in a human-readable format. + + + ); +} diff --git a/src/app/(sidebar)/xdr/view/page.tsx b/src/app/(sidebar)/xdr/view/page.tsx new file mode 100644 index 00000000..8dfc7fcd --- /dev/null +++ b/src/app/(sidebar)/xdr/view/page.tsx @@ -0,0 +1,187 @@ +"use client"; + +import { useEffect } from "react"; +import { + Text, + Card, + Alert, + Link, + Loader, + Button, + Icon, + CopyText, +} from "@stellar/design-system"; + +import { useLatestTxn } from "@/query/useLatestTxn"; +import { stringify } from "lossless-json"; +import * as StellarXdr from "@/helpers/StellarXdr"; +import { XDR_TYPE_TRANSACTION_ENVELOPE } from "@/constants/settings"; + +import { Box } from "@/components/layout/Box"; +import { SdsLink } from "@/components/SdsLink"; +import { XdrPicker } from "@/components/FormElements/XdrPicker"; +import { PrettyJson } from "@/components/PrettyJson"; +import { XdrTypeSelect } from "@/components/XdrTypeSelect"; + +import { parseToLosslessJson } from "@/helpers/parseToLosslessJson"; +import { useIsXdrInit } from "@/hooks/useIsXdrInit"; +import { useStore } from "@/store/useStore"; + +export default function ViewXdr() { + const { xdr, network } = useStore(); + const { updateXdrBlob, updateXdrType, resetXdr } = xdr; + + const isXdrInit = useIsXdrInit(); + + const { + data: latestTxn, + error: latestTxnError, + isSuccess: isLatestTxnSuccess, + isFetching: isLatestTxnFetching, + isLoading: isLatestTxnLoading, + refetch: fetchLatestTxn, + } = useLatestTxn(network.horizonUrl); + + useEffect(() => { + if (isLatestTxnSuccess && latestTxn) { + updateXdrBlob(latestTxn); + updateXdrType(XDR_TYPE_TRANSACTION_ENVELOPE); + } + }, [isLatestTxnSuccess, latestTxn, updateXdrBlob, updateXdrType]); + + const isFetchingLatestTxn = isLatestTxnFetching || isLatestTxnLoading; + + const xdrDecodeJson = () => { + if (!(isXdrInit && xdr.blob && xdr.type)) { + return null; + } + + try { + const xdrJson = StellarXdr.decode(xdr.type, xdr.blob); + + return { + jsonString: xdrJson, + error: "", + }; + } catch (e) { + return { + jsonString: "", + error: `Unable to decode input as ${xdr.type}: ${e}`, + }; + } + }; + + const xdrJsonDecoded = xdrDecodeJson(); + + const prettifyJsonString = (jsonString: string): string => { + try { + const parsedJson = parseToLosslessJson(jsonString); + return stringify(parsedJson, null, 2) || ""; + } catch (e) { + return jsonString; + } + }; + + return ( + +
+ + View XDR + +
+ + + + + Input a base-64 encoded XDR blob,{" "} + { + fetchLatestTxn(); + }} + isDisabled={isFetchingLatestTxn} + icon={isFetchingLatestTxn ? : null} + > + or fetch the latest transaction to try it out. + + + } + onChange={(e) => { + updateXdrBlob(e.target.value); + }} + error={latestTxnError?.toString()} + disabled={isFetchingLatestTxn} + /> + + + + <> + {!xdr.blob || !xdr.type ? ( + + {!xdr.blob + ? "Enter a base-64 encoded XDR blob to decode." + : "Please select a XDR type"} + + ) : null} + + + + + + + <> + {xdrJsonDecoded?.jsonString ? ( + +
+ +
+ + + + + + +
+ ) : null} + +
+
+ + + You can use use this tool to decode XDR into JSON.{" "} + + External Data Representation + {" "} + (XDR) is a standardized protocol that the Stellar network uses to encode + data. The XDR Viewer is a tool that displays contents of a Stellar XDR + blob in a human-readable format. + +
+ ); +} diff --git a/src/app/apple-icon.png b/src/app/apple-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..1b2d0223704263a1788e900da67638f1c450128c GIT binary patch literal 2580 zcmbW3=|9v98^(WQrtC}h!`MP(Fp@1{oN%NpWs74Ob&{vP_ZYgzRmY zVIm%~W^0IPlpK>~W-K!p#^d}8&x`xI-rS%2`h4y;*Ejo$v%RR0f)D@zq7D~rU5}jn z?+6?T5clrv*CPW(yV_p>8b+XW01zB;u>IW~J-b%kocn!DHj9BMFu~z)Q$}AYf)mxv z&CQa!H-&_S6@_6iSQ#i6lq;PoQZ3Pq4N!x)-p|X($W!%#2&&ns3aBl1zRM^5T3TGy zDDB^Q-xW3Byx}*xyEJDeSm~mC;i&}_5a*`>E+@pWSzr|QZvlRC56Fz{mJX&Z08rZL zZV(d%h%u!X0JIsvkIq2>7EmnM!p;m(79)e!vx8Jj2HR>KPvw{+!^Pfmi~xLC_@w_E z_x^vPsru`<)k(3 zHX=vE^V5$C?hl~c4(@W}pKHkcY?@*|AmCf?ubRCv{%1w1yq@tg0wDXv^^4LYh!OfJ zraA@AY=HX#9_4n)Cha>b&L&%8d{}{8Q38>CaHXJjn0N6>NPELD?rN7ePUu9ILwlC& zD6_;`8E8@w7&A<=`{wPBn$p0NCUD6a>8|pnpG&%MPd>LCV-_24#C;s+&PJ)*F*>H> zcXa&yl2hVxEKrC70Sp9NC)?c>Di_OiLC)mjxBdplhr!#?f56i%AY_HiQdeqU6F0;( zSyRK5QeNc~x5aOe0Mu#uo8F9+j~inBC!fleChajA`7jdL&%8P%{;$|Rm%FUhK-ERL zb1nNixi+F|gX18aj(zuDD!0!M=~ zAnBFlY2gjJJy^1$LJd?oG$`t>_gQ}B0veViuS?2CE>k@${#rhuZWOVK4dn}?_t=*8 z=XDBE@nKq1B`S2Ls~Np`zw$c$`fEBL#PB-Z%oLM?$fPprp{vZaVtq0%k^N;&ulKLS zq72m9yD#BbX!rxznmdTt-0$hc4rlTp=&rFT7wxqzT!CjTu!IpuT8&rF49ZA4%jqeH zI)sn|E(KyQCtUbFkQS7iIhoLn<7ap=_c;5NQl!m4ER-s zqFd}E5x~6N|Dtr_o(C%H>$_Y|EJrcAUwwybzlb zNIQ6^`76n%X0aPzuU&FImmsd%`W^qrI*%qj=KVgnZs-|j<IV=Anj+ltM5! zMf0pBmi+ibXz(a&y5ftvX>MfIBLuyj4ti<)Y&7#h0y0U;K|9cRF-e!&#*~IzVm;rZ zsY__q5bWfZm4SG%UI)wFcVY;b6(*u@Io)iPhx0I$TA$xQ_l<|yXBc%cv?PZ&l9Q=d z!L4`OfwpOp&CUqD&@rx5;i>xwDft}}DJ?8poj+*2;d>?Qm zSAG9mXslrr#emn6xiU)!H)o1R_K!Qs1OzVhreP46a@-4OSO&(l<9N$+NL)vh?u6g0;5pdIX-n-sV_TImgjtV7XA2-QWB+XC&? zJ1U`ZYQT!KNPNPo)w!TcXOE*g|0HuCh3;&z-}mI^aGeQ2XY0#*!zY=^-&f@HlU_gf z=JU$EKkXqBe{GdBxGi_LR1JGR>;j{XV9&_G92hp3_j;*Hc=1bZ&L^}03}|5niY91CJMLy@D{`X z%fU!65*&(C&TALcZ8?_8Si|s~vR2#n;m$Q3uFD9zR zMg^=|^Eqs_zP%S=zh(5#(fI-oNF&Ko-M787IOw|*zzzc-paNPl*zdmvxrQY*iN<}oD&3lfwy@=&g3TDkw% z1*HCVhPm?Vu%9LOdp_-D-x6h#IQc4?M;)&+#Pj9@7(M8(R&8nr_4cj&%e|!>mld|K zLs1F4)WhX1V3Jod5p_kQ*$t}ef>>4ZDQf3NKKXbF({hM`3v!jdeNLDv2}*KORE+j4 zT!-v1FfLJv8$kq>dh-?Z;LP+SGx8Q5Skjr9>guX*s=w+f6~(3gdA$mLmDmqOaVv`A zQ-`WjeyRg{E1_@suQKrQ@j(|C7j%4lOa})CJa7*k=Ds4Yudf-GU0z;NBod+O>S|KC zBpo$1HEaW0C(_;BO-oBl^!WH_TK4|_P7@Oox_B)uEv#E!UM398x3;$GY@kb}QYL>g zMMp;muPrVvmf}bzlQc6kL#wN+ba!_rbHO^yt*oq2MMVYsYiw+!csy=tFD9<9uPGc3 zlgs7O;dpv_5+;tWz}wZ;#l8Z8fGrFNaCLP>p-_m|VUJ5nN;n^1!SVL?M#ICy?5n=M zo}QndZNGyI2lm-14qyPc@Gb)b1D5eOH#hm+jRwFmG&H2khf^HjwBPS%A7^K0#t{50 z_=nshrct09930ee_n5qAnd?NqoA(8g5%-gfqm!a z=abc0gW9RBt<~NUIKUq(9N15B4%x{^TU#63pPZZ+UrT#lUteb%)GfFV|Gx{z^z=0Q zJ32bj;u&xD_xITbXCd|$SDZ-#$H>TtWj^}*``He*rKP1Net@@_+u7MMhSi?8x3}2_ zwnD&P;3z68(r}E9j#46#5GL9c{OIfJlj496#NXT7)9j5mhlhu36OBfVQ~YhPiv!=n z&p5#ChK2_Ay|J-j@+}nL1~9g_w+of&ihRUkF)A!9WLxlKY-~)L58wy}gKP)C7)ow7a`2buZ34)PfxW&c($=@_0P#KPxMX z#>dC$=H|w<9QhD9aOTP6^z@YdR8>_;`vKV+=md^}f`W`V@J&v~1F>g4Jw1ePh!X*h zg@pym%gfVnpcj$l!^$seA3OnHa0WWX0KWo9Zf-97$as2H}jmZ!JeacH41Rd&CO9~XQy#0?K3z#H8n-(=R^$S k6}@>x?a@(ZndIf=C6kGC{!je>Ar17c{3{tyIrLBE7mXF8F8}}l literal 0 HcmV?d00001 diff --git a/src/app/icon.svg b/src/app/icon.svg new file mode 100644 index 00000000..e85f97c7 --- /dev/null +++ b/src/app/icon.svg @@ -0,0 +1,8 @@ + + + + + diff --git a/src/app/icon1.png b/src/app/icon1.png new file mode 100644 index 0000000000000000000000000000000000000000..5b963270601a8805407f171f210ce45314e10b19 GIT binary patch literal 2667 zcmV-x3Y7JUP)Px4a&$ZY?sPuoCTx>oJ|=@Y3zvOkKO@!fnz@& zltr=L?hVG1>2xw4_S*GQ8vZ0lCNUm)0cTV2nFf9i(CTo24L^sh<#cM@WnCMh0y zf%8zfel6cy>6Rr*P47Ye29fHPx2UG~`>!Rr^qpeMOcZ{n)9J0e>P&`>ciNNOl z_Vl^I&UT5|`Y^A7lL;FCG*MN5D#5|b#O`N{Fk?{HF!J`1ZLXR{MKKNr^dG*Md11Y zXqoqj=eKbCb-w*b0(Juz)C~3G&vFpa_+*k-i&I=sIH->&4*{{-#+JPs-M_(0dgrRe z{0N9gQh>GLCB9T0PaY!bJRS*wuQ-N)&+^ywogZpb4-FJY)_^#xDxvsji9ffGV)j;9;U*{JDyF$O29W z9`c6#_yu7+l}}PUzkm<|hm^_>;4B-@zR$;}34Fjq_H?i9qe_k^oB%7s!|-nLkhag` zp$qI1;G}ekc;+QxJQZ?0;RPn}(2BnOMNu5j$|lAWAQ1c#_)a*+2MEmIp|3ig%8D}nAO!)*?#>Mm=zybbB5Z$A)I{4auPw^<(-4sA>W<3=f)AqE zvl|l2FP@d$_;J2{9|0X6x(^f&%HNJl5Lm#&B4j)zaXb>+=l9AKfgU(XJxn}{64a0H zy_cm4RKUqw^mvvfaXd?EJYwpmOA|0M;Izr{EXDDZDBC~q?cXG=yEFkuPk=L_##5Gz zXOMkppC|2T0`oBAYsH0vcsOHl5~i9@z+U;pLmGb= z6c1+_O~4cjSnG;7p7~iao;CBi-%J=}0Za4{+iTf)hJ<+J1(h%J><| zk7M!)vHXn}nJpd9$ftd8Jc5TfX^{n-5;)zU@io%+kHbtrJVD3eG@}btuMTtU{_zA~ zF61K~=F0Zn;}O%2c$mwAlUY<^!g%KDu!!=BgGA+(7Koqw7G%)zdGpHjg&;oBC8XT!DS^XtzXBOtv%)iHg@@0| zB0mtO0`Y2KWtT5F!dfCBz$5gC@E9Yyg=2oiv_Nsf^OIx>d4{JzXV_goJoF0+lSEq}^jfCF z!+$}cwL?t-;kAhH7$xYyG1dYJKs`J}`AUdBNQ`1F0dX!o%NUIl4MD++%{3Zao!w|xlb4Z1qshj#0X^i5h@A@kNnX!Pk0A1_7>Fyghz+RJlh_~ z)c!*bKn%MR;W5VA2ARq~$O06?W1iTnfs8dv6a*r#^BLvi&Vi3i4#)#OJv^8^x8Wns z0rLt(J}W%t*`0VidGv;P1^mwm55|iVeRCqrEznUOISqBvvp)5Iq46Gd1^C?$?wigw zQGTwo3cpdA9#BJoUw%5bQyXs-6q1*d51&`v81)4B;YsIqs>A0u)hBCZ8cReq0iyfV z=!MmpZQ~pZ7upt_;%0-Y0;=VwR0l4{A>Kart8fy_2~k-)- zx^=4Wc5hPXm3H4^so*zR>-f%hSgctJlmdmP6v(C&CGgC|+1` literal 0 HcmV?d00001 diff --git a/src/app/icon2.png b/src/app/icon2.png new file mode 100644 index 0000000000000000000000000000000000000000..897f472fff7947306e55a80f13cefd66714a948a GIT binary patch literal 7608 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 + +
+ + + {children} + + +
+ + + ); +} diff --git a/src/app/not-found.tsx b/src/app/not-found.tsx new file mode 100644 index 00000000..463af830 --- /dev/null +++ b/src/app/not-found.tsx @@ -0,0 +1,45 @@ +"use client"; + +import { useRouter } from "next/navigation"; +import { Button, Card, Heading, Icon, Text } from "@stellar/design-system"; + +import { Routes } from "@/constants/routes"; +import { LayoutContentContainer } from "@/components/layout/LayoutContentContainer"; +import { Box } from "@/components/layout/Box"; + +export default function NotFound() { + const router = useRouter(); + + const handleBackClick = () => { + router.push(Routes.ROOT); + }; + + return ( + + + + + + Error 404 - Page not found + + + + Oops! The page you’re looking for doesn’t exist. It might have + been removed, had its name changed, or is temporarily unavailable. + + + + + + + + ); +} diff --git a/src/app/page.tsx b/src/app/page.tsx new file mode 100644 index 00000000..24a92532 --- /dev/null +++ b/src/app/page.tsx @@ -0,0 +1,127 @@ +"use client"; + +import { Card, Link, Text, Icon, Logo } from "@stellar/design-system"; + +import { NextLink } from "@/components/NextLink"; +import { LayoutContentContainer } from "@/components/layout/LayoutContentContainer"; +import { InfoCards } from "@/components/InfoCards"; +import { SdsLink } from "@/components/SdsLink"; +import { Box } from "@/components/layout/Box"; + +import { Routes } from "@/constants/routes"; +import { GITHUB_URL } from "@/constants/settings"; +import { openUrl } from "@/helpers/openUrl"; + +export default function Introduction() { + const infoCards = [ + { + id: "stellar-quest", + title: "Stellar Quest", + description: + "Learn to build world-class applications on the Stellar network in a gamified experience", + buttonLabel: "Go to site", + buttonIcon: , + buttonAction: () => openUrl("https://quest.stellar.org/"), + }, + { + id: "tools", + title: "Developer Tools", + description: + "Tools, like the Stellar CLI, for reading and interacting with smart contracts on the Stellar Network", + buttonLabel: "See tools", + buttonIcon: undefined, + buttonAction: () => openUrl("https://developers.stellar.org/docs/tools"), + }, + { + id: "soroban-rpc", + title: "Soroban RPC", + description: "Learn about the Soroban RPC, a RPC gateway to Stellar", + buttonLabel: "Go to docs", + buttonIcon: , + buttonAction: () => + openUrl("https://developers.stellar.org/network/soroban-rpc"), + }, + { + id: "horizon", + title: "Horizon", + description: + "Learn about the Horizon for interacting with the Stellar network", + buttonLabel: "Go to docs", + buttonIcon: , + buttonAction: () => + openUrl("https://developers.stellar.org/network/horizon"), + }, + ]; + + return ( + + +
+ + Stellar Lab + + + + The Stellar Lab is a set of tools that enables people to try out and + learn about the Stellar network. The Lab can{" "} + + build transactions + + ,{" "} + + sign them + + , and{" "} + + submit them to the network + + . It can also make requests to RPC and Horizon endpoints. You can + save your transactions and runbooks for future use. + + + + For Stellar docs, take a look at the{" "} + + Stellar developers site + + . + +
+
+ + + +
+ + + Privacy Policy + + + Terms of Service + + + + + <> + {process.env.NEXT_PUBLIC_COMMIT_HASH ? ( +
{`Commit hash: ${process.env.NEXT_PUBLIC_COMMIT_HASH}`}
+ ) : null} + + } + /> + +
+
+
+ ); +} diff --git a/src/assets/suisseintl-regular-webfont.woff b/src/assets/suisseintl-regular-webfont.woff deleted file mode 100644 index 41d3a65e03f7ce9f9c743cd254b944e185b0d55b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27840 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 diff --git a/src/assets/suisseintl-regular-webfont.woff2 b/src/assets/suisseintl-regular-webfont.woff2 deleted file mode 100644 index 5534e362d2c634c58bc539a926fd2b5ec0a29ca8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21740 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

j{9usd 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 H*y$2vV4P4X diff --git a/src/assets/suisseintlmono-regular-webfont.woff2 b/src/assets/suisseintlmono-regular-webfont.woff2 deleted file mode 100644 index 5c2942d1d5f2d1d2d7deccc5afe6fc3b6f1a496c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19068 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 diff --git a/src/components/CodeBlock.tsx b/src/components/CodeBlock.tsx deleted file mode 100644 index 411f4ea4..00000000 --- a/src/components/CodeBlock.tsx +++ /dev/null @@ -1,37 +0,0 @@ -import Prism from "helpers/prism.js"; -import jsonLinkHighlighter from "helpers/prism-jsonLinkHighlighter.js"; -import scrollOnAnchorOpen from "helpers/scrollOnAnchorOpen.js"; -import { sanitizeHtml } from "helpers/sanitizeHtml"; - -interface CodeBlockProps { - code: string; - language: string; - className?: string; -} - -export const CodeBlock = ({ - code, - language = "json", - className, -}: CodeBlockProps) => { - const getHighlightedCode = () => { - const highlightedCode = Prism.highlight(code, Prism.languages[language]); - - if (language === "json") { - return jsonLinkHighlighter(highlightedCode); - } - - return highlightedCode; - }; - - return ( -

-      
-        {sanitizeHtml(getHighlightedCode())}
-      
-    
- ); -}; diff --git a/src/components/Collapsible.js b/src/components/Collapsible.js deleted file mode 100644 index abeb23ea..00000000 --- a/src/components/Collapsible.js +++ /dev/null @@ -1,24 +0,0 @@ -import React from "react"; - -const hasChildren = (children) => - Array.isArray(children) ? children.some(Boolean) : Boolean(children); - -export const Collapsible = ({ isOpen = false, children }) => { - const [finalIsOpen, setIsOpen] = React.useState(isOpen); - - React.useEffect(() => { - setIsOpen(isOpen); - }, [isOpen]); - - return ( -
- {children} -
- ); -}; diff --git a/src/components/EasySelect.tsx b/src/components/EasySelect.tsx deleted file mode 100644 index 29eb18a8..00000000 --- a/src/components/EasySelect.tsx +++ /dev/null @@ -1,20 +0,0 @@ -import { clickToSelect } from "../helpers/clickToSelect"; - -interface EasySelectProps { - children: React.ReactNode; - plain?: boolean; -} - -// Clicking an EasySelect element will select the contents -export const EasySelect = ({ children, plain, ...props }: EasySelectProps) => { - let className = "EasySelect"; - if (plain) { - className = `${className} EasySelect__plain`; - } - - return ( - - {children} - - ); -}; diff --git a/src/components/EndpointPicker.tsx b/src/components/EndpointPicker.tsx deleted file mode 100644 index 8ea91481..00000000 --- a/src/components/EndpointPicker.tsx +++ /dev/null @@ -1,120 +0,0 @@ -import { findIndex } from "lodash"; -import { endpointsMap } from "data/endpoints"; -import { EndpointItemProps, EndpointItemEndpoint } from "types/types"; - -interface EndpointPickerProps { - onChange: (resource: string, endpoint: string) => void; - currentResource: string; - currentEndpoint: string; -} - -interface ButtonGroupProps { - onChange: (resource: string, endpoint: string) => void; - items: { - id: string; - label: string; - }[]; - selectedIndex: number; -} - -interface ButtonGroupButtonProps { - selected: boolean; - label: string; - onChange: (resource: string, endpoint: string) => void; - id: string; -} - -export const EndpointPicker = ({ - onChange, - currentResource, - currentEndpoint, -}: EndpointPickerProps) => { - const makeItems = (itemMap: { - [key: string]: EndpointItemProps | EndpointItemEndpoint; - }) => - Object.entries(itemMap).map(([key, value]) => ({ - id: key, - label: value.label, - })); - - const resources = makeItems(endpointsMap); - - const ButtonGroupButton = ({ - selected, - label, - onChange, - id, - }: ButtonGroupButtonProps) => ( -
  • onChange(id, "")} - > - {label} -
  • - ); - - const ButtonGroup = ({ - onChange, - items, - selectedIndex, - }: ButtonGroupProps) => ( - - ); - - const renderResourcePicker = () => ( -
    -

    1. Select a resource

    - - onChange(newResource, "")} - selectedIndex={findIndex(resources, { id: currentResource })} - /> -
    - ); - - const renderEndpointPicker = () => { - if (!currentResource) { - return null; - } - - const endpoints = makeItems(endpointsMap[currentResource].endpoints); - - return ( -
    -

    2. Select an endpoint

    - - - onChange(currentResource, newEndpoint) - } - selectedIndex={findIndex(endpoints, { id: currentEndpoint })} - /> -
    - ); - }; - - return ( -
    - {renderResourcePicker()} - {renderEndpointPicker()} -
    - ); -}; diff --git a/src/components/EndpointResult.tsx b/src/components/EndpointResult.tsx deleted file mode 100644 index 3086a78d..00000000 --- a/src/components/EndpointResult.tsx +++ /dev/null @@ -1,57 +0,0 @@ -import { CodeBlock } from "components/CodeBlock"; - -interface EndpointResultProps { - available: boolean; - isError: boolean; - body: any[]; -} - -export const EndpointResult = ({ - available, - isError, - body, -}: EndpointResultProps) => { - if (!available) { - return null; - } - - if (body.length === 0) { - return ( -
    -
    Loading…
    -
    - ); - } - - if (isError) { - return ( -
    -
    - {body.map((code, index) => ( - - ))} -
    -
    - ); - } - - return ( -
    -
    -
    - -
    -
    - {body.map((code, index) => ( - - ))} -
    -
    -
    - ); -}; diff --git a/src/components/EndpointSetup.tsx b/src/components/EndpointSetup.tsx deleted file mode 100644 index df4422ef..00000000 --- a/src/components/EndpointSetup.tsx +++ /dev/null @@ -1,120 +0,0 @@ -import HelpMark from "components/HelpMark.js"; -import { EasySelect } from "components/EasySelect"; -import { - EndpointBuildRequest, - EndpointItemEndpoint, - RequestMethod, -} from "types/types"; - -interface EndpointSetupProps { - onSubmit: () => void; - onUpdate: (param: string, value: string | boolean) => void; - request: EndpointBuildRequest; - endpoint: EndpointItemEndpoint | undefined; - values: any; -} - -export const EndpointSetup = ({ - onSubmit, - onUpdate, - request, - endpoint, - values, -}: EndpointSetupProps) => { - if (!endpoint) { - return null; - } - - const StreamingRow = ({ - onUpdate, - checked, - }: { - onUpdate: (param: string, value: string | boolean) => void; - checked: boolean; - }) => ( -
    - -
    - ); - - const UrlRow = ({ - method, - url, - }: { - method: RequestMethod | undefined; - url: string; - }) => { - return ( -
    - {method} -   - {url} -
    - ); - }; - - const PostDataRow = ({ formData }: { formData: string }) => { - if (!formData) { - return null; - } - - return ( -
    - {formData} -
    - ); - }; - - const SubmitRow = ({ onSubmit }: { onSubmit: () => void }) => { - return ( -
    - -
    - ); - }; - - const renderStreamingRow = () => { - if (endpoint.disableStreaming) { - return null; - } - - return ( - <> -
    - - - ); - }; - - return ( -
    -

    - {endpoint.label} -

    -
    - - {renderStreamingRow()} -
    - - - -
    -
    - ); -}; diff --git a/src/components/ExpandBox/index.tsx b/src/components/ExpandBox/index.tsx new file mode 100644 index 00000000..c0e4b098 --- /dev/null +++ b/src/components/ExpandBox/index.tsx @@ -0,0 +1,46 @@ +import React, { useLayoutEffect, useState } from "react"; +import { delayedAction } from "@/helpers/delayedAction"; +import "./styles.scss"; + +export const ExpandBox = ({ + children, + isExpanded, + offsetTop, + customValue, +}: ( + | { + offsetTop: "xs" | "sm" | "md" | "lg" | "xl" | "xxl"; + customValue?: undefined; + } + | { offsetTop: "custom"; customValue: string } +) & { + children: React.ReactNode; + isExpanded: boolean; +}) => { + const [isOpen, setIsOpen] = useState(false); + + // We need a bit of delay to enable overflow visible when the section is expanded + useLayoutEffect(() => { + if (isExpanded) { + delayedAction({ + action: () => { + setIsOpen(true); + }, + delay: 200, + }); + } else { + setIsOpen(false); + } + }, [isExpanded]); + + return ( +
    +
    {children}
    +
    + ); +}; diff --git a/src/components/ExpandBox/styles.scss b/src/components/ExpandBox/styles.scss new file mode 100644 index 00000000..008b0641 --- /dev/null +++ b/src/components/ExpandBox/styles.scss @@ -0,0 +1,57 @@ +.ExpandBox { + display: grid; + grid-template-rows: 0fr; + transition: + grid-template-rows 100ms ease-out, + margin-top 100ms ease-out; + margin-top: 0; + + &--xs { + margin-top: calc(var(--sds-gap-xs) * -1); + } + + &--sm { + margin-top: calc(var(--sds-gap-sm) * -1); + } + + &--md { + margin-top: calc(var(--sds-gap-md) * -1); + } + + &--lg { + margin-top: calc(var(--sds-gap-lg) * -1); + } + + &--xl { + margin-top: calc(var(--sds-gap-xl) * -1); + } + + &--xxl { + margin-top: calc(var(--sds-gap-xxl) * -1); + } + + &[data-is-expanded="true"] { + grid-template-rows: 1fr; + margin-top: 0; + } + + // Don't want to affect nested ExpandBox + &[data-is-open="true"]:not(:is(.ExpandBox)) { + .ExpandBox__inset { + overflow: visible; + } + } + + &__inset { + overflow: hidden; + } + + // Allow tooltip, etc overflow + &[data-is-open="true"] { + &[data-is-expanded="true"] { + .ExpandBox__inset { + overflow: visible; + } + } + } +} diff --git a/src/components/Footer.tsx b/src/components/Footer.tsx deleted file mode 100644 index 1433ef84..00000000 --- a/src/components/Footer.tsx +++ /dev/null @@ -1,21 +0,0 @@ -export const Footer = () => ( -
    -); diff --git a/src/components/FormComponents/AmountPicker.js b/src/components/FormComponents/AmountPicker.js deleted file mode 100644 index 917c6435..00000000 --- a/src/components/FormComponents/AmountPicker.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; -import PositiveNumberPicker from "./PositiveNumberPicker"; - -// AmountPicker picks a positive amount. It extends the PositiveNumberPicker and -// adds validation rules IN ADDITION to the ones already present in PositiveNumberPicker. -export default function AmountPicker(props) { - return ( - { - if (value.charAt(0) === "-") { - return "Amount can only be a positive number."; - } else if (!value.match(/^[0-9]*(\.[0-9]+){0,1}$/g)) { - return "Amount can only contain numbers and a period for the decimal point."; - } else if (value.match(/\.([0-9]){8,}$/g)) { - return "Amount can only support a precision of 7 decimals."; - } - }} - /> - ); -} diff --git a/src/components/FormComponents/AssetMultiPicker.js b/src/components/FormComponents/AssetMultiPicker.js deleted file mode 100644 index f0d3174d..00000000 --- a/src/components/FormComponents/AssetMultiPicker.js +++ /dev/null @@ -1,73 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; -import AssetPicker from "./AssetPicker"; - -export default function AssetMultiPicker({ - value, - onUpdate, - stringForm = false, - ...props -}) { - return ( - <> - {value.map((asset, index) => ( -
    - - { - onUpdate( - // Immutably update the value at the current index - value.map((oldValue, i) => (i === index ? newValue : oldValue)), - ); - }} - {...props} - /> -
    - ))} - - - ); -} - -AssetMultiPicker.propTypes = { - value: PropTypes.arrayOf( - PropTypes.oneOfType([ - PropTypes.string, - PropTypes.shape({ - type: PropTypes.string, - code: PropTypes.string, - issuer: PropTypes.string, - }), - ]), - ).isRequired, - onUpdate: PropTypes.func.isRequired, - stringForm: PropTypes.bool, -}; diff --git a/src/components/FormComponents/AssetPicker.js b/src/components/FormComponents/AssetPicker.js deleted file mode 100644 index bc382d5c..00000000 --- a/src/components/FormComponents/AssetPicker.js +++ /dev/null @@ -1,293 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; -import assign from "lodash/assign"; -import RadioButtonPicker from "components/FormComponents/RadioButtonPicker.js"; -import PubKeyPicker from "components/FormComponents/PubKeyPicker"; -import PickerError from "components/FormComponents/PickerError.js"; -import TextPicker from "components/FormComponents/TextPicker.js"; -import { LiquidityPoolAssetPicker } from "components/FormComponents/LiquidityPoolAssetPicker"; - -// Value is a string containing the currently selected id (or undefined) -function AssetObjectPicker({ - value, - onUpdate, - disableNative, - includeLiquidityPoolShares, - ...props -}) { - const initialLiquidityPoolValue = { - liquidity_pool: { - assetA: { - type: "", - code: "", - issuer: "", - }, - assetB: { - type: "", - code: "", - issuer: "", - }, - fee: 30, - }, - }; - - const localValue = assign( - { - type: "", - code: "", - issuer: "", - ...(includeLiquidityPoolShares ? initialLiquidityPoolValue : {}), - }, - value, - ); - - const isCredit = - localValue.type === "credit_alphanum4" || - localValue.type === "credit_alphanum12"; - - const isLiquidityPool = localValue.type === "liquidity_pool_shares"; - - const assetButtons = { - ...(!disableNative && { native: "native" }), - credit_alphanum4: "Alphanumeric 4", - credit_alphanum12: "Alphanumeric 12", - ...(includeLiquidityPoolShares && { - liquidity_pool_shares: "Liquidity pool shares", - }), - }; - - const renderAssetInputs = () => { - if (isCredit) { - return ( - <> - - onUpdate( - assign({}, value, { - code: event.target.value, - }), - ) - } - placeholder="Asset Code" - className="picker picker--textInput" - /> - - - onUpdate(assign({}, value, { issuer: issuer })) - } - placeholder="Issuer Account ID" - /> - - ); - } - - if (isLiquidityPool) { - return ( - { - onUpdate( - assign({}, value, { - ...value, - liquidity_pool: lpValue, - }), - ); - }} - /> - ); - } - - return null; - }; - - return ( -
    - { - const newTypeValue = localValue.type === typeValue ? "" : typeValue; - onUpdate( - assign({}, value, { - type: newTypeValue, - code: newTypeValue ? "" : localValue.code, - issuer: newTypeValue ? "" : localValue.issuer, - ...(includeLiquidityPoolShares ? initialLiquidityPoolValue : {}), - }), - ); - }} - className={isCredit ? "picker--spaceBottom" : ""} - items={assetButtons} - /> - {renderAssetInputs()} -
    - ); -} - -function codeValidator(value, ignoreType = false) { - let minLength, maxLength; - if (ignoreType) { - minLength = 1; - maxLength = 12; - } else if (value.type === "credit_alphanum4") { - minLength = 1; - maxLength = 4; - } else if (value.type === "credit_alphanum12") { - minLength = 5; - maxLength = 12; - } else { - return; - } - - let code = value.code || ""; - - if (code && !code.match(/^[a-zA-Z0-9]+$/g)) { - return "Asset code must consist of only letters and numbers."; - } else if (code.length < minLength || code.length > maxLength) { - return `Asset code must be between ${minLength} and ${maxLength} characters long.`; - } -} - -const ASSET_TYPES = { - none: "none", - native: "native", - issued: "issued", -}; -const stringFormRadioOptions = { - [ASSET_TYPES.native]: "Native", - [ASSET_TYPES.issued]: "Issued", -}; -const optionalOptions = { - [ASSET_TYPES.none]: "None", - ...stringFormRadioOptions, -}; -function getAssetType(assetString = "") { - if (assetString === "native") { - return "native"; - } - if (assetString.includes(":")) { - return "issued"; - } - return "none"; -} -function AssetStringPicker({ value, onUpdate, optional, ...props }) { - const assetType = getAssetType(value); - - return ( -
    - { - switch (value) { - case ASSET_TYPES.none: - return onUpdate(""); - case ASSET_TYPES.issued: - return onUpdate(":"); - case ASSET_TYPES.native: - return onUpdate("native"); - } - }} - className={ - assetType === ASSET_TYPES.issued ? "picker--spaceBottom" : "" - } - items={optional ? optionalOptions : stringFormRadioOptions} - /> - {assetType === ASSET_TYPES.issued && - (() => { - const [code, issuer] = value.split(":"); - return ( - <> - { - onUpdate(`${newCode}:${issuer}`); - }} - placeholder="Asset Code" - className="picker picker--textInput picker--spaceBottom" - /> - - { - onUpdate(`${code}:${newIssuer}`); - }} - placeholder="Issuer Account ID" - /> - - ); - })()} -
    - ); -} - -export default function AssetPicker({ - stringForm = false, - value, - optional, - onUpdate, - ...props -}) { - return stringForm ? ( - - ) : ( - - ); -} - -export function AssetPickerWithoutNative({ - stringForm = false, - value, - optional, - onUpdate, - ...props -}) { - return ( - - ); -} - -AssetPicker.propTypes = { - stringForm: PropTypes.bool, - onUpdate: PropTypes.func.isRequired, - value: PropTypes.oneOfType([ - PropTypes.string, - PropTypes.shape({ - type: PropTypes.string.isRequired, - code: PropTypes.string, - issuer: PropTypes.string, - liquidity_pool: PropTypes.shape({ - assetA: PropTypes.shape({ - type: PropTypes.string, - code: PropTypes.string, - issuer: PropTypes.string, - }), - assetB: PropTypes.shape({ - type: PropTypes.string, - code: PropTypes.string, - issuer: PropTypes.string, - }), - fee: PropTypes.number, - }), - }), - ]), -}; diff --git a/src/components/FormComponents/BipPathPicker.tsx b/src/components/FormComponents/BipPathPicker.tsx deleted file mode 100644 index 4350f481..00000000 --- a/src/components/FormComponents/BipPathPicker.tsx +++ /dev/null @@ -1,29 +0,0 @@ -import TextPicker from "./TextPicker"; - -type BipPathPickerProps = { - className?: string; - placeholder?: string; - onUpdate: (val: string) => void; -} & React.InputHTMLAttributes<"input">; - -export const BipPathPicker = ({ - className = "", - placeholder, - ...props -}: BipPathPickerProps) => ( - { - const regexp = /44'\/148'\/(\d+)'/; - const match = regexp.exec(value); - - if (!(match && match[1].length > 0)) { - return "Invalid BIP path. Please provide it in format 44'/148'/x'. We call 44'/148'/0' the primary account"; - } - - return ""; - }} - className={className} - /> -); diff --git a/src/components/FormComponents/BooleanPicker.js b/src/components/FormComponents/BooleanPicker.js deleted file mode 100644 index 52a9f604..00000000 --- a/src/components/FormComponents/BooleanPicker.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; -import RadioButtonPicker from "./RadioButtonPicker"; - -export default function BooleanPicker(props) { - let { value, onUpdate } = props; - - return ( - onUpdate(value)} - items={{ - true: "true", - false: "false", - }} - /> - ); -} diff --git a/src/components/FormComponents/CheckboxButtonPicker.js b/src/components/FormComponents/CheckboxButtonPicker.js deleted file mode 100644 index a46dde0e..00000000 --- a/src/components/FormComponents/CheckboxButtonPicker.js +++ /dev/null @@ -1,59 +0,0 @@ -import React from "react"; -import map from "lodash/map"; - -// @param {object} props.items An object whose keys are the onUpdate values and -// object values are labels the user will see. -// { -// 'valueToBeStored': 'Human Readable Label', -// } -// @param {array} props.value Value is expected to be in an array format containing -// all the keys of the checked items -export default function CheckboxButtonPicker(props) { - let { value, onUpdate, items } = props; - let group = Math.random(); // Allows for tabbing and prevents radio button collisions - - return ( -
    - {map(items, (label, id) => { - return ( - - ); - })} -
    - ); -} - -// Calculate the new value of the array when changing around the array -function calculateNewValue(previousValue, value, checked) { - let valueArray = [].concat(previousValue); - let valueIndex = valueArray.indexOf(value); - let valueExists = valueIndex >= 0; - - if (checked && !valueExists) { - valueArray.push(value); - } - if (!checked && valueExists) { - valueArray.splice(valueIndex, 1); - } - - valueArray.sort(); - return valueArray; -} diff --git a/src/components/FormComponents/ClaimantPicker.js b/src/components/FormComponents/ClaimantPicker.js deleted file mode 100644 index d8ab1d04..00000000 --- a/src/components/FormComponents/ClaimantPicker.js +++ /dev/null @@ -1,344 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; -import { assign, set, isEmpty, unset } from "lodash"; -import { - transformPredicateDataForRender, - addPathDelimiter, -} from "../../helpers/claimantHelpers"; -import OptionsTablePair from "../OptionsTable/Pair"; -import RadioButtonPicker from "./RadioButtonPicker"; -import PubKeyPicker from "./PubKeyPicker"; -import TextPicker from "./TextPicker"; -import TimestampPicker from "./TimestampPicker"; - -// Value is a string containing the currently selected id (or undefined) -function ClaimantObjectPicker({ value, onUpdate, ...props }) { - const localValue = assign( - { - destination: "", - predicate: {}, - }, - value, - ); - - function handleUpdate({ parentPath, type, childValue }) { - const path = type ? addPathDelimiter(parentPath, type) : parentPath; - - let updatedPredicate = localValue.predicate; - - if (!parentPath) { - // Root element - updatedPredicate = {}; - } else { - // Clear parent before adding new value - unset(updatedPredicate, parentPath); - } - - onUpdate( - assign({}, value, { - predicate: set(updatedPredicate, path, childValue), - }), - ); - } - - return ( -
    - - - onUpdate(assign({}, value, { destination })) - } - /> - - {isEmpty(localValue.predicate) ? ( - - ) : ( - renderComponent({ - nodes: transformPredicateDataForRender(localValue.predicate), - onUpdate: handleUpdate, - }) - )} -
    - ); -} - -function getLastItemFromPath(path, size = 1) { - const pathArray = path.split("."); - return pathArray[pathArray.length - size]; -} - -function getNestingLevel(str) { - const regex = /(conditional|unconditional)/g; - return ((str || "").match(regex) || []).length; -} - -function getParentLabel(parentPath) { - return getNestingLevel(parentPath) >= 2 - ? `${parentPath.split(".")[1].toUpperCase()}: ` - : ""; -} - -function getChildValue(val) { - switch (val) { - case "and": - case "or": - return [{}, {}]; - case "not": - case "time": - return {}; - case "absolute": - case "relative": - return ""; - default: - return null; - } -} - -function getComponent(type, parentPath) { - if (type) { - // Parent component - switch (type) { - case "conditional": - case "unconditional": - return Predicate; - case "and": - case "or": - case "not": - case "time": - return PredicateType; - case "absolute": - case "relative": - return PredicateTimeType; - default: - return null; - } - } - - let parentType = getLastItemFromPath(parentPath); - - // If parentType is a number, it means it's an index in array, so we need to - // use its parent instead. - if (!isNaN(parentType)) { - parentType = getLastItemFromPath(parentPath, 2); - } - - // Child component - switch (parentType) { - case "conditional": - return PredicateType; - case "and": - case "or": - case "not": - return Predicate; - case "time": - return PredicateTimeType; - case "absolute": - case "relative": - return PredicateTimeValue; - case "unconditional": - default: - return null; - } -} - -function renderComponent({ nodes, onUpdate }) { - return nodes.map((node, index) => { - const { parentPath, type, value: nodeValue } = node; - const Component = getComponent(type, parentPath); - - return ( - - ); - }); -} - -function Predicate({ parentPath, type, nodeValue, onUpdate }) { - const predicateButtons = { - unconditional: "Unconditional", - conditional: "Conditional", - }; - - const isConditional = type === "conditional"; - - let label; - let parentType = getLastItemFromPath(parentPath); - - if (!parentType) { - label = "Predicate"; - } else if (!isNaN(parentType)) { - label = `${getLastItemFromPath( - parentPath, - 2, - ).toUpperCase()} Predicate ${++parentType}`; - } else { - label = `${parentType.toUpperCase()} Predicate`; - } - - return ( -
    - - - onUpdate({ - parentPath, - type: val, - childValue: {}, - }) - } - items={predicateButtons} - /> - - {isConditional && renderComponent({ nodes: nodeValue, onUpdate })} -
    - ); -} - -function PredicateType({ parentPath, type, nodeValue, onUpdate }) { - const predicateTypeButtons = { - time: "Time", - and: "AND", - or: "OR", - not: "NOT", - }; - - let disabledPredicateTypeButtons; - const hasMaxNestingLevel = getNestingLevel(parentPath) >= 3; - - if (hasMaxNestingLevel) { - disabledPredicateTypeButtons = ["and", "or", "not"]; - } - - return ( -
    - - - onUpdate({ - parentPath, - type: val, - childValue: getChildValue(val), - }) - } - items={predicateTypeButtons} - disabledItems={disabledPredicateTypeButtons} - /> - {hasMaxNestingLevel && ( -

    - Deeper nesting is not allowed. -

    - )} -
    - {nodeValue && - nodeValue.length > 0 && - renderComponent({ nodes: nodeValue, onUpdate })} -
    - ); -} - -function PredicateTimeType({ parentPath, type, nodeValue, onUpdate }) { - const predicateTimeTypeButtons = { - relative: "Relative", - absolute: "Absolute", - }; - - return ( - <> - - - onUpdate({ - parentPath, - type: val, - childValue: getChildValue(val), - }) - } - items={predicateTimeTypeButtons} - /> - - {nodeValue && - nodeValue.length > 0 && - renderComponent({ nodes: nodeValue, onUpdate })} - - ); -} - -function PredicateTimeValue({ parentPath, nodeValue, onUpdate }) { - let inputType = getLastItemFromPath(parentPath); - - function handleUpdate(val) { - onUpdate({ - parentPath, - childValue: val, - }); - } - - return ( - <> - - {inputType === "absolute" && ( - <> - -

    - Unix epoch as a string representing a deadline for when the - claimable balance can be claimed. If the balance is claimed before - the date then this clause of the condition is satisfied. -

    - - )} - {inputType === "relative" && ( - <> - -

    - A relative deadline for when the claimable balance can be claimed. - The value represents the number of seconds since the close time of - the ledger which created the claimable balance. -

    - - )} -
    - - ); -} - -export default function ClaimantPicker({ - stringForm = false, - value, - optional, - onUpdate, - ...props -}) { - return ( - - ); -} - -ClaimantPicker.propTypes = { - onUpdate: PropTypes.func.isRequired, - value: PropTypes.any, -}; diff --git a/src/components/FormComponents/FlagfieldPicker.js b/src/components/FormComponents/FlagfieldPicker.js deleted file mode 100644 index df4e1428..00000000 --- a/src/components/FormComponents/FlagfieldPicker.js +++ /dev/null @@ -1,81 +0,0 @@ -import React from "react"; -import each from "lodash/each"; -import reduce from "lodash/reduce"; -import CheckboxButtonPicker from "./CheckboxButtonPicker"; - -// When all the items are empty, then this picker should be equal to '' - -// @param {object} props.items An object whose keys are the bitfield number -// and values are the label displayed to the user. The keys must be consecutive -// or else it won't work (example: 1, 2, 4, 8, 16...). -// { -// 1: 'Human Readable Label', -// } -export default function FlagfieldPicker(props) { - let { value, onUpdate, items } = props; - // eslint-disable-next-line no-unused-vars - let group = Math.random(); // Allows for tabbing and prevents checkbox collisions - - let parsedValue = parseInt(value); - let pickerValue = []; - if (isInteger(parsedValue)) { - pickerValue = intToExistenceArray(parsedValue); - } - - let statusLine; - if (pickerValue.length > 0) { - let sumItems = [], - total = 0; - each(pickerValue, (bitValue) => { - sumItems.push(`${items[bitValue]} (${bitValue})`); - total += parseInt(bitValue); - }); - statusLine = sumItems.join(" + ") + ` = ${total}`; - } - - return ( -
    -
    - onUpdate(existenceArrayToInt(valueArray))} - items={items} - /> -
    - - {statusLine} -
    - ); -} - -// Converts an integer to an array of strings with decimal representations of the number -// Example: -// int input: 5 -// existence array output: [1, 4] -function intToExistenceArray(inputInt) { - let existenceArray = []; - // iterate through binary representation of number - let binaryArray = inputInt.toString(2).split(""); - each(binaryArray, (binaryValue, index) => { - if (binaryValue === "1") { - existenceArray.push(String(Math.pow(2, binaryArray.length - 1 - index))); // calculate decimal representation of bit in specific index - } - }); - return existenceArray; -} - -// The reverse of intToExistenceArray -function existenceArrayToInt(existenceArray) { - return reduce( - existenceArray, - (result, intValue) => { - return result | parseInt(intValue); - }, - undefined, - ); -} - -function isInteger(input) { - return String(input).match(/^[0-9]*$/g); -} diff --git a/src/components/FormComponents/LedgerPicker.js b/src/components/FormComponents/LedgerPicker.js deleted file mode 100644 index a482139e..00000000 --- a/src/components/FormComponents/LedgerPicker.js +++ /dev/null @@ -1,11 +0,0 @@ -import React from "react"; -import PositiveIntPicker from "./PositiveIntPicker"; - -export default function LedgerPicker(props) { - return ( - - ); -} diff --git a/src/components/FormComponents/LiquidityPoolAssetPicker.tsx b/src/components/FormComponents/LiquidityPoolAssetPicker.tsx deleted file mode 100644 index b6c82ea0..00000000 --- a/src/components/FormComponents/LiquidityPoolAssetPicker.tsx +++ /dev/null @@ -1,76 +0,0 @@ -import { useState, useEffect } from "react"; -import AssetPicker from "components/FormComponents/AssetPicker.js"; -import PositiveNumberPicker from "components/FormComponents/PositiveNumberPicker.js"; -import { AssetWithType, AnyObject } from "types/types"; - -interface LiquidityPoolValue { - assetA: AssetWithType; - assetB: AssetWithType; - fee: number; -} - -interface LiquidityPoolAssetPickerProps { - value: LiquidityPoolValue; - onUpdate: (value: LiquidityPoolValue) => void; - optional?: AnyObject; -} - -export const LiquidityPoolAssetPicker = ({ - value, - onUpdate, - optional, -}: LiquidityPoolAssetPickerProps) => { - const [localState, setLocalState] = useState(value); - - useEffect(() => { - onUpdate(localState); - }, [localState]); - - const updateKeyValue = (key: string, value: T) => { - const updatedValue = { - ...localState, - [key]: value, - }; - - setLocalState(updatedValue); - }; - - return ( -
    -
    Asset A
    -
    - { - updateKeyValue("assetA", assetAValue); - }} - optional={optional} - /> -
    - -
    Asset B
    -
    - { - updateKeyValue("assetB", assetBValue); - }} - optional={optional} - /> -
    - -
    Fee
    -
    - { - updateKeyValue("fee", Number(feeValue)); - }} - /> -

    - For now the only fee supported is 30. -

    -
    -
    - ); -}; diff --git a/src/components/FormComponents/LiquidityPoolId.tsx b/src/components/FormComponents/LiquidityPoolId.tsx deleted file mode 100644 index 55e3a278..00000000 --- a/src/components/FormComponents/LiquidityPoolId.tsx +++ /dev/null @@ -1,15 +0,0 @@ -import TextPicker from "components/FormComponents/TextPicker.js"; - -interface LiquidityPoolIdProps { - value: string; - onUpdate: (key: string, value: string) => void; -} - -// TODO: Do we need to validate Liquidity Pool ID? -export const LiquidityPoolId = ({ value, onUpdate }: LiquidityPoolIdProps) => ( - -); diff --git a/src/components/FormComponents/ManualMultiPicker.js b/src/components/FormComponents/ManualMultiPicker.js deleted file mode 100644 index 7c0e6f0b..00000000 --- a/src/components/FormComponents/ManualMultiPicker.js +++ /dev/null @@ -1,77 +0,0 @@ -import React from "react"; -import isArray from "lodash/isArray"; -import map from "lodash/map"; -import classNames from "classnames"; - -// ManualMultiPicker is a compound picker interface that displays multiple -// instances of a Picker. It is manual in that the user uses to add or reduce -// the amount of pickers displayed. This picker is useful for instances where -// the number of items are more precise (like payment paths) or the picker has a -// compound value (AssetPicker values are objects). - -// @param {array} props.value - Array of values. If empty or non array, then it will default to a zero element array -// @param {Picker|function} props.component - A React Picker component function to be repeated -// @param {object|string} [props.default] - This is the default value for new elements that are added -// @param {function} props.onUpdate - Picker callback function called when the values change. -// @param {stromg} (props.addNewLabel) - Custom label for the `add new` button. -export default function ManualMultiPicker(props) { - let { onUpdate, component } = props; - let values = isArray(props.value) ? props.value : [props.default]; - let addNewLabel = props.addNewLabel || "Add new"; - - return ( -
    - {map(values, (singleValue, index) => { - return ( -
    -
    - - #{index + 1} - - -
    - - - onUpdate(updateValueAt(values, index, newValue)) - } - value={singleValue} - /> -
    - ); - })} -
    - -
    -
    - ); -} - -// Removes a item in specific area of index -function removeValueAt(values, index) { - values = [].concat(values); - values.splice(index, 1); - return values; -} - -// Replaces a value of the array at a specific index -function updateValueAt(values, index, newValue) { - values = values.slice(); - values[index] = newValue; - return values; -} diff --git a/src/components/FormComponents/MemoPicker.js b/src/components/FormComponents/MemoPicker.js deleted file mode 100644 index c0a23e33..00000000 --- a/src/components/FormComponents/MemoPicker.js +++ /dev/null @@ -1,94 +0,0 @@ -import React from "react"; -import assign from "lodash/assign"; -import { UnsignedHyper } from "@stellar/stellar-sdk"; -import RadioButtonPicker from "./RadioButtonPicker"; -import TextPicker from "./TextPicker"; - -export default function MemoPicker(props) { - let { onUpdate } = props; - let contentPicker; - let normalizedValue = assign({}, props.value); - normalizedValue.type = - props.value.type === "" ? "MEMO_NONE" : props.value.type; - - if (normalizedValue.type !== "MEMO_NONE") { - contentPicker = ( - - onUpdate( - assign({}, normalizedValue, { - content: contentValue, - }), - ) - } - placeholder={memoPlaceholder(normalizedValue.type)} - validator={contentValidator.bind(null, normalizedValue)} // Use entire Memo value and not just the content value - /> - ); - } - - return ( -
    - - onUpdate( - assign({}, normalizedValue, { - type: typeValue, - }), - ) - } - className="picker--spaceBottom" - items={{ - MEMO_NONE: "None", - MEMO_TEXT: "Text", - MEMO_ID: "ID", - MEMO_HASH: "Hash", - MEMO_RETURN: "Return", - }} - /> - {contentPicker} -
    - ); -} - -function contentValidator(value) { - switch (value.type) { - case "MEMO_TEXT": - let memoTextBytes = Buffer.byteLength(value.content, "utf8"); - if (memoTextBytes > 28) { - return `MEMO_TEXT accepts a string of up to 28 bytes. ${memoTextBytes} bytes entered.`; - } - break; - case "MEMO_ID": - if (!value.content.match(/^[0-9]*$/g) || value < 0) { - return "MEMO_ID accepts a positive integer."; - } - if ( - value.content !== UnsignedHyper.fromString(value.content).toString() - ) { - return `MEMO_ID is an unsigned 64-bit integer and the max valid - value is 18446744073709551615`; - } - break; - case "MEMO_HASH": - case "MEMO_RETURN": - if (!value.content.match(/^[0-9a-f]{64}$/gi)) { - return `${value.type} accepts a 32-byte hash in hexadecimal format (64 characters).`; - } - break; - } -} - -function memoPlaceholder(type) { - switch (type) { - case "MEMO_TEXT": - return `UTF-8 string of up to 28 bytes`; - case "MEMO_ID": - return `Unsigned 64-bit integer`; - case "MEMO_HASH": - case "MEMO_RETURN": - return `32-byte hash in hexadecimal format (64 [0-9a-f] characters)`; - } -} diff --git a/src/components/FormComponents/MultiPicker.tsx b/src/components/FormComponents/MultiPicker.tsx deleted file mode 100644 index cd4ad943..00000000 --- a/src/components/FormComponents/MultiPicker.tsx +++ /dev/null @@ -1,94 +0,0 @@ -import isArray from "lodash/isArray"; -import isUndefined from "lodash/isUndefined"; -import map from "lodash/map"; -import React from "react"; - -// MultiPicker is a compound picker interface that ensures there is always -// enough rows for the user to add more data. MultiPicker accomplishes this -// by making sure there is only one consecutive empty picker at the end. -// -// An empty element is defined as null, undefined, or ''. This means that only -// string value pickers (like PositiveIntPicker but not AssetPicker) can be -// used inside the MultiPicker. For non string values with no way to empty the -// value (such as radio buttons that can't be cleared), use ManualMultiPicker. - -// @param {array} props.value - Array of values. If empty or non array, then it -// will default to a one element array. The length of the array will be -// normalized to have one empty element at the end. -// @param {function} props.onUpdate - Picker callback function called when the values change. - -type Value = string | undefined; - -type Values = Value[]; - -// Updates a value of the array at a specific index -const updateValueAt = (values: Values, index: number, newValue: Value) => { - values = values.slice(); - values[index] = newValue; - return values; -}; - -const isEmpty = (value: Value) => - value === null || isUndefined(value) || value === ""; - -const arelastTwoEmpty = (values: Values) => - isEmpty(values[values.length - 1]) && isEmpty(values[values.length - 2]); - -// Makes sure there is only one consecutive trailing element in the value array. -// Does not mutate value. -const adjustTrailingEmptyElements = (values: Values) => { - values = values.slice(); - - // Add a trailing empty element. May be removed in the next step - // This is to ensure that we have at least one trailing empty element. In many - // cases, this will cause two trailing empty elements, but it will be removed - // in the next step. - values.push(""); - - // Remove trailing empty elements until there is only one trailing empty element. - // This makes sure we will only have one consecutive trailing element (especially) - // remove the defensive one we just added before. - while (values.length > 1 && arelastTwoEmpty(values)) { - values.pop(); - } - - return values; -}; - -interface MultiPickerProps { - component: React.ComponentType< - { onUpdate: (val: Value) => void } & React.InputHTMLAttributes<"input"> - >; - onUpdate: (val: Values) => void; - value: string[]; -} - -export const MultiPicker = ({ - component, - onUpdate, - value, -}: MultiPickerProps) => { - if (!isArray(value)) { - value = []; - } - - const normalizedValues = adjustTrailingEmptyElements(value); - const SingleComponent = component; - - return ( -
    - {map(normalizedValues, (singleValue, index) => { - return ( - - onUpdate(updateValueAt(normalizedValues, index, newValue)) - } - value={singleValue} - className="picker--spaceBottom" - key={index} - /> - ); - })} -
    - ); -}; diff --git a/src/components/FormComponents/MuxedKeyPicker.tsx b/src/components/FormComponents/MuxedKeyPicker.tsx deleted file mode 100644 index 8249a7ca..00000000 --- a/src/components/FormComponents/MuxedKeyPicker.tsx +++ /dev/null @@ -1,54 +0,0 @@ -import { StrKey } from "@stellar/stellar-sdk"; - -import TextPicker from "components/FormComponents/TextPicker.js"; -import { ImportMark } from "components/ImportMark.js"; -import { useFreighter, freighterGetPublicKey } from "helpers/useFreighter.js"; - -interface MuxedKeyPickerProps { - [key: string]: any; - placeholder?: string; - value: string; - onUpdate: (value: string) => void; -} - -export default function MuxedKeyPicker({ - placeholder, - value, - onUpdate, - ...props -}: MuxedKeyPickerProps) { - const hasFreighter = useFreighter(); - - return ( -
    - { - // TODO: remove when type is added to @stellar/stellar-sdk - // @ts-ignore - if (!StrKey.isValidMed25519PublicKey(value)) { - return "Muxed account address is invalid."; - } - - return null; - }} - /> - - {hasFreighter && ( - - )} -
    - ); -} diff --git a/src/components/FormComponents/NumberFractionPicker.tsx b/src/components/FormComponents/NumberFractionPicker.tsx deleted file mode 100644 index c3bf6bc6..00000000 --- a/src/components/FormComponents/NumberFractionPicker.tsx +++ /dev/null @@ -1,86 +0,0 @@ -import { useState } from "react"; -import RadioButtonPicker from "components/FormComponents/RadioButtonPicker.js"; -import AmountPicker from "components/FormComponents/AmountPicker.js"; -import { NumberFractionValue } from "types/types"; - -enum NumberType { - NUMBER = "NUMBER", - FRACTION = "FRACTION", -} - -interface NumberFractionPickerProps { - value: string | number | NumberFractionValue; - onUpdate: (value: string | number | NumberFractionValue) => void; -} - -export const NumberFractionPicker = (props: NumberFractionPickerProps) => { - const getInitialNumberType = () => { - if (!props.value) { - return NumberType.NUMBER; - } - - if (typeof props.value === "string" || typeof props.value === "number") { - return NumberType.NUMBER; - } - - return NumberType.FRACTION; - }; - - const [numberType, setNumberType] = useState(getInitialNumberType()); - - const handleSwitch = (typeValue: NumberType) => { - props.onUpdate(""); - setNumberType(typeValue); - }; - - const renderInputs = () => { - if (numberType === NumberType.FRACTION) { - return ( -
    - { - props.onUpdate({ - ...((props.value as NumberFractionValue) || {}), - n: Number(value), - }); - }} - placeholder="Numerator" - /> - - {/* Divider */} - / - - { - props.onUpdate({ - ...((props.value as NumberFractionValue) || {}), - d: Number(value), - }); - }} - placeholder="Denominator" - /> -
    - ); - } - - return ; - }; - - return ( -
    - - - {renderInputs()} -
    - ); -}; diff --git a/src/components/FormComponents/OperationPicker.js b/src/components/FormComponents/OperationPicker.js deleted file mode 100644 index 08792174..00000000 --- a/src/components/FormComponents/OperationPicker.js +++ /dev/null @@ -1,14 +0,0 @@ -import React from "react"; -import PositiveIntPicker from "./PositiveIntPicker"; - -export default function OperationPicker(props) { - let { value, onUpdate } = props; - - return ( - onUpdate(value)} - /> - ); -} diff --git a/src/components/FormComponents/OperationTypePicker.tsx b/src/components/FormComponents/OperationTypePicker.tsx deleted file mode 100644 index 77ea5ba7..00000000 --- a/src/components/FormComponents/OperationTypePicker.tsx +++ /dev/null @@ -1,25 +0,0 @@ -import each from "lodash/each"; -import { operationsMap } from "../../data/operations"; -import { SelectPicker } from "./SelectPicker"; - -let operationItemMap: Record = {}; -each(operationsMap, (op) => { - operationItemMap[op.name] = op.label; -}); - -interface OperationTypePickerProps { - value: string; - onUpdate: (val: any) => void; -} - -export const OperationTypePicker = ({ - value, - onUpdate, -}: OperationTypePickerProps) => ( - -); diff --git a/src/components/FormComponents/OrderPicker.js b/src/components/FormComponents/OrderPicker.js deleted file mode 100644 index 5d66c22e..00000000 --- a/src/components/FormComponents/OrderPicker.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; -import RadioButtonPicker from "./RadioButtonPicker"; - -export default function OrderPicker(props) { - let { value, onUpdate } = props; - - return ( - onUpdate(value)} - items={{ - asc: "asc", - desc: "desc", - }} - /> - ); -} diff --git a/src/components/FormComponents/PickerError.js b/src/components/FormComponents/PickerError.js deleted file mode 100644 index 21c196b4..00000000 --- a/src/components/FormComponents/PickerError.js +++ /dev/null @@ -1,13 +0,0 @@ -import React from "react"; -import isString from "lodash/isString"; - -// @param {string} [props.message] - Message will display only if a string is passed in -export default class PickerError extends React.Component { - render() { - let message = this.props.message; - if (isString(message)) { - return

    {message}

    ; - } - return null; - } -} diff --git a/src/components/FormComponents/PositiveIntPicker.js b/src/components/FormComponents/PositiveIntPicker.js deleted file mode 100644 index 2c66cafa..00000000 --- a/src/components/FormComponents/PositiveIntPicker.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; -import TextPicker from "./TextPicker"; - -export default function PositiveIntPicker(props) { - return ( - { - if (value.charAt(0) === "-") { - return "Expected a positive number or zero."; - } else if (!value.match(/^[0-9]*$/g)) { - return "Expected a whole number."; - } - - if (typeof props.validator !== "undefined") { - return props.validator(value); - } - }} - /> - ); -} diff --git a/src/components/FormComponents/PositiveNumberPicker.js b/src/components/FormComponents/PositiveNumberPicker.js deleted file mode 100644 index eadb6529..00000000 --- a/src/components/FormComponents/PositiveNumberPicker.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; -import TextPicker from "./TextPicker"; - -export default function PositiveNumberPicker(props) { - return ( - { - if (value.charAt(0) === "-") { - return "Expected a positive number or zero."; - } else if (!value.match(/^[0-9]*(\.[0-9]+){0,1}$/g)) { - return "Expected a positive number with a period for the decimal point."; - } - - if (typeof props.validator !== "undefined") { - return props.validator(value); - } - }} - /> - ); -} diff --git a/src/components/FormComponents/PubKeyPicker.tsx b/src/components/FormComponents/PubKeyPicker.tsx deleted file mode 100644 index 72a0e1f7..00000000 --- a/src/components/FormComponents/PubKeyPicker.tsx +++ /dev/null @@ -1,58 +0,0 @@ -import { StrKey } from "@stellar/stellar-sdk"; - -import TextPicker from "components/FormComponents/TextPicker.js"; -import { ImportMark } from "components/ImportMark.js"; -import { useFreighter, freighterGetPublicKey } from "helpers/useFreighter.js"; - -interface PubKeyPickerProps { - [key: string]: any; - placeholder?: string; - value: string; - onUpdate: (value: string) => void; -} - -export default function PubKeyPicker({ - placeholder, - value, - onUpdate, - ...props -}: PubKeyPickerProps) { - const hasFreighter = useFreighter(); - - return ( -
    - { - if (value.startsWith("M")) { - // TODO: remove when type is added to stellar-sdk - // @ts-ignore - if (!StrKey.isValidMed25519PublicKey(value)) { - return "Muxed account address is invalid."; - } - } else if (!StrKey.isValidEd25519PublicKey(value)) { - return "Public key is invalid."; - } - - return null; - }} - /> - - {hasFreighter && ( - - )} -
    - ); -} diff --git a/src/components/FormComponents/RadioButtonPicker.js b/src/components/FormComponents/RadioButtonPicker.js deleted file mode 100644 index 6fada8a1..00000000 --- a/src/components/FormComponents/RadioButtonPicker.js +++ /dev/null @@ -1,42 +0,0 @@ -import React from "react"; -import map from "lodash/map"; - -// @param {object} props.items An object whose keys are the onUpdate values and -// object values are labels the user will see. -// { -// 'valueToBeStored': 'Human Readable Label', -// } -export default function RadioButtonPicker(props) { - let { value, onUpdate, items, disabledItems = [] } = props; - let group = Math.random(); // Allows for tabbing and prevents radio button collisions - - return ( -
    - {map(items, (label, id) => { - return ( - - ); - })} -
    - ); -} diff --git a/src/components/FormComponents/RevokeSponsorshipPicker.js b/src/components/FormComponents/RevokeSponsorshipPicker.js deleted file mode 100644 index 1977685c..00000000 --- a/src/components/FormComponents/RevokeSponsorshipPicker.js +++ /dev/null @@ -1,196 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; -import assign from "lodash/assign"; - -import AssetPicker from "./AssetPicker.js"; -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "./PubKeyPicker"; -import { SelectPicker } from "./SelectPicker"; -import SignerPicker from "./SignerPicker"; -import TextPicker from "./TextPicker.js"; - -// Value is a string containing the currently selected id (or undefined) -export default function RevokeSponsorshipPicker({ value, onUpdate, ...props }) { - const localValue = assign({ type: "", fields: {} }, value); - const selectedType = localValue.type; - - const revokeTypes = { - account: "Account", - trustline: "Trustline", - offer: "Offer", - data: "Data", - claimableBalance: "Claimable Balance", - signer: "Signer", - }; - - const fields = { - account: { - account: "", - }, - trustline: { - account: "", - asset: "", - }, - offer: { - seller: "", - offerId: "", - }, - data: { - account: "", - name: "", - }, - claimableBalance: { - balanceId: "", - }, - signer: { - account: "", - signer: "", - }, - }; - - function renderTypeFields() { - if (!selectedType) { - return null; - } - - function handleUpdate(value, field) { - onUpdate( - assign({}, localValue, { - fields: { - ...localValue.fields, - [field]: value, - }, - }), - ); - } - - switch (selectedType) { - case "account": - return ( - - handleUpdate(value, "account")} - /> - - ); - case "trustline": - return ( - <> - - handleUpdate(value, "account")} - /> - - - handleUpdate(value, "asset")} - disableNative - /> - - - ); - case "offer": - return ( - <> - - handleUpdate(value, "seller")} - /> - - - handleUpdate(value, "offerId")} - /> -

    - Offer ID is a number -

    -
    - - ); - case "data": - return ( - <> - - handleUpdate(value, "account")} - /> - - - handleUpdate(value, "name")} - /> - - - ); - case "claimableBalance": - return ( - - handleUpdate(value, "balanceId")} - /> - - ); - case "signer": - return ( - <> - - handleUpdate(value, "account")} - /> - - - handleUpdate(value, "signer")} - disableWeight - /> - - - ); - default: - return null; - } - } - - return ( -
    - - { - const newTypeValue = localValue.type === typeValue ? "" : typeValue; - onUpdate( - assign({}, localValue, { - type: newTypeValue, - fields: newTypeValue ? fields[newTypeValue] : {}, - }), - ); - }} - items={revokeTypes} - /> - - {renderTypeFields()} -
    - ); -} - -RevokeSponsorshipPicker.propTypes = { - onUpdate: PropTypes.func.isRequired, - value: PropTypes.shape({ - type: PropTypes.string, - fields: PropTypes.shape({}), - }), -}; diff --git a/src/components/FormComponents/SecretKeyPicker.js b/src/components/FormComponents/SecretKeyPicker.js deleted file mode 100644 index 1be427f5..00000000 --- a/src/components/FormComponents/SecretKeyPicker.js +++ /dev/null @@ -1,28 +0,0 @@ -import React from "react"; -import { StrKey } from "@stellar/stellar-sdk"; -import TextPicker from "./TextPicker"; - -export default function SecretKeyPicker(props) { - return ( - { - if (value.charAt(0) == "S") { - if (!StrKey.isValidEd25519SecretSeed(value)) { - return "Invalid secret key."; - } - } else { - if (!value.match(/^[0-9a-f]{2,128}$/gi) || value.length % 2 == 1) { - return `Invalid hex value. Please provide up to 64 bytes in hexadecimal format.`; - } - } - }} - className={props.className} - data-testid="secret-key-picker" - /> - ); -} diff --git a/src/components/FormComponents/SelectPicker.tsx b/src/components/FormComponents/SelectPicker.tsx deleted file mode 100644 index c05b24a2..00000000 --- a/src/components/FormComponents/SelectPicker.tsx +++ /dev/null @@ -1,67 +0,0 @@ -import isArray from "lodash/isArray"; -import map from "lodash/map"; - -// @param {object|array} props.items An object whose keys are the onUpdate values and -// object values are labels the user will see. -// { -// 'valueToBeStored': 'Human Readable Label', -// } -// -// For array values, the UI label and onUpdate values are the same. -// The benefit of using an array is that it can contain duplicate items. -interface SelectPickerProps { - className?: string; - items: string[] | Record; - onUpdate: (input: string) => void; - placeholder?: string; - value: string; -} - -export const SelectPicker = ({ - className, - items, - onUpdate, - placeholder, - value, -}: SelectPickerProps) => { - let optionsList; - - if (isArray(items)) { - optionsList = map(items, (value, index) => { - return ( - - ); - }); - } else { - optionsList = map(items, (value, index) => { - return ( - - ); - }); - } - - let selectPlaceholderClass; - - if (value === "") { - selectPlaceholderClass = "so-dropdown__select--placeholder"; - } - - return ( -
    - -
    - ); -}; diff --git a/src/components/FormComponents/SequencePicker.js b/src/components/FormComponents/SequencePicker.js deleted file mode 100644 index 5ee1966b..00000000 --- a/src/components/FormComponents/SequencePicker.js +++ /dev/null @@ -1,14 +0,0 @@ -import React from "react"; -import PositiveIntPicker from "./PositiveIntPicker"; - -export default function SequencePicker(props) { - let { value, onUpdate } = props; - - return ( - onUpdate(value)} - /> - ); -} diff --git a/src/components/FormComponents/SignerPicker.js b/src/components/FormComponents/SignerPicker.js deleted file mode 100644 index 925a19c5..00000000 --- a/src/components/FormComponents/SignerPicker.js +++ /dev/null @@ -1,90 +0,0 @@ -import React from "react"; -import extend from "lodash/extend"; -import PubKeyPicker from "./PubKeyPicker"; -import { SelectPicker } from "./SelectPicker"; -import TextPicker from "./TextPicker"; -import Unsigned8bitIntPicker from "./Unsigned8bitIntPicker"; - -export default function SignerPicker(props) { - let value = extend({ type: null, content: "", weight: null }, props.value); - - const items = { - ed25519PublicKey: "Ed25519 Public Key", - sha256Hash: "sha256 Hash", - preAuthTx: "Pre-authorized Transaction Hash", - }; - - let onUpdate = (val) => { - if (val.type) { - // When changing type clean content. - val.content = ""; - } - value = extend(value, val); - props.onUpdate(value); - }; - - let input = null; - let weight = null; - - switch (value.type) { - case "ed25519PublicKey": - input = ( - { - onUpdate({ content }); - }} - /> - ); - break; - case "sha256Hash": - case "preAuthTx": - input = ( - onUpdate({ content })} - placeholder="Accepts a 32-byte hash in hexadecimal format (64 characters)." - validator={hashValidator.bind(null, value.content)} - /> - ); - break; - } - - if (!props.disableWeight && value.type) { - weight = ( -
    - { - onUpdate({ weight }); - }} - /> -

    - Signer will be removed from account if this weight is 0. -

    -
    - ); - } - - return ( -
    - { - onUpdate({ type }); - }} - placeholder="Select signer type" - items={items} - className="picker--spaceBottom" - /> - {input} - {weight} -
    - ); -} - -function hashValidator(value) { - if (!value.match(/^[0-9a-f]{64}$/gi)) { - return `Accepts a 32-byte hash in hexadecimal format (64 characters).`; - } -} diff --git a/src/components/FormComponents/StroopsPicker.js b/src/components/FormComponents/StroopsPicker.js deleted file mode 100644 index 7a464400..00000000 --- a/src/components/FormComponents/StroopsPicker.js +++ /dev/null @@ -1,14 +0,0 @@ -import React from "react"; -import PositiveIntPicker from "./PositiveIntPicker"; - -export default function SequencePicker(props) { - let { value, onUpdate } = props; - - return ( - onUpdate(value)} - /> - ); -} diff --git a/src/components/FormComponents/TextPicker.js b/src/components/FormComponents/TextPicker.js deleted file mode 100644 index 3b123c69..00000000 --- a/src/components/FormComponents/TextPicker.js +++ /dev/null @@ -1,33 +0,0 @@ -import React from "react"; -import isFunction from "lodash/isFunction"; -import isString from "lodash/isString"; -import PickerError from "./PickerError"; - -export default function TextPicker(props) { - let { value, onUpdate, validator } = props; - let errorMessage; - - let validatorIsPresent = isFunction(validator); - let valueIsNonEmpty = isString(value) && value.length > 0; - if (validatorIsPresent && valueIsNonEmpty) { - errorMessage = validator(value); - } - - const testId = props["data-testid"]; - - return ( -
    - { - onUpdate(event.target.value); - }} - placeholder={props.placeholder} - className={`picker picker--textInput ${props.className}`} - {...(testId ? { "data-testid": testId } : {})} - /> - -
    - ); -} diff --git a/src/components/FormComponents/TimeBoundsPicker.js b/src/components/FormComponents/TimeBoundsPicker.js deleted file mode 100644 index eb4ec25c..00000000 --- a/src/components/FormComponents/TimeBoundsPicker.js +++ /dev/null @@ -1,34 +0,0 @@ -import React from "react"; -import assign from "lodash/assign"; -import TimestampPicker from "./TimestampPicker"; - -export default function TimeBoundsPicker(props) { - let { value, onUpdate } = props; - - return ( -
    - - onUpdate( - assign({}, value, { - minTime: minTimeValue, - }), - ) - } - /> - - onUpdate( - assign({}, value, { - maxTime: maxTimeValue, - }), - ) - } - /> -
    - ); -} diff --git a/src/components/FormComponents/TimestampPicker.js b/src/components/FormComponents/TimestampPicker.js deleted file mode 100644 index c27b2438..00000000 --- a/src/components/FormComponents/TimestampPicker.js +++ /dev/null @@ -1,14 +0,0 @@ -import React from "react"; -import PositiveIntPicker from "./PositiveIntPicker"; - -export default function TimestampPicker(props) { - let { value, placeholder, onUpdate } = props; - - return ( - onUpdate(value)} - /> - ); -} diff --git a/src/components/FormComponents/TransactionPicker.js b/src/components/FormComponents/TransactionPicker.js deleted file mode 100644 index 260996cd..00000000 --- a/src/components/FormComponents/TransactionPicker.js +++ /dev/null @@ -1,31 +0,0 @@ -import React from "react"; -import isString from "lodash/isString"; -import PickerError from "./PickerError"; - -export default function TransactionPicker(props) { - let { value, onUpdate } = props; - - return ( -
    - { - onUpdate(event.target.value); - }} - placeholder="Example: 3389e9f0f1a65f19736cacf544c2e825313e8447f569233bb8db39aa607c8889" - className="picker picker--textInput" - /> - -
    - ); -} - -function validator(value) { - if (!isString(value) || value.length === 0) { - return; - } - if (value.match(/^[0-9a-f]{64}$/g) === null) { - return "Transaction hash is invalid."; - } -} diff --git a/src/components/FormComponents/TxTypePicker.js b/src/components/FormComponents/TxTypePicker.js deleted file mode 100644 index cd9ee174..00000000 --- a/src/components/FormComponents/TxTypePicker.js +++ /dev/null @@ -1,24 +0,0 @@ -/** - * @prettier - */ - -import React from "react"; -import RadioButtonPicker from "./RadioButtonPicker"; -import TX_TYPES from "../../constants/transaction_types"; - -export default function TxTypePicker(props) { - const { onUpdate, value } = props; - return ( -
    - -
    - ); -} diff --git a/src/components/FormComponents/Unsigned8bitIntPicker.js b/src/components/FormComponents/Unsigned8bitIntPicker.js deleted file mode 100644 index 133018ec..00000000 --- a/src/components/FormComponents/Unsigned8bitIntPicker.js +++ /dev/null @@ -1,16 +0,0 @@ -import React from "react"; -import PositiveIntPicker from "./PositiveIntPicker"; - -export default function Unsigned8bitIntPicker(props) { - return ( - { - if (value > 255) { - return "Expected an integer between 0 and 255 (inclusive)."; - } - }} - /> - ); -} diff --git a/src/components/FormComponents/XdrPicker.js b/src/components/FormComponents/XdrPicker.js deleted file mode 100644 index 45efb3a2..00000000 --- a/src/components/FormComponents/XdrPicker.js +++ /dev/null @@ -1,28 +0,0 @@ -import React from "react"; -import isString from "lodash/isString"; -import PickerError from "./PickerError"; - -export default function XdrPicker(props) { - let { value, onUpdate } = props; - - return ( -
    - +); diff --git a/src/components/FriendBot/ErrorMsg.tsx b/src/components/FriendBot/ErrorMsg.tsx new file mode 100644 index 00000000..f08d5d31 --- /dev/null +++ b/src/components/FriendBot/ErrorMsg.tsx @@ -0,0 +1,21 @@ +import { Alert } from "@stellar/design-system"; + +export const ErrorMsg = ({ + onClose, + isVisible, + errorMsg, +}: { + onClose: () => void | undefined; + isVisible: boolean; + errorMsg: string | undefined; +}) => + isVisible ? ( + + {""} + + ) : null; diff --git a/src/components/FriendBot/SuccessMsg.tsx b/src/components/FriendBot/SuccessMsg.tsx new file mode 100644 index 00000000..6eafc7ae --- /dev/null +++ b/src/components/FriendBot/SuccessMsg.tsx @@ -0,0 +1,39 @@ +import { Alert } from "@stellar/design-system"; + +import { useStore } from "@/store/useStore"; + +import { shortenStellarAddress } from "@/helpers/shortenStellarAddress"; + +export const SuccessMsg = ({ + onClose, + publicKey, + isVisible, +}: { + onClose: () => void | undefined; + publicKey: string; + isVisible: boolean; +}) => { + const { network } = useStore(); + const IS_STELLAR_EXPERT_ENABLED = + network.id === "testnet" || network.id === "mainnet"; + + return isVisible ? ( + + {""} + + ) : null; +}; diff --git a/src/components/GenerateKeypair.tsx b/src/components/GenerateKeypair.tsx new file mode 100644 index 00000000..8e4eb28d --- /dev/null +++ b/src/components/GenerateKeypair.tsx @@ -0,0 +1,40 @@ +import { Input } from "@stellar/design-system"; + +export const GenerateKeypair = ({ + publicKey, + secretKey, +}: { + publicKey: string | undefined; + secretKey: string | undefined; +}) => { + return ( +
    + {publicKey && ( + + )} + + {secretKey && ( + + )} +
    + ); +}; diff --git a/src/components/Header.tsx b/src/components/Header.tsx deleted file mode 100644 index c95a439e..00000000 --- a/src/components/Header.tsx +++ /dev/null @@ -1,28 +0,0 @@ -import NetworkPicker from "views/NetworkPicker.js"; - -export const Header = () => ( -
    -
    - -
    -
    -); diff --git a/src/components/HelpMark.js b/src/components/HelpMark.js deleted file mode 100644 index 4b6b5710..00000000 --- a/src/components/HelpMark.js +++ /dev/null @@ -1,36 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; - -// @param {string} props.href - Url that the help mark links to. Currently required -function HelpMark(props) { - return ( - - - - - - - - - ); -} -HelpMark.propTypes = { - href: PropTypes.string.isRequired, -}; - -export default HelpMark; diff --git a/src/components/Hydration.tsx b/src/components/Hydration.tsx new file mode 100644 index 00000000..a9e2e1fa --- /dev/null +++ b/src/components/Hydration.tsx @@ -0,0 +1,14 @@ +"use client"; + +import { useEffect, useState } from "react"; + +// Component to detect when client is ready to be rendered. +export const Hydration = ({ children }: { children: React.ReactNode }) => { + const [isHydrated, setIsHydrated] = useState(false); + + useEffect(() => { + setIsHydrated(true); + }, []); + + return isHydrated ? children : null; +}; diff --git a/src/components/ImportMark.js b/src/components/ImportMark.js deleted file mode 100644 index 20f05883..00000000 --- a/src/components/ImportMark.js +++ /dev/null @@ -1,17 +0,0 @@ -/** @format */ -import React from "react"; - -export const ImportMark = ({ width = 32, height = width, ...props }) => ( - - Import Public Key via Freighter Button - - -); diff --git a/src/components/InfoCards/index.tsx b/src/components/InfoCards/index.tsx new file mode 100644 index 00000000..77ceed07 --- /dev/null +++ b/src/components/InfoCards/index.tsx @@ -0,0 +1,32 @@ +import { Button, Card, Text } from "@stellar/design-system"; +import { InfoCard } from "@/types/types"; +import "./styles.scss"; + +export const InfoCards = ({ infoCards }: { infoCards: InfoCard[] }) => { + return ( +
    + {infoCards.map((c) => ( + + + {c.title} + + + + {c.description} + + +
    + +
    +
    + ))} +
    + ); +}; diff --git a/src/components/InfoCards/styles.scss b/src/components/InfoCards/styles.scss new file mode 100644 index 00000000..bddb43d8 --- /dev/null +++ b/src/components/InfoCards/styles.scss @@ -0,0 +1,20 @@ +@use "../../styles/utils.scss" as *; + +.InfoCards { + display: grid; + gap: pxToRem(12px); + grid-template-columns: 1fr 1fr; + + .Card { + display: flex; + flex-direction: column; + gap: pxToRem(8px); + justify-content: space-between; + // needed height: auto; to fix sizing issue on safari + height: auto; + + :nth-child(2) { + flex: 1; + } + } +} diff --git a/src/components/InputSideElement/index.tsx b/src/components/InputSideElement/index.tsx new file mode 100644 index 00000000..0905af5b --- /dev/null +++ b/src/components/InputSideElement/index.tsx @@ -0,0 +1,67 @@ +import { Button } from "@stellar/design-system"; +import "./styles.scss"; + +type InputSideElementProps = ( + | { + variant: "text"; + onClick?: undefined; + disabled?: undefined; + title?: undefined; + icon?: undefined; + } + | { + variant: "button"; + onClick: () => void; + disabled?: boolean; + title?: string; + icon?: React.ReactNode; + } +) & { + children?: string; + placement: "left" | "right"; + isLoading?: boolean; + addlClassName?: string; +}; + +export const InputSideElement = ({ + variant, + children, + onClick, + disabled, + title, + placement = "right", + isLoading, + addlClassName, + icon, + ...props +}: InputSideElementProps) => { + if (variant === "text") { + return ( +
    + {children} +
    + ); + } + + return ( +
    + +
    + ); +}; diff --git a/src/components/InputSideElement/styles.scss b/src/components/InputSideElement/styles.scss new file mode 100644 index 00000000..64a307fb --- /dev/null +++ b/src/components/InputSideElement/styles.scss @@ -0,0 +1,52 @@ +@use "../../styles/utils.scss" as *; + +.InputSideElement { + flex-shrink: 0; + flex-grow: 0; + + &--text { + font-size: pxToRem(14px); + line-height: pxToRem(20px); + font-weight: var(--sds-fw-semi-bold); + color: var(--sds-clr-gray-12); + background-color: var(--sds-clr-gray-01); + height: 100%; + display: flex; + align-items: center; + flex-shrink: 0; + flex-grow: 0; + padding: pxToRem(6px) pxToRem(10px); + } + + &--left { + border-right: 1px solid var(--Input-color-border); + margin-left: calc(var(--Input-padding-horizontal) * -1); + border-top-left-radius: var(--Input-border-radius); + border-bottom-left-radius: var(--Input-border-radius); + + .Button { + border-top-left-radius: var(--Input-border-radius); + border-bottom-left-radius: var(--Input-border-radius); + border-top-right-radius: 0; + border-bottom-right-radius: 0; + } + } + + &--right { + border-left: 1px solid var(--Input-color-border); + margin-right: calc(var(--Input-padding-horizontal) * -1); + border-top-right-radius: var(--Input-border-radius); + border-bottom-right-radius: var(--Input-border-radius); + + .Button { + border-top-right-radius: var(--Input-border-radius); + border-bottom-right-radius: var(--Input-border-radius); + border-top-left-radius: 0; + border-bottom-left-radius: 0; + } + } + + .Button { + border: none; + } +} diff --git a/src/components/LoadingView.tsx b/src/components/LoadingView.tsx deleted file mode 100644 index dc95b088..00000000 --- a/src/components/LoadingView.tsx +++ /dev/null @@ -1,43 +0,0 @@ -interface LoadingViewProps { - pastDelay: boolean; - error: any; -} - -export const LoadingView = ({ pastDelay, error }: LoadingViewProps) => { - if (error) { - return ( -
    -
    -

    - There was a problem loading this page. If your network connection is - still working, try reloading. -

    -

    - -

    -
    - View stack trace -
    {error.stack}
    -
    -
    -
    - ); - } - - if (pastDelay) { - return ( -
    -
    loading…
    -
    - ); - } - - return null; -}; diff --git a/src/components/MainNav.tsx b/src/components/MainNav.tsx new file mode 100644 index 00000000..ab9f34ab --- /dev/null +++ b/src/components/MainNav.tsx @@ -0,0 +1,78 @@ +import { ReactNode } from "react"; +import { usePathname } from "next/navigation"; +import { Icon } from "@stellar/design-system"; + +import { Routes } from "@/constants/routes"; +import { NextLink } from "@/components/NextLink"; + +type NavLink = { + href: Routes | string; + label: string; + icon?: ReactNode; +}; + +const primaryNavLinks: NavLink[] = [ + { + href: Routes.ROOT, + label: "Introduction", + }, + { + href: Routes.VIEW_XDR, + label: "View XDR", + }, + { + href: Routes.ACCOUNT_CREATE, + label: "Account", + }, + { + href: Routes.ENDPOINTS, + label: "Endpoints", + }, + { + href: Routes.BUILD_TRANSACTION, + label: "Transactions", + }, + // TODO: hide until ready + // { + // href: Routes.SMART_CONTRACTS, + // label: "Smart Contracts", + // }, + { + href: "https://developers.stellar.org/", + label: "View Docs", + icon: , + }, +]; + +export const MainNav = () => { + const pathname = usePathname(); + + const isActiveRoute = (link: string) => { + if (link.startsWith("http")) { + return false; + } + + return pathname.split("/")[1] === link.split("/")[1]; + }; + + const NavItem = ({ link }: { link: NavLink }) => ( + + {link.label} + + {link.icon ? {link.icon} : null} + + ); + + return ( + + ); +}; diff --git a/src/components/MaintenanceBanner.tsx b/src/components/MaintenanceBanner.tsx index 4b5038f6..94fef7e0 100644 --- a/src/components/MaintenanceBanner.tsx +++ b/src/components/MaintenanceBanner.tsx @@ -1,93 +1,58 @@ -import React, { useState, useEffect } from "react"; -import { fetchMaintenanceData } from "helpers/fetchMaintenanceData"; -import { isMaintenanceRelevant } from "helpers/isMaintenanceRelevant"; -import { sanitizeHtml } from "helpers/sanitizeHtml"; -import { useRedux } from "hooks/useRedux"; -import { Network, StatusPageScheduled } from "types/types"; - -const sortMaintenanceSchedule = (schedule: StatusPageScheduled[]) => - schedule.sort( - (a, b) => - new Date(a.scheduled_for).getTime() - new Date(b.scheduled_for).getTime(), - ); - -export const MaintenanceBanner = () => { - const { network } = useRedux("network"); - const currentNetwork = network.current.name; - const [maintenance, setMaintenance] = useState< - StatusPageScheduled[] | null - >(); - const [error, setError] = useState(null); - - useEffect(() => { - const fetchData = async () => { - try { - const data = await fetchMaintenanceData(); - setMaintenance(sortMaintenanceSchedule(data)); - setError(null); - } catch (e) { - setMaintenance(null); - setError("Failed to fetch testnet reset date."); - } - }; - - fetchData(); - }, []); - - const renderBanner = (message: React.ReactNode) => ( -
    -
    {message}
    -
    - ); - - if (maintenance === undefined) { - return renderBanner(error ?? "Loading testnet information…"); - } - - const relevantMaintenance = isMaintenanceRelevant( - maintenance, - currentNetwork, - ); - - if (!relevantMaintenance) { - return currentNetwork === Network.TEST - ? renderBanner( - <> - Failed to fetch testnet reset date. Check status{" "} - - here - - . - , - ) - : null; - } - - if (relevantMaintenance.length === 0) { - return currentNetwork === Network.TEST - ? renderBanner("The next testnet reset has not yet been scheduled.") - : null; - } - - const nextMaintenance = relevantMaintenance[0]; - const date = new Date(nextMaintenance.scheduled_for); - - return renderBanner( - <> - - {nextMaintenance.name} - {" "} - on {date.toDateString()} at {date.toTimeString()} - {nextMaintenance.incident_updates.map((update) => ( -
    {sanitizeHtml(update.body)}
    - ))} - , - ); -}; +import React from "react"; +import { Banner, Link } from "@stellar/design-system"; + +import { getRelevantMaintenanceMsg } from "@/helpers/getRelevantMaintenanceMsg"; +import { sanitizeHtml } from "@/helpers/sanitizeHtml"; +import { useMaintenanceData } from "@/query/useMaintenanceData"; +import { useStore } from "@/store/useStore"; + +export const MaintenanceBanner = () => { + const { network } = useStore(); + const { data, error, isFetching, isLoading } = useMaintenanceData(); + + const relevantMaintenance = getRelevantMaintenanceMsg(network.id, data); + + const renderBanner = (message: React.ReactNode) => ( +
    + {message} +
    + ); + + if (isFetching || isLoading) { + return null; + } + + if (error) { + return renderBanner(error.message); + } + + if (!relevantMaintenance) { + return network.id === "testnet" + ? renderBanner( + <> + Failed to fetch testnet reset date. Check status{" "} + here. + , + ) + : null; + } + + if (relevantMaintenance.length === 0) { + return null; + } + + const nextMaintenance = relevantMaintenance[0]; + const date = new Date(nextMaintenance.scheduled_for); + + return renderBanner( + <> + + {nextMaintenance.name} + {" "} + on {date.toDateString()} at {date.toTimeString()} + {nextMaintenance.incident_updates.map((update) => ( +
    {sanitizeHtml(update.body)}
    + ))} + , + ); +}; diff --git a/src/components/MuxedAccountResult.tsx b/src/components/MuxedAccountResult.tsx new file mode 100644 index 00000000..a426e529 --- /dev/null +++ b/src/components/MuxedAccountResult.tsx @@ -0,0 +1,50 @@ +import { Input } from "@stellar/design-system"; + +import { PubKeyPicker } from "@/components/FormElements/PubKeyPicker"; + +export const MuxedAccountResult = ({ + baseAddress, + muxedId, + muxedAddress, +}: { + baseAddress: string; + muxedId: string; + muxedAddress: string; +}) => ( +
    + + + + + +
    +); diff --git a/src/components/Navigation.tsx b/src/components/Navigation.tsx deleted file mode 100644 index ed60e53c..00000000 --- a/src/components/Navigation.tsx +++ /dev/null @@ -1,63 +0,0 @@ -import SLUG from "constants/slug.js"; -import { useRedux } from "hooks/useRedux"; - -const navItems = [ - { - label: "Introduction", - slug: SLUG.HOME, - }, - { - label: "Create Account", - slug: SLUG.ACCOUNT_CREATOR, - }, - { - label: "Explore Endpoints", - slug: SLUG.EXPLORER, - }, - { - label: "Build Transaction", - slug: SLUG.TXBUILDER, - }, - { - label: "Sign Transaction", - slug: SLUG.TXSIGNER, - }, - { - label: "Submit Transaction", - slug: SLUG.TXSUBMITTER, - }, - { - label: "View XDR", - slug: SLUG.XDRVIEWER, - }, -]; - -export const Navigation = () => { - const { routing } = useRedux("routing"); - - // TODO: add test for active nav item - - return ( -
    -
    - -
    -
    - ); -}; diff --git a/src/components/NetworkIndicator/index.tsx b/src/components/NetworkIndicator/index.tsx new file mode 100644 index 00000000..efa869e1 --- /dev/null +++ b/src/components/NetworkIndicator/index.tsx @@ -0,0 +1,20 @@ +import "./styles.scss"; + +export const NetworkIndicator = ({ + networkId, + networkLabel, +}: { + networkId: string; + networkLabel: string; +}) => { + return ( +
    + + {networkLabel} +
    + ); +}; diff --git a/src/components/NetworkIndicator/styles.scss b/src/components/NetworkIndicator/styles.scss new file mode 100644 index 00000000..09b9a331 --- /dev/null +++ b/src/components/NetworkIndicator/styles.scss @@ -0,0 +1,34 @@ +@use "../../styles/utils.scss" as *; + +.NetworkIndicator { + --NetworkSelector-dot-color: var(--sds-clr-gray-09); + + display: flex; + align-items: center; + gap: pxToRem(4px); + + font-size: pxToRem(14px); + line-height: pxToRem(20px); + font-weight: var(--sds-fw-medium); + color: var(--sds-clr-gray-12); + + &__dot { + display: block; + width: pxToRem(6px); + height: pxToRem(6px); + border-radius: pxToRem(3px); + background-color: var(--NetworkSelector-dot-color); + + &[data-network="futurenet"] { + --NetworkSelector-dot-color: var(--sds-clr-mint-09); + } + + &[data-network="testnet"] { + --NetworkSelector-dot-color: var(--sds-clr-pink-09); + } + + &[data-network="mainnet"] { + --NetworkSelector-dot-color: var(--sds-clr-lime-09); + } + } +} diff --git a/src/components/NetworkSelector/index.tsx b/src/components/NetworkSelector/index.tsx new file mode 100644 index 00000000..a584dde9 --- /dev/null +++ b/src/components/NetworkSelector/index.tsx @@ -0,0 +1,398 @@ +import React, { + useCallback, + useEffect, + useLayoutEffect, + useRef, + useState, +} from "react"; +import { Button, Icon, Input, Notification } from "@stellar/design-system"; + +import { NetworkIndicator } from "@/components/NetworkIndicator"; +import { localStorageSavedNetwork } from "@/helpers/localStorageSavedNetwork"; +import { delayedAction } from "@/helpers/delayedAction"; +import { NetworkOptions } from "@/constants/settings"; +import { useStore } from "@/store/useStore"; +import { Network, NetworkType } from "@/types/types"; + +import "./styles.scss"; + +export const NetworkSelector = () => { + const { + network, + isDynamicNetworkSelect, + selectNetwork, + updateIsDynamicNetworkSelect, + } = useStore(); + + const [activeNetworkId, setActiveNetworkId] = useState(network.id); + const [isDropdownActive, setIsDropdownActive] = useState(false); + const [isDropdownVisible, setIsDropdownVisible] = useState(false); + + const initialCustomState = { + horizonUrl: network.id === "custom" ? network.horizonUrl : "", + rpcUrl: network.id === "custom" ? network.rpcUrl : "", + passphrase: network.id === "custom" ? network.passphrase : "", + }; + + const [customNetwork, setCustomNetwork] = useState(initialCustomState); + const [mainnetRpc, setMainnetRpc] = useState(""); + const buttonRef = useRef(null); + const dropdownRef = useRef(null); + + const isSameNetwork = () => { + if (activeNetworkId === "custom") { + return ( + network.horizonUrl && + network.rpcUrl && + network.passphrase && + customNetwork.horizonUrl === network.horizonUrl && + customNetwork.rpcUrl === network.rpcUrl && + customNetwork.passphrase === network.passphrase + ); + } + + if (activeNetworkId === "mainnet") { + return ( + network.horizonUrl && + network.rpcUrl && + network.passphrase && + mainnetRpc === network.rpcUrl + ); + } + + return activeNetworkId === network.id; + }; + + const isNetworkUrlInvalid = (url: string) => { + if (!url) { + return ""; + } + + try { + new URL(url); + return ""; + } catch (e) { + return "Value is not a valid URL"; + } + }; + + const isSubmitDisabled = + isSameNetwork() || + // custom network + (activeNetworkId === "custom" && + !(customNetwork.horizonUrl && customNetwork.passphrase)) || + Boolean( + customNetwork.horizonUrl && isNetworkUrlInvalid(customNetwork.horizonUrl), + ) || + // mainnet ; + Boolean( + activeNetworkId === "mainnet" && + Boolean(mainnetRpc && isNetworkUrlInvalid(mainnetRpc)), + ); + + const isCustomNetwork = activeNetworkId === "custom"; + const isMainnetNetwork = activeNetworkId === "mainnet"; + + const setNetwork = useCallback(() => { + if (!network?.id) { + const defaultNetwork = + localStorageSavedNetwork.get() || getNetworkById("testnet"); + + if (defaultNetwork) { + selectNetwork(defaultNetwork); + setActiveNetworkId(defaultNetwork.id); + } + } + + if (network.id === "mainnet") { + setMainnetRpc(network?.rpcUrl || ""); + } + }, [network.id, network?.rpcUrl, selectNetwork]); + + // Set default network on launch + useEffect(() => { + setNetwork(); + }, [setNetwork]); + + useEffect(() => { + if (isDynamicNetworkSelect) { + setActiveNetworkId(network.id); + localStorageSavedNetwork.set(network as Network); + } + // Not including network + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [isDynamicNetworkSelect, network.id]); + + const handleKeyPress = useCallback( + (event: KeyboardEvent) => { + if (event.key === "Escape") { + toggleDropdown(false); + } + + if (event.key === "Enter" && !isSubmitDisabled) { + handleSelectNetwork(event); + } + }, + // eslint-disable-next-line react-hooks/exhaustive-deps + [isSubmitDisabled], + ); + + const handleClickOutside = useCallback( + (event: MouseEvent) => { + if ( + dropdownRef?.current?.contains(event.target as Node) || + buttonRef?.current?.contains(event.target as Node) + ) { + return; + } + + toggleDropdown(false); + setActiveNetworkId(network.id); + setCustomNetwork({ + horizonUrl: network.horizonUrl ?? "", + rpcUrl: network.rpcUrl ?? "", + passphrase: network.passphrase ?? "", + }); + }, + [network.id, network.horizonUrl, network.rpcUrl, network.passphrase], + ); + + // Close dropdown when clicked outside + useLayoutEffect(() => { + if (isDropdownVisible) { + document.addEventListener("pointerup", handleClickOutside); + document.addEventListener("keyup", handleKeyPress); + } else { + document.removeEventListener("pointerup", handleClickOutside); + document.removeEventListener("keyup", handleKeyPress); + } + + return () => { + document.removeEventListener("pointerup", handleClickOutside); + document.removeEventListener("keyup", handleKeyPress); + }; + }, [isDropdownVisible, handleClickOutside, handleKeyPress]); + + const handleSelectNetwork = ( + event: React.FormEvent | KeyboardEvent, + ) => { + event.preventDefault(); + + const networkData = getNetworkById(activeNetworkId); + + if (networkData) { + const getData = () => { + if (isCustomNetwork) { + return { ...networkData, ...customNetwork }; + } + if (isMainnetNetwork) { + return { ...networkData, rpcUrl: mainnetRpc }; + } + return networkData; + }; + + const latestData = getData(); + + selectNetwork(latestData); + setCustomNetwork( + networkData.id === "custom" ? customNetwork : initialCustomState, + ); + localStorageSavedNetwork.set(latestData); + toggleDropdown(false); + updateIsDynamicNetworkSelect(false); + } + }; + + const handleSelectActive = (networkId: NetworkType) => { + setActiveNetworkId(networkId); + setCustomNetwork(initialCustomState); + }; + + const getNetworkById = (networkId: NetworkType) => { + return NetworkOptions.find((op) => op.id === networkId); + }; + + const getButtonLabel = () => { + if (activeNetworkId === "custom") { + return "Switch to Custom Network"; + } + + return `Switch to ${getNetworkById(activeNetworkId)?.label}`; + }; + + const toggleDropdown = (show: boolean) => { + const delay = 100; + + if (show) { + setIsDropdownActive(true); + delayedAction({ + action: () => { + setIsDropdownVisible(true); + }, + delay, + }); + } else { + setIsDropdownVisible(false); + delayedAction({ + action: () => { + setIsDropdownActive(false); + }, + delay, + }); + } + }; + + const getRpcValue = () => { + if (isCustomNetwork) { + return customNetwork.rpcUrl; + } + if (isMainnetNetwork) { + return mainnetRpc; + } + return getNetworkById(activeNetworkId)?.rpcUrl; + }; + + const horizonValue = isCustomNetwork + ? customNetwork.horizonUrl + : getNetworkById(activeNetworkId)?.horizonUrl; + const passphraseValue = isCustomNetwork + ? customNetwork.passphrase + : getNetworkById(activeNetworkId)?.passphrase; + + return ( +
    + +
    +
    +
    + {NetworkOptions.map((op) => ( +
    handleSelectActive(op.id)} + tabIndex={0} + data-testid="networkSelector-option" + > + + {op.id === activeNetworkId ? ( +
    + Selected +
    + ) : null} +
    + ))} +
    + +
    + {activeNetworkId === "futurenet" ? ( + } + > + Futurenet is an unstable network. We recommend using Testnet for + your development purposes. + + ) : null} + +
    + { + if (isCustomNetwork) { + setCustomNetwork({ + ...customNetwork, + rpcUrl: e.target.value, + }); + } + if (isMainnetNetwork) { + setMainnetRpc(e.target.value); + } + }} + error={ + isMainnetNetwork + ? isNetworkUrlInvalid(mainnetRpc) + : isNetworkUrlInvalid(customNetwork.rpcUrl) + } + tabIndex={0} + copyButton={{ + position: "right", + }} + /> + + setCustomNetwork({ + ...customNetwork, + horizonUrl: e.target.value, + }) + } + error={isNetworkUrlInvalid(customNetwork.horizonUrl)} + tabIndex={0} + copyButton={{ + position: "right", + }} + /> + + setCustomNetwork({ + ...customNetwork, + passphrase: e.target.value, + }) + } + tabIndex={0} + copyButton={{ + position: "right", + }} + /> + +
    +
    +
    +
    +
    + ); +}; diff --git a/src/components/NetworkSelector/styles.scss b/src/components/NetworkSelector/styles.scss new file mode 100644 index 00000000..bda7576e --- /dev/null +++ b/src/components/NetworkSelector/styles.scss @@ -0,0 +1,149 @@ +@use "../../styles/utils.scss" as *; + +.NetworkSelector { + --NetworkSelector-color-background-default: var(--sds-clr-gray-01); + --NetworkSelector-color-border: var(--sds-clr-gray-06); + + --NetworkSelector-color-background-hover: var(--sds-clr-gray-02); + --NetworkSelector-color-background-active: var(--sds-clr-gray-02); + --NetworkSelector-box-shadow-color: var(--sds-clr-gray-05); + + --NetworkSelector-border-radius: #{pxToRem(6px)}; + --NetworkSelector-padding-vertical: #{pxToRem(6px)}; + --NetworkSelector-padding-horizontal: #{pxToRem(10px)}; + --NetworkSelector-box-shadow-size: 0; + + position: relative; + + // Button + &__button { + display: flex; + align-items: center; + gap: pxToRem(8px); + + transition: background-color var(--sds-anim-transition-default); + padding: var(--NetworkSelector-padding-vertical) + var(--NetworkSelector-padding-horizontal); + background-color: var(--NetworkSelector-color-background-default); + border: 1px solid var(--NetworkSelector-color-border); + border-radius: var(--NetworkSelector-border-radius); + cursor: pointer; + + @media (hover: hover) { + &:hover { + background-color: var(--NetworkSelector-color-background-hover); + } + } + + svg { + display: block; + width: pxToRem(14px); + height: pxToRem(14px); + stroke: var(--sds-clr-gray-09); + } + + .NetworkIndicator { + font-weight: var(--sds-fw-semi-bold); + } + } + + // Floater + &__floater { + z-index: 2; + top: calc(100% + 0.5rem); + right: 0; + left: auto; + bottom: auto; + transform: none; + display: none; + opacity: 0; + min-width: pxToRem(360px); + + &[data-is-active="true"] { + display: block; + } + + &[data-is-visible="true"] { + opacity: 1; + } + } + + // Body + &__body { + padding: pxToRem(4px); + + &__links { + display: flex; + flex-direction: column; + gap: pxToRem(4px); + } + + &__link { + display: flex; + align-items: center; + justify-content: space-between; + gap: pxToRem(24px); + padding: pxToRem(6px) pxToRem(8px); + cursor: pointer; + background-color: transparent; + border-radius: pxToRem(4px); + transition: background-color var(--sds-anim-transition-default); + + @media (hover: hover) { + &:hover { + background-color: var(--sds-clr-gray-03); + } + } + + &[data-is-active="true"] { + background-color: var(--sds-clr-gray-03); + cursor: default; + } + + &__note { + font-size: pxToRem(12px); + line-height: pxToRem(18px); + color: var(--sds-clr-gray-11); + font-weight: var(--sds-fw-medium); + text-wrap: nowrap; + text-align: right; + } + } + + &__inputs { + display: grid; + gap: pxToRem(8px); + padding: pxToRem(6px) pxToRem(8px); + background-color: transparent; + border-radius: pxToRem(4px); + transition: background-color var(--sds-anim-transition-default); + + form { + display: flex; + flex-direction: column; + gap: pxToRem(12px); + background-color: var(--sds-clr-gray-01); + border-radius: pxToRem(6px); + border: 1px solid var(--sds-clr-gray-06); + padding: pxToRem(12px); + + // TODO: temp fix until SDS is fixed (tooltip overlap) + // Adjusting form element z-index to fix "Copied" tooltip overlap + & > * { + &:nth-child(1) { + z-index: 4; + } + &:nth-child(2) { + z-index: 3; + } + &:nth-child(3) { + z-index: 2; + } + &:nth-child(4) { + z-index: 1; + } + } + } + } + } +} diff --git a/src/components/NextLink.tsx b/src/components/NextLink.tsx new file mode 100644 index 00000000..ec041f04 --- /dev/null +++ b/src/components/NextLink.tsx @@ -0,0 +1,28 @@ +import { ComponentProps } from "react"; +import Link from "next/link"; + +type LinkProps = ComponentProps & { + "sds-variant"?: "primary" | "secondary" | "error" | "success" | "warning"; +}; + +/** `NextLink` is extended `next/link`. */ +export const NextLink = (props: LinkProps) => { + const externalLinkProps = (href: string) => { + const isExternalLink = href?.startsWith("http") || href?.startsWith("//"); + + return isExternalLink + ? { rel: "noreferrer noopener", target: "_blank" } + : {}; + }; + + return ( + + ); +}; diff --git a/src/components/NotFoundPage.tsx b/src/components/NotFoundPage.tsx deleted file mode 100644 index 72ea4030..00000000 --- a/src/components/NotFoundPage.tsx +++ /dev/null @@ -1,9 +0,0 @@ -interface NotFoundPageProps { - children: React.ReactNode; -} - -export const NotFoundPage = ({ children }: NotFoundPageProps) => ( -
    -
    {children}
    -
    -); diff --git a/src/components/OperationPanes/AccountMerge.js b/src/components/OperationPanes/AccountMerge.js deleted file mode 100644 index f8feec88..00000000 --- a/src/components/OperationPanes/AccountMerge.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; - -export default function AccountMerge(props) { - return [ - - { - props.onUpdate("destination", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/AllowTrust.js b/src/components/OperationPanes/AllowTrust.js deleted file mode 100644 index ec4fa911..00000000 --- a/src/components/OperationPanes/AllowTrust.js +++ /dev/null @@ -1,44 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import TextPicker from "../FormComponents/TextPicker.js"; -import RadioButtonPicker from "../FormComponents/RadioButtonPicker.js"; -import PickerError from "../FormComponents/PickerError"; - -export default function AllowTrust(props) { - return [ - - - , - - { - props.onUpdate("trustor", value); - }} - /> - , - - { - props.onUpdate("assetCode", value); - }} - /> - , - - { - props.onUpdate("authorize", value); - }} - items={{ - 0: "unauthorized", - 1: "authorized", - 2: "authorized to maintain liabilities", - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/BeginSponsoringFutureReserves.js b/src/components/OperationPanes/BeginSponsoringFutureReserves.js deleted file mode 100644 index eb3e4159..00000000 --- a/src/components/OperationPanes/BeginSponsoringFutureReserves.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; - -export default function BeginSponsoringFutureReserves(props) { - return [ - - { - props.onUpdate("sponsoredId", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/BumpSequence.js b/src/components/OperationPanes/BumpSequence.js deleted file mode 100644 index a2ad90a1..00000000 --- a/src/components/OperationPanes/BumpSequence.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; - -export default function BumpSequence(props) { - return [ - - { - props.onUpdate("bumpTo", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/ChangeTrust.js b/src/components/OperationPanes/ChangeTrust.js deleted file mode 100644 index 715f7db5..00000000 --- a/src/components/OperationPanes/ChangeTrust.js +++ /dev/null @@ -1,33 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker"; - -export default function ChangeTrust(props) { - return [ - - { - props.onUpdate("asset", value); - }} - includeLiquidityPoolShares - /> - , - - { - props.onUpdate("limit", value); - }} - /> -

    - Leave empty to default to the max int64. -
    - Set to 0 to remove the trust line. -

    -
    , - ]; -} diff --git a/src/components/OperationPanes/ClaimClaimableBalance.js b/src/components/OperationPanes/ClaimClaimableBalance.js deleted file mode 100644 index 3023cc1a..00000000 --- a/src/components/OperationPanes/ClaimClaimableBalance.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; - -export default function ClaimClaimableBalance(props) { - return [ - - { - props.onUpdate("balanceId", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/Clawback.js b/src/components/OperationPanes/Clawback.js deleted file mode 100644 index 8ec611ef..00000000 --- a/src/components/OperationPanes/Clawback.js +++ /dev/null @@ -1,36 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import AmountPicker from "../FormComponents/AmountPicker.js"; - -export default function Clawback(props) { - return [ - - { - props.onUpdate("asset", value); - }} - /> - , - - { - props.onUpdate("from", value); - }} - /> - , - - { - props.onUpdate("amount", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/ClawbackClaimableBalance.js b/src/components/OperationPanes/ClawbackClaimableBalance.js deleted file mode 100644 index decfb402..00000000 --- a/src/components/OperationPanes/ClawbackClaimableBalance.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; - -export default function ClawbackClaimableBalance(props) { - return [ - - { - props.onUpdate("balanceId", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/CreateAccount.js b/src/components/OperationPanes/CreateAccount.js deleted file mode 100644 index 82c80274..00000000 --- a/src/components/OperationPanes/CreateAccount.js +++ /dev/null @@ -1,26 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import AmountPicker from "../FormComponents/AmountPicker.js"; - -export default function CreateAccount(props) { - return [ - - { - props.onUpdate("destination", value); - }} - /> - , - - { - props.onUpdate("startingBalance", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/CreateClaimableBalance.js b/src/components/OperationPanes/CreateClaimableBalance.js deleted file mode 100644 index 168dd9fd..00000000 --- a/src/components/OperationPanes/CreateClaimableBalance.js +++ /dev/null @@ -1,39 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import ManualMultiPicker from "../FormComponents/ManualMultiPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import ClaimantPicker from "../FormComponents/ClaimantPicker.js"; - -export default function CreateClaimableBalance(props) { - return [ - - { - props.onUpdate("asset", value); - }} - /> - , - - { - props.onUpdate("amount", value); - }} - /> - , - - { - props.onUpdate("claimants", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/EndSponsoringFutureReserves.js b/src/components/OperationPanes/EndSponsoringFutureReserves.js deleted file mode 100644 index 15a339d3..00000000 --- a/src/components/OperationPanes/EndSponsoringFutureReserves.js +++ /dev/null @@ -1,3 +0,0 @@ -export default function EndSponsoringFutureReserves(props) { - return null; -} diff --git a/src/components/OperationPanes/GenericOffer.js b/src/components/OperationPanes/GenericOffer.js deleted file mode 100644 index 3a47b3bf..00000000 --- a/src/components/OperationPanes/GenericOffer.js +++ /dev/null @@ -1,56 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PositiveNumberPicker from "../FormComponents/PositiveNumberPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import AssetPicker from "../FormComponents/AssetPicker.js"; - -export default function GenericOffer(props, isBuy) { - return [ - - { - props.onUpdate("selling", value); - }} - /> - , - - { - props.onUpdate("buying", value); - }} - /> - , - - { - props.onUpdate(isBuy ? "buyAmount" : "amount", value); - }} - /> -

    - An amount of zero will delete the offer. -

    -
    , - - { - props.onUpdate("price", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/LiquidityPoolDeposit.tsx b/src/components/OperationPanes/LiquidityPoolDeposit.tsx deleted file mode 100644 index 32a60e3b..00000000 --- a/src/components/OperationPanes/LiquidityPoolDeposit.tsx +++ /dev/null @@ -1,68 +0,0 @@ -import OptionsTablePair from "components/OptionsTable/Pair.js"; -import TextPicker from "components/FormComponents/TextPicker.js"; -import AmountPicker from "components/FormComponents/AmountPicker.js"; -import { NumberFractionPicker } from "components/FormComponents/NumberFractionPicker"; -import { NumberFractionValue } from "types/types"; - -interface LiquidityPoolDepositProps { - values: { - liquidityPoolId: string; - maxAmountA: string; - maxAmountB: string; - minPrice: string | number | NumberFractionValue; - maxPrice: string | number | NumberFractionValue; - }; - onUpdate: (key: string, value: string | number | NumberFractionValue) => void; -} - -export const LiquidityPoolDeposit = (props: LiquidityPoolDepositProps) => { - return [ - - { - props.onUpdate("liquidityPoolId", value); - }} - placeholder="Example: 67260c4c1807b262ff851b0a3fe141194936bb0215b2f77447f1df11998eabb9" - /> - , - - { - props.onUpdate("maxAmountA", value); - }} - /> - , - - { - props.onUpdate("maxAmountB", value); - }} - /> - , - - { - props.onUpdate("minPrice", value); - }} - /> -

    - Minimum depositA/depositB price. -

    -
    , - - { - props.onUpdate("maxPrice", value); - }} - /> -

    - Maximum depositA/depositB price. -

    -
    , - ]; -}; diff --git a/src/components/OperationPanes/LiquidityPoolWithdraw.tsx b/src/components/OperationPanes/LiquidityPoolWithdraw.tsx deleted file mode 100644 index 61df9c10..00000000 --- a/src/components/OperationPanes/LiquidityPoolWithdraw.tsx +++ /dev/null @@ -1,51 +0,0 @@ -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker"; -import AmountPicker from "../FormComponents/AmountPicker.js"; - -interface LiquidityPoolWithdrawProps { - values: { - liquidityPoolId: string; - amount: string; - minAmountA: string; - minAmountB: string; - }; - onUpdate: (key: string, value: string) => void; -} - -export const LiquidityPoolWithdraw = (props: LiquidityPoolWithdrawProps) => { - return [ - - { - props.onUpdate("liquidityPoolId", value); - }} - placeholder="Example: 67260c4c1807b262ff851b0a3fe141194936bb0215b2f77447f1df11998eabb9" - /> - , - - { - props.onUpdate("amount", value); - }} - /> - , - - { - props.onUpdate("minAmountA", value); - }} - /> - , - - { - props.onUpdate("minAmountB", value); - }} - /> - , - ]; -}; diff --git a/src/components/OperationPanes/ManageBuyOffer.js b/src/components/OperationPanes/ManageBuyOffer.js deleted file mode 100644 index 85eeee84..00000000 --- a/src/components/OperationPanes/ManageBuyOffer.js +++ /dev/null @@ -1,23 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import GenericOffer from "./GenericOffer"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; - -export default function ManageBuyOffer(props) { - let GenericOfferPickers = GenericOffer(props, true); - return GenericOfferPickers.concat( - - { - props.onUpdate("offerId", value); - }} - /> -

    - If 0, will create a new offer. Existing offer id numbers can be found - using the Offers for Account endpoint. -

    -
    , - ); -} diff --git a/src/components/OperationPanes/ManageData.js b/src/components/OperationPanes/ManageData.js deleted file mode 100644 index 4c62bc6f..00000000 --- a/src/components/OperationPanes/ManageData.js +++ /dev/null @@ -1,45 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; - -export default function ManageData(props) { - let nameValidator = (value) => { - if (value.length > 64) { - return `Entry name can only contain a maximum of 64 characters. ${value.length} entered.`; - } - }; - - let valueValidator = (value) => { - let valueSize = new Buffer(value).length; - if (valueSize > 64) { - return `Entry value can only contain a maximum of 64 bytes. ${valueSize} bytes entered.`; - } - }; - - return [ - - { - props.onUpdate("name", value); - }} - validator={nameValidator} - /> - , - - { - props.onUpdate("value", value); - }} - validator={valueValidator} - /> -

    - If empty, will delete the data entry named in this operation. -
    - Note: The laboratory only supports strings. -

    -
    , - ]; -} diff --git a/src/components/OperationPanes/ManageSellOffer.js b/src/components/OperationPanes/ManageSellOffer.js deleted file mode 100644 index c6bed7b0..00000000 --- a/src/components/OperationPanes/ManageSellOffer.js +++ /dev/null @@ -1,23 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import GenericOffer from "./GenericOffer"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; - -export default function ManageSellOffer(props) { - let GenericOfferPickers = GenericOffer(props); - return GenericOfferPickers.concat( - - { - props.onUpdate("offerId", value); - }} - /> -

    - If 0, will create a new offer. Existing offer id numbers can be found - using the Offers for Account endpoint. -

    -
    , - ); -} diff --git a/src/components/OperationPanes/PathPaymentStrictReceive.js b/src/components/OperationPanes/PathPaymentStrictReceive.js deleted file mode 100644 index d84fd8f0..00000000 --- a/src/components/OperationPanes/PathPaymentStrictReceive.js +++ /dev/null @@ -1,73 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import ManualMultiPicker from "../FormComponents/ManualMultiPicker.js"; - -export default function PathPayment(props) { - return [ - - { - props.onUpdate("destination", value); - }} - /> - , - - { - props.onUpdate("sendAsset", value); - }} - /> -

    - The asset to be deduced from the sender's account -

    -
    , - - { - props.onUpdate("sendMax", value); - }} - /> -

    - The most the sender is willing to spend to take the paths to. Resulting - amount may vary due to the offers in the orderbook. -

    -
    , - - { - props.onUpdate("path", value); - }} - /> - , - - { - props.onUpdate("destAsset", value); - }} - /> -

    - The asset to be received by the destination account -

    -
    , - - { - props.onUpdate("destAmount", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/PathPaymentStrictSend.js b/src/components/OperationPanes/PathPaymentStrictSend.js deleted file mode 100644 index 1a002144..00000000 --- a/src/components/OperationPanes/PathPaymentStrictSend.js +++ /dev/null @@ -1,69 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import ManualMultiPicker from "../FormComponents/ManualMultiPicker.js"; - -export default function PathPayment(props) { - return [ - - { - props.onUpdate("destination", value); - }} - /> - , - - { - props.onUpdate("sendAsset", value); - }} - /> -

    - The asset to be deduced from the sender's account -

    -
    , - - { - props.onUpdate("sendAmount", value); - }} - /> - , - - { - props.onUpdate("path", value); - }} - /> - , - - { - props.onUpdate("destAsset", value); - }} - /> -

    - The minimum amount the destination can receive. -

    -
    , - - { - props.onUpdate("destMin", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/Payment.js b/src/components/OperationPanes/Payment.js deleted file mode 100644 index 361c2d21..00000000 --- a/src/components/OperationPanes/Payment.js +++ /dev/null @@ -1,35 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import AssetPicker from "../FormComponents/AssetPicker.js"; - -export default function Payment(props) { - return [ - - { - props.onUpdate("destination", value); - }} - /> - , - - { - props.onUpdate("asset", value); - }} - /> - , - - { - props.onUpdate("amount", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/RevokeSponsorship.js b/src/components/OperationPanes/RevokeSponsorship.js deleted file mode 100644 index 852ed8f3..00000000 --- a/src/components/OperationPanes/RevokeSponsorship.js +++ /dev/null @@ -1,13 +0,0 @@ -import React from "react"; -import RevokeSponsorshipPicker from "../FormComponents/RevokeSponsorshipPicker"; - -export default function RevokeSponsorship(props) { - return ( - { - props.onUpdate("revoke", value); - }} - /> - ); -} diff --git a/src/components/OperationPanes/SetOptions.js b/src/components/OperationPanes/SetOptions.js deleted file mode 100644 index 1284804e..00000000 --- a/src/components/OperationPanes/SetOptions.js +++ /dev/null @@ -1,234 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker"; -import SignerPicker from "../FormComponents/SignerPicker"; -import TextPicker from "../FormComponents/TextPicker"; -import FlagfieldPicker from "../FormComponents/FlagfieldPicker"; -import Unsigned8bitIntPicker from "../FormComponents/Unsigned8bitIntPicker"; -import HelpMark from "../HelpMark"; - -const accountFlagFieldsSet = { - 1: "Authorization required", - 2: "Authorization revocable", - 4: "Authorization immutable", - 8: "Authorization clawback enabled", -}; - -const accountFlagFieldsClear = { - 1: "Authorization required", - 2: "Authorization revocable", - 8: "Authorization clawback enabled", -}; - -function WarningMessage() { - return ( - <> -

    - This can result in a permanently locked account. Are you sure you know - what you're doing? -

    -

    - - See documentation for multisignature accounts - -

    - - ); -} - -export default function SetOptions(props) { - return [ - - Inflation Destination{" "} - - - } - optional={true} - key="inflationDest" - > - { - props.onUpdate("inflationDest", value); - }} - /> - , - - Set Flags{" "} - - - } - optional={true} - key="setFlags" - > - { - props.onUpdate("setFlags", value); - }} - /> -

    - Selected{" "} - - flags - {" "} - mean to add selected flags in addition to flags already present on the - account. -

    -
    , - - Clear Flags{" "} - - - } - optional={true} - key="clearFlags" - > - { - props.onUpdate("clearFlags", value); - }} - /> -

    - Selected{" "} - - flags - {" "} - mean to remove selected flags already present on the account. -

    -
    , - - Master Weight{" "} - - - } - optional={true} - key="masterWeight" - > - { - props.onUpdate("masterWeight", value); - }} - /> - - , - - Low Threshold{" "} - - - } - optional={true} - key="lowThreshold" - > - { - props.onUpdate("lowThreshold", value); - }} - /> - , - - Medium Threshold{" "} - - - } - optional={true} - key="medThreshold" - > - { - props.onUpdate("medThreshold", value); - }} - /> - - , - - High Threshold{" "} - - - } - optional={true} - key="highThreshold" - > - { - props.onUpdate("highThreshold", value); - }} - /> - - , - - Signer Type{" "} - - - } - optional={true} - key="signer" - > - { - props.onUpdate("signer", value); - }} - /> -

    - Used to add/remove or adjust weight of an additional signer on the - account. -

    -
    , - - Home Domain{" "} - - - } - optional={true} - key="homeDomain" - > - { - props.onUpdate("homeDomain", value); - }} - /> - , - ]; -} diff --git a/src/components/OperationPanes/SetTrustLineFlags.js b/src/components/OperationPanes/SetTrustLineFlags.js deleted file mode 100644 index 0cea1073..00000000 --- a/src/components/OperationPanes/SetTrustLineFlags.js +++ /dev/null @@ -1,69 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import FlagfieldPicker from "../FormComponents/FlagfieldPicker"; -import CheckboxButtonPicker from "../FormComponents/CheckboxButtonPicker"; -import HelpMark from "../HelpMark"; - -const flagsSet = { - authorized: "Authorized", - authorizedToMaintainLiabilities: "Authorized to maintain liabilites", -}; - -const flagsClear = { - authorized: "Authorized", - authorizedToMaintainLiabilities: "Authorized to maintain liabilites", - clawbackEnabled: "Clawback enabled", -}; - -export default function SetTrustLineFlags(props) { - return [ - - { - props.onUpdate("asset", value); - }} - /> - , - - { - props.onUpdate("trustor", value); - }} - /> - , - Set Flags} - optional={true} - key="setFlags" - > - { - props.onUpdate("setFlags", value); - }} - items={flagsSet} - /> - , - Clear Flags} - optional={true} - key="clearFlags" - > - { - props.onUpdate("clearFlags", value); - }} - items={flagsClear} - /> - , - ]; -} diff --git a/src/components/OptionsTable/Pair.js b/src/components/OptionsTable/Pair.js deleted file mode 100644 index 10256900..00000000 --- a/src/components/OptionsTable/Pair.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; - -export default function Pair(props) { - let optionalTextBreak, optionalText; - if (props.optional) { - optionalTextBreak =
    ; - optionalText = ( - (optional) - ); - } - - return ( -
    -
    - {props.label} {optionalTextBreak} - {optionalText} -
    -
    {props.children}
    -
    - ); -} diff --git a/src/components/PrettyJson/index.tsx b/src/components/PrettyJson/index.tsx new file mode 100644 index 00000000..b8254959 --- /dev/null +++ b/src/components/PrettyJson/index.tsx @@ -0,0 +1,256 @@ +import React from "react"; +import { isEmptyObject } from "@/helpers/isEmptyObject"; +import { isValidUrl } from "@/helpers/isValidUrl"; +import { SdsLink } from "@/components/SdsLink"; +import { AnyObject } from "@/types/types"; + +import "./styles.scss"; + +export type CustomKeyValueLinkMap = { + [key: string]: { + text?: string; + getHref: (value: string, key?: string) => string; + condition?: (val: string) => boolean; + }; +}; + +type PrettyJsonProps = { + json: AnyObject; + customKeyValueLinkMap?: CustomKeyValueLinkMap; +}; + +export const PrettyJson = ({ + json, + customKeyValueLinkMap, +}: PrettyJsonProps) => { + if (typeof json !== "object") { + return null; + } + + const Key = ({ children }: { children: string }) => ( +
    + {`"${children}"`} + +
    + ); + const Value = ({ children }: { children: React.ReactNode }) => ( +
    {children}
    + ); + const ValueType = ({ + children, + type, + }: { + children: React.ReactNode; + type: string; + }) => {children}; + const Quotes = () => {'"'}; + const Colon = () => {":"}; + const Comma = () => {","}; + const Bracket = ({ + char, + children, + }: { + char: "{" | "}" | "[" | "]"; + children?: React.ReactNode; + }) => ( + + {char} + {children} + + ); + + const render = (item: any, parentKey?: string): React.ReactElement => { + const renderValue = (item: any, key: string) => { + const custom = customKeyValueLinkMap?.[key]; + + if (custom) { + if (custom.condition && !custom.condition(item)) { + return render(item, key); + } + + const href = custom.getHref(item, key); + + return ( + + {custom.text || item} + + ); + } + + return render(item, key); + }; + + switch (typeof item) { + case "object": + return ( + + {Object.entries(item).map(([key, value]) => { + const keyProp = parentKey ? `${parentKey}-${key}` : key; + + if (typeof value === "object") { + if (value === null) { + return ( +
    +
    + {key} +
    + + null + + +
    + ); + } + + if (Array.isArray(value)) { + if (value.length === 0) { + return ( +
    +
    + {key} +
    + + {`[]`} + + +
    + ); + } + + return ( +
    +
    + {key} + +
    +
    + {value.map((v, index) => { + if (typeof v === "object") { + if (v === null) { + return ( +
    + + null + + +
    + ); + } + + return ( +
    +
    + +
    +
    {render(v)}
    +
    + + +
    +
    + ); + } + + return render(v, key); + })} +
    +
    + + +
    +
    + ); + } + + if (value && isEmptyObject(value)) { + return ( +
    +
    + {key} +
    + + {`{}`} + + +
    + ); + } + + return ( +
    +
    + {key} + +
    +
    {render(value, key)}
    +
    + + +
    +
    + ); + } + + return ( +
    +
    + {key} +
    + {renderValue(value, key)} +
    + ); + })} +
    + ); + case "string": + return ( + + {isValidUrl(item) ? ( + <> + + {item} + + + ) : ( + <> + + + {item} + + + + )} + + + ); + case "function": + return ( + + {`${JSON.stringify(item)}`} + + + ); + default: + return ( + + {`${item}`} + + + ); + } + }; + + return ( +
    + + {render(json)} + +
    + ); +}; diff --git a/src/components/PrettyJson/styles.scss b/src/components/PrettyJson/styles.scss new file mode 100644 index 00000000..bd96d98c --- /dev/null +++ b/src/components/PrettyJson/styles.scss @@ -0,0 +1,47 @@ +@use "../../styles/utils.scss" as *; + +.PrettyJson { + font-family: var(--sds-ff-monospace); + font-size: pxToRem(14px); + line-height: pxToRem(20px); + font-weight: var(--sds-fw-medium); + letter-spacing: -0.5px; + + &__nested { + padding-left: pxToRem(16px); + } + + &__inline { + display: flex; + gap: pxToRem(4px); + } + + &__value { + white-space: nowrap; + + &--string { + color: var(--sds-clr-navy-11); + } + + &--number, + &--bigint { + color: var(--sds-clr-lime-11); + } + + &--boolean { + color: var(--sds-clr-pink-11); + } + } + + &__value, + &__comma, + &__quotes, + &__bracket, + &__key { + color: var(--sds-clr-gray-12); + } + + .Link { + font-family: var(--sds-ff-monospace); + } +} diff --git a/src/components/RadioPicker/index.tsx b/src/components/RadioPicker/index.tsx new file mode 100644 index 00000000..c789feba --- /dev/null +++ b/src/components/RadioPicker/index.tsx @@ -0,0 +1,86 @@ +import React from "react"; +import { Label } from "@stellar/design-system"; +import "./styles.scss"; + +interface RadioPickerProps { + id: string; + selectedOption: string | undefined; + label?: string | React.ReactNode; + labelSuffix?: string | React.ReactNode; + onChange: (optionId: any | undefined, optionValue?: TOptionValue) => void; + options: { + id: string; + label: string; + value?: TOptionValue; + }[]; + fitContent?: boolean; + infoLink?: string; + infoText?: string | React.ReactNode; + disabledOptions?: string[]; +} + +export const RadioPicker = ({ + id, + selectedOption, + label, + labelSuffix, + onChange, + options, + fitContent, + infoLink, + infoText, + disabledOptions, +}: RadioPickerProps) => { + const customStyle = { + ...(fitContent ? { "--RadioPicker-width": "fit-content" } : {}), + } as React.CSSProperties; + + return ( +
    + {label ? ( + + ) : null} +
    + {options.map((o) => { + const opId = `${o.id}-${id}`; + const curId = opId.split("-")[0]; + + const isDisabled = + disabledOptions?.length && disabledOptions.includes(o.id); + + return ( +
    + { + onChange(o.id, o.value); + }} + onClick={() => { + if (curId === selectedOption) { + // Clear selection if selected the same + onChange(undefined); + } + }} + /> + +
    + ); + })} +
    +
    + ); +}; diff --git a/src/components/RadioPicker/styles.scss b/src/components/RadioPicker/styles.scss new file mode 100644 index 00000000..f6e64056 --- /dev/null +++ b/src/components/RadioPicker/styles.scss @@ -0,0 +1,114 @@ +@use "../../styles/utils.scss" as *; + +.RadioPicker { + --RadioPicker-width: 100%; + --RadioPicker-color-text: var(--sds-clr-gray-12); + --RadioPicker-color-background: var(--sds-clr-gray-01); + --RadioPicker-color-border: var(--sds-clr-gray-06); + --RadioPicker-box-shadow-size: 0; + --RadioPicker-box-shadow-color: var(--sds-clr-lilac-06); + + display: flex; + flex-direction: column; + gap: pxToRem(8px); + width: var(--RadioPicker-width); + + &__inset { + display: flex; + flex-direction: column; + gap: pxToRem(8px); + } + + &__options { + display: flex; + align-items: stretch; + justify-content: stretch; + } + + &__item { + flex: 1; + + input[type="radio"] { + opacity: 0; + position: absolute; + z-index: -1; + + &:checked + label { + --RadioPicker-color-text: var(--sds-clr-white); + --RadioPicker-color-background: var(--sds-clr-lilac-09); + --RadioPicker-color-border: var(--sds-clr-lilac-09); + } + + &:focus + label { + --RadioPicker-box-shadow-size: #{pxToRem(2px)}; + z-index: 1000; + } + } + + label { + position: relative; + display: flex; + min-height: 100%; + align-items: center; + justify-content: center; + font-size: pxToRem(12px); + line-height: pxToRem(18px); + font-weight: var(--sds-fw-semi-bold); + color: var(--RadioPicker-color-text); + text-align: center; + padding: pxToRem(4px) pxToRem(16px); + width: 100%; + background-color: var(--RadioPicker-color-background); + border: 1px solid var(--RadioPicker-color-border); + cursor: pointer; + transition: + color var(--sds-anim-transition-default), + background-color var(--sds-anim-transition-default), + border-color var(--sds-anim-transition-default), + box-shadow var(--sds-anim-transition-default); + box-shadow: 0 0 0 var(--RadioPicker-box-shadow-size) + var(--RadioPicker-box-shadow-color); + } + + &:not(:first-child) { + label { + border-left: none; + } + } + + &:first-child { + label { + border-top-left-radius: pxToRem(4px); + border-bottom-left-radius: pxToRem(4px); + } + } + + &:last-child { + label { + border-top-right-radius: pxToRem(4px); + border-bottom-right-radius: pxToRem(4px); + } + } + + &[data-disabled="true"] { + pointer-events: none; + cursor: default; + + input[type="radio"] { + & + label { + --RadioPicker-color-text: var(--sds-clr-gray-09); + --RadioPicker-color-background: var(--sds-clr-gray-03); + --RadioPicker-color-border: var(--sds-clr-gray-06); + } + } + } + + @media (hover: hover) { + &:hover { + --RadioPicker-color-text: var(--sds-clr-base-01); + --RadioPicker-color-background: var(--sds-clr-gray-04); + --RadioPicker-color-border: var(--sds-clr-gray-04); + } + } + } +} diff --git a/src/components/SaveTransactionModal.tsx b/src/components/SaveTransactionModal.tsx new file mode 100644 index 00000000..c8af3d32 --- /dev/null +++ b/src/components/SaveTransactionModal.tsx @@ -0,0 +1,153 @@ +import { useEffect, useState } from "react"; +import { Button, Input, Modal } from "@stellar/design-system"; +import { arrayItem } from "@/helpers/arrayItem"; +import { localStorageSavedTransactions } from "@/helpers/localStorageSavedTransactions"; +import { getSaveItemNetwork } from "@/helpers/getSaveItemNetwork"; +import { useStore } from "@/store/useStore"; +import { SavedTransactionPage } from "@/types/types"; + +type SaveTransactionModalProps = ( + | { + type: "save"; + txnTimestamp?: undefined; + page: SavedTransactionPage; + xdr: string; + } + | { + type: "editName"; + txnTimestamp: number | undefined; + page?: undefined; + xdr?: undefined; + } +) & { + isVisible: boolean; + onClose: (isUpdate?: boolean) => void; +}; + +export const SaveTransactionModal = ({ + type, + page, + xdr, + isVisible, + txnTimestamp, + onClose, +}: SaveTransactionModalProps) => { + const { network, transaction } = useStore(); + const [savedTxnName, setSavedTxnName] = useState(""); + + const allTxns = localStorageSavedTransactions.get(); + const currentTxn = allTxns.find((t) => t.timestamp === txnTimestamp); + const currentTxnIndex = allTxns.findIndex( + (t) => t.timestamp === txnTimestamp, + ); + const currentTxnName = currentTxn?.name || ""; + + useEffect(() => { + if (isVisible && type === "editName") { + setSavedTxnName(currentTxnName); + } + }, [isVisible, type, currentTxnName]); + + const handleClose = (isUpdate?: boolean) => { + setSavedTxnName(""); + onClose(isUpdate); + }; + + if (type === "editName" && txnTimestamp !== undefined) { + return ( + + Edit Saved Transaction +
    + { + setSavedTxnName(e.target.value); + }} + /> +
    + + + + +
    + ); + } + + if (type === "save") { + return ( + + Save Transaction +
    + { + setSavedTxnName(e.target.value); + }} + /> +
    + + + + +
    + ); + } + + return null; +}; diff --git a/src/components/SdsLink.tsx b/src/components/SdsLink.tsx new file mode 100644 index 00000000..98d8b3d6 --- /dev/null +++ b/src/components/SdsLink.tsx @@ -0,0 +1,14 @@ +import NextLink from "next/link"; +import { Props as LinkProps, Link } from "@stellar/design-system"; + +/** Use `SdsLink` instead of `Link` from Stellar Design System to support client-side routing. `SdsLink` uses `next/link` internally. */ +export const SdsLink = (props: LinkProps) => { + return ( + } + > + {props.children} + + ); +}; diff --git a/src/components/SetupPanes/Accounts.js b/src/components/SetupPanes/Accounts.js deleted file mode 100644 index 821e431c..00000000 --- a/src/components/SetupPanes/Accounts.js +++ /dev/null @@ -1,70 +0,0 @@ -import React from "react"; - -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; -import AssetPicker from "../FormComponents/AssetPicker.js"; - -export default function SingleAccount({ onUpdate, values }) { - return ( - <> - - { - onUpdate("sponsor", value); - }} - /> - - - - { - onUpdate("signer", value); - }} - /> - - - - { - onUpdate("asset", value); - }} - /> - - - - { - onUpdate("cursor", value); - }} - /> - - - - { - onUpdate("limit", value); - }} - /> - - - - { - onUpdate("order", value); - }} - /> - - - ); -} diff --git a/src/components/SetupPanes/All.js b/src/components/SetupPanes/All.js deleted file mode 100644 index 48d6247f..00000000 --- a/src/components/SetupPanes/All.js +++ /dev/null @@ -1,42 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; - -export default function All(props) { - return ( -
    - - { - props.onUpdate("cursor", value); - }} - key="cursor" - /> - - - - { - props.onUpdate("limit", value); - }} - key="limit" - /> - - - - { - props.onUpdate("order", value); - }} - key="order" - /> - -
    - ); -} diff --git a/src/components/SetupPanes/AllAssets.js b/src/components/SetupPanes/AllAssets.js deleted file mode 100644 index db614d35..00000000 --- a/src/components/SetupPanes/AllAssets.js +++ /dev/null @@ -1,32 +0,0 @@ -import React from "react"; - -import All from "./All"; -import TextPicker from "../FormComponents/TextPicker.js"; -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; - -export default function AllAssets(props) { - return ( -
    - - { - props.onUpdate("asset_code", value); - }} - /> - - - - { - props.onUpdate("asset_issuer", value); - }} - /> - - - -
    - ); -} diff --git a/src/components/SetupPanes/AllLiquidityPools.tsx b/src/components/SetupPanes/AllLiquidityPools.tsx deleted file mode 100644 index 15ae8bda..00000000 --- a/src/components/SetupPanes/AllLiquidityPools.tsx +++ /dev/null @@ -1,59 +0,0 @@ -import { useEffect } from "react"; -import All from "components/SetupPanes/All.js"; -import OptionsTablePair from "components/OptionsTable/Pair.js"; -import AssetPicker from "components/FormComponents/AssetPicker.js"; -import ManualMultiPicker from "components/FormComponents/ManualMultiPicker.js"; -import { AssetWithType } from "types/types"; - -const NATIVE_TYPE = "native"; - -interface AllLiquidityPoolsProps { - values: { - reserves_assets: AssetWithType[]; - }; - onUpdate: (key: string, value: string) => void; -} - -export const AllLiquidityPools = (props: AllLiquidityPoolsProps) => { - const getReservesString = () => { - if (!props.values.reserves_assets) { - return ""; - } - - return props.values.reserves_assets - .reduce((result: string[], current) => { - if (current.type === NATIVE_TYPE) { - result.push(NATIVE_TYPE); - } else { - if (current?.code && current?.issuer) { - result.push(`${current.code}:${current.issuer}`); - } - } - - return result; - }, []) - .join(","); - }; - - useEffect(() => { - props.onUpdate("reserves", getReservesString()); - }, [props.values.reserves_assets]); - - return ( -
    - - { - props.onUpdate("reserves_assets", value); - }} - /> - - - -
    - ); -}; diff --git a/src/components/SetupPanes/AllOffers.js b/src/components/SetupPanes/AllOffers.js deleted file mode 100644 index 5f3fb1d2..00000000 --- a/src/components/SetupPanes/AllOffers.js +++ /dev/null @@ -1,82 +0,0 @@ -import React from "react"; - -import PubKeyPicker from "../FormComponents/PubKeyPicker"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; -import AssetPicker from "../FormComponents/AssetPicker.js"; - -export default function AllOffers({ values, onUpdate }) { - return ( - <> - - { - onUpdate("sponsor", value); - }} - /> - - - - { - onUpdate("seller", value); - }} - /> - - - - { - onUpdate("selling", value); - }} - /> - - - - { - onUpdate("buying", value); - }} - /> - - - - { - onUpdate("cursor", value); - }} - /> - - - - { - onUpdate("limit", value); - }} - /> - - - - { - onUpdate("order", value); - }} - /> - - - ); -} diff --git a/src/components/SetupPanes/AllWithFailed.js b/src/components/SetupPanes/AllWithFailed.js deleted file mode 100644 index 9ee86dd3..00000000 --- a/src/components/SetupPanes/AllWithFailed.js +++ /dev/null @@ -1,53 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; -import BooleanPicker from "../FormComponents/BooleanPicker"; - -export default function AllWithFailed(props) { - return ( -
    - - { - props.onUpdate("cursor", value); - }} - key="cursor" - /> - - - - { - props.onUpdate("limit", value); - }} - key="limit" - /> - - - - { - props.onUpdate("order", value); - }} - key="order" - /> - - - - { - props.onUpdate("include_failed", value); - }} - key="include_failed" - /> - -
    - ); -} diff --git a/src/components/SetupPanes/ClaimableBalances.js b/src/components/SetupPanes/ClaimableBalances.js deleted file mode 100644 index 9440bd3d..00000000 --- a/src/components/SetupPanes/ClaimableBalances.js +++ /dev/null @@ -1,70 +0,0 @@ -import React from "react"; - -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; -import AssetPicker from "../FormComponents/AssetPicker.js"; - -export default function ClaimableBalances({ onUpdate, values }) { - return ( - <> - - { - onUpdate("sponsor", value); - }} - /> - - - - { - onUpdate("asset", value); - }} - /> - - - - { - onUpdate("claimant", value); - }} - /> - - - - { - onUpdate("cursor", value); - }} - /> - - - - { - onUpdate("limit", value); - }} - /> - - - - { - onUpdate("order", value); - }} - /> - - - ); -} diff --git a/src/components/SetupPanes/FindPaymentPaths.js b/src/components/SetupPanes/FindPaymentPaths.js deleted file mode 100644 index 06f29a7a..00000000 --- a/src/components/SetupPanes/FindPaymentPaths.js +++ /dev/null @@ -1,45 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; - -export default function FindPaymentPaths(props) { - return ( -
    - - { - props.onUpdate("source_account", value); - }} - /> - - - { - props.onUpdate("destination_account", value); - }} - /> - - - { - props.onUpdate("destination_asset", value); - }} - /> - - - { - props.onUpdate("destination_amount", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/FindStrictReceivePaymentPaths.js b/src/components/SetupPanes/FindStrictReceivePaymentPaths.js deleted file mode 100644 index 5f701192..00000000 --- a/src/components/SetupPanes/FindStrictReceivePaymentPaths.js +++ /dev/null @@ -1,53 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import AssetMultiPicker from "../FormComponents/AssetMultiPicker.js"; - -export default function FindStrictReceivePaymentPaths({ values, onUpdate }) { - return ( -
    - - { - onUpdate("source_account", value); - }} - /> - - - { - onUpdate("source_assets", value.join(",")); - }} - /> - - - { - onUpdate("destination_amount", value); - }} - /> - - - { - onUpdate("destination_asset", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/FindStrictSendPaymentPaths.js b/src/components/SetupPanes/FindStrictSendPaymentPaths.js deleted file mode 100644 index 741880a0..00000000 --- a/src/components/SetupPanes/FindStrictSendPaymentPaths.js +++ /dev/null @@ -1,54 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import AmountPicker from "../FormComponents/AmountPicker.js"; -import AssetMultiPicker from "../FormComponents/AssetMultiPicker.js"; - -export default function FindStrictSendPaymentPaths({ values, onUpdate }) { - return ( -
    - - { - onUpdate("source_amount", value); - }} - /> - - - { - onUpdate("source_asset", value); - }} - /> - - - { - onUpdate("destination_assets", value.join(",")); - }} - /> - - - - { - onUpdate("destination_account", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/For.js b/src/components/SetupPanes/For.js deleted file mode 100644 index 150f6558..00000000 --- a/src/components/SetupPanes/For.js +++ /dev/null @@ -1,57 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; - -// Helper that generates any of the other For SetupPanes. -// Adds the new option row at the top with cursor, limit, and order below. - -// Required props: -// - onUpdate -// - values -// - label -// - optional -// - content - -export default function For(props) { - return ( -
    - - {props.content} - - - - { - props.onUpdate("cursor", value); - }} - key="cursor" - /> - - - - { - props.onUpdate("limit", value); - }} - key="limit" - /> - - - - { - props.onUpdate("order", value); - }} - key="order" - /> - - {props.children} -
    - ); -} diff --git a/src/components/SetupPanes/ForAccount.js b/src/components/SetupPanes/ForAccount.js deleted file mode 100644 index 57729793..00000000 --- a/src/components/SetupPanes/ForAccount.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; - -import For from "./For"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; - -export default function ForAccount(props) { - return ( - { - props.onUpdate("account_id", value); - }} - /> - } - {...props} - /> - ); -} diff --git a/src/components/SetupPanes/ForAccountWithFailed.js b/src/components/SetupPanes/ForAccountWithFailed.js deleted file mode 100644 index 679ac7ae..00000000 --- a/src/components/SetupPanes/ForAccountWithFailed.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import ForAccount from "./ForAccount"; -import BooleanPicker from "../FormComponents/BooleanPicker"; - -export default function ForAccountWithFailed(props) { - return ( - - - { - props.onUpdate("include_failed", value); - }} - key="include_failed" - /> - - - ); -} diff --git a/src/components/SetupPanes/ForLedger.js b/src/components/SetupPanes/ForLedger.js deleted file mode 100644 index 3e9dcf2a..00000000 --- a/src/components/SetupPanes/ForLedger.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; - -import For from "./For"; -import LedgerPicker from "../FormComponents/LedgerPicker.js"; - -export default function ForLedger(props) { - let label = "Ledger Sequence"; - let content = ( - { - props.onUpdate("ledger", value); - }} - /> - ); - - return ; -} diff --git a/src/components/SetupPanes/ForLedgerWithFailed.js b/src/components/SetupPanes/ForLedgerWithFailed.js deleted file mode 100644 index fe5efb55..00000000 --- a/src/components/SetupPanes/ForLedgerWithFailed.js +++ /dev/null @@ -1,21 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import ForLedger from "./ForLedger"; -import BooleanPicker from "../FormComponents/BooleanPicker"; - -export default function ForLedgerWithFailed(props) { - return ( - - - { - props.onUpdate("include_failed", value); - }} - key="include_failed" - /> - - - ); -} diff --git a/src/components/SetupPanes/ForLiquidityPool.tsx b/src/components/SetupPanes/ForLiquidityPool.tsx deleted file mode 100644 index 315a4738..00000000 --- a/src/components/SetupPanes/ForLiquidityPool.tsx +++ /dev/null @@ -1,23 +0,0 @@ -import For from "components/SetupPanes/For.js"; -import { LiquidityPoolId } from "components/FormComponents/LiquidityPoolId"; -import { AnyObject } from "types/types"; - -interface ForLiquidityPoolProps { - values: AnyObject; - onUpdate: (key: string, value: string) => void; -} - -export const ForLiquidityPool = (props: ForLiquidityPoolProps) => ( - { - props.onUpdate("liquidity_pool_id", value); - }} - /> - } - {...props} - /> -); diff --git a/src/components/SetupPanes/ForLiquidityPoolWithFailed.tsx b/src/components/SetupPanes/ForLiquidityPoolWithFailed.tsx deleted file mode 100644 index 13488de1..00000000 --- a/src/components/SetupPanes/ForLiquidityPoolWithFailed.tsx +++ /dev/null @@ -1,25 +0,0 @@ -import OptionsTablePair from "components/OptionsTable/Pair.js"; -import { ForLiquidityPool } from "components/SetupPanes/ForLiquidityPool"; -import BooleanPicker from "components/FormComponents/BooleanPicker.js"; -import { AnyObject } from "types/types"; - -interface ForLiquidityPoolWithFailedProps { - values: AnyObject; - onUpdate: (key: string, value: string) => void; -} - -export const ForLiquidityPoolWithFailed = ( - props: ForLiquidityPoolWithFailedProps, -) => ( - - - { - props.onUpdate("include_failed", value); - }} - key="include_failed" - /> - - -); diff --git a/src/components/SetupPanes/ForOffer.js b/src/components/SetupPanes/ForOffer.js deleted file mode 100644 index 2590f19b..00000000 --- a/src/components/SetupPanes/ForOffer.js +++ /dev/null @@ -1,19 +0,0 @@ -import React from "react"; - -import For from "./For"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; - -export default function ForOffer(props) { - let label = "Offer ID"; - let content = ( - { - props.onUpdate("offer_id", value); - }} - placeholder="Example: 323223" - /> - ); - - return ; -} diff --git a/src/components/SetupPanes/ForOperation.js b/src/components/SetupPanes/ForOperation.js deleted file mode 100644 index 0af7a565..00000000 --- a/src/components/SetupPanes/ForOperation.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; - -import For from "./For"; -import OperationPicker from "../FormComponents/OperationPicker.js"; - -export default function ForOperation(props) { - let label = "Operation ID"; - let content = ( - { - props.onUpdate("operation", value); - }} - /> - ); - - return ; -} diff --git a/src/components/SetupPanes/ForTransaction.js b/src/components/SetupPanes/ForTransaction.js deleted file mode 100644 index 95b0ceba..00000000 --- a/src/components/SetupPanes/ForTransaction.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; - -import For from "./For"; -import TransactionPicker from "../FormComponents/TransactionPicker.js"; - -export default function ForTransaction(props) { - let label = "Transaction Hash"; - let content = ( - { - props.onUpdate("transaction", value); - }} - /> - ); - - return ; -} diff --git a/src/components/SetupPanes/OrderBookDetails.js b/src/components/SetupPanes/OrderBookDetails.js deleted file mode 100644 index 7cc7f6df..00000000 --- a/src/components/SetupPanes/OrderBookDetails.js +++ /dev/null @@ -1,26 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; - -export default function Trades(props) { - return ( -
    - - { - props.onUpdate("selling_asset", value); - }} - /> - - - { - props.onUpdate("buying_asset", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/PostTransaction.js b/src/components/SetupPanes/PostTransaction.js deleted file mode 100644 index 023f8e15..00000000 --- a/src/components/SetupPanes/PostTransaction.js +++ /dev/null @@ -1,19 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import XdrPicker from "../FormComponents/XdrPicker.js"; - -export default function PostTransaction(props) { - return ( -
    - - { - props.onUpdate("tx", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/SingleAccount.js b/src/components/SetupPanes/SingleAccount.js deleted file mode 100644 index 7f8b1a2b..00000000 --- a/src/components/SetupPanes/SingleAccount.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import PubKeyPicker from "../FormComponents/PubKeyPicker"; - -export default function SingleAccount(props) { - return ( -
    - - { - props.onUpdate("account_id", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/SingleClaimableBalance.js b/src/components/SetupPanes/SingleClaimableBalance.js deleted file mode 100644 index 3978c057..00000000 --- a/src/components/SetupPanes/SingleClaimableBalance.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; - -export default function SingleClaimableBalance(props) { - return ( -
    - - { - props.onUpdate("claimable_balance_id", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/SingleLedger.js b/src/components/SetupPanes/SingleLedger.js deleted file mode 100644 index bd74d808..00000000 --- a/src/components/SetupPanes/SingleLedger.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import LedgerPicker from "../FormComponents/LedgerPicker.js"; - -export default function SingleLedger(props) { - return ( -
    - - { - props.onUpdate("ledger", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/SingleLiquidityPool.tsx b/src/components/SetupPanes/SingleLiquidityPool.tsx deleted file mode 100644 index be69addf..00000000 --- a/src/components/SetupPanes/SingleLiquidityPool.tsx +++ /dev/null @@ -1,21 +0,0 @@ -import OptionsTablePair from "components/OptionsTable/Pair.js"; -import { LiquidityPoolId } from "components/FormComponents/LiquidityPoolId"; -import { AnyObject } from "types/types"; - -interface SingleLiquidityPoolProps { - values: AnyObject; - onUpdate: (key: string, value: string) => void; -} - -export const SingleLiquidityPool = (props: SingleLiquidityPoolProps) => ( -
    - - { - props.onUpdate("liquidity_pool_id", value); - }} - /> - -
    -); diff --git a/src/components/SetupPanes/SingleOffer.js b/src/components/SetupPanes/SingleOffer.js deleted file mode 100644 index d03a1982..00000000 --- a/src/components/SetupPanes/SingleOffer.js +++ /dev/null @@ -1,17 +0,0 @@ -import React from "react"; - -import OptionsTablePair from "../OptionsTable/Pair"; -import TextPicker from "../FormComponents/TextPicker.js"; - -export default function SingleOffer({ values, onUpdate }) { - return ( - - { - onUpdate("offer_id", value); - }} - /> - - ); -} diff --git a/src/components/SetupPanes/SingleOperation.js b/src/components/SetupPanes/SingleOperation.js deleted file mode 100644 index 9c2ccf9e..00000000 --- a/src/components/SetupPanes/SingleOperation.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import OperationPicker from "../FormComponents/OperationPicker.js"; - -export default function SingleOperation(props) { - return ( -
    - - { - props.onUpdate("operation", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/SingleTransaction.js b/src/components/SetupPanes/SingleTransaction.js deleted file mode 100644 index 22f7e526..00000000 --- a/src/components/SetupPanes/SingleTransaction.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import TransactionPicker from "../FormComponents/TransactionPicker.js"; - -export default function SingleTransaction(props) { - return ( -
    - - { - props.onUpdate("transaction", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/TradeAggregations.js b/src/components/SetupPanes/TradeAggregations.js deleted file mode 100644 index b443748b..00000000 --- a/src/components/SetupPanes/TradeAggregations.js +++ /dev/null @@ -1,69 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; - -export default function TradeAggregations(props) { - return ( -
    - - { - props.onUpdate("base_asset", value); - }} - /> - - - { - props.onUpdate("counter_asset", value); - }} - /> - - - { - props.onUpdate("start_time", value); - }} - /> - - - { - props.onUpdate("end_time", value); - }} - /> - - - { - props.onUpdate("resolution", value); - }} - /> - - - { - props.onUpdate("limit", value); - }} - /> - - - { - props.onUpdate("order", value); - }} - /> - -
    - ); -} diff --git a/src/components/SetupPanes/Trades.js b/src/components/SetupPanes/Trades.js deleted file mode 100644 index 1c614b23..00000000 --- a/src/components/SetupPanes/Trades.js +++ /dev/null @@ -1,61 +0,0 @@ -import React from "react"; -import OptionsTablePair from "../OptionsTable/Pair"; -import AssetPicker from "../FormComponents/AssetPicker.js"; -import TextPicker from "../FormComponents/TextPicker.js"; -import PositiveIntPicker from "../FormComponents/PositiveIntPicker.js"; -import OrderPicker from "../FormComponents/OrderPicker.js"; - -export default function Trades(props) { - return ( -
    - - { - props.onUpdate("base_asset", value); - }} - /> - - - { - props.onUpdate("counter_asset", value); - }} - /> - - - { - props.onUpdate("offer_id", value); - }} - /> - - - { - props.onUpdate("cursor", value); - }} - /> - - - { - props.onUpdate("limit", value); - }} - /> - - - { - props.onUpdate("order", value); - }} - /> - -
    - ); -} diff --git a/src/components/SorobanBanner.tsx b/src/components/SorobanBanner.tsx deleted file mode 100644 index 358476b3..00000000 --- a/src/components/SorobanBanner.tsx +++ /dev/null @@ -1,23 +0,0 @@ -import { useIsSoroban } from "hooks/useIsSoroban"; -import { useRedux } from "hooks/useRedux"; - -export const SorobanBanner = () => { - let isSoroban = useIsSoroban(); - const { network } = useRedux("network"); - - return isSoroban ? ( -
    -
    - You are connected to the{" "} - - Soroban - {" "} - {network.current.name} network -
    -
    - ) : null; -}; diff --git a/src/components/TabView/index.tsx b/src/components/TabView/index.tsx new file mode 100644 index 00000000..960b4930 --- /dev/null +++ b/src/components/TabView/index.tsx @@ -0,0 +1,115 @@ +import React from "react"; +import { Text } from "@stellar/design-system"; + +import { WithInfoText } from "@/components/WithInfoText"; +import { Tabs } from "@/components/Tabs"; +import { Box } from "@/components/layout/Box"; + +import "./styles.scss"; + +type Tab = { + id: string; + label: string; + content: React.ReactNode; +}; + +type TabViewProps = { + heading: TabViewHeadingProps; + tab1: Tab; + tab2: Tab; + tab3?: Tab; + tab4?: Tab; + tab5?: Tab; + tab6?: Tab; + onTabChange: (id: string) => void; + activeTabId: string; +}; + +export const TabView = ({ + heading, + onTabChange, + activeTabId, + ...tabs +}: TabViewProps) => { + const tabItems = Object.values(tabs).map((t) => ({ + id: t.id, + label: t.label, + })); + + const tabContent = Object.values(tabs).map((t) => ({ + id: t.id, + content: t.content, + })); + + return ( + +
    + + +
    + +
    +
    + + +
    + {tabContent.map((tc) => ( +
    + {tc.content} +
    + ))} +
    +
    +
    + ); +}; + +type TabViewHeadingProps = ( + | { + infoText: React.ReactNode | string; + href?: undefined; + } + | { + infoText?: undefined; + href: string; + } + | { infoText?: undefined; href?: undefined } +) & { + title: string; + infoHoverText?: string; +}; + +const TabViewHeading = ({ + title, + infoHoverText, + infoText, + href, +}: TabViewHeadingProps) => { + const renderTitle = () => ( + + {title} + + ); + + if (href || infoText) { + if (href) { + return ( + + {renderTitle()} + + ); + } + + return ( + + {renderTitle()} + + ); + } + + return renderTitle(); +}; diff --git a/src/components/TabView/styles.scss b/src/components/TabView/styles.scss new file mode 100644 index 00000000..a1d6f2e0 --- /dev/null +++ b/src/components/TabView/styles.scss @@ -0,0 +1,20 @@ +@use "../../styles/utils.scss" as *; + +.TabView { + &__heading { + display: flex; + justify-content: space-between; + align-items: center; + gap: pxToRem(24px); + } + + &__content { + & > [data-is-active="false"] { + display: none; + } + + & > [data-is-active="true"] { + display: block; + } + } +} diff --git a/src/components/TabbedButtons/index.tsx b/src/components/TabbedButtons/index.tsx new file mode 100644 index 00000000..2e787dac --- /dev/null +++ b/src/components/TabbedButtons/index.tsx @@ -0,0 +1,45 @@ +import { Button } from "@stellar/design-system"; + +import "./styles.scss"; + +type TabbedButton = { + id: string; + hoverTitle: string; + icon?: React.ReactNode; + label?: string; + isError?: boolean; + isDisabled?: boolean; + onClick: () => void; +}; + +type TabbedButtonsProps = { + size: "sm" | "md" | "lg"; + buttons: TabbedButton[]; +}; + +export const TabbedButtons = ({ size, buttons }: TabbedButtonsProps) => { + return ( +
    + {buttons.map((b) => { + if (b.isDisabled) { + return null; + } + + return ( + + ); + })} +
    + ); +}; diff --git a/src/components/TabbedButtons/styles.scss b/src/components/TabbedButtons/styles.scss new file mode 100644 index 00000000..eca8b1d5 --- /dev/null +++ b/src/components/TabbedButtons/styles.scss @@ -0,0 +1,39 @@ +@use "../../styles/utils.scss" as *; + +.TabbedButtons { + display: flex; + flex-direction: row; + + .Button { + border-radius: 0; + + &:first-child { + border-top-left-radius: var(--Button-border-radius); + border-bottom-left-radius: var(--Button-border-radius); + } + + &:last-child { + border-top-right-radius: var(--Button-border-radius); + border-bottom-right-radius: var(--Button-border-radius); + } + + &:not(:first-child) { + border-left-color: transparent; + } + + &:focus { + --Button-box-shadow-size: #{pxToRem(2px)}; + z-index: 1; + + &:not(:first-child) { + border-left-color: var(--Button-color-border-active); + } + } + + &[data-variant="error"] { + --Button-color-icon-default: var(--sds-clr-red-09); + --Button-color-icon-hover: var(--sds-clr-red-09); + --Button-color-icon-active: var(--sds-clr-red-09); + } + } +} diff --git a/src/components/Tabs/index.tsx b/src/components/Tabs/index.tsx new file mode 100644 index 00000000..2c3f31e9 --- /dev/null +++ b/src/components/Tabs/index.tsx @@ -0,0 +1,31 @@ +import "./styles.scss"; + +type Tab = { + id: string; + label: string; +}; + +export const Tabs = ({ + tabs, + activeTabId, + onChange, +}: { + tabs: Tab[]; + activeTabId: string; + onChange: (id: string) => void; +}) => { + return ( +
    + {tabs.map((t) => ( +
    onChange(t.id)} + > + {t.label} +
    + ))} +
    + ); +}; diff --git a/src/components/Tabs/styles.scss b/src/components/Tabs/styles.scss new file mode 100644 index 00000000..86cf646f --- /dev/null +++ b/src/components/Tabs/styles.scss @@ -0,0 +1,37 @@ +@use "../../styles/utils.scss" as *; + +.Tabs { + --Tabs-default-text: var(--sds-clr-gray-11); + --Tabs-default-background: transparent; + + display: flex; + align-items: center; + gap: pxToRem(8px); + + .Tab { + font-size: pxToRem(14px); + line-height: pxToRem(20px); + font-weight: var(--sds-fw-medium); + color: var(--Tabs-default-text); + background-color: var(--Tabs-default-background); + border-radius: pxToRem(6px); + padding: pxToRem(6px) pxToRem(10px); + cursor: pointer; + transition: + color var(--sds-anim-transition-default), + background-color var(--sds-anim-transition-default); + + @media (hover: hover) { + &:hover { + --Tabs-default-text: var(--sds-clr-lilac-11); + --Tabs-default-background: var(--sds-clr-lilac-04); + } + } + + &[data-is-active="true"] { + --Tabs-default-text: var(--sds-clr-lilac-11); + --Tabs-default-background: var(--sds-clr-lilac-04); + cursor: default; + } + } +} diff --git a/src/components/TransactionImporter.js b/src/components/TransactionImporter.js deleted file mode 100644 index 19d4ad01..00000000 --- a/src/components/TransactionImporter.js +++ /dev/null @@ -1,75 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; -import { validateTxXdr } from "../helpers/validateTxXdr"; - -// TransactionImporter will call the onImport passed to it's props when the user -// presses the import button and the input is valid -// If no onImport function given, button is hidden and can trigger an update using onUpdate instead - -export default class TransactionImporter extends React.Component { - constructor(props) { - super(props); - this.state = { - input: props.value ? props.value : "", - }; - } - updateTextarea(event) { - this.setState({ - input: event.target.value, - }); - if (this.props.onUpdate) { - this.props.onUpdate(event.target.value); - } - } - triggerImport() { - if ( - validateTxXdr(this.state.input, this.props.networkPassphrase).result === - "success" - ) { - this.props.onImport(this.state.input); - } - } - render() { - let validation, message, submitEnabled, messageClass; - validation = validateTxXdr(this.state.input, this.props.networkPassphrase); - messageClass = - validation.result === "error" - ? "xdrInput__message__alert" - : "xdrInput__message__success"; - message =

    {validation.message}

    ; - - submitEnabled = validation.result === "success"; - - return ( -
    -
    - -
    -
    {message}
    - {this.props.onImport && ( -
    - -
    - )} -
    - ); - } -} -TransactionImporter.propTypes = { - onImport: PropTypes.func, - networkPassphrase: PropTypes.string.isRequired, - onUpdate: PropTypes.func, -}; diff --git a/src/components/TreeView.tsx b/src/components/TreeView.tsx deleted file mode 100644 index b4656174..00000000 --- a/src/components/TreeView.tsx +++ /dev/null @@ -1,284 +0,0 @@ -// TreeView is a recursive tree view -// It takes data from extrapolateFromXdr and formats it in a more user friendly way - -import has from "lodash/has"; -import map from "lodash/map"; -import { FETCHED_SIGNERS } from "constants/fetched_signers"; -import { SIGNATURE } from "constants/signature"; -import { TransactionNode, TransactionNodeValue } from "types/types"; -import { EasySelect } from "./EasySelect"; - -// TODO: Move this to FetchedSigners reducer -type FetchedSignersState = { - state: FETCHED_SIGNERS; - data: [{ sig: any; isValid: string }]; -}; - -interface TreeViewProps { - className?: string; - fetchedSigners: FetchedSignersState; - nodes: TransactionNode[]; - parent?: string; -} - -// @param {array} props.nodes - Array of TreeView compatible nodes -export const TreeView = ({ - className, - fetchedSigners, - nodes, - parent, -}: TreeViewProps) => { - const rootClass = "TreeView " + className ? className : ""; - - const result = ( -
    - {map(Array.prototype.slice.call(nodes), (node, index) => { - const position = getPosition(node, parent); - let childNodes; - - if (typeof node.nodes !== "undefined") { - childNodes = ( -
    - -
    - ); - } - - return ( -
    -
    - -
    - {childNodes} -
    - ); - })} -
    - ); - - return result; -}; - -interface RowValueProps { - node: TransactionNode; - position: string; - fetchedSigners: FetchedSignersState; -} - -const RowValue = ({ node, position, fetchedSigners }: RowValueProps) => { - let value; - let separatorNeeded; - let separator; - - if (typeof node.value === "string") { - value = String(node.value); - separatorNeeded = true; - } else if (typeof node.value !== "undefined" && has(node.value, "type")) { - value = convertTypedValue(node.value); - separatorNeeded = true; - } else { - if (typeof node.nodes !== "undefined") { - value = ""; - } else { - value = none; - separatorNeeded = true; - } - } - if (separatorNeeded) { - separator = ": "; - } - - if (position.match(/^TransactionEnvelope\.(\w+\.)+signatures$/)) { - checkSignatures(node, fetchedSigners); - return formatSignatureCheckState(node, separator); - } - - if ( - position.match( - /^TransactionEnvelope\.(\w+\.)+signatures\[[0-9]+\]\.signature$/, - ) - ) { - return formatSignature(node, separator); - } - - // Buffers with possible text representation - if ( - node.value && - (position.match(/^TransactionEnvelope\.(\w+\.)+tx.memo.text$/) || - position.match( - /^TransactionEnvelope\.(\w+\.)+tx.operations\[[0-9]+\]\.body.manageDataOp.data.*$/, - ) || - position.match( - /^TransactionEnvelope\.(\w+\.)+tx.operations\[[0-9]+\]\.body.setOptionsOp.homeDomain$/, - )) - ) { - return ( - - {node.type} - {separator} - {node.value.raw.toString()} [hex: {value}] - - ); - } - - return ( - - {node.type} - {separator} - {value} - - ); -}; - -const checkSignatures = ( - signatures: TransactionNode, - fetchedSigners: FetchedSignersState, -) => { - // catch fetch signature errors - signatures.state = fetchedSigners.state; - - if (fetchedSigners.state !== FETCHED_SIGNERS.SUCCESS) { - return; - } - - for (var i = 0; i < signatures.nodes.length; i++) { - const sig = signatures.nodes[i].nodes.find( - (n: any) => n.type == "signature", - ); - if (!sig) { - /* eslint-disable no-continue */ - continue; - /* eslint-enable no-continue */ - } - const fetchedSignature = fetchedSigners.data.find((x) => - x.sig.equals(sig.value.raw), - ); - - let isValid = SIGNATURE.NOT_VERIFIED_YET; - if (fetchedSignature) { - isValid = fetchedSignature.isValid; - } - - sig.value.isValid = isValid; - } -}; - -const formatter = new Intl.NumberFormat("en-US", { - minimumFractionDigits: 1, - maximumFractionDigits: 7, -}); - -interface ConvertTypedValue { - type: string; - value: TransactionNodeValue; -} -// Types values are values that will be displayed with special formatting to -// provide for a more rich experience other than just plain text. -// "untyped" values are simply strings. They will be displayed as strings in the -// tree node. -const convertTypedValue = ({ type, value }: ConvertTypedValue) => { - switch (type) { - case "code": - return ( - - {value} - - ); - case "amount": - return ( - - {formatter.format(value.parsed)} (raw: {value.raw}) - - ); - default: - return <>; - } -}; - -// Calculating position within xdr tree allows for awareness of location. -// This is useful for many things, for example, adding visual indicators for -// signature verification. -const getPosition = (node: TransactionNode, parent: string | undefined) => { - let sep = "."; - - if (!parent || node.type.charAt(0) == "[") { - sep = ""; - } - - return `${parent ? `${parent}${sep}` : ""}${node.type}`; -}; - -// Signatures have a special verification feature, so they require a -// richer formating with ternary based coloring based on whether the -// signature is valid for one of the signers related to the transaction -// envelope. -const formatSignature = (node: any, separator?: string) => { - let style = { color: "black" }; - let symbol = ""; - - if (node.value.isValid === SIGNATURE.INVALID) { - style = { color: "red" }; - symbol = " ❌ "; - } else if (node.value.isValid === SIGNATURE.VALID) { - style = { color: "green" }; - symbol = " ✅ "; - } - return ( - - {node.type} - {separator} - {node.value.value} {symbol} - - ); -}; - -// Signature fetch may exist in different states so it requires -// richer formating with ternary based coloring based on whether the -// state is NONE, SUCCCESS, PENDING, FAIL or NOT_EXIST. -const formatSignatureCheckState = ( - node: TransactionNode, - separator?: string, -) => { - let message = ; - switch (node.state) { - case FETCHED_SIGNERS.SUCCESS: - message = ( - Signatures checked! - ); - break; - case FETCHED_SIGNERS.PENDING: - message = ( - Checking signatures... - ); - break; - case FETCHED_SIGNERS.FAIL: - message = ( - Error checking signatures... - ); - break; - case FETCHED_SIGNERS.NOT_EXIST: - message = ( - - {" "} - Some source accounts don't exist. Are you on the right network? - - ); - break; - } - return ( - - {node.type} - {separator} - {node.value} - {message} - - ); -}; diff --git a/src/components/TxResponse/index.tsx b/src/components/TxResponse/index.tsx new file mode 100644 index 00000000..14d83338 --- /dev/null +++ b/src/components/TxResponse/index.tsx @@ -0,0 +1,18 @@ +import "./styles.scss"; + +import { Box } from "@/components/layout/Box"; + +export const TxResponse = ({ + label, + value, + item, +}: { + label: string; + value?: string | number; + item?: React.ReactNode; +}) => ( + +
    {label}
    +
    {value || item}
    +
    +); diff --git a/src/components/TxResponse/styles.scss b/src/components/TxResponse/styles.scss new file mode 100644 index 00000000..0b74fe5a --- /dev/null +++ b/src/components/TxResponse/styles.scss @@ -0,0 +1,7 @@ +@use "../../styles/utils.scss" as *; + +.TxResponse { + &__value { + margin-left: var(--sds-gap-sm); + } +} diff --git a/src/components/TxSubmitterResult.tsx b/src/components/TxSubmitterResult.tsx deleted file mode 100644 index cb6b301c..00000000 --- a/src/components/TxSubmitterResult.tsx +++ /dev/null @@ -1,277 +0,0 @@ -import { useReducer } from "react"; -import { - TransactionBuilder, - AccountRequiresMemoError, - BadResponseError, - NetworkError, - Horizon, -} from "@stellar/stellar-sdk"; -import { EasySelect } from "./EasySelect"; -import { Collapsible } from "./Collapsible"; - -const NETWORK_STATES = { - idle: "idle", - pending: "pending", - success: "success", - fail: "failed", -}; -enum ACTIONS { - submit = "submit", - success = "success", - fail = "fail", -} -const initialState = { - state: NETWORK_STATES.idle, - response: null, - error: null, -}; - -const reducer = ( - state: any, - action: { - type: ACTIONS; - payload?: Horizon.HorizonApi.SubmitTransactionResponse; - }, -) => { - switch (action.type) { - case ACTIONS.submit: - return { ...initialState, state: NETWORK_STATES.pending }; - case ACTIONS.success: - return { - ...state, - error: null, - response: action.payload, - state: NETWORK_STATES.success, - }; - case ACTIONS.fail: - return { - ...state, - response: null, - error: action.payload, - state: NETWORK_STATES.fail, - }; - default: - return state; - } -}; - -interface TxSubmitterResultProps { - txXdr: string; - networkPassphrase: string; - horizonURL: string; -} - -export const TxSubmitterResult = ({ - txXdr, - networkPassphrase, - horizonURL, -}: TxSubmitterResultProps) => { - const [submission, dispatch] = useReducer(reducer, initialState); - - const isIdle = submission.state === NETWORK_STATES.idle; - const isDisabled = !txXdr || !isIdle; - - return ( -
    -
    -
    - -
    -
    - - {!isIdle && submission.response && ( - - )} - {!isIdle && submission.error && } - -
    - ); -}; - -interface ResponseProps { - successful: boolean; -} - -const Response = ({ - operation_count, - successful, - paging_token, - hash, - ledger, - result_xdr, - result_meta_xdr, - fee_meta_xdr, -}: ResponseProps & Horizon.HorizonApi.TransactionResponse) => ( -
    -
    -

    - Transaction submitted! -

    -

    - Transaction {successful ? "succeeded" : "failed"} with {operation_count}{" "} - operation(s). -

    -
    -        
    -          
    - Hash: -
    {" "} - - {hash} - {" "} -
    - Ledger number: -
    {" "} - - {ledger} - {" "} -
    - Paging token: -
    {" "} - - {paging_token} - {" "} -
    - Result XDR: -
    {" "} - - {result_xdr} - {" "} -
    - Result Meta XDR: -
    {" "} - - {result_meta_xdr} - {" "} -
    - Fee Meta XDR: -
    {" "} - - {fee_meta_xdr} - -
    -
    -
    -
    -
    -); - -interface ErrorProps { - // TODO: result_codes and result_xdr don't appear to be on the NetworkError type. Perhaps this code is outdated - error: NetworkError & { - response: { - data: { - extras: { - result_codes: string; - result_xdr: string; - }; - }; - }; - }; -} - -const Error = ({ error }: ErrorProps) => { - let message = "", - extras = null; - if (error instanceof AccountRequiresMemoError) { - message = "This destination requires a memo."; - extras = ( - <> - Destination account: -
    {" "} - - {error.accountId} - {" "} -
    - Operation index: -
    {" "} - - {error.operationIndex} - {" "} -
    - - ); - } else if (error?.response) { - const { result_codes, result_xdr } = error.response.data?.extras || {}; - message = error.message; - extras = ( - <> - extras.result_codes: -
    {" "} - - {JSON.stringify(result_codes)} - {" "} -
    - Result XDR: -
    {" "} - - {result_xdr} - {" "} -
    - - ); - } else { - message = - error instanceof BadResponseError - ? "Received a bad response when submitting." - : "An unknown error occurred."; - extras = ( - <> - original error: -
    - - {JSON.stringify(error, null, 2)} - -
    - - ); - } - - return ( -
    -
    -

    - Transaction failed! -

    -

    {message}

    - {extras && ( -
    -            {extras}
    -          
    - )} -
    -
    - ); -}; diff --git a/src/components/ValidationResponseCard/index.tsx b/src/components/ValidationResponseCard/index.tsx new file mode 100644 index 00000000..0c8ec7a2 --- /dev/null +++ b/src/components/ValidationResponseCard/index.tsx @@ -0,0 +1,98 @@ +import { Card, Text } from "@stellar/design-system"; +import { Box } from "@/components/layout/Box"; +import "./styles.scss"; + +type ValidationResponseCard = { + variant: "primary" | "success" | "error"; + title: string | React.ReactNode; + response: string | React.ReactNode; + subtitle?: string | React.ReactNode; + note?: string | React.ReactNode; + footerLeftEl?: React.ReactNode; + footerRightEl?: React.ReactNode; +}; + +export const ValidationResponseCard = ({ + variant, + title, + response, + subtitle, + note, + footerLeftEl, + footerRightEl, +}: ValidationResponseCard) => { + return ( + + + <> + + {title} + + {subtitle ? ( + + {subtitle} + + ) : null} + + +
    {response}
    +
    + + {footerLeftEl || footerRightEl || note ? ( + + <> + {note ? ( + + {note} + + ) : null} + + {footerLeftEl || footerRightEl ? ( + + <> + {footerLeftEl ? ( + + <>{footerLeftEl} + + ) : null} + + {footerRightEl ? ( + + <>{footerRightEl} + + ) : null} + + + ) : null} + + + ) : null} + +
    +
    + ); +}; diff --git a/src/components/ValidationResponseCard/styles.scss b/src/components/ValidationResponseCard/styles.scss new file mode 100644 index 00000000..d5195495 --- /dev/null +++ b/src/components/ValidationResponseCard/styles.scss @@ -0,0 +1,39 @@ +@use "../../styles/utils.scss" as *; + +.ValidationResponseCard { + --ValidationResponseCard-title-color: var(--sds-clr-gray-12); + + &[data-variant="success"] { + --ValidationResponseCard-title-color: var(--sds-clr-green-11); + } + &[data-variant="error"] { + --ValidationResponseCard-title-color: var(--sds-clr-red-11); + } + + &__title { + color: var(--ValidationResponseCard-title-color); + } + + &__subtitle, + &__note { + color: var(--sds-clr-gray-11); + } + + &__content { + font-size: pxToRem(14px); + line-height: pxToRem(20px); + color: var(--sds-clr-gray-12); + font-family: var(--sds-ff-monospace); + font-weight: var(--sds-fw-medium); + padding: pxToRem(16px); + word-wrap: break-word; + + ul { + font-size: inherit; + line-height: inherit; + font-family: var(--sds-ff-monospace); + font-weight: var(--sds-fw-medium); + padding-left: pxToRem(16px); + } + } +} diff --git a/src/components/ViewInXdrButton.tsx b/src/components/ViewInXdrButton.tsx new file mode 100644 index 00000000..3e437ee8 --- /dev/null +++ b/src/components/ViewInXdrButton.tsx @@ -0,0 +1,25 @@ +import { useRouter } from "next/navigation"; +import { Button } from "@stellar/design-system"; +import { Routes } from "@/constants/routes"; +import { XDR_TYPE_TRANSACTION_ENVELOPE } from "@/constants/settings"; +import { useStore } from "@/store/useStore"; + +export const ViewInXdrButton = ({ xdrBlob }: { xdrBlob: string }) => { + const { xdr } = useStore(); + const router = useRouter(); + + return ( + + ); +}; diff --git a/src/components/WithInfoText/index.tsx b/src/components/WithInfoText/index.tsx new file mode 100644 index 00000000..52dba5c7 --- /dev/null +++ b/src/components/WithInfoText/index.tsx @@ -0,0 +1,58 @@ +import React from "react"; +import { Icon, Tooltip } from "@stellar/design-system"; +import { NextLink } from "@/components/NextLink"; +import "./styles.scss"; + +type WithInfoTextProps = ( + | { + infoText: React.ReactNode | string; + href?: undefined; + } + | { + infoText?: undefined; + href: string; + } +) & { + children: React.ReactNode; + infoHoverText?: string; +}; + +export const WithInfoText = ({ + children, + infoText, + infoHoverText, + href, +}: WithInfoTextProps) => { + const buttonBaseProps = { + className: "WithInfoText__button", + title: infoHoverText || "Learn more", + }; + + if (href) { + return ( +
    + {children} + + + + +
    + ); + } + + return ( +
    + {children} + + + + + } + > + {infoText} + +
    + ); +}; diff --git a/src/components/WithInfoText/styles.scss b/src/components/WithInfoText/styles.scss new file mode 100644 index 00000000..46049279 --- /dev/null +++ b/src/components/WithInfoText/styles.scss @@ -0,0 +1,34 @@ +@use "../../styles/utils.scss" as *; + +.WithInfoText { + --WithInfoText-icon-color: var(--sds-clr-gray-08); + + display: inline-flex; + gap: pxToRem(2px); + align-items: center; + + &__button { + display: block; + + text-decoration: none; + cursor: pointer; + border: none; + background: none; + padding: pxToRem(2px); + margin: 0; + + svg { + display: block; + width: pxToRem(12px); + height: pxToRem(12px); + transition: stroke var(--sds-anim-transition-default); + stroke: var(--WithInfoText-icon-color); + } + + @media (hover: hover) { + &:hover { + --WithInfoText-icon-color: var(--sds-clr-gray-11); + } + } + } +} diff --git a/src/components/XdrTypeSelect/index.tsx b/src/components/XdrTypeSelect/index.tsx new file mode 100644 index 00000000..322eb5a7 --- /dev/null +++ b/src/components/XdrTypeSelect/index.tsx @@ -0,0 +1,137 @@ +import { useEffect, useState } from "react"; +import { Icon, Input } from "@stellar/design-system"; +import { ALL_XDR_TYPES } from "@/constants/xdr"; +import { delayedAction } from "@/helpers/delayedAction"; +import { useStore } from "@/store/useStore"; +import "./styles.scss"; + +export interface XdrTypeSelectProps { + error?: string | React.ReactNode; +} + +export const XdrTypeSelect = ({ error }: XdrTypeSelectProps) => { + const { xdr } = useStore(); + + const [searchValue, setSearchValue] = useState(""); + const [isOptionsVisible, setIsOptionsVisible] = useState(false); + const [displayOptions, setDisplayOptions] = useState([]); + + useEffect(() => { + if (searchValue) { + const res = ALL_XDR_TYPES.filter((t) => + t.toLowerCase().includes(searchValue.toLowerCase()), + ); + setDisplayOptions(res); + } else { + setDisplayOptions([]); + } + }, [searchValue]); + + const OptionItem = ({ + option, + sectionTitle, + }: { + option?: string; + sectionTitle?: string; + }) => { + if (sectionTitle) { + return ( +
    + {sectionTitle} +
    + ); + } + + if (option) { + return ( +
    { + xdr.updateXdrType(option); + setIsOptionsVisible(false); + }} + data-is-current={xdr.type === option} + > + {option} +
    + ); + } + + return null; + }; + + const renderOptions = () => { + // Default + if (!searchValue) { + return ( + <> + + + {["TransactionEnvelope", "TransactionResult", "TransactionMeta"].map( + (p) => ( + + ), + )} + + + + {ALL_XDR_TYPES.map((o) => ( + + ))} + + ); + } + + // No search results + if (searchValue && displayOptions.length === 0) { + return ; + } + + // Search results + return displayOptions.map((o) => ( + + )); + }; + + return ( + <> +
    + { + setSearchValue(e.target.value); + }} + onFocus={() => { + setIsOptionsVisible(true); + }} + onBlur={() => { + if (isOptionsVisible) { + delayedAction({ + action: () => { + setIsOptionsVisible(false); + setSearchValue(""); + }, + delay: 200, + }); + } + }} + leftElement={} + rightElement={} + /> + +
    + {renderOptions()} +
    +
    + + ); +}; diff --git a/src/components/XdrTypeSelect/styles.scss b/src/components/XdrTypeSelect/styles.scss new file mode 100644 index 00000000..dca993b2 --- /dev/null +++ b/src/components/XdrTypeSelect/styles.scss @@ -0,0 +1,68 @@ +@use "../../styles/utils.scss" as *; + +.XdrTypeSelect { + position: relative; + + &__options { + display: none; + position: absolute; + top: pxToRem(64px); + left: 0; + width: 100%; + height: fit-content; + max-height: pxToRem(300px); + z-index: var(--sds-z-index-modal); + overflow-x: auto; + + border-radius: pxToRem(6px); + background-color: var(--sds-clr-gray-01); + border: 1px solid var(--sds-clr-gray-06); + box-shadow: 0 pxToRem(10px) pxToRem(20px) pxToRem(-6px) + var(--sds-overlay-01); + + padding: pxToRem(4px); + + &[data-is-visible="true"] { + display: flex; + flex-direction: column; + gap: pxToRem(4px); + } + } + + &__item { + display: block; + padding: pxToRem(4px) pxToRem(8px); + border-radius: pxToRem(4px); + background-color: var(--sds-clr-gray-01); + text-decoration: none; + color: var(--sds-clr-gray-12); + font-size: pxToRem(14px); + line-height: pxToRem(22px); + font-weight: var(--font-weight-medium); + transition: all var(--anim-transition-default); + cursor: pointer; + + @media (hover: hover) { + &:hover { + background-color: var(--sds-clr-gray-04); + } + } + + &--section { + color: var(--sds-clr-gray-10); + pointer-events: none; + } + + &[data-is-current="true"] { + background-color: var(--sds-clr-gray-04); + cursor: default; + } + } + + .Input__side-element--right { + svg { + width: pxToRem(18px); + height: 100%; + } + } +} diff --git a/src/components/formComponentTemplateEndpoints.tsx b/src/components/formComponentTemplateEndpoints.tsx new file mode 100644 index 00000000..2d4e74de --- /dev/null +++ b/src/components/formComponentTemplateEndpoints.tsx @@ -0,0 +1,730 @@ +import { JSX } from "react"; + +import { AssetPicker } from "@/components/FormElements/AssetPicker"; +import { PubKeyPicker } from "@/components/FormElements/PubKeyPicker"; +import { OrderPicker } from "@/components/FormElements/OrderPicker"; +import { CursorPicker } from "@/components/FormElements/CursorPicker"; +import { LimitPicker } from "@/components/FormElements/LimitPicker"; +import { TextPicker } from "@/components/FormElements/TextPicker"; +import { PositiveIntPicker } from "@/components/FormElements/PositiveIntPicker"; +import { IncludeFailedPicker } from "@/components/FormElements/IncludeFailedPicker"; +import { XdrPicker } from "@/components/FormElements/XdrPicker"; +import { AssetMultiPicker } from "@/components/FormElements/AssetMultiPicker"; +import { FiltersPicker } from "@/components/FormElements/FiltersPicker"; + +import { parseJsonString } from "@/helpers/parseJsonString"; +import { validate } from "@/validate"; +import { + AnyObject, + AssetObjectValue, + AssetPoolShareObjectValue, +} from "@/types/types"; + +type TemplateRenderProps = { + value: string | undefined; + error: string | undefined; + onChange: (val: any) => void; + isRequired?: boolean; +}; + +type TemplateRenderAssetProps = { + value: AssetObjectValue | undefined; + error: { code: string | undefined; issuer: string | undefined } | undefined; + onChange: ( + asset: AssetObjectValue | AssetPoolShareObjectValue | undefined, + ) => void; + isRequired?: boolean; +}; + +type TemplateRenderAssetMultiProps = { + values: AssetObjectValue[] | undefined; + error: { code: string | undefined; issuer: string | undefined }[] | undefined; + onChange: (asset: AssetObjectValue[] | undefined) => void; + isRequired?: boolean; +}; + +type TemplateRenderOrderProps = { + value: string | undefined; + onChange: (optionId: string | undefined, optionValue?: string) => void; + isRequired?: boolean; +}; + +type TemplateRenderIncludeFailedProps = { + value: string | undefined; + onChange: (optionId: string | undefined, optionValue?: boolean) => void; + isRequired?: boolean; +}; + +type TemplateRenderTxProps = { + value: string | undefined; + error: + | { result: string; message: "string"; originalError?: string } + | undefined; + onChange: (val: any) => void; + isRequired?: boolean; +}; + +type FormComponentTemplateEndpointsProps = { + render: (...args: any[]) => JSX.Element; + validate: ((...args: any[]) => any) | null; +}; + +export const formComponentTemplateEndpoints = ( + id: string, + custom?: AnyObject, +): FormComponentTemplateEndpointsProps | null => { + switch (id) { + case "account_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "asset_code": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAssetCodeError, + }; + case "asset_issuer": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "base_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "buying": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "buying_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "claimable_balance_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "claimant": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "counter_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "cursor": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "destination": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "destination_account": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "destination_amount": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAmountError, + }; + case "destination_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "destination_assets": + return { + render: (templ: TemplateRenderAssetMultiProps) => ( + + ), + validate: validate.getAssetMultiError, + }; + case "end_time": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "include_failed": + return { + render: (templ: TemplateRenderIncludeFailedProps) => ( + + ), + validate: null, + }; + case "ledger": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + case "startLedger": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + case "limit": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + case "liquidity_pool_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "offer_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "operation": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + case "order": + return { + render: (templ: TemplateRenderOrderProps) => ( + + ), + validate: null, + }; + case "reserves": + return { + render: (templ: TemplateRenderAssetMultiProps) => ( + + ), + validate: validate.getAssetMultiError, + }; + case "resolution": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "seller": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "selling": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "selling_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "signer": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "source_account": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "source_amount": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAmountError, + }; + case "source_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "source_assets": + return { + render: (templ: TemplateRenderAssetMultiProps) => ( + + ), + validate: validate.getAssetMultiError, + }; + case "sponsor": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "starting_balance": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAmountError, + }; + case "start_time": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "transaction": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getTransactionHashError, + }; + case "tx": + return { + render: (templ: TemplateRenderTxProps) => ( + + ), + validate: validate.getXdrError, + }; + case "filters": + return { + render: (templ: TemplateRenderTxProps) => ( + + ), + validate: validate.getEventsFiltersError, + }; + case "resourceConfig": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + default: + return null; + } +}; diff --git a/src/components/formComponentTemplateTxnOps.tsx b/src/components/formComponentTemplateTxnOps.tsx new file mode 100644 index 00000000..8c5efb13 --- /dev/null +++ b/src/components/formComponentTemplateTxnOps.tsx @@ -0,0 +1,664 @@ +import { JSX } from "react"; + +import { Box } from "@/components/layout/Box"; +import { SdsLink } from "@/components/SdsLink"; + +import { PubKeyPicker } from "@/components/FormElements/PubKeyPicker"; +import { TextPicker } from "@/components/FormElements/TextPicker"; +import { AssetPicker } from "@/components/FormElements/AssetPicker"; +import { PositiveIntPicker } from "@/components/FormElements/PositiveIntPicker"; +import { AssetMultiPicker } from "@/components/FormElements/AssetMultiPicker"; +import { FlagFieldPicker } from "@/components/FormElements/FlagFieldPicker"; +import { SignerPicker } from "@/components/FormElements/SignerPicker"; +import { AuthorizePicker } from "@/components/FormElements/AuthorizePicker"; +import { NumberFractionPicker } from "@/components/FormElements/NumberFractionPicker"; +import { RevokeSponsorshipPicker } from "@/components/FormElements/RevokeSponsorshipPicker"; +import { ClaimantsPicker } from "@/components/FormElements/ClaimantsPicker"; + +import { validate } from "@/validate"; +import { + AnyObject, + AssetObjectValue, + AssetPoolShareObjectValue, + NumberFractionValue, + OptionSigner, + RevokeSponsorshipValue, +} from "@/types/types"; + +// Types +type TemplateRenderProps = { + value: string | undefined; + error: string | undefined; + onChange: (val: any) => void; + isRequired?: boolean; +}; + +type TemplateRenderAssetProps = { + value: AssetObjectValue | undefined; + error: { code: string | undefined; issuer: string | undefined } | undefined; + onChange: ( + asset: AssetObjectValue | AssetPoolShareObjectValue | undefined, + ) => void; + isRequired?: boolean; +}; + +type TemplateRenderAssetMultiProps = { + value: AssetObjectValue[]; + error: { code: string | undefined; issuer: string | undefined }[]; + onChange: (asset: AssetObjectValue[] | undefined) => void; + isRequired?: boolean; +}; + +type TemplateRenderFlagFieldProps = { + value: string[]; + onChange: (val: string[]) => void; + isRequired?: boolean; +}; + +type TemplateRenderSignerProps = { + value: OptionSigner | undefined; + error: { key: string | undefined; weight: string | undefined } | undefined; + onChange: (val: OptionSigner | undefined) => void; + isRequired?: boolean; +}; + +type TemplateRenderNumberFractionProps = { + value: NumberFractionValue | undefined; + error: string | undefined; + onChange: (val: NumberFractionValue | undefined) => void; + isRequired?: boolean; +}; + +type TemplateRenderRevokeSponsorshipProps = { + value: RevokeSponsorshipValue | undefined; + error: AnyObject | undefined; + onChange: (val: RevokeSponsorshipValue | undefined) => void; + isRequired?: boolean; +}; + +type TemplateRenderClaimantsProps = { + value: AnyObject[] | undefined; + error: (AnyObject | undefined)[] | undefined; + onChange: (val: AnyObject[] | undefined) => void; + isRequired?: boolean; +}; + +type FormComponentTemplateTxnOpsProps = { + render: (...args: any[]) => JSX.Element; + validate: ((...args: any[]) => any) | null; +}; + +export const formComponentTemplateTxnOps = ({ + param, + opType, + index, + custom, +}: { + param: string; + opType: string; + index: number; + custom?: AnyObject; +}): FormComponentTemplateTxnOpsProps | null => { + const id = `${index}-${opType}-${param}`; + + switch (param) { + case "amount": + case "buy_amount": + case "send_amount": + case "dest_min": + case "send_max": + case "dest_amount": + case "max_amount_a": + case "max_amount_b": + case "min_amount_a": + case "min_amount_b": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAmountError, + }; + case "asset": + case "send_asset": + case "dest_asset": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "assetCode": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAssetCodeError, + }; + case "authorize": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "balance_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getClaimableBalanceIdError, + }; + case "bump_to": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + case "buying": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "claimants": + return { + render: (templ: TemplateRenderClaimantsProps) => ( + + ), + validate: validate.getClaimaintsError, + }; + case "clear_flags": + return { + render: (templ: TemplateRenderFlagFieldProps) => ( + + Selected{" "} + + flags + {" "} + mean to remove selected flags already present on the account. + + } + onChange={templ.onChange} + options={custom?.options} + /> + ), + validate: null, + }; + case "data_name": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getDataNameError, + }; + case "data_value": + return { + render: (templ: TemplateRenderProps) => ( + + {custom.note} +
    + {custom.note_add} + + ) : ( + custom?.note + ) + } + /> + ), + validate: validate.getDataValueError, + }; + case "destination": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "from": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "home_domain": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "inflation_dest": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "limit": + return { + render: (templ: TemplateRenderProps) => ( + + {custom.note} +
    + {custom.note_add} + + ) : ( + custom?.note + ) + } + infoLink={custom?.infoLink} + /> + ), + validate: validate.getPositiveNumberError, + }; + case "line": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "liquidity_pool_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: null, + }; + case "master_weight": + case "low_threshold": + case "med_threshold": + case "high_threshold": + return { + render: (templ: TemplateRenderProps) => ( + + + <> + {custom?.showWarning ? ( +
    + This can result in a permanently locked account. Are you sure + you know what you’re doing? +
    + ) : null} + +
    + ), + validate: validate.getAccountThresholdError, + }; + case "min_price": + case "max_price": + return { + render: (templ: TemplateRenderNumberFractionProps) => ( + + ), + validate: validate.getNumberFractionError, + }; + case "offer_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveIntError, + }; + case "path": + return { + render: (templ: TemplateRenderAssetMultiProps) => ( + + ), + validate: validate.getAssetMultiError, + }; + case "price": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPositiveNumberError, + }; + // Custom operation + case "revokeSponsorship": + return { + render: (templ: TemplateRenderRevokeSponsorshipProps) => ( + + ), + validate: validate.getRevokeSponsorshipError, + }; + case "selling": + return { + render: (templ: TemplateRenderAssetProps) => ( + + ), + validate: validate.getAssetError, + }; + case "set_flags": + return { + render: (templ: TemplateRenderFlagFieldProps) => ( + + Selected{" "} + + flags + {" "} + mean to add selected flags in addition to flags already present + on the account. + + } + onChange={templ.onChange} + options={custom?.options} + /> + ), + validate: null, + }; + case "signer": + return { + render: (templ: TemplateRenderSignerProps) => ( + + ), + validate: validate.getOptionsSignerError, + }; + case "source_account": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "sponsored_id": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + case "starting_balance": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getAmountError, + }; + case "trustor": + return { + render: (templ: TemplateRenderProps) => ( + + ), + validate: validate.getPublicKeyError, + }; + default: + return null; + } +}; diff --git a/src/components/layout/Box/index.tsx b/src/components/layout/Box/index.tsx new file mode 100644 index 00000000..564009fc --- /dev/null +++ b/src/components/layout/Box/index.tsx @@ -0,0 +1,46 @@ +import React from "react"; +import "./styles.scss"; + +export const Box = ({ + gap, + children, + customValue, + addlClassName, + direction = "column", + justify = "baseline", + align = "stretch", + ...props +}: ( + | { gap: "xs" | "sm" | "md" | "lg" | "xl" | "xxl"; customValue?: undefined } + | { gap: "custom"; customValue: string } +) & { + children: React.ReactElement | React.ReactElement[] | null; + addlClassName?: string; + direction?: "column" | "row" | "column-reverse" | "row-reverse"; + justify?: + | "center" + | "space-between" + | "space-around" + | "end" + | "left" + | "right" + | "baseline"; + align?: "center" | "end" | "start" | "baseline" | "stretch"; +}) => { + const customStyle = { + "--Box-direction": direction, + "--Box-justify": justify, + "--Box-align": align, + } as React.CSSProperties; + + return ( +
    + {children} +
    + ); +}; diff --git a/src/components/layout/Box/styles.scss b/src/components/layout/Box/styles.scss new file mode 100644 index 00000000..2008af9f --- /dev/null +++ b/src/components/layout/Box/styles.scss @@ -0,0 +1,34 @@ +.Box { + --Box-direction: column; + --Box-justify: left; + --Box-align: stretch; + + display: flex; + flex-direction: var(--Box-direction); + justify-content: var(--Box-justify); + align-items: var(--Box-align); + + &--xs { + gap: var(--sds-gap-xs); + } + + &--sm { + gap: var(--sds-gap-sm); + } + + &--md { + gap: var(--sds-gap-md); + } + + &--lg { + gap: var(--sds-gap-lg); + } + + &--xl { + gap: var(--sds-gap-xl); + } + + &--xxl { + gap: var(--sds-gap-xxl); + } +} diff --git a/src/components/layout/LayoutContentContainer.tsx b/src/components/layout/LayoutContentContainer.tsx new file mode 100644 index 00000000..0115f784 --- /dev/null +++ b/src/components/layout/LayoutContentContainer.tsx @@ -0,0 +1,11 @@ +import React from "react"; + +export const LayoutContentContainer = ({ + children, +}: { + children: React.ReactNode; +}) => ( +
    +
    {children}
    +
    +); diff --git a/src/components/layout/LayoutMain.tsx b/src/components/layout/LayoutMain.tsx new file mode 100644 index 00000000..72eb4bf5 --- /dev/null +++ b/src/components/layout/LayoutMain.tsx @@ -0,0 +1,40 @@ +"use client"; + +import { ReactNode } from "react"; +import Link from "next/link"; + +import { ProjectLogo, ThemeSwitch } from "@stellar/design-system"; + +import { MainNav } from "@/components/MainNav"; +import { NetworkSelector } from "@/components/NetworkSelector"; +import { MaintenanceBanner } from "@/components/MaintenanceBanner"; +import { Hydration } from "@/components/Hydration"; + +export const LayoutMain = ({ children }: { children: ReactNode }) => { + return ( +
    +
    + +
    +
    + } + /> + + +
    + + + + +
    +
    +
    +
    + + {children} +
    + ); +}; diff --git a/src/components/layout/LayoutSidebarContent.tsx b/src/components/layout/LayoutSidebarContent.tsx new file mode 100644 index 00000000..002a06db --- /dev/null +++ b/src/components/layout/LayoutSidebarContent.tsx @@ -0,0 +1,200 @@ +"use client"; + +import { ReactNode, useEffect, useState } from "react"; +import { usePathname } from "next/navigation"; +import { Icon, Logo } from "@stellar/design-system"; +import { Routes } from "@/constants/routes"; +import { NextLink } from "@/components/NextLink"; +import { GITHUB_URL } from "@/constants/settings"; + +export type SidebarLink = { + route: Routes | string; + label: string; + icon?: ReactNode; + nestedItems?: SidebarLink[]; +}; + +export type Sidebar = { + navItems: SidebarLink[]; + instruction?: string; + bottomItems?: SidebarLink[]; + hasBottomDivider?: boolean; +}; + +export const LayoutSidebarContent = ({ + children, + sidebar, +}: { + children: ReactNode; + sidebar: Sidebar | Sidebar[]; +}) => { + const pathname = usePathname(); + + const sidebarArray = Array.isArray(sidebar) ? sidebar : [sidebar]; + const bottomItems = sidebarArray?.reduce((res, cur) => { + if (cur.bottomItems?.length) { + return [...res, ...cur.bottomItems]; + } + + return res; + }, [] as SidebarLink[]); + + return ( + <> +
    +
    + {sidebarArray.map((sidebar, index) => ( +
    + {sidebar.instruction ? ( + + ) : ( + sidebar.navItems.map((item) => ( + + )) + )} +
    + ))} +
    +
    +
    + {bottomItems?.map((bi) => ( + + ))} +
    +
    + + Got product feedback? + + + GitHub + +
    +
    +
    +
    +
    {children}
    +
    + + ); +}; + +const NestedNav = ({ + pathname, + sidebar, +}: { + pathname: string; + sidebar: Sidebar; +}) => { + const isSelectedParent = sidebar.navItems.some((item) => + pathname.includes(item.route), + ); + const [isExpanded, setIsExpanded] = useState(true); + + useEffect(() => { + if (isSelectedParent) { + setIsExpanded(isSelectedParent); + } + }, [isSelectedParent]); + + return ( +
    +
    { + setIsExpanded(!isExpanded); + }} + data-is-expanded={isExpanded} + data-testid="endpoints-sidebar-linkToggle" + > + {sidebar.instruction} +
    + + {sidebar.navItems?.length ? ( +
    +
    + {sidebar.navItems.map((item) => ( + + ))} +
    +
    + ) : null} +
    + ); +}; + +const Link = ({ item, pathname }: { item: SidebarLink; pathname: string }) => { + const isSelectedParent = item.nestedItems?.length + ? pathname?.split(Routes.ENDPOINTS)?.[1]?.split("/")?.[1] === + item.route?.split(Routes.ENDPOINTS)?.[1]?.split("/")?.[1] + : false; + + useEffect(() => { + if (isSelectedParent) { + setIsExpanded(isSelectedParent); + } + }, [isSelectedParent]); + + const [isExpanded, setIsExpanded] = useState(isSelectedParent); + + if (item.nestedItems?.length) { + return ( +
    +
    { + setIsExpanded(!isExpanded); + }} + data-testid="endpoints-sidebar-linkToggle" + > + {item.label} +
    + + {item.nestedItems?.length ? ( +
    +
    + {item.nestedItems.map((nested) => ( + + {nested.label} + + ))} +
    +
    + ) : null} +
    + ); + } + + return ( + + {item.label} {item.icon ?? null} + + ); +}; diff --git a/src/components/layout/LayoutWithSidebar.tsx b/src/components/layout/LayoutWithSidebar.tsx new file mode 100644 index 00000000..e9373a5e --- /dev/null +++ b/src/components/layout/LayoutWithSidebar.tsx @@ -0,0 +1,7 @@ +"use client"; + +import { ReactNode } from "react"; + +export const LayoutWithSidebar = ({ children }: { children: ReactNode }) => { + return
    {children}
    ; +}; diff --git a/src/config/store.ts b/src/config/store.ts deleted file mode 100644 index 92dfa914..00000000 --- a/src/config/store.ts +++ /dev/null @@ -1,49 +0,0 @@ -import { configureStore, createAction, CombinedState } from "@reduxjs/toolkit"; -import { combineReducers, Action } from "redux"; - -import { RESET_STORE_ACTION_TYPE } from "constants/settings"; -import metrics from "middleware/metrics.js"; -import { routerMiddleware } from "helpers/simpleRouter.js"; - -import accountCreator from "reducers/accountCreator.js"; -import endpointExplorer from "reducers/endpointExplorer.js"; -import transactionBuilder from "reducers/transactionBuilder.js"; -import transactionSigner from "reducers/transactionSigner.js"; -import xdrViewer from "reducers/xdrViewer.js"; -import network from "reducers/network.js"; -import routing from "reducers/routing.js"; - -export type RootState = ReturnType; - -const loggerMiddleware = - (storeVal: any) => (next: any) => (action: Action) => { - console.log("Dispatching: ", action.type); - const dispatchedAction = next(action); - console.log("NEW STATE: ", storeVal.getState()); - return dispatchedAction; - }; - -export const reducers = combineReducers({ - accountCreator, - endpointExplorer, - transactionBuilder, - transactionSigner, - xdrViewer, - network, - routing, -}); - -export const resetStoreAction = createAction(RESET_STORE_ACTION_TYPE); - -const rootReducer = (state: CombinedState, action: Action) => { - const newState = action.type === RESET_STORE_ACTION_TYPE ? undefined : state; - return reducers(newState, action); -}; - -export const store = configureStore({ - reducer: rootReducer, - middleware: (getDefaultMiddleware) => - getDefaultMiddleware({ - immutableCheck: false, - }).concat(loggerMiddleware, metrics, routerMiddleware), -}); diff --git a/src/constants/endpointsPages.ts b/src/constants/endpointsPages.ts new file mode 100644 index 00000000..3deb5320 --- /dev/null +++ b/src/constants/endpointsPages.ts @@ -0,0 +1,998 @@ +import { ReactNode } from "react"; +import { Routes } from "@/constants/routes"; +import { AnyObject } from "@/types/types"; + +export type EndpointsPagesFormProps = { + docsUrl: string; + docsLabel?: string; + requestMethod: "GET" | "POST"; + endpointUrlTemplate?: string; + requiredParams: string; + rpcMethod?: string; + isStreaming?: boolean; + custom?: AnyObject; +}; + +export type EndpointsPagesProps = { + instruction?: string; + navItems: { + route: Routes; + label: string; + form?: EndpointsPagesFormProps; + nestedItems?: { + route: Routes; + label: string; + form: EndpointsPagesFormProps; + }[]; + icon?: ReactNode; + }[]; + hasBottomDivider?: boolean; +}; + +export const ENDPOINTS_PAGES_RPC: EndpointsPagesProps = { + instruction: "RPC Endpoints", + navItems: [ + { + route: Routes.ENDPOINTS_GET_EVENTS, + label: "getEvents", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getEvents", + docsLabel: "getEvents", + endpointUrlTemplate: "{?startLedger,cursor,limit,filters}", + requestMethod: "POST", + requiredParams: "startLedger,filters", + rpcMethod: "getEvents", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_GET_FEE_STATS, + label: "getFeeStats", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getFeeStats", + docsLabel: "getFeeStats", + requestMethod: "POST", + requiredParams: "", + rpcMethod: "getFeeStats", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_GET_HEALTH, + label: "getHealth", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getHealth", + docsLabel: "getHealth", + requestMethod: "POST", + requiredParams: "", + rpcMethod: "getHealth", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_GET_LATEST_LEDGER, + label: "getLatestLedger", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getLatestLedger", + docsLabel: "getLatestLedger", + requestMethod: "POST", + requiredParams: "", + rpcMethod: "getLatestLedger", + isStreaming: false, + }, + }, + // TODO: remove until ready + // { + // route: Routes.ENDPOINTS_GET_LEDGER_ENTRIES, + // label: "getLedgerEntries", + // form: { + // docsUrl: + // "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getLedgerEntries", + // docsLabel: "getLedgerEntries", + // endpointUrlTemplate: "{?tx}", + // requestMethod: "POST", + // requiredParams: "tx", + // rpcMethod: "getLedgerEntries", + // isStreaming: false, + // }, + // }, + { + route: Routes.ENDPOINTS_GET_NETWORK, + label: "getNetwork", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getNetwork", + docsLabel: "getNetwork", + requestMethod: "POST", + requiredParams: "", + rpcMethod: "getNetwork", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_GET_TRANSACTION, + label: "getTransaction", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getTransaction", + docsLabel: "getTransaction", + endpointUrlTemplate: "{?transaction}", + requestMethod: "POST", + requiredParams: "transaction", + rpcMethod: "getTransaction", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_GET_TRANSACTIONS, + label: "getTransactions", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getTransactions", + docsLabel: "getTransactions", + endpointUrlTemplate: "{?startLedger,cursor,limit}", + requestMethod: "POST", + requiredParams: "startLedger", + rpcMethod: "getTransactions", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_GET_VERSION_INFO, + label: "getVersionInfo", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/getVersionInfo", + docsLabel: "getVersionInfo", + requestMethod: "POST", + requiredParams: "", + rpcMethod: "getVersionInfo", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_SEND_TRANSACTION, + label: "sendTransaction", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/sendTransaction", + docsLabel: "sendTransaction", + endpointUrlTemplate: "{?tx}", + requestMethod: "POST", + requiredParams: "tx", + rpcMethod: "sendTransaction", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_SIMULATE_TRANSACTION, + label: "simulateTransaction", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/rpc/api-reference/methods/simulateTransaction", + docsLabel: "simulateTransaction", + endpointUrlTemplate: "{?tx,resourceConfig}", + requestMethod: "POST", + requiredParams: "tx", + rpcMethod: "simulateTransaction", + isStreaming: false, + }, + }, + ], +}; + +export const ENDPOINTS_PAGES_HORIZON: EndpointsPagesProps = { + instruction: "Horizon Endpoints", + navItems: [ + { + route: Routes.ENDPOINTS_ACCOUNTS, + label: "Accounts", + nestedItems: [ + { + route: Routes.ENDPOINTS_ACCOUNTS, + label: "All Accounts", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/list-all-accounts", + docsLabel: "accounts", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{?sponsor,signer,asset,cursor,limit,order}", + requiredParams: "", + isStreaming: true, + custom: { + asset: { + assetInput: "issued", + includeNative: true, + }, + }, + }, + }, + { + route: Routes.ENDPOINTS_ACCOUNTS_SINGLE, + label: "Single Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-an-account", + docsLabel: "account", + requestMethod: "GET", + endpointUrlTemplate: "/accounts/{account_id}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_ASSETS, + label: "Assets", + nestedItems: [ + { + route: Routes.ENDPOINTS_ASSETS, + label: "All Assets", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/list-all-assets", + docsLabel: "assets", + requestMethod: "GET", + endpointUrlTemplate: + "/assets{?asset_code,asset_issuer,cursor,order,limit}", + requiredParams: "", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_CLAIMABLE_BALANCES, + label: "Claimable Balances", + nestedItems: [ + { + route: Routes.ENDPOINTS_CLAIMABLE_BALANCES, + label: "All Claimable Balances", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/list-all-claimable-balances", + docsLabel: "claimable balances", + requestMethod: "GET", + endpointUrlTemplate: + "/claimable_balances/{?sponsor,asset,claimant,cursor,limit,order}", + requiredParams: "", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_CLAIMABLE_BALANCES_SINGLE, + label: "Single Claimable Balance", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-claimable-balance", + docsLabel: "claimable balance", + requestMethod: "GET", + endpointUrlTemplate: "/claimable_balances/{claimable_balance_id}", + requiredParams: "claimable_balance_id", + isStreaming: false, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_EFFECTS, + label: "Effects", + nestedItems: [ + { + route: Routes.ENDPOINTS_EFFECTS, + label: "All Effects", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/list-all-effects", + docsLabel: "effects", + requestMethod: "GET", + endpointUrlTemplate: "/effects{?cursor,limit,order}", + requiredParams: "", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_EFFECTS_ACCOUNT, + label: "Effects for Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-effects-by-account-id", + docsLabel: "effects for account", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{account_id}/effects{?cursor,limit,order}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_EFFECTS_LEDGER, + label: "Effects for Ledger", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-ledgers-effects", + docsLabel: "effects for ledger", + requestMethod: "GET", + endpointUrlTemplate: + "/ledgers/{ledger}/effects{?cursor,limit,order}", + requiredParams: "ledger", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_EFFECTS_LIQUIDITY_POOL, + label: "Effects for Liquidity Pool", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-related-effects", + docsLabel: "effects for liquidity pool", + requestMethod: "GET", + endpointUrlTemplate: + "/liquidity_pools/{liquidity_pool_id}/effects{?cursor,limit,order}", + requiredParams: "liquidity_pool_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_EFFECTS_OPERATION, + label: "Effects for Operation", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-an-operations-effects", + docsLabel: "effects for operation", + requestMethod: "GET", + endpointUrlTemplate: + "/operations/{operation}/effects{?cursor,limit,order}", + requiredParams: "operation", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_EFFECTS_TRANSACTION, + label: "Effects for Transaction", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-transactions-effects", + docsLabel: "effects for transaction", + requestMethod: "GET", + endpointUrlTemplate: + "/transactions/{transaction}/effects{?cursor,limit,order}", + requiredParams: "transaction", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_FEE_STATS, + label: "Fee Stats", + nestedItems: [ + { + route: Routes.ENDPOINTS_FEE_STATS, + label: "All Fee Stats", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/aggregations/fee-stats/object", + docsLabel: "fee stats", + requestMethod: "GET", + endpointUrlTemplate: "/fee_stats", + requiredParams: "", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_LEDGERS, + label: "Ledgers", + nestedItems: [ + { + route: Routes.ENDPOINTS_LEDGERS, + label: "All Ledgers", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/ledgers", + docsLabel: "ledgers", + requestMethod: "GET", + endpointUrlTemplate: "/ledgers{?cursor,limit,order}", + requiredParams: "", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_LEDGERS_SINGLE, + label: "Single Ledger", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-ledger", + docsLabel: "ledger", + requestMethod: "GET", + endpointUrlTemplate: "/ledgers/{ledger}", + requiredParams: "ledger", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_LIQUIDITY_POOLS, + label: "Liquidity Pools", + nestedItems: [ + { + route: Routes.ENDPOINTS_LIQUIDITY_POOLS, + label: "All Liquidity Pools", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/list-liquidity-pools", + docsLabel: "liquidity pools", + requestMethod: "GET", + endpointUrlTemplate: + "/liquidity_pools{?reserves,cursor,limit,order}", + requiredParams: "", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_LIQUIDITY_POOLS_SINGLE, + label: "Single Liquidity Pool", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-liquidity-pool", + docsLabel: "liquidity pool", + requestMethod: "GET", + endpointUrlTemplate: "/liquidity_pools/{liquidity_pool_id}", + requiredParams: "liquidity_pool_id", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_OFFERS, + label: "Offers", + nestedItems: [ + { + route: Routes.ENDPOINTS_OFFERS, + label: "All Offers", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/offers", + docsLabel: "offers", + requestMethod: "GET", + endpointUrlTemplate: + "/offers{?sponsor,seller,selling,buying,cursor,limit,order}", + requiredParams: "", + isStreaming: true, + custom: { + selling: { + assetInput: "issued", + includeNative: true, + }, + buying: { + assetInput: "issued", + includeNative: true, + }, + }, + }, + }, + { + route: Routes.ENDPOINTS_OFFERS_SINGLE, + label: "Single Offer", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-offer-by-offer-id", + docsLabel: "offer", + requestMethod: "GET", + endpointUrlTemplate: "/offers/{offer_id}", + requiredParams: "offer_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_OFFERS_ACCOUNT, + label: "Offers for Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-offers-by-account-id", + docsLabel: "offers for account", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{account_id}/offers{?cursor,limit,order}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_OPERATIONS, + label: "Operations", + nestedItems: [ + { + route: Routes.ENDPOINTS_OPERATIONS, + label: "All Operations", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/operations", + docsLabel: "operations", + requestMethod: "GET", + endpointUrlTemplate: + "/operations{?cursor,limit,order,include_failed}", + requiredParams: "", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_OPERATIONS_SINGLE, + label: "Single Operation", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-an-operation", + docsLabel: "operation", + requestMethod: "GET", + endpointUrlTemplate: "/operations/{operation}", + requiredParams: "operation", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_OPERATIONS_ACCOUNT, + label: "Operations for Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-operations-by-account-id", + docsLabel: "operations for account", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{account_id}/operations{?cursor,limit,order,include_failed}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_OPERATIONS_LEDGER, + label: "Operations for Ledger", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-ledgers-operations", + docsLabel: "operations for ledger", + requestMethod: "GET", + endpointUrlTemplate: + "/ledgers/{ledger}/operations{?cursor,limit,order,include_failed}", + requiredParams: "ledger", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_OPERATIONS_LIQUIDITY_POOL, + label: "Operations for Liquidity Pool", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/lp-retrieve-related-operations", + docsLabel: "operations for liquidity pool", + requestMethod: "GET", + endpointUrlTemplate: + "/liquidity_pools/{liquidity_pool_id}/operations{?cursor,limit,order,include_failed}", + requiredParams: "liquidity_pool_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_OPERATIONS_TRANSACTION, + label: "Operations for Transaction", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-transactions-operations", + docsLabel: "operations for transaction", + requestMethod: "GET", + endpointUrlTemplate: + "/transactions/{transaction}/operations{?cursor,limit,order}", + requiredParams: "transaction", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_ORDER_BOOK_DETAILS, + label: "Order Book", + nestedItems: [ + { + route: Routes.ENDPOINTS_ORDER_BOOK_DETAILS, + label: "Details", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/aggregations/order-books/single", + docsLabel: "order book", + requestMethod: "GET", + endpointUrlTemplate: + "/order_book{?selling_asset_type,selling_asset_code,selling_asset_issuer,buying_asset_type,buying_asset_code,buying_asset_issuer}", + requiredParams: "selling_asset,buying_asset", + isStreaming: true, + custom: { + renderComponents: ["selling_asset", "buying_asset"], + paramMapping: { + selling_asset_type: "selling_asset.type", + selling_asset_code: "selling_asset.code", + selling_asset_issuer: "selling_asset.issuer", + buying_asset_type: "buying_asset.type", + buying_asset_code: "buying_asset.code", + buying_asset_issuer: "buying_asset.issuer", + }, + selling_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + buying_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + }, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_PATHS, + label: "Paths", + nestedItems: [ + { + route: Routes.ENDPOINTS_PATHS, + label: "Find Payment Paths", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/aggregations/paths", + docsLabel: "payment paths", + requestMethod: "GET", + endpointUrlTemplate: + "/paths{?destination_asset_type,destination_asset_code,destination_asset_issuer,destination_amount,destination_account,source_account}", + requiredParams: + "source_account,destination_asset,destination_amount", + isStreaming: true, + custom: { + renderComponents: ["destination_asset"], + paramMapping: { + destination_asset_type: "destination_asset.type", + destination_asset_code: "destination_asset.code", + destination_asset_issuer: "destination_asset.issuer", + }, + destination_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + }, + }, + }, + { + route: Routes.ENDPOINTS_PATHS_STRICT_RECEIVE, + label: "Find Strict Receive Payment Paths", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/aggregations/paths/strict-receive", + docsLabel: "strict receive payment paths", + requestMethod: "GET", + endpointUrlTemplate: + "/paths/strict-receive{?,destination_asset_type,destination_asset_issuer,destination_asset_code,destination_amount,destination_account,source_account,source_assets}", + requiredParams: + "source_account,destination_asset,destination_amount", + isStreaming: true, + custom: { + renderComponents: ["destination_asset"], + paramMapping: { + destination_asset_type: "destination_asset.type", + destination_asset_code: "destination_asset.code", + destination_asset_issuer: "destination_asset.issuer", + }, + destination_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + }, + }, + }, + { + route: Routes.ENDPOINTS_PATHS_STRICT_SEND, + label: "Find Strict Send Payment Paths", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/aggregations/paths/strict-send", + docsLabel: "strict send payment paths", + requestMethod: "GET", + endpointUrlTemplate: + "/paths/strict-send{?source_amount,destination_account,destination_assets,source_asset_type,source_asset_issuer,source_asset_code}", + requiredParams: "source_asset,source_amount", + isStreaming: true, + custom: { + renderComponents: ["source_asset"], + paramMapping: { + source_asset_type: "source_asset.type", + source_asset_code: "source_asset.code", + source_asset_issuer: "source_asset.issuer", + }, + source_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + }, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_PAYMENTS, + label: "Payments", + nestedItems: [ + { + route: Routes.ENDPOINTS_PAYMENTS, + label: "All Payments", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/list-all-payments", + docsLabel: "payments", + requestMethod: "GET", + endpointUrlTemplate: + "/payments{?cursor,limit,order,include_failed}", + requiredParams: "", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_PAYMENTS_ACCOUNT, + label: "Payments for Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-payments-by-account-id", + docsLabel: "payments for account", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{account_id}/payments{?cursor,limit,order,include_failed}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_PAYMENTS_LEDGER, + label: "Payments for Ledger", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-ledgers-payments", + docsLabel: "payments for ledger", + requestMethod: "GET", + endpointUrlTemplate: + "/ledgers/{ledger}/payments{?cursor,limit,order,include_failed}", + requiredParams: "ledger", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_PAYMENTS_TRANSACTION, + label: "Payments for Transaction", + form: { + docsUrl: + "https://developers.stellar.org/docs/data/horizon/api-reference/retrieve-a-transactions-payments", + docsLabel: "payments for transaction", + requestMethod: "GET", + endpointUrlTemplate: + "/transactions/{transaction}/payments{?cursor,limit,order}", + requiredParams: "transaction", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_TRADE_AGGREGATIONS, + label: "Trade Aggregations", + nestedItems: [ + { + route: Routes.ENDPOINTS_TRADE_AGGREGATIONS, + label: "All Trade Aggregations", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/aggregations/trade-aggregations/list", + docsLabel: "trade aggregations", + requestMethod: "GET", + endpointUrlTemplate: + "/trade_aggregations{?base_asset_type,base_asset_code,base_asset_issuer,counter_asset_type,counter_asset_code,counter_asset_issuer,resolution,start_time,end_time,limit,order}", + requiredParams: "base_asset,counter_asset,resolution", + isStreaming: true, + custom: { + renderComponents: ["base_asset", "counter_asset"], + paramMapping: { + base_asset_type: "base_asset.type", + base_asset_code: "base_asset.code", + base_asset_issuer: "base_asset.issuer", + counter_asset_type: "counter_asset.type", + counter_asset_code: "counter_asset.code", + counter_asset_issuer: "counter_asset.issuer", + }, + base_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + counter_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + }, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_TRADES, + label: "Trades", + nestedItems: [ + { + route: Routes.ENDPOINTS_TRADES, + label: "All Trades", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-all-trades", + docsLabel: "trades", + requestMethod: "GET", + endpointUrlTemplate: + "/trades{?base_asset_type,base_asset_code,base_asset_issuer,counter_asset_type,counter_asset_code,counter_asset_issuer,offer_id,cursor,limit,order}", + requiredParams: "", + isStreaming: true, + custom: { + renderComponents: ["base_asset", "counter_asset"], + paramMapping: { + base_asset_type: "base_asset.type", + base_asset_code: "base_asset.code", + base_asset_issuer: "base_asset.issuer", + counter_asset_type: "counter_asset.type", + counter_asset_code: "counter_asset.code", + counter_asset_issuer: "counter_asset.issuer", + }, + base_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + counter_asset: { + assetInput: "alphanumeric", + includeNative: true, + }, + }, + }, + }, + { + route: Routes.ENDPOINTS_TRADES_ACCOUNT, + label: "Trades for Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-trades-by-account-id", + docsLabel: "trades for account", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{account_id}/trades{?cursor,limit,order}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_TRADES_LIQUIDITY_POOL, + label: "Trades for Liquidity Pool", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-related-trades", + docsLabel: "trades for liquidity pool", + requestMethod: "GET", + endpointUrlTemplate: + "/liquidity_pools/{liquidity_pool_id}/trades{?cursor,limit,order}", + requiredParams: "liquidity_pool_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_TRADES_OFFER, + label: "Trades for Offer", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-trades-by-offer-id", + docsLabel: "trades for offer", + requestMethod: "GET", + endpointUrlTemplate: + "/offers/{offer_id}/trades{?cursor,limit,order}", + requiredParams: "offer_id", + isStreaming: true, + }, + }, + ], + }, + { + route: Routes.ENDPOINTS_TRANSACTIONS, + label: "Transactions", + nestedItems: [ + { + route: Routes.ENDPOINTS_TRANSACTIONS, + label: "All Transactions", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/transactions", + docsLabel: "transactions", + requestMethod: "GET", + endpointUrlTemplate: + "/transactions{?cursor,limit,order,include_failed}", + requiredParams: "", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_TRANSACTIONS_SINGLE, + label: "Single Transaction", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-transaction", + docsLabel: "transaction", + requestMethod: "GET", + endpointUrlTemplate: "/transactions/{transaction}", + requiredParams: "transaction", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_TRANSACTIONS_POST, + label: "Post Transaction", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/submit-a-transaction", + docsLabel: "post transaction", + requestMethod: "POST", + endpointUrlTemplate: "/transactions{?tx}", + requiredParams: "tx", + isStreaming: false, + }, + }, + { + route: Routes.ENDPOINTS_TRANSACTIONS_ACCOUNT, + label: "Transactions for Account", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/get-transactions-by-account-id", + docsLabel: "transactions for account", + requestMethod: "GET", + endpointUrlTemplate: + "/accounts/{account_id}/transactions{?cursor,limit,order,include_failed}", + requiredParams: "account_id", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_TRANSACTIONS_LEDGER, + label: "Transactions for Ledger", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/retrieve-a-ledgers-transactions", + docsLabel: "transactions for ledger", + requestMethod: "GET", + endpointUrlTemplate: + "/ledgers/{ledger}/transactions{?cursor,limit,order,include_failed}", + requiredParams: "ledger", + isStreaming: true, + }, + }, + { + route: Routes.ENDPOINTS_TRANSACTIONS_LIQUIDITY_POOL, + label: "Transactions for Liquidity Pool", + form: { + docsUrl: + "https://developers.stellar.org/network/horizon/resources/lp-retrieve-related-transactions", + docsLabel: "transactions for liquidity pool", + requestMethod: "GET", + endpointUrlTemplate: + "/liquidity_pools/{liquidity_pool_id}/transactions{?cursor,limit,order,include_failed}", + requiredParams: "liquidity_pool_id", + isStreaming: true, + }, + }, + ], + }, + ], +}; diff --git a/src/constants/fetched_signers.ts b/src/constants/fetched_signers.ts deleted file mode 100644 index 3af18f32..00000000 --- a/src/constants/fetched_signers.ts +++ /dev/null @@ -1,9 +0,0 @@ -// This standardizes all the signatures verification states -// into a single map. -export enum FETCHED_SIGNERS { - NONE = "NONE", - PENDING = "PENDING", - SUCCESS = "SUCCESS", - FAIL = "FAIL", - NOT_EXIST = "NOT_EXIST", -} diff --git a/src/constants/network.js b/src/constants/network.js deleted file mode 100644 index 996f467f..00000000 --- a/src/constants/network.js +++ /dev/null @@ -1,20 +0,0 @@ -import { Networks } from "@stellar/stellar-sdk"; - -const NETWORK = { - available: { - futurenet: { - horizonURL: "https://horizon-futurenet.stellar.org", - networkPassphrase: Networks.FUTURENET, - }, - test: { - horizonURL: "https://horizon-testnet.stellar.org", - networkPassphrase: Networks.TESTNET, - }, - public: { - horizonURL: "https://horizon.stellar.org", - networkPassphrase: Networks.PUBLIC, - }, - }, - defaultName: "test", -}; -export default NETWORK; diff --git a/src/constants/routes.ts b/src/constants/routes.ts new file mode 100644 index 00000000..32257201 --- /dev/null +++ b/src/constants/routes.ts @@ -0,0 +1,83 @@ +/* eslint-disable no-unused-vars */ + +export enum Routes { + ROOT = "/", + // Account + ACCOUNT_CREATE = "/account/create", + ACCOUNT_FUND = "/account/fund", + ACCOUNT_CREATE_MUXED = "/account/muxed-create", + ACCOUNT_PARSE_MUXED = "/account/muxed-parse", + // Endpoints + ENDPOINTS = "/endpoints", + ENDPOINTS_SAVED = "/endpoints/saved", + ENDPOINTS_RPC = "/endpoints/rpc", + // Endpoints Horizon + ENDPOINTS_ACCOUNTS = "/endpoints/accounts", + ENDPOINTS_ACCOUNTS_SINGLE = "/endpoints/accounts/single", + ENDPOINTS_ASSETS = "/endpoints/assets", + ENDPOINTS_CLAIMABLE_BALANCES = "/endpoints/claimable-balances", + ENDPOINTS_CLAIMABLE_BALANCES_SINGLE = "/endpoints/claimable-balances/single", + ENDPOINTS_EFFECTS = "/endpoints/effects", + ENDPOINTS_EFFECTS_ACCOUNT = "/endpoints/effects/account", + ENDPOINTS_EFFECTS_LEDGER = "/endpoints/effects/ledger", + ENDPOINTS_EFFECTS_LIQUIDITY_POOL = "/endpoints/effects/liquidity-pool", + ENDPOINTS_EFFECTS_OPERATION = "/endpoints/effects/operation", + ENDPOINTS_EFFECTS_TRANSACTION = "/endpoints/effects/transaction", + ENDPOINTS_FEE_STATS = "/endpoints/fee-stats", + ENDPOINTS_LEDGERS = "/endpoints/ledgers", + ENDPOINTS_LEDGERS_SINGLE = "/endpoints/ledgers/single", + ENDPOINTS_LIQUIDITY_POOLS = "/endpoints/liquidity-pools", + ENDPOINTS_LIQUIDITY_POOLS_SINGLE = "/endpoints/liquidity-pools/single", + ENDPOINTS_OFFERS = "/endpoints/offers", + ENDPOINTS_OFFERS_SINGLE = "/endpoints/offers/single", + ENDPOINTS_OFFERS_ACCOUNT = "/endpoints/offers/account", + ENDPOINTS_OPERATIONS = "/endpoints/operations", + ENDPOINTS_OPERATIONS_SINGLE = "/endpoints/operations/single", + ENDPOINTS_OPERATIONS_ACCOUNT = "/endpoints/operations/account", + ENDPOINTS_OPERATIONS_LEDGER = "/endpoints/operations/ledger", + ENDPOINTS_OPERATIONS_LIQUIDITY_POOL = "/endpoints/operations/liquidity-pool", + ENDPOINTS_OPERATIONS_TRANSACTION = "/endpoints/operations/transaction", + ENDPOINTS_ORDER_BOOK_DETAILS = "/endpoints/order-book/details", + ENDPOINTS_PATHS = "/endpoints/paths", + ENDPOINTS_PATHS_STRICT_RECEIVE = "/endpoints/paths/strict-receive", + ENDPOINTS_PATHS_STRICT_SEND = "/endpoints/paths/strict-send", + ENDPOINTS_PAYMENTS = "/endpoints/payments", + ENDPOINTS_PAYMENTS_ACCOUNT = "/endpoints/payments/account", + ENDPOINTS_PAYMENTS_LEDGER = "/endpoints/payments/ledger", + ENDPOINTS_PAYMENTS_TRANSACTION = "/endpoints/payments/transaction", + ENDPOINTS_TRADE_AGGREGATIONS = "/endpoints/trade-aggregations", + ENDPOINTS_TRADES = "/endpoints/trades", + ENDPOINTS_TRADES_ACCOUNT = "/endpoints/trades/account", + ENDPOINTS_TRADES_LIQUIDITY_POOL = "/endpoints/trades/liquidity-pool", + ENDPOINTS_TRADES_OFFER = "/endpoints/trades/offer", + ENDPOINTS_TRANSACTIONS = "/endpoints/transactions", + ENDPOINTS_TRANSACTIONS_SINGLE = "/endpoints/transactions/single", + ENDPOINTS_TRANSACTIONS_POST = "/endpoints/transactions/post", + ENDPOINTS_TRANSACTIONS_ACCOUNT = "/endpoints/transactions/account", + ENDPOINTS_TRANSACTIONS_LEDGER = "/endpoints/transactions/ledger", + ENDPOINTS_TRANSACTIONS_LIQUIDITY_POOL = "/endpoints/transactions/liquidity-pool", + // Endpoints RPC + ENDPOINTS_GET_EVENTS = "/endpoints/rpc/get-events", + ENDPOINTS_GET_FEE_STATS = "/endpoints/rpc/get-fee-stats", + ENDPOINTS_GET_HEALTH = "/endpoints/rpc/get-health", + ENDPOINTS_GET_LATEST_LEDGER = "/endpoints/rpc/get-latest-ledger", + ENDPOINTS_GET_LEDGER_ENTRIES = "/endpoints/rpc/get-ledger-entries", + ENDPOINTS_GET_NETWORK = "/endpoints/rpc/get-network", + ENDPOINTS_GET_TRANSACTION = "/endpoints/rpc/get-transaction", + ENDPOINTS_GET_TRANSACTIONS = "/endpoints/rpc/get-transactions", + ENDPOINTS_GET_VERSION_INFO = "/endpoints/rpc/get-version-info", + ENDPOINTS_SEND_TRANSACTION = "/endpoints/rpc/send-transaction", + ENDPOINTS_SIMULATE_TRANSACTION = "/endpoints/rpc/simulate-transaction", + // Transactions + BUILD_TRANSACTION = "/transaction/build", + SIGN_TRANSACTION = "/transaction/sign", + SIMULATE_TRANSACTION = "/transaction/simulate", + SUBMIT_TRANSACTION = "/transaction/submit", + FEE_BUMP_TRANSACTION = "/transaction/fee-bump", + SAVED_TRANSACTIONS = "/transaction/saved", + // View XDR + VIEW_XDR = "/xdr/view", + TO_XDR = "/xdr/to", + // Smart Contracts + SMART_CONTRACTS = "/smart-contracts", +} diff --git a/src/constants/settings.ts b/src/constants/settings.ts index e8d6e518..84bc5954 100644 --- a/src/constants/settings.ts +++ b/src/constants/settings.ts @@ -1,2 +1,117 @@ -export const RESET_STORE_ACTION_TYPE = "RESET"; -export const LOCAL_STORAGE_NETWORK = "stellarLab:network"; +import { Networks } from "@stellar/stellar-sdk"; +import { Network } from "@/types/types"; + +export const LOCAL_STORAGE_SAVED_NETWORK = "stellar_lab_network"; +export const LOCAL_STORAGE_SAVED_ENDPOINTS_HORIZON = + "stellar_lab_saved_horizon_endpoints"; +export const LOCAL_STORAGE_SAVED_ENDPOINTS_RPC = + "stellar_lab_saved_rpc_endpoints"; +export const LOCAL_STORAGE_SAVED_TRANSACTIONS = + "stellar_lab_saved_transactions"; + +export const XDR_TYPE_TRANSACTION_ENVELOPE = "TransactionEnvelope"; + +export const NetworkOptions: Network[] = [ + { + id: "futurenet", + label: "Futurenet", + horizonUrl: "https://horizon-futurenet.stellar.org", + rpcUrl: "https://rpc-futurenet.stellar.org", + passphrase: Networks.FUTURENET, + }, + { + id: "testnet", + label: "Testnet", + horizonUrl: "https://horizon-testnet.stellar.org", + rpcUrl: "https://soroban-testnet.stellar.org", + passphrase: Networks.TESTNET, + }, + { + id: "mainnet", + label: "Mainnet", + horizonUrl: "https://horizon.stellar.org", + rpcUrl: "", + passphrase: Networks.PUBLIC, + }, + { + id: "custom", + label: "Custom", + horizonUrl: "", + rpcUrl: "", + passphrase: "", + }, +]; + +export const OPERATION_SET_FLAGS = [ + { + id: "set-auth-required", + label: "Authorization required", + value: 1, + }, + { + id: "set-auth-revocable", + label: "Authorization revocable", + value: 2, + }, + { + id: "set-auth-immutable", + label: "Authorization immutable", + value: 4, + }, + { + id: "set-auth-clawback", + label: "Authorization clawback enabled", + value: 8, + }, +]; + +export const OPERATION_CLEAR_FLAGS = [ + { + id: "clear-auth-required", + label: "Authorization required", + value: 1, + }, + { + id: "clear-auth-revocable", + label: "Authorization revocable", + value: 2, + }, + { + id: "clear-auth-clawback", + label: "Authorization clawback enabled", + value: 8, + }, +]; + +export const OPERATION_TRUSTLINE_SET_FLAGS = [ + { + id: "trustline-set-authorized", + label: "Authorized", + value: 1, + }, + { + id: "trustline-set-liabilites", + label: "Authorized to maintain liabilites", + value: 2, + }, +]; + +export const OPERATION_TRUSTLINE_CLEAR_FLAGS = [ + { + id: "trustline-clear-authorized", + label: "Authorized", + value: 1, + }, + { + id: "trustline-clear-liabilites", + label: "Authorized to maintain liabilites", + value: 2, + }, + { + id: "trustline-clear-clawback", + label: "Clawback enabled", + value: 4, + }, +]; + +export const GITHUB_URL = "https://github.com/stellar/laboratory"; diff --git a/src/constants/signTransactionPage.ts b/src/constants/signTransactionPage.ts new file mode 100644 index 00000000..87407683 --- /dev/null +++ b/src/constants/signTransactionPage.ts @@ -0,0 +1,62 @@ +import { FeeBumpTransaction, Transaction } from "@stellar/stellar-sdk"; + +export const FEE_BUMP_TX_FIELDS = (feeBumpTx: FeeBumpTransaction) => [ + { + label: "Fee source account", + value: feeBumpTx.feeSource, + }, + { + label: "Transaction Fee (stroops)", + value: feeBumpTx.fee, + }, + { + label: "Number of existing signatures", + value: feeBumpTx.signatures?.length, + }, + { + label: "Inner transaction hash", + value: feeBumpTx.innerTransaction.hash().toString("hex"), + }, + { + label: "Inner transaction source account", + value: feeBumpTx.innerTransaction.source, + }, + { + label: "Inner transaction sequence number", + value: feeBumpTx.innerTransaction.sequence, + }, + { + label: "Inner transaction fee (stroops)", + value: feeBumpTx.innerTransaction.fee, + }, + { + label: "Inner transaction number of operations", + value: feeBumpTx.innerTransaction.operations.length, + }, + { + label: "Inner transaction number of existing signatures", + value: feeBumpTx.innerTransaction.signatures.length, + }, +]; +export const TX_FIELDS = (transaction: Transaction) => [ + { + label: "Source account", + value: transaction.source, + }, + { + label: "Sequence number", + value: transaction.sequence, + }, + { + label: "Transaction Fee (stroops)", + value: transaction.fee, + }, + { + label: "Number of operations", + value: transaction.operations.length, + }, + { + label: "Number of existing signatures", + value: transaction.signatures.length, + }, +]; diff --git a/src/constants/signature.ts b/src/constants/signature.ts deleted file mode 100644 index 25afecc4..00000000 --- a/src/constants/signature.ts +++ /dev/null @@ -1,7 +0,0 @@ -// This standardizes all the signature verification states -// into a single map. -export const SIGNATURE = { - NOT_VERIFIED_YET: "NOT_VERIFIED_YET", - INVALID: "INVALID", - VALID: "VALID", -}; diff --git a/src/constants/slug.js b/src/constants/slug.js deleted file mode 100644 index ef3bf206..00000000 --- a/src/constants/slug.js +++ /dev/null @@ -1,12 +0,0 @@ -// This standardizes all the slug strings into a simple map -// These are used in to build the url and are the "page name" -const SLUG = { - HOME: '', - ACCOUNT_CREATOR: 'account-creator', - EXPLORER: 'explorer', - TXBUILDER: 'txbuilder', - TXSIGNER: 'txsigner', - XDRVIEWER: 'xdr-viewer', - TXSUBMITTER: 'txsubmitter', -}; -export default SLUG; diff --git a/src/constants/transactionOperations.tsx b/src/constants/transactionOperations.tsx new file mode 100644 index 00000000..fcdee6a4 --- /dev/null +++ b/src/constants/transactionOperations.tsx @@ -0,0 +1,430 @@ +import { SdsLink } from "@/components/SdsLink"; +import { + OPERATION_CLEAR_FLAGS, + OPERATION_SET_FLAGS, + OPERATION_TRUSTLINE_CLEAR_FLAGS, + OPERATION_TRUSTLINE_SET_FLAGS, +} from "@/constants/settings"; +import { AnyObject } from "@/types/types"; + +type TransactionOperation = { + label: string; + description: string; + docsUrl: string; + params: string[]; + requiredParams: string[]; + custom?: AnyObject; +}; + +export const TRANSACTION_OPERATIONS: { [key: string]: TransactionOperation } = { + create_account: { + label: "Create Account", + description: + "Creates and funds a new account with the specified starting balance.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#create-account", + params: ["destination", "starting_balance"], + requiredParams: ["destination", "starting_balance"], + }, + payment: { + label: "Payment", + description: + "Sends an amount in a specific asset to a destination account.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#payment", + params: ["destination", "asset", "amount"], + requiredParams: ["destination", "asset", "amount"], + }, + path_payment_strict_send: { + label: "Path Payment Strict Send", + description: + "Sends an amount in a specific asset to a destination account through a path of offers. This allows the asset sent (e.g., 450 XLM) to be different from the asset received (e.g, 6 BTC). A Path Payment Strict Send allows a user to specify the amount of the asset to send. The amount received will vary based on offers in the order books.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#path-payment-strict-send", + params: [ + "destination", + "send_asset", + "send_amount", + "path", + "dest_asset", + "dest_min", + ], + requiredParams: [ + "destination", + "send_asset", + "send_amount", + "dest_asset", + "dest_min", + ], + custom: { + send_asset: { + label: "Sending Asset", + note: "The asset to be deduced from the sender's account.", + }, + send_amount: { + label: "Send Amount", + }, + dest_asset: { + label: "Destination Asset", + note: "The asset to be received by the destination account.", + }, + dest_min: { + label: "Minimum Destination Amount", + note: "The minimum amount the destination can receive.", + }, + }, + }, + path_payment_strict_receive: { + label: "Path Payment Strict Receive", + description: + "Sends an amount in a specific asset to a destination account through a path of offers. This allows the asset sent (e.g., 450 XLM) to be different from the asset received (e.g, 6 BTC). A Path Payment Strict Receive allows a user to specify the amount of the asset received. The amount sent varies based on offers in the order books.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#path-payment-strict-receive", + params: [ + "destination", + "send_asset", + "send_max", + "path", + "dest_asset", + "dest_amount", + ], + requiredParams: [ + "destination", + "send_asset", + "send_max", + "dest_asset", + "dest_amount", + ], + custom: { + send_asset: { + label: "Sending Asset", + note: "The asset to be deduced from the sender's account.", + }, + send_max: { + label: "Maximum send amount", + }, + dest_asset: { + label: "Destination Asset", + note: "The asset to be received by the destination account.", + }, + dest_amount: { + label: "Destination Amount", + }, + }, + }, + manage_sell_offer: { + label: "Manage Sell Offer", + description: "Creates, updates, or deletes an offer.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#manage-sell-offer", + params: ["selling", "buying", "amount", "price", "offer_id"], + requiredParams: ["selling", "buying", "amount", "price", "offer_id"], + custom: { + amount: { + label: "Amount you are selling", + note: "An amount of zero will delete the offer.", + }, + price: { + label: "Price of 1 unit of selling in terms of buying", + }, + offer_id: { + note: "If 0, will create a new offer. Existing offer id numbers can be found using the Offers for Account endpoint.", + }, + }, + }, + manage_buy_offer: { + label: "Manage Buy Offer", + description: "Creates, updates, or deletes an offer.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#manage-buy-offer", + params: ["selling", "buying", "buy_amount", "price", "offer_id"], + requiredParams: ["selling", "buying", "buy_amount", "price", "offer_id"], + custom: { + buy_amount: { + label: "Amount you are buying", + note: "An amount of zero will delete the offer.", + }, + price: { + label: "Price of 1 unit of buying in terms of selling", + }, + offer_id: { + note: "If 0, will create a new offer. Existing offer id numbers can be found using the Offers for Account endpoint.", + }, + }, + }, + create_passive_sell_offer: { + label: "Create Passive Sell Offer", + description: + "Creates an offer that does not take another offer of equal price when created.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#create-passive-sell-offer", + params: ["selling", "buying", "amount", "price"], + requiredParams: ["selling", "buying", "amount", "price"], + custom: { + amount: { + label: "Amount you are selling", + note: "An amount of zero will delete the offer.", + }, + price: { + label: "Price of 1 unit of selling in terms of buying", + }, + }, + }, + set_options: { + label: "Set Options", + description: "Sets various configuration options for an account.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#set-options", + params: [ + "inflation_dest", + "set_flags", + "clear_flags", + "master_weight", + "low_threshold", + "med_threshold", + "high_threshold", + "signer", + "home_domain", + ], + requiredParams: [], + custom: { + master_weight: { + label: "Master Weight", + infoLink: + "https://developers.stellar.org/docs/encyclopedia/signatures-multisig#thresholds", + note: ( + + See documentation for multisignature accounts + + ), + showWarning: true, + }, + low_threshold: { + label: "Low Threshold", + infoLink: + "https://developers.stellar.org/docs/encyclopedia/signatures-multisig#thresholds", + }, + med_threshold: { + label: "Medium Threshold", + infoLink: + "https://developers.stellar.org/docs/encyclopedia/signatures-multisig#thresholds", + note: ( + + See documentation for multisignature accounts + + ), + showWarning: true, + }, + high_threshold: { + label: "High Threshold", + infoLink: + "https://developers.stellar.org/docs/encyclopedia/signatures-multisig#thresholds", + note: ( + + See documentation for multisignature accounts + + ), + showWarning: true, + }, + set_flags: { + options: OPERATION_SET_FLAGS, + }, + clear_flags: { + options: OPERATION_CLEAR_FLAGS, + }, + }, + }, + change_trust: { + label: "Change Trust", + description: "Creates, updates, or deletes a trustline.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#change-trust", + params: ["line", "limit"], + requiredParams: ["line"], + custom: { + limit: { + note: "Leave empty to default to the max int64.", + // Use "note_add" to show another note below "note" + note_add: "Set to 0 to remove the trust line.", + }, + }, + }, + allow_trust: { + label: "Allow Trust", + description: "Updates the authorized flag of an existing trustline.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#allow-trust", + params: ["trustor", "assetCode", "authorize"], + requiredParams: ["trustor", "assetCode", "authorize"], + }, + account_merge: { + label: "Account Merge", + description: + "Transfers the native balance (the amount of XLM an account holds) to another account and removes the source account from the ledger.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#account-merge", + params: ["destination"], + requiredParams: ["destination"], + }, + manage_data: { + label: "Manage Data", + description: "Sets, modifies, or deletes a Data Entry (name/value pair).", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#manage-data", + params: ["data_name", "data_value"], + requiredParams: ["data_name"], + custom: { + data_value: { + note: "If empty, will delete the data entry named in this operation.", + // Use "note_add" to show another note below "note" + note_add: "Note: The Lab only supports strings.", + }, + }, + }, + bump_sequence: { + label: "Bump Sequence", + description: "Bumps sequence number.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#bump-sequence", + params: ["bump_to"], + requiredParams: ["bump_to"], + }, + create_claimable_balance: { + label: "Create Claimable Balance", + description: "Creates a new claimable balance.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#create-claimable-balance", + params: ["asset", "amount", "claimants"], + requiredParams: ["asset", "amount", "claimants"], + }, + claim_claimable_balance: { + label: "Claim Claimable Balance", + description: "Claims a claimable balance.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#claim-claimable-balance", + params: ["balance_id"], + requiredParams: ["balance_id"], + }, + begin_sponsoring_future_reserves: { + label: "Begin Sponsoring Future Reserves", + description: + "Initiate a sponsorship. There must be a corresponding End Sponsoring Future Reserves operation in the same transaction.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#begin-sponsoring-future-reserves", + params: ["sponsored_id"], + requiredParams: ["sponsored_id"], + }, + end_sponsoring_future_reserves: { + label: "End Sponsoring Future Reserves", + description: "End a sponsorship.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#end-sponsoring-future-reserves", + params: [], + requiredParams: [], + }, + clawback: { + label: "Clawback", + description: "Creates a clawback operation.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#clawback", + params: ["asset", "from", "amount"], + requiredParams: ["asset", "from", "amount"], + custom: { + asset: { + includeNative: false, + }, + }, + }, + revoke_sponsorship: { + label: "Revoke Sponsorship", + description: "Revoke sponsorship of a ledger entry.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#revoke-sponsorship", + params: ["revokeSponsorship"], + requiredParams: ["revokeSponsorship"], + }, + clawback_claimable_balance: { + label: "Clawback Claimable Balance", + description: "Creates a clawback operation for a claimable balance.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#clawback-claimable-balance", + params: ["balance_id"], + requiredParams: ["balance_id"], + }, + set_trust_line_flags: { + label: "Set Trust Line Flags", + description: "Creates a trustline flag configuring operation.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#set-trustline-flags", + params: ["asset", "trustor", "set_flags", "clear_flags"], + requiredParams: ["asset", "trustor"], + custom: { + asset: { + includeNative: false, + }, + set_flags: { + options: OPERATION_TRUSTLINE_SET_FLAGS, + }, + clear_flags: { + options: OPERATION_TRUSTLINE_CLEAR_FLAGS, + }, + }, + }, + liquidity_pool_deposit: { + label: "Liquidity Pool Deposit", + description: "Deposits assets into a liquidity pool.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#liquidity-pool-deposit", + params: [ + "liquidity_pool_id", + "max_amount_a", + "max_amount_b", + "min_price", + "max_price", + ], + requiredParams: [ + "liquidity_pool_id", + "max_amount_a", + "max_amount_b", + "min_price", + "max_price", + ], + custom: { + max_amount_a: { + label: "Max Amount A", + }, + max_amount_b: { + label: "Max Amount B", + }, + min_price: { + label: "Min Price", + note: "Minimum depositA/depositB price.", + }, + max_price: { + label: "Max Price", + note: "Maximum depositA/depositB price.", + }, + }, + }, + liquidity_pool_withdraw: { + label: "Liquidity Pool Withdraw", + description: "Withdraw assets from a liquidity pool.", + docsUrl: + "https://developers.stellar.org/docs/learn/fundamentals/list-of-operations#liquidity-pool-withdraw", + params: ["liquidity_pool_id", "amount", "min_amount_a", "min_amount_b"], + requiredParams: [ + "liquidity_pool_id", + "amount", + "min_amount_a", + "min_amount_b", + ], + custom: { + min_amount_a: { + label: "Min Amount A", + }, + min_amount_b: { + label: "Min Amount B", + }, + }, + }, +}; diff --git a/src/constants/transaction_types.js b/src/constants/transaction_types.js deleted file mode 100644 index 1598eee9..00000000 --- a/src/constants/transaction_types.js +++ /dev/null @@ -1,10 +0,0 @@ -/** - * @prettier - */ - -const TX_TYPES = { - REGULAR: "REGULAR", - FEE_BUMP: "FEE_BUMP", -}; - -export default TX_TYPES; diff --git a/src/constants/xdr.ts b/src/constants/xdr.ts new file mode 100644 index 00000000..9b51e6de --- /dev/null +++ b/src/constants/xdr.ts @@ -0,0 +1,4 @@ +import { functions } from "lodash"; +import { xdr } from "@stellar/stellar-sdk"; + +export const ALL_XDR_TYPES = functions(xdr).sort(); diff --git a/src/data/endpoints.ts b/src/data/endpoints.ts deleted file mode 100644 index 98cb0720..00000000 --- a/src/data/endpoints.ts +++ /dev/null @@ -1,602 +0,0 @@ -import All from "components/SetupPanes/All.js"; -import Accounts from "components/SetupPanes/Accounts.js"; -import AllAssets from "components/SetupPanes/AllAssets.js"; -import { AllLiquidityPools } from "components/SetupPanes/AllLiquidityPools"; -import AllOffers from "components/SetupPanes/AllOffers.js"; -import AllWithFailed from "components/SetupPanes/AllWithFailed.js"; -import ClaimableBalances from "components/SetupPanes/ClaimableBalances.js"; -import FindPaymentPaths from "components/SetupPanes/FindPaymentPaths.js"; -import FindStrictSendPaymentPaths from "components/SetupPanes/FindStrictSendPaymentPaths.js"; -import FindStrictReceivePaymentPaths from "components/SetupPanes/FindStrictReceivePaymentPaths.js"; -import ForAccount from "components/SetupPanes/ForAccount.js"; -import ForAccountWithFailed from "components/SetupPanes/ForAccountWithFailed.js"; -import ForLedger from "components/SetupPanes/ForLedger.js"; -import { ForLiquidityPool } from "components/SetupPanes/ForLiquidityPool"; -import { ForLiquidityPoolWithFailed } from "components/SetupPanes/ForLiquidityPoolWithFailed"; -import ForLedgerWithFailed from "components/SetupPanes/ForLedgerWithFailed.js"; -import ForOffer from "components/SetupPanes/ForOffer.js"; -import ForOperation from "components/SetupPanes/ForOperation.js"; -import ForTransaction from "components/SetupPanes/ForTransaction.js"; -import OrderBookDetails from "components/SetupPanes/OrderBookDetails.js"; -import PostTransaction from "components/SetupPanes/PostTransaction.js"; -import SingleAccount from "components/SetupPanes/SingleAccount.js"; -import SingleClaimableBalance from "components/SetupPanes/SingleClaimableBalance.js"; -import SingleLedger from "components/SetupPanes/SingleLedger.js"; -import { SingleLiquidityPool } from "components/SetupPanes/SingleLiquidityPool"; -import SingleOperation from "components/SetupPanes/SingleOperation.js"; -import SingleOffer from "components/SetupPanes/SingleOffer.js"; -import SingleTransaction from "components/SetupPanes/SingleTransaction.js"; -import TradeAggregations from "components/SetupPanes/TradeAggregations.js"; -import Trades from "components/SetupPanes/Trades.js"; -import { EndpointItemProps, RequestMethod } from "types/types"; - -type EndpointsMap = { - [key: string]: EndpointItemProps; -}; - -export const endpointsMap: EndpointsMap = { - accounts: { - label: "Accounts", - endpoints: { - multiple: { - label: "Accounts", - helpUrl: - "https://developers.stellar.org/docs/fundamentals-and-concepts/stellar-data-structures/accounts", - method: RequestMethod.GET, - path: { - template: "/accounts/{?sponsor,signer,asset,cursor,limit,order}", - }, - setupComponent: Accounts, - }, - single: { - label: "Single Account", - helpUrl: - "https://developers.stellar.org/api/resources/accounts/single/", - method: RequestMethod.GET, - path: { - template: "/accounts/{account_id}", - }, - setupComponent: SingleAccount, - }, - }, - }, - assets: { - label: "Assets", - endpoints: { - single: { - label: "All Assets", - helpUrl: "https://developers.stellar.org/api/resources/assets/", - method: RequestMethod.GET, - path: { - template: "/assets{?asset_code,asset_issuer,cursor,order,limit}", - }, - setupComponent: AllAssets, - }, - }, - }, - claimable_balances: { - label: "Claimable Balances", - endpoints: { - multiple: { - label: "All Claimable Balances", - helpUrl: - "https://developers.stellar.org/api/resources/claimablebalances/list/", - method: RequestMethod.GET, - disableStreaming: true, - path: { - template: - "/claimable_balances/{?sponsor,asset,claimant,cursor,limit,order}", - }, - setupComponent: ClaimableBalances, - }, - single: { - label: "Single Claimable Balance", - helpUrl: - "https://developers.stellar.org/api/resources/claimablebalances/single/", - method: RequestMethod.GET, - disableStreaming: true, - path: { - template: "/claimable_balances/{claimable_balance_id}", - }, - setupComponent: SingleClaimableBalance, - }, - }, - }, - effects: { - label: "Effects", - endpoints: { - all: { - label: "All Effects", - helpUrl: "https://developers.stellar.org/api/resources/effects/list/", - method: RequestMethod.GET, - path: { - template: "/effects{?cursor,limit,order}", - }, - setupComponent: All, - }, - for_account: { - label: "Effects for Account", - helpUrl: - "https://developers.stellar.org/api/resources/accounts/effects/", - method: RequestMethod.GET, - path: { - template: "/accounts/{account_id}/effects{?cursor,limit,order}", - }, - setupComponent: ForAccount, - }, - for_ledger: { - label: "Effects for Ledger", - helpUrl: - // TODO: vcarl Replace this with a glossary link. This one 404s: https://developers.stellar.org/docs/glossary/effects/ - "https://developers.stellar.org/api/resources/effects/", - method: RequestMethod.GET, - path: { - template: "/ledgers/{ledger}/effects{?cursor,limit,order}", - }, - setupComponent: ForLedger, - }, - for_liquidity_pool: { - label: "Effects for Liquidity Pool", - helpUrl: - "https://developers.stellar.org/api/resources/liquiditypools/effects/", - method: RequestMethod.GET, - path: { - template: - "/liquidity_pools/{liquidity_pool_id}/effects{?cursor,limit,order}", - }, - setupComponent: ForLiquidityPool, - }, - for_operation: { - label: "Effects for Operation", - helpUrl: - "https://developers.stellar.org/api/resources/operations/effects/", - method: RequestMethod.GET, - path: { - template: "/operations/{operation}/effects{?cursor,limit,order}", - }, - setupComponent: ForOperation, - }, - for_transaction: { - label: "Effects for Transaction", - helpUrl: - "https://developers.stellar.org/api/resources/transactions/effects/", - method: RequestMethod.GET, - path: { - template: "/transactions/{transaction}/effects{?cursor,limit,order}", - }, - setupComponent: ForTransaction, - }, - }, - }, - fee_stats: { - label: "Fee Stats", - endpoints: { - all: { - label: "All Fee Stats", - helpUrl: - "https://developers.stellar.org/api/aggregations/fee-stats/object/", - method: RequestMethod.GET, - path: { - template: "/fee_stats", - }, - setupComponent: () => null, - }, - }, - }, - ledgers: { - label: "Ledger", - endpoints: { - all: { - label: "All Ledgers", - helpUrl: "https://developers.stellar.org/api/resources/ledgers/", - method: RequestMethod.GET, - path: { - template: "/ledgers{?cursor,limit,order}", - }, - setupComponent: All, - }, - single: { - label: "Single Ledger", - helpUrl: "https://developers.stellar.org/api/resources/ledgers/single/", - method: RequestMethod.GET, - path: { - template: "/ledgers/{ledger}", - }, - setupComponent: SingleLedger, - }, - }, - }, - liquidity_pools: { - label: "Liquidity Pools", - endpoints: { - all: { - label: "All Liquidity Pools", - helpUrl: "https://developers.stellar.org/api/resources/liquiditypools/", - method: RequestMethod.GET, - path: { - template: "/liquidity_pools{?reserves,cursor,limit,order}", - }, - setupComponent: AllLiquidityPools, - }, - single: { - label: "Single Liquidity Pool", - helpUrl: - "https://developers.stellar.org/api/resources/liquiditypools/single/", - method: RequestMethod.GET, - path: { - template: "/liquidity_pools/{liquidity_pool_id}", - }, - setupComponent: SingleLiquidityPool, - }, - }, - }, - offers: { - label: "Offers", - endpoints: { - all: { - label: "All Offers", - helpUrl: "https://developers.stellar.org/api/resources/offers/list/", - method: RequestMethod.GET, - path: { - template: - "/offers{?sponsor,selling,buying,seller,cursor,limit,order}", - }, - setupComponent: AllOffers, - }, - single: { - label: "Single Offer", - helpUrl: "https://developers.stellar.org/api/resources/offers/", - method: RequestMethod.GET, - path: { - template: "/offers/{offer_id}", - }, - setupComponent: SingleOffer, - }, - for_account: { - label: "Offers for Account", - helpUrl: - "https://developers.stellar.org/api/resources/accounts/offers/", - method: RequestMethod.GET, - path: { - template: "/accounts/{account_id}/offers{?cursor,limit,order}", - }, - setupComponent: ForAccount, - }, - }, - }, - operations: { - label: "Operations", - endpoints: { - all: { - label: "All Operations", - helpUrl: "https://developers.stellar.org/api/resources/operations/", - method: RequestMethod.GET, - path: { - template: "/operations{?cursor,limit,order,include_failed}", - }, - setupComponent: AllWithFailed, - }, - single: { - label: "Single Operation", - helpUrl: - "https://developers.stellar.org/api/resources/operations/single/", - method: RequestMethod.GET, - path: { - template: "/operations/{operation}", - }, - setupComponent: SingleOperation, - }, - for_account: { - label: "Operations for Account", - helpUrl: - "https://developers.stellar.org/api/resources/accounts/operations/", - method: RequestMethod.GET, - path: { - template: - "/accounts/{account_id}/operations{?cursor,limit,order,include_failed}", - }, - setupComponent: ForAccountWithFailed, - }, - for_ledger: { - label: "Operations for Ledger", - helpUrl: - "https://developers.stellar.org/api/resources/ledgers/operations/", - method: RequestMethod.GET, - path: { - template: - "/ledgers/{ledger}/operations{?cursor,limit,order,include_failed}", - }, - setupComponent: ForLedgerWithFailed, - }, - for_liquidity_pool: { - label: "Operations for Liquidity Pool", - helpUrl: - "https://developers.stellar.org/api/resources/liquiditypools/operations/", - method: RequestMethod.GET, - path: { - template: - "/liquidity_pools/{liquidity_pool_id}/operations{?cursor,limit,order,include_failed}", - }, - setupComponent: ForLiquidityPoolWithFailed, - }, - for_transaction: { - label: "Operations for Transaction", - helpUrl: - "https://developers.stellar.org/api/resources/transactions/operations/", - method: RequestMethod.GET, - path: { - template: - "/transactions/{transaction}/operations{?cursor,limit,order}", - }, - setupComponent: ForTransaction, - }, - }, - }, - order_book: { - label: "Order Book", - endpoints: { - details: { - label: "Details", - helpUrl: "https://developers.stellar.org/api/aggregations/order-books/", - method: RequestMethod.GET, - path: { - template: - "/order_book{?selling_asset_type,selling_asset_code,selling_asset_issuer,buying_asset_type,buying_asset_code,buying_asset_issuer}", - selling_asset_type: "selling_asset.type", - selling_asset_code: "selling_asset.code", - selling_asset_issuer: "selling_asset.issuer", - buying_asset_type: "buying_asset.type", - buying_asset_code: "buying_asset.code", - buying_asset_issuer: "buying_asset.issuer", - }, - setupComponent: OrderBookDetails, - }, - }, - }, - paths: { - label: "Paths", - endpoints: { - all: { - label: "Find Payment Paths", - helpUrl: "https://developers.stellar.org/api/aggregations/paths/", - method: RequestMethod.GET, - path: { - template: - "/paths{?source_account,destination_account,destination_asset_type,destination_asset_code,destination_asset_issuer,destination_amount}", - destination_asset_type: "destination_asset.type", - destination_asset_code: "destination_asset.code", - destination_asset_issuer: "destination_asset.issuer", - }, - setupComponent: FindPaymentPaths, - }, - strict_receive: { - label: "Find Strict Receive Payment Paths", - helpUrl: - "https://developers.stellar.org/api/aggregations/paths/strict-receive/", - method: RequestMethod.GET, - path: { - template: - "/paths/strict-receive{?source_assets,source_account,destination_account,destination_asset_type,destination_asset_issuer,destination_asset_code,destination_amount}", - destination_asset_type: "destination_asset.type", - destination_asset_code: "destination_asset.code", - destination_asset_issuer: "destination_asset.issuer", - }, - setupComponent: FindStrictReceivePaymentPaths, - }, - strict_send: { - label: "Find Strict Send Payment Paths", - helpUrl: - "https://developers.stellar.org/api/aggregations/paths/strict-send/", - method: RequestMethod.GET, - path: { - template: - "/paths/strict-send{?destination_account,destination_assets,source_asset_type,source_asset_issuer,source_asset_code,source_amount}", - source_asset_type: "source_asset.type", - source_asset_code: "source_asset.code", - source_asset_issuer: "source_asset.issuer", - }, - setupComponent: FindStrictSendPaymentPaths, - }, - }, - }, - payments: { - label: "Payments", - endpoints: { - all: { - label: "All Payments", - helpUrl: - // TODO: vcarl This doesn't have a replacement page yet - "https://www.stellar.org/developers/horizon/reference/endpoints/payments-all.html", - method: RequestMethod.GET, - path: { - template: "/payments{?cursor,limit,order,include_failed}", - }, - setupComponent: AllWithFailed, - }, - for_account: { - label: "Payments for Account", - helpUrl: - // TODO: vcarl This doesn't have a replacement page yet - "https://www.stellar.org/developers/horizon/reference/endpoints/payments-for-account.html", - method: RequestMethod.GET, - path: { - template: - "/accounts/{account_id}/payments{?cursor,limit,order,include_failed}", - }, - setupComponent: ForAccountWithFailed, - }, - for_ledger: { - label: "Payments for Ledger", - helpUrl: - "https://developers.stellar.org/api/resources/ledgers/payments/", - method: RequestMethod.GET, - path: { - template: - "/ledgers/{ledger}/payments{?cursor,limit,order,include_failed}", - }, - setupComponent: ForLedgerWithFailed, - }, - for_transaction: { - label: "Payments for Transaction", - helpUrl: - // TODO: vcarl This doesn't have a replacement page yet - "https://www.stellar.org/developers/horizon/reference/endpoints/payments-for-transaction.html", - method: RequestMethod.GET, - path: { - template: "/transactions/{transaction}/payments{?cursor,limit,order}", - }, - setupComponent: ForTransaction, - }, - }, - }, - trade_aggregations: { - label: "Trade Aggregations", - endpoints: { - all: { - label: "Trade Aggregations", - helpUrl: - "https://developers.stellar.org/api/aggregations/trade-aggregations/", - method: RequestMethod.GET, - path: { - template: - "/trade_aggregations{?base_asset_type,base_asset_code,base_asset_issuer,counter_asset_type,counter_asset_code,counter_asset_issuer,start_time,end_time,resolution,limit,order}", - base_asset_type: "base_asset.type", - base_asset_code: "base_asset.code", - base_asset_issuer: "base_asset.issuer", - counter_asset_type: "counter_asset.type", - counter_asset_code: "counter_asset.code", - counter_asset_issuer: "counter_asset.issuer", - start_time: "start_time", - end_time: "end_time", - resolution: "resolution", - }, - setupComponent: TradeAggregations, - }, - }, - }, - trades: { - label: "Trades", - endpoints: { - all: { - label: "All Trades", - helpUrl: "https://developers.stellar.org/api/resources/trades/", - method: RequestMethod.GET, - path: { - template: - "/trades{?base_asset_type,base_asset_code,base_asset_issuer,counter_asset_type,counter_asset_code,counter_asset_issuer,offer_id,cursor,limit,order}", - base_asset_type: "base_asset.type", - base_asset_code: "base_asset.code", - base_asset_issuer: "base_asset.issuer", - counter_asset_type: "counter_asset.type", - counter_asset_code: "counter_asset.code", - counter_asset_issuer: "counter_asset.issuer", - offer_id: "offer_id", - }, - setupComponent: Trades, - }, - for_account: { - label: "Trades for Account", - helpUrl: - "https://developers.stellar.org/api/resources/accounts/trades/", - method: RequestMethod.GET, - path: { - template: "/accounts/{account_id}/trades{?cursor,limit,order}", - }, - setupComponent: ForAccount, - }, - for_liquidity_pool: { - label: "Trades for Liquidity Pool", - // TODO: need docs - helpUrl: - "https://developers.stellar.org/api/resources/liquiditypools/trades/", - method: RequestMethod.GET, - path: { - template: - "/liquidity_pools/{liquidity_pool_id}/trades{?cursor,limit,order}", - }, - setupComponent: ForLiquidityPool, - }, - for_offer: { - label: "Trades for Offer", - helpUrl: - // TODO: vcarl This doesn't have a replacement page yet - "https://www.stellar.org/developers/horizon/reference/endpoints/trades-for-offer.html", - method: RequestMethod.GET, - path: { - template: "/offers/{offer_id}/trades{?cursor,limit,order}", - }, - setupComponent: ForOffer, - }, - }, - }, - transactions: { - label: "Transactions", - endpoints: { - all: { - label: "All Transactions", - helpUrl: - "https://developers.stellar.org/api/resources/transactions/list/", - method: RequestMethod.GET, - path: { - template: "/transactions{?cursor,limit,order,include_failed}", - }, - setupComponent: AllWithFailed, - }, - single: { - label: "Single Transaction", - helpUrl: - "https://developers.stellar.org/api/resources/transactions/single/", - method: RequestMethod.GET, - path: { - template: "/transactions/{transaction}", - }, - setupComponent: SingleTransaction, - }, - create: { - label: "Post Transaction", - helpUrl: - // TODO: vcarl This doesn't have a replacement page yet - "https://www.stellar.org/developers/horizon/reference/endpoints/transactions-create.html", - method: RequestMethod.POST, - disableStreaming: true, - path: { - template: "/transactions", - }, - setupComponent: PostTransaction, - }, - for_account: { - label: "Transactions for Account", - helpUrl: - "https://developers.stellar.org/api/resources/accounts/transactions/", - method: RequestMethod.GET, - path: { - template: - "/accounts/{account_id}/transactions{?cursor,limit,order,include_failed}", - }, - setupComponent: ForAccountWithFailed, - }, - for_ledger: { - label: "Transactions for Ledger", - helpUrl: - "https://developers.stellar.org/api/resources/ledgers/transactions/", - method: RequestMethod.GET, - path: { - template: - "/ledgers/{ledger}/transactions{?cursor,limit,order,include_failed}", - }, - setupComponent: ForLedgerWithFailed, - }, - for_liquidity_pool: { - label: "Transactions for Liquidity Pool", - helpUrl: - "https://developers.stellar.org/api/resources/liquiditypools/transactions/", - method: RequestMethod.GET, - path: { - template: - "/liquidity_pools/{liquidity_pool_id}/transactions{?cursor,limit,order,include_failed}", - }, - setupComponent: ForLiquidityPoolWithFailed, - }, - }, - }, -}; diff --git a/src/data/operations.ts b/src/data/operations.ts deleted file mode 100644 index 190ae09c..00000000 --- a/src/data/operations.ts +++ /dev/null @@ -1,232 +0,0 @@ -import find from "lodash/find"; -import AccountMerge from "../components/OperationPanes/AccountMerge"; -import AllowTrust from "../components/OperationPanes/AllowTrust"; -import BeginSponsoringFutureReserves from "../components/OperationPanes/BeginSponsoringFutureReserves"; -import BumpSequence from "../components/OperationPanes/BumpSequence"; -import ChangeTrust from "../components/OperationPanes/ChangeTrust"; -import ClaimClaimableBalance from "../components/OperationPanes/ClaimClaimableBalance"; -import Clawback from "../components/OperationPanes/Clawback"; -import ClawbackClaimableBalance from "../components/OperationPanes/ClawbackClaimableBalance"; -import CreateAccount from "../components/OperationPanes/CreateAccount"; -import CreateClaimableBalance from "../components/OperationPanes/CreateClaimableBalance"; -import EndSponsoringFutureReserves from "../components/OperationPanes/EndSponsoringFutureReserves"; -import GenericOffer from "../components/OperationPanes/GenericOffer"; -import { LiquidityPoolDeposit } from "../components/OperationPanes/LiquidityPoolDeposit"; -import { LiquidityPoolWithdraw } from "../components/OperationPanes/LiquidityPoolWithdraw"; -import ManageBuyOffer from "../components/OperationPanes/ManageBuyOffer"; -import ManageData from "../components/OperationPanes/ManageData"; -import ManageSellOffer from "../components/OperationPanes/ManageSellOffer"; -import PathPaymentStrictReceive from "../components/OperationPanes/PathPaymentStrictReceive"; -import PathPaymentStrictSend from "../components/OperationPanes/PathPaymentStrictSend"; -import Payment from "../components/OperationPanes/Payment"; -import RevokeSponsorship from "../components/OperationPanes/RevokeSponsorship"; -import SetOptions from "../components/OperationPanes/SetOptions"; -import SetTrustLineFlags from "../components/OperationPanes/SetTrustLineFlags"; - -export function getOperation(opName: any) { - return find(operationsMap, { name: opName }); -} - -// Operations map documentation: -// [ // In an array because we really want this to be ordered correctly (whereas for params, it is not as important) -// { -// name: 'createAccount', // Corresponds to the operation key in js-stellar-sdk.Operation -// label: 'Create Account', // Human friendly name for the operation -// operationPane: require('../components/OperationPanes/CreateAccount'), // React component that contains the multiple pickers for this operation -// helpNote: "" // Operation description or note -// docsUrl: "" // Link to docs -// }, -// ] - -export const operationsMap: any = [ - { - name: "createAccount", - label: "Create Account", - operationPane: CreateAccount, - helpNote: - "Creates and funds a new account with the specified starting balance.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#create-account", - }, - { - name: "payment", - label: "Payment", - operationPane: Payment, - helpNote: "Sends an amount in a specific asset to a destination account.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#payment", - }, - { - name: "pathPaymentStrictSend", - label: "Path Payment Strict Send", - operationPane: PathPaymentStrictSend, - helpNote: - "Sends an amount in a specific asset to a destination account through a path of offers. This allows the asset sent (e.g., 450 XLM) to be different from the asset received (e.g, 6 BTC). A Path Payment Strict Send allows a user to specify the amount of the asset to send. The amount received will vary based on offers in the order books", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#path-payment-strict-send", - }, - { - name: "pathPaymentStrictReceive", - label: "Path Payment Strict Receive", - operationPane: PathPaymentStrictReceive, - helpNote: - "Sends an amount in a specific asset to a destination account through a path of offers. This allows the asset sent (e.g., 450 XLM) to be different from the asset received (e.g, 6 BTC). A Path Payment Strict Receive allows a user to specify the amount of the asset received. The amount sent varies based on offers in the order books.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#path-payment-strict-receive", - }, - { - name: "manageSellOffer", - label: "Manage Sell Offer", - operationPane: ManageSellOffer, - helpNote: "Creates, updates, or deletes an offer.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#manage-buy-offer", - }, - { - name: "manageBuyOffer", - label: "Manage Buy Offer", - operationPane: ManageBuyOffer, - helpNote: "Creates, updates, or deletes an offer.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#manage-sell-offer", - }, - { - name: "createPassiveSellOffer", - label: "Create Passive Sell Offer", - operationPane: GenericOffer, - helpNote: - "Creates an offer that does not take another offer of equal price when created.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#create-passive-offer", - }, - { - name: "setOptions", - label: "Set Options", - operationPane: SetOptions, - helpNote: "Sets various configuration options for an account.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#set-options", - }, - { - name: "changeTrust", - label: "Change Trust", - operationPane: ChangeTrust, - helpNote: "Creates, updates, or deletes a trustline.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#change-trust", - }, - { - name: "allowTrust", - label: "Allow Trust", - operationPane: AllowTrust, - helpNote: "Updates the authorized flag of an existing trustline.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#allow-trust", - }, - { - name: "accountMerge", - label: "Account Merge", - operationPane: AccountMerge, - helpNote: - "Transfers the native balance (the amount of XLM an account holds) to another account and removes the source account from the ledger.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#account-merge", - }, - { - name: "manageData", - label: "Manage Data", - operationPane: ManageData, - helpNote: "Sets, modifies, or deletes a Data Entry (name/value pair).", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#manage-data", - }, - { - name: "bumpSequence", - label: "Bump Sequence", - operationPane: BumpSequence, - helpNote: "Bumps sequence number.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#bump-sequence", - }, - { - name: "createClaimableBalance", - label: "Create Claimable Balance", - operationPane: CreateClaimableBalance, - helpNote: "Creates a new claimable balance.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#create-claimable-balance", - }, - { - name: "claimClaimableBalance", - label: "Claim Claimable Balance", - operationPane: ClaimClaimableBalance, - helpNote: "Claims a claimable balance.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#claim-claimable-balance", - }, - { - name: "beginSponsoringFutureReserves", - label: "Begin Sponsoring Future Reserves", - operationPane: BeginSponsoringFutureReserves, - helpNote: - "Initiate a sponsorship. There must be a corresponding End Sponsoring Future Reserves operation in the same transaction.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#begin-sponsoring-future-reserves", - }, - { - name: "endSponsoringFutureReserves", - label: "End Sponsoring Future Reserves", - operationPane: EndSponsoringFutureReserves, - helpNote: "End a sponsorship.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#end-sponsoring-future-reserves", - }, - { - name: "revokeSponsorship", - label: "Revoke Sponsorship", - operationPane: RevokeSponsorship, - helpNote: "Revoke sponsorship of a ledger entry.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#revoke-sponsorship", - }, - { - name: "clawback", - label: "Clawback", - operationPane: Clawback, - helpNote: "Creates a clawback operation.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#clawback", - }, - { - name: "clawbackClaimableBalance", - label: "Clawback Claimable Balance", - operationPane: ClawbackClaimableBalance, - helpNote: "Creates a clawback operation for a claimable balance.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#clawback-claimable-balance", - }, - { - name: "setTrustLineFlags", - label: "Set Trust Line Flags", - operationPane: SetTrustLineFlags, - helpNote: "Creates a trustline flag configuring operation.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#set-trustline-flags", - }, - { - name: "liquidityPoolDeposit", - label: "Liquidity Pool Deposit", - operationPane: LiquidityPoolDeposit, - helpNote: "Deposits assets into a liquidity pool.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#liquidity-pool-deposit", - }, - { - name: "liquidityPoolWithdraw", - label: "Liquidity Pool Withdraw", - operationPane: LiquidityPoolWithdraw, - helpNote: "Withdraw assets from a liquidity pool.", - docsUrl: - "https://developers.stellar.org/docs/start/list-of-operations/#liquidity-pool-withdraw", - }, -]; diff --git a/src/helpers/Libify.js b/src/helpers/Libify.js deleted file mode 100644 index 3620e444..00000000 --- a/src/helpers/Libify.js +++ /dev/null @@ -1,939 +0,0 @@ -// Libify is a utility that converts a wide variety of inputs into their stricter -// representations in Stellar libraries such as js-stellar-sdk and js-stellar-sdk. -// -// The Libify api aims to look similar to that of js-stellar-sdk and Sdk. It -// will output better error messages in cases where helpful (instead of just -// undefined error messages). -// -// Libify could also be used to generate source code from input but might not be -// the best choice since source code differs based on content. - -import * as Sdk from "@stellar/stellar-sdk"; -import defaults from "lodash/defaults"; -import each from "lodash/each"; -import has from "lodash/has"; -import isEmpty from "lodash/isEmpty"; -import isString from "lodash/isString"; -import isUndefined from "lodash/isUndefined"; -import map from "lodash/map"; -import { createPredicate } from "helpers/claimantHelpers.js"; - -// Helpers -let isInt = function (value) { - return String(value).match(/^[0-9]*$/g); -}; -let assertNotEmpty = function (value, message) { - if (isEmpty(value)) { - throw new Error(message); - } -}; -let assertIntOrEmpty = function (value, message) { - if (!isEmpty(value) && !isInt(value)) { - throw new Error(message); - } -}; - -// Converts a value into a boolean. String values are converted to their respective -// boolean values since html forms can only output string values. -let isLooseTruthy = function (value) { - if (value == "true") { - return true; - } - if (value == "false") { - return false; - } - return value == true; -}; - -// This function processes the value in three situations: -// 1. Is a number: return as is -// 2. String contains just digits: will convert into JavaScript Number integer -// 3. String is empty: converts to undefined (useful for optional arguments) -let castIntOrUndefined = function (value) { - if (typeof value === "number") { - return value; - } - if (isString(value) && value.match(/^[0-9]+$/g)) { - return Number(value); - } - return undefined; -}; - -// This function processes the value in three situations: -// 1. Is a string: return as is -// 2. String is empty: converts to undefined (useful for optional arguments) -let castStringOrUndefined = function (value) { - if (!isString(value) || value === "") { - return undefined; - } - return String(value); -}; - -let castStringOrNull = function (value) { - if (!isString(value) || value === "") { - return null; - } - return String(value); -}; - -let Libify = {}; - -Libify.Asset = function (opts) { - if (isEmpty(opts) || opts.type === "native") { - return Sdk.Asset.native(); - } - - if (opts.type === "liquidity_pool_shares") { - const lp = opts.liquidity_pool; - let assetA; - let assetB; - - if (!lp.assetA) { - throw new Error("Liquidity pool asset requires Asset A"); - } - - if (lp.assetA.type === "native") { - assetA = Sdk.Asset.native(); - } else { - assertNotEmpty( - lp.assetA.code, - "Liquidity pool Asset A requires asset code", - ); - assertNotEmpty( - lp.assetA.issuer, - "Liquidity pool Asset A requires asset issuer", - ); - assetA = new Sdk.Asset(lp.assetA.code, lp.assetA.issuer); - } - - if (!lp.assetB) { - throw new Error("Liquidity pool asset requires Asset B"); - } - - if (lp.assetB.type === "native") { - assetB = Sdk.Asset.native(); - } else { - assertNotEmpty( - lp.assetB.code, - "Liquidity pool Asset B requires asset code", - ); - assertNotEmpty( - lp.assetB.issuer, - "Liquidity pool Asset B requires asset issuer", - ); - assetB = new Sdk.Asset(lp.assetB.code, lp.assetB.issuer); - } - - return new Sdk.LiquidityPoolAsset(assetA, assetB, lp.fee); - } - - assertNotEmpty(opts.code, "Asset requires asset code"); - assertNotEmpty(opts.issuer, "Asset requires asset issuer"); - - return new Sdk.Asset(opts.code, opts.issuer); -}; - -Libify.Memo = function (opts) { - switch (opts.type) { - case "": - case "MEMO_TEXT": - return Sdk.Memo.text(opts.content); - case "MEMO_ID": - return Sdk.Memo.id(opts.content); - case "MEMO_HASH": - return Sdk.Memo.hash(opts.content); - case "MEMO_RETURN": - return Sdk.Memo.return(opts.content); - } -}; - -Libify.Claimant = function (opts) { - if (opts.predicate && opts.predicate.unconditional) { - return new Sdk.Claimant(opts.destination); - } - - // Predicate validation is handled in createPredicate() - return new Sdk.Claimant(opts.destination, createPredicate(opts.predicate)); -}; - -// Takes in a type and a pile of options and attempts to turn it into a valid -// js-stellar-sdk operation. If not, it will throw an error. -Libify.Operation = function (type, opts) { - assertNotEmpty(type, "Operation type is required"); - let opFunction = Libify.Operation[type]; - if ( - typeof opFunction === "undefined" || - has(Libify.Operation, "opFunction") - ) { - throw new Error("Unknown operation type: " + type); - } - return opFunction(opts); -}; - -Libify.Operation.createAccount = function (opts) { - assertNotEmpty( - opts.destination, - "Create Account operation requires destination", - ); - assertNotEmpty( - opts.startingBalance, - "Create Account operation requires starting balance", - ); - return Sdk.Operation.createAccount({ - destination: opts.destination, - startingBalance: opts.startingBalance, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.payment = function (opts) { - assertNotEmpty(opts.destination, "Payment operation requires destination"); - assertNotEmpty(opts.asset, "Payment operation requires asset"); - assertNotEmpty(opts.amount, "Payment operation requires amount"); - return Sdk.Operation.payment({ - destination: opts.destination, - asset: Libify.Asset(opts.asset), - amount: opts.amount, - source: opts.sourceAccount, - withMuxing: true, - }); -}; - -Libify.Operation.pathPaymentStrictSend = function (opts) { - assertNotEmpty( - opts.sendAsset, - "Path Payment Strict Send operation requires sending asset", - ); - assertNotEmpty( - opts.sendAmount, - "Path Payment Strict Send operation requires send amount", - ); - assertNotEmpty( - opts.destination, - "Path Payment Strict Send operation requires destination", - ); - assertNotEmpty( - opts.destAsset, - "Path Payment Strict Send operation requires destination asset", - ); - assertNotEmpty( - opts.destMin, - "Path Payment Strict Send operation requires the minimum destination amount", - ); - - let libifiedPath = map(opts.path, (hopAsset) => { - if (isUndefined(hopAsset.type)) { - throw new Error("All assets in path must be filled out"); - } - return Libify.Asset(hopAsset); - }); - - return Sdk.Operation.pathPaymentStrictSend({ - sendAsset: Libify.Asset(opts.sendAsset), - sendAmount: opts.sendAmount, - destination: opts.destination, - destAsset: Libify.Asset(opts.destAsset), - destMin: opts.destMin, - path: libifiedPath, - source: opts.sourceAccount, - withMuxing: true, - }); -}; - -Libify.Operation.pathPaymentStrictReceive = function (opts) { - assertNotEmpty( - opts.sendAsset, - "Path Payment Strict Receive operation requires sending asset", - ); - assertNotEmpty( - opts.sendMax, - "Path Payment Strict Receive operation requires max send", - ); - assertNotEmpty( - opts.destination, - "Path Payment Strict Receive operation requires destination", - ); - assertNotEmpty( - opts.destAsset, - "Path Payment Strict Receive operation requires destination asset", - ); - assertNotEmpty( - opts.destAmount, - "Path Payment Strict Receive operation requires the destination amount", - ); - - let libifiedPath = map(opts.path, (hopAsset) => { - if (isUndefined(hopAsset.type)) { - throw new Error("All assets in path must be filled out"); - } - return Libify.Asset(hopAsset); - }); - - return Sdk.Operation.pathPaymentStrictReceive({ - sendAsset: Libify.Asset(opts.sendAsset), - sendMax: opts.sendMax, - destination: opts.destination, - destAsset: Libify.Asset(opts.destAsset), - destAmount: opts.destAmount, - path: libifiedPath, - source: opts.sourceAccount, - withMuxing: true, - }); -}; - -Libify.Operation.changeTrust = function (opts) { - assertNotEmpty(opts.asset, "Change Trust operation requires asset"); - return Sdk.Operation.changeTrust({ - asset: Libify.Asset(opts.asset), - limit: opts.limit === "" ? undefined : opts.limit, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.allowTrust = function (opts) { - assertNotEmpty(opts.trustor, "Allow Trust operation requires trustor"); - assertNotEmpty(opts.assetCode, "Allow Trust operation requires asset code"); - assertNotEmpty( - opts.authorize, - "Allow Trust operation requires authorization setting", - ); - - return Sdk.Operation.allowTrust({ - trustor: opts.trustor, - assetCode: opts.assetCode, - authorize: Number(opts.authorize), - source: opts.sourceAccount, - }); -}; - -Libify.Operation.accountMerge = function (opts) { - assertNotEmpty( - opts.destination, - "Account Merge operation requires destination", - ); - return Sdk.Operation.accountMerge({ - destination: opts.destination, - source: opts.sourceAccount, - withMuxing: true, - }); -}; - -Libify.Operation.manageSellOffer = function (opts) { - assertNotEmpty( - opts.selling, - "Manage Sell Offer operation requires selling asset", - ); - assertNotEmpty( - opts.buying, - "Manage Sell Offer operation requires buying asset", - ); - assertNotEmpty(opts.amount, "Manage Sell Offer operation requires amount"); - assertNotEmpty(opts.price, "Manage Sell Offer operation requires price"); - assertNotEmpty(opts.offerId, "Manage Sell Offer operation requires Offer ID"); - return Sdk.Operation.manageSellOffer({ - selling: Libify.Asset(opts.selling), - buying: Libify.Asset(opts.buying), - amount: opts.amount, - price: opts.price, - offerId: opts.offerId, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.manageBuyOffer = function (opts) { - assertNotEmpty( - opts.selling, - "Manage Buy Offer operation requires selling asset", - ); - assertNotEmpty( - opts.buying, - "Manage Buy Offer operation requires buying asset", - ); - assertNotEmpty( - opts.buyAmount, - "Manage Buy Offer operation requires buyAmount", - ); - assertNotEmpty(opts.price, "Manage Buy Offer operation requires price"); - assertNotEmpty(opts.offerId, "Manage Buy Offer operation requires Offer ID"); - return Sdk.Operation.manageBuyOffer({ - selling: Libify.Asset(opts.selling), - buying: Libify.Asset(opts.buying), - buyAmount: opts.buyAmount, - price: opts.price, - offerId: opts.offerId, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.createPassiveSellOffer = function (opts) { - assertNotEmpty( - opts.selling, - "Create Passive Sell Offer operation requires selling asset", - ); - assertNotEmpty( - opts.buying, - "Create Passive Sell Offer operation requires buying asset", - ); - assertNotEmpty( - opts.amount, - "Create Passive Sell Offer operation requires amount", - ); - assertNotEmpty( - opts.price, - "Create Passive Sell Offer operation requires price", - ); - return Sdk.Operation.createPassiveSellOffer({ - selling: Libify.Asset(opts.selling), - buying: Libify.Asset(opts.buying), - amount: opts.amount, - price: opts.price, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.setOptions = function (opts) { - let signer; - if (opts.signer && opts.signer.type) { - let signerPubKeyEmpty = isEmpty(opts.signer.content); - let signerWeightEmpty = isEmpty(opts.signer.weight); - if (signerPubKeyEmpty && !signerWeightEmpty) { - throw new Error("Signer weight is required if signer key is present"); - } - if (!signerPubKeyEmpty && signerWeightEmpty) { - throw new Error("Signer key is required if signer weight is present"); - } - - if (!signerPubKeyEmpty && !signerWeightEmpty) { - signer = { - weight: castIntOrUndefined(opts.signer.weight), - }; - switch (opts.signer.type) { - case "ed25519PublicKey": - signer.ed25519PublicKey = opts.signer.content; - break; - case "sha256Hash": - case "preAuthTx": - signer[opts.signer.type] = Buffer.from(opts.signer.content, "hex"); - break; - default: - throw new Error("Invalid signer type"); - } - } else { - throw new Error("Enter signer key and weight"); - } - } - - assertIntOrEmpty(opts.clearFlags, "Clear flags must be an integer"); - assertIntOrEmpty(opts.setFlags, "Set flags must be an integer"); - assertIntOrEmpty(opts.masterWeight, "Master Weight must be an integer"); - assertIntOrEmpty(opts.lowThreshold, "Low Threshold must be an integer"); - assertIntOrEmpty(opts.medThreshold, "Medium Threshold must be an integer"); - assertIntOrEmpty(opts.highThreshold, "High Threshold must be an integer"); - - return Sdk.Operation.setOptions({ - inflationDest: opts.inflationDest, - clearFlags: castIntOrUndefined(opts.clearFlags), - setFlags: castIntOrUndefined(opts.setFlags), - masterWeight: castIntOrUndefined(opts.masterWeight), - lowThreshold: castIntOrUndefined(opts.lowThreshold), - medThreshold: castIntOrUndefined(opts.medThreshold), - highThreshold: castIntOrUndefined(opts.highThreshold), - signer: signer, - homeDomain: castStringOrUndefined(opts.homeDomain), - source: opts.sourceAccount, - }); -}; - -Libify.Operation.manageData = function (opts) { - assertNotEmpty(opts.name, "Manage Data operation requires entry name"); - - return Sdk.Operation.manageData({ - name: opts.name, - value: castStringOrNull(opts.value), - source: opts.sourceAccount, - }); -}; - -Libify.Operation.bumpSequence = function (opts) { - assertNotEmpty(opts.bumpTo, "Sequence number should be set"); - return Sdk.Operation.bumpSequence({ - bumpTo: opts.bumpTo, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.claimClaimableBalance = function (opts) { - assertNotEmpty( - opts.balanceId, - "Claim Claimable Balance operation requires claimable balance ID", - ); - - return Sdk.Operation.claimClaimableBalance({ - balanceId: opts.balanceId, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.createClaimableBalance = function (opts) { - assertNotEmpty( - opts.asset, - "Create Claimable Balance operation requires asset", - ); - assertNotEmpty( - opts.amount, - "Create Claimable Balance operation requires amount", - ); - assertNotEmpty( - opts.claimants, - "Create Claimable Balance operation requires at least one claimant", - ); - - let libifiedClaimants = map(opts.claimants, (claimant) => { - if (!claimant || !claimant.destination) { - throw new Error( - "Create Claimable Balance operation requires claimant destination", - ); - } else if (!claimant.predicate) { - throw new Error( - "Create Claimable Balance operation requires claimant predicate", - ); - } - - return Libify.Claimant(claimant); - }); - - return Sdk.Operation.createClaimableBalance({ - asset: Libify.Asset(opts.asset), - amount: opts.amount, - claimants: libifiedClaimants, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.beginSponsoringFutureReserves = function (opts) { - assertNotEmpty(opts.sponsoredId, "Sponsored ID should be set"); - return Sdk.Operation.beginSponsoringFutureReserves({ - sponsoredId: opts.sponsoredId, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.endSponsoringFutureReserves = function (opts) { - return Sdk.Operation.endSponsoringFutureReserves({ - source: opts.sourceAccount, - }); -}; - -Libify.Operation.revokeSponsorship = function (opts) { - if (!(opts.revoke && opts.revoke.type && opts.revoke.fields)) { - throw new Error("Revoke Sponsorship Type should be selected"); - } - - switch (opts.revoke.type) { - case "account": - assertNotEmpty(opts.revoke.fields.account, "Account should be set"); - - return Sdk.Operation.revokeAccountSponsorship({ - account: opts.revoke.fields.account, - source: opts.sourceAccount, - }); - case "trustline": - assertNotEmpty(opts.revoke.fields.account, "Account should be set"); - assertNotEmpty(opts.revoke.fields.asset, "Asset should be set"); - - return Sdk.Operation.revokeTrustlineSponsorship({ - account: opts.revoke.fields.account, - asset: Libify.Asset(opts.revoke.fields.asset), - source: opts.sourceAccount, - }); - case "offer": - assertNotEmpty(opts.revoke.fields.seller, "Seller should be set"); - assertNotEmpty(opts.revoke.fields.offerId, "Offer ID should be set"); - - if (opts.revoke.fields.offerId && isNaN(opts.revoke.fields.offerId)) { - throw new Error("Offer ID should be a number"); - } - - return Sdk.Operation.revokeOfferSponsorship({ - seller: opts.revoke.fields.seller, - offerId: opts.revoke.fields.offerId, - source: opts.sourceAccount, - }); - case "data": - assertNotEmpty(opts.revoke.fields.account, "Account should be set"); - assertNotEmpty(opts.revoke.fields.name, "Name should be set"); - - return Sdk.Operation.revokeDataSponsorship({ - account: opts.revoke.fields.account, - name: opts.revoke.fields.name, - source: opts.sourceAccount, - }); - case "claimableBalance": - assertNotEmpty( - opts.revoke.fields.balanceId, - "Claimable balance ID should be set", - ); - - return Sdk.Operation.revokeClaimableBalanceSponsorship({ - balanceId: opts.revoke.fields.balanceId, - source: opts.sourceAccount, - }); - case "signer": - const signer = opts.revoke.fields.signer; - - assertNotEmpty(opts.revoke.fields.account, "Account should be set"); - assertNotEmpty(signer, "Signer should be set"); - - if (signer) { - assertNotEmpty(signer.content, "Signer content should be set"); - } - - return Sdk.Operation.revokeSignerSponsorship({ - account: opts.revoke.fields.account, - signer: { - [signer.type]: signer.content, - }, - source: opts.sourceAccount, - }); - default: - return; - } -}; - -Libify.Operation.clawback = function (opts) { - assertNotEmpty(opts.asset, "Clawback operation requires asset"); - assertNotEmpty( - opts.from, - "Clawback operation requires account from which the asset is clawed back", - ); - assertNotEmpty(opts.amount, "Clawback operation requires amount clawed back"); - return Sdk.Operation.clawback({ - asset: Libify.Asset(opts.asset), - from: opts.from, - amount: opts.amount, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.clawbackClaimableBalance = function (opts) { - assertNotEmpty( - opts.balanceId, - "Clawback Claimable Balance operation requires claimable balance ID", - ); - - return Sdk.Operation.clawbackClaimableBalance({ - balanceId: opts.balanceId, - }); -}; - -Libify.Operation.setTrustLineFlags = function (opts) { - assertNotEmpty(opts.asset, "Set Trust Line Flags operation requires asset"); - assertNotEmpty( - opts.trustor, - "Set Trust Line Flags operation requires trustor", - ); - - if ( - !(opts.setFlags && opts.setFlags.length) && - !(opts.clearFlags && opts.clearFlags.length) - ) { - throw new Error( - "Set Trust Line Flags operation requires at least one flag to be selected", - ); - } - - const flagLabels = { - authorized: "Authorized", - authorizedToMaintainLiabilities: "Authorized to maintain liabilites", - clawbackEnabled: "Clawback enabled", - }; - - let flags = (opts.setFlags || []).reduce( - (setFlagsResult, flag) => ({ ...setFlagsResult, [flag]: true }), - {}, - ); - - flags = (opts.clearFlags || []).reduce((clearFlagsResult, flag) => { - if (clearFlagsResult[flag]) { - throw new Error( - `Set Trust Line Flags operation cannot set and clear the same flag (${flagLabels[flag]})`, - ); - } - - return { ...clearFlagsResult, [flag]: false }; - }, flags); - - return Sdk.Operation.setTrustLineFlags({ - asset: Libify.Asset(opts.asset), - trustor: opts.trustor, - flags, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.liquidityPoolDeposit = function (opts) { - assertNotEmpty( - opts.liquidityPoolId, - "Liquidity Pool Deposit operation requires Liquidity Pool ID", - ); - - assertNotEmpty( - opts.maxAmountA, - "Liquidity Pool Deposit operation requires Max Amount A", - ); - - assertNotEmpty( - opts.maxAmountB, - "Liquidity Pool Deposit operation requires Max Amount B", - ); - - assertNotEmpty( - opts.minPrice, - "Liquidity Pool Deposit operation requires Min Price", - ); - - if (opts.minPrice && typeof opts.minPrice === "object") { - if (!(opts.minPrice.n && opts.minPrice.d)) { - throw new Error( - "Liquidity Pool Deposit operation requires both numerator and denominator for Min Price fraction", - ); - } - } - - assertNotEmpty( - opts.maxPrice, - "Liquidity Pool Deposit operation requires Max Price", - ); - - if (opts.maxPrice && typeof opts.maxPrice === "object") { - if (!(opts.maxPrice.n && opts.maxPrice.d)) { - throw new Error( - "Liquidity Pool Deposit operation requires both numerator and denominator for Max Price fraction", - ); - } - } - - return Sdk.Operation.liquidityPoolDeposit({ - liquidityPoolId: opts.liquidityPoolId, - maxAmountA: opts.maxAmountA, - maxAmountB: opts.maxAmountB, - minPrice: opts.minPrice, - maxPrice: opts.maxPrice, - source: opts.sourceAccount, - }); -}; - -Libify.Operation.liquidityPoolWithdraw = function (opts) { - assertNotEmpty( - opts.liquidityPoolId, - "Liquidity Pool Withdraw operation requires Liquidity Pool ID", - ); - - assertNotEmpty( - opts.amount, - "Liquidity Pool Withdraw operation requires amount", - ); - - assertNotEmpty( - opts.minAmountA, - "Liquidity Pool Withdraw operation requires Min Amount A", - ); - - assertNotEmpty( - opts.minAmountB, - "Liquidity Pool Withdraw operation requires Min Amount B", - ); - - return Sdk.Operation.liquidityPoolWithdraw({ - liquidityPoolId: opts.liquidityPoolId, - amount: opts.amount, - minAmountA: opts.minAmountA, - minAmountB: opts.minAmountB, - source: opts.sourceAccount, - }); -}; - -// buildTransaction is not something found js-stellar libs but acts as an -// abstraction to building a transaction with input data in the same format -// as the reducers -Libify.buildTransaction = function (attributes, operations, networkPassphrase) { - let result = { - errors: [], - xdr: "", - }; - - try { - let account; - const sequence = (BigInt(attributes.sequence) - BigInt(1)).toString(); - - if (Sdk.StrKey.isValidMed25519PublicKey(attributes.sourceAccount)) { - account = new Sdk.MuxedAccount.fromAddress( - attributes.sourceAccount, - sequence, - ); - } else { - account = new Sdk.Account(attributes.sourceAccount, sequence); - } - - let opts = { - networkPassphrase, - withMuxing: true, - }; - if (attributes.fee !== "") { - const MAX_UINT32 = Math.pow(2, 32) - 1; - if (parseInt(attributes.fee) > MAX_UINT32) { - throw Error(`Base Fee: too large (invalid 32-bit unisigned integer)`); - } - - opts.fee = attributes.fee; - } - - let timebounds = {}; - - if (attributes.minTime !== "") { - timebounds.minTime = attributes.minTime; - } - - if (attributes.maxTime !== "") { - timebounds.maxTime = attributes.maxTime; - } - - opts.timebounds = defaults(timebounds, { - minTime: "0", - maxTime: "0", - }); - - var transaction = new Sdk.TransactionBuilder(account, opts); - - if (attributes.memoType !== "MEMO_NONE" && attributes.memoType !== "") { - try { - transaction = transaction.addMemo( - Libify.Memo({ - type: attributes.memoType, - content: attributes.memoContent, - }), - ); - } catch (e) { - result.errors.push(`Memo: ${e.message}`); - } - } - - each(operations, (op, index) => { - try { - transaction = transaction.addOperation( - Libify.Operation(op.name, op.attributes), - ); - } catch (e) { - result.errors.push(`Operation #${index + 1}: ${e.message}`); - } - }); - - transaction = transaction.build(); - result.xdr = transaction.toEnvelope().toXDR("base64"); - result.hash = transaction.hash().toString("hex"); - } catch (e) { - result.errors.push(e.message); - } - return result; -}; - -Libify.buildFeeBumpTransaction = function (attributes, networkPassphrase) { - const result = { - errors: [], - xdr: "", - }; - - const { innerTxXDR, maxFee, sourceAccount } = attributes; - let innerTx; - try { - innerTx = new Sdk.TransactionBuilder.fromXDR(innerTxXDR, networkPassphrase); - } catch (e) { - result.errors.push("Invalid inner transaction XDR."); - return result; - } - - if (typeof innerTx.operations === "undefined") { - result.errors.push("Inner transaction must be a regular transaction."); - return result; - } - - let feeBumpTx; - try { - feeBumpTx = new Sdk.TransactionBuilder.buildFeeBumpTransaction( - sourceAccount, - maxFee, - innerTx, - networkPassphrase, - true, // withMuxing - ); - result.xdr = feeBumpTx.toEnvelope().toXDR("base64"); - } catch (e) { - result.errors.push(e.message); - } - return result; -}; - -Libify.signTransaction = function ( - txXdr, - signers, - networkPassphrase, - ledgerWalletSigs, - isSoroban = false, -) { - let validSecretKeys = []; - let validPreimages = []; - for (let i = 0; i < signers.length; i++) { - let signer = signers[i]; - if (signer !== null && !isUndefined(signer) && signer !== "") { - // Signer - if (signer.charAt(0) == "S") { - if (!Sdk.StrKey.isValidEd25519SecretSeed(signer)) { - return { - message: "One of secret keys is invalid", - }; - } - validSecretKeys.push(signer); - } else { - // Hash preimage - if (!signer.match(/^[0-9a-f]{2,128}$/gi) || signer.length % 2 == 1) { - return { - message: "Hash preimage is invalid", - }; - } - validPreimages.push(signer); - } - } - } - - let newTx = Sdk.TransactionBuilder.fromXDR(txXdr, networkPassphrase); - let existingSigs = newTx.signatures.length; - let addedSigs = 0; - - each(validSecretKeys, (signer) => { - addedSigs++; - newTx.sign(Sdk.Keypair.fromSecret(signer)); - }); - each(validPreimages, (signer) => { - addedSigs++; - newTx.signHashX(Buffer.from(signer, "hex")); - }); - each(ledgerWalletSigs, (ledgerSig) => { - addedSigs++; - newTx.signatures.push(ledgerSig); - }); - - if (addedSigs < 1) { - return { - message: "Enter a secret key to sign message", - }; - } - - return { - xdr: newTx.toEnvelope().toXDR("base64"), - message: `${addedSigs} signature(s) added; ${ - existingSigs + addedSigs - } signature(s) total`, - }; -}; - -export default Libify; diff --git a/src/helpers/StellarXdr.ts b/src/helpers/StellarXdr.ts new file mode 100644 index 00000000..eadfaf04 --- /dev/null +++ b/src/helpers/StellarXdr.ts @@ -0,0 +1,17 @@ +import wasm, { decode, encode } from "@stellar/stellar-xdr-json-web"; + +// A wrapper for the Stellar XDR JSON +declare global { + interface Window { + __STELLAR_XDR_INIT__?: boolean; + } +} + +const init = async () => { + if (!window.__STELLAR_XDR_INIT__) { + await wasm(); + window.__STELLAR_XDR_INIT__ = true; + } +}; + +export { init, decode, encode }; diff --git a/src/helpers/arrayItem.ts b/src/helpers/arrayItem.ts new file mode 100644 index 00000000..cdf961f6 --- /dev/null +++ b/src/helpers/arrayItem.ts @@ -0,0 +1,82 @@ +const isValidItemIndex = (array: any[], itemIndex: number) => { + // No items in the array + if (array.length === 0) { + return false; + } + + // Invalid item index + if (itemIndex < 0 || itemIndex > array.length - 1) { + return false; + } + + return true; +}; + +const addItem = (array: any[], item: T) => { + return [...array, item]; +}; + +const deleteItem = (array: any[], itemIndex: number) => { + if (!isValidItemIndex(array, itemIndex)) { + return array; + } + + const itemArray = [...array]; + itemArray.splice(itemIndex, 1); + + return itemArray; +}; + +const duplicateItem = (array: any[], itemIndexToDuplicate: number) => { + if (!isValidItemIndex(array, itemIndexToDuplicate)) { + return array; + } + + return [...array, array[itemIndexToDuplicate]]; +}; + +const moveItem = ( + array: any[], + itemIndex: number, + direction: "before" | "after", +) => { + if (!isValidItemIndex(array, itemIndex)) { + return array; + } + + // Can't move before the first item + if (itemIndex === 0 && direction === "before") { + return array; + } + + // Can't move after the last item + if (itemIndex === array.length - 1 && direction === "after") { + return array; + } + + const itemArray = [...array]; + const el = itemArray.splice(itemIndex, 1)[0]; + const moveTo = direction === "after" ? itemIndex + 1 : itemIndex - 1; + + itemArray.splice(moveTo, 0, el); + return itemArray; +}; + +const updateItem = (array: any[], itemIndex: number, newItem: any) => { + if (!isValidItemIndex(array, itemIndex)) { + return array; + } + + const itemArray = [...array]; + itemArray[itemIndex] = newItem; + + return itemArray; +}; + +export const arrayItem = { + add: addItem, + delete: deleteItem, + duplicate: duplicateItem, + move: moveItem, + update: updateItem, +}; diff --git a/src/helpers/buildRequest.ts b/src/helpers/buildRequest.ts deleted file mode 100644 index f3e68125..00000000 --- a/src/helpers/buildRequest.ts +++ /dev/null @@ -1,41 +0,0 @@ -import { each, trim } from "lodash"; -import querystring from "querystring"; -import { buildRequestUrl } from "helpers/buildRequestUrl"; -import { - AnyObject, - EndpointItemEndpoint, - EndpointBuildRequest, -} from "types/types"; - -export const buildRequest = ( - baseUrl: string, - endpoint: EndpointItemEndpoint | undefined, - pendingRequest: AnyObject, -) => { - const request: EndpointBuildRequest = { - url: buildRequestUrl(baseUrl, endpoint, pendingRequest.values), - formData: "", - }; - - if (typeof endpoint !== "undefined") { - request.method = endpoint.method; - } - - // Currently, this only supports simple string values - if (request.method === "POST") { - const postData: AnyObject = {}; - - each(pendingRequest.values, (value, key) => { - postData[key] = trim(value); - }); - - // TODO: remove querystring package in Tier 3 (deprecated) - request.formData = querystring.stringify(postData); - } - - if (pendingRequest.values.streaming) { - request.streaming = true; - } - - return request; -}; diff --git a/src/helpers/buildRequestUrl.ts b/src/helpers/buildRequestUrl.ts deleted file mode 100644 index a907078e..00000000 --- a/src/helpers/buildRequestUrl.ts +++ /dev/null @@ -1,101 +0,0 @@ -import { - each, - trim, - isFunction, - isUndefined, - isString, - get, - reduce, -} from "lodash"; -import UriTemplates from "uri-templates"; -import { EndpointItemEndpoint, AnyObject } from "types/types"; - -export const buildRequestUrl = ( - baseUrl: string, - endpoint: EndpointItemEndpoint | undefined, - values: AnyObject, -) => { - if (typeof endpoint === "undefined") { - return ""; - } - - const uriTemplate = `${baseUrl}${endpoint.path.template}`; - - type Template = { - fill: any; - fromUri: any; - template: string; - varNames: string[]; - }; - - // TODO: maybe we remove this package in Tier 3 (not updated in 5 years) - const template: Template = UriTemplates(uriTemplate); - - // uriParams contains what we want to fill the url with - const uriParams: AnyObject = {}; - - each(template.varNames, (varName) => { - // With the appropriate getter, extract/transform the relevant value from values - // 1. Simple value: - // - no getter string in `endpoint.path` - // 2. String resolver: value is inside object in `values` - // - getter string in `endpoint.path` - // 3. Function resolver: - // - getter function in `endpoint.path` - // - // getter can only either be: `undefined`, `String`, or `Function` - - const getterPresent = varName in endpoint.path; - const getter = endpoint.path[varName]; - const getterIsFunc = isFunction(getter); - let value; - - if (getterPresent && getterIsFunc) { - // case 3 - value = getter(values); - } else if (getterPresent && !getterIsFunc) { - // case 2 - value = get(values, getter); - } else { - // case 1 - value = values[varName]; - } - - if (!isUndefined(value) && value !== "") { - if (!isString(value)) { - throw new Error("Endpoint explorer value must be a string"); - } - - uriParams[varName] = trim(value); - } - }); - - // Fill in unfilled parameters with placeholders (like {source_account}) - // Also create a map to unescape these placeholders - type UnescapeMap = { - oldStr: string; - newStr: string; - }; - - const unescapeMap: UnescapeMap[] = []; - - each(template.fromUri(uriTemplate), (placeholder, param) => { - if (!(param in uriParams)) { - uriParams[param] = placeholder; - unescapeMap.push({ - oldStr: encodeURIComponent(placeholder), - newStr: placeholder, - }); - } - }); - - const builtUrl = reduce( - unescapeMap, - (url, replacement) => { - return url.replace(replacement.oldStr, replacement.newStr); - }, - template.fill(uriParams), - ); - - return builtUrl; -}; diff --git a/src/helpers/capitalizeString.ts b/src/helpers/capitalizeString.ts new file mode 100644 index 00000000..4f0c8c1f --- /dev/null +++ b/src/helpers/capitalizeString.ts @@ -0,0 +1,2 @@ +export const capitalizeString = (text: string) => + (text && text[0].toUpperCase() + text.slice(1)) || text; diff --git a/src/helpers/claimantHelpers.js b/src/helpers/claimantHelpers.js deleted file mode 100644 index 67f0eae6..00000000 --- a/src/helpers/claimantHelpers.js +++ /dev/null @@ -1,258 +0,0 @@ -import * as Sdk from "@stellar/stellar-sdk"; -import flatten from "lodash/flatten"; -import flowRight from "lodash/flowRight"; -import isArray from "lodash/isArray"; -import isEmpty from "lodash/isEmpty"; - -export function addPathDelimiter(a, b) { - return a ? `${a}.${b}` : b; -} - -// Claimant predicate store data is in the following format: -// { -// conditional: { -// and: [ -// { -// conditional: { -// or: [{...}, {...}], -// }, -// }, -// {...}, -// ], -// }, -// } -// - -// For rendering (transformPredicateDataForRender) we transform them in a more -// consistent format to make rendering and updates more clear. -// [ -// { -// "parentPath": "", -// "type": "conditional", -// "value": [ -// { -// "parentPath": "conditional", -// "type": "and", -// "value": [ -// { -// "parentPath": "conditional.and.0", -// "type": "conditional", -// "value": [ -// { -// "parentPath": "conditional.and.0.conditional", -// "type": "or", -// "value": [{...},{...}] -// } -// ] -// }, -// { -// "parentPath": "conditional.and.1", -// "type": "", -// "value": [] -// } -// ] -// } -// ] -// } -// ] -export function transformPredicateDataForRender(data) { - // parentPath is used to update item in ClaimantPicker using Lodash set() - function loop(items, parentPath = "") { - return Object.entries(items).map((item) => { - const [key, value] = item; - - if (isArray(value)) { - return { - parentPath, - type: key, - // If value is array, we need to loop through all items. - value: flatten( - value.map((v, i) => { - // If there is no value yet, return default. - return isEmpty(v) - ? [ - { - parentPath: addPathDelimiter(parentPath, `${key}.${i}`), - type: "", - value: [], - }, - ] - : loop(v, addPathDelimiter(parentPath, `${key}.${i}`)); - }), - ), - }; - } else { - const isTimeValue = key === "absolute" || key === "relative"; - const isValueString = typeof value === "string"; - - return { - parentPath, - type: key, - // If value is empty or type string (it means time value is set and - // we need to stop), we return default or value. - value: - isEmpty(value) || isValueString - ? [ - { - parentPath: addPathDelimiter(parentPath, key), - type: "", - value: isTimeValue ? (isValueString ? value : "") : [], - }, - ] - : loop(value, addPathDelimiter(parentPath, key)), - }; - } - }); - } - - // Return value is array of formatted items for rendering. - return loop(data); -} - -function getPredicateMethod(type) { - switch (type) { - case "unconditional": - return Sdk.Claimant.predicateUnconditional; - case "and": - return Sdk.Claimant.predicateAnd; - case "or": - return Sdk.Claimant.predicateOr; - case "not": - return Sdk.Claimant.predicateNot; - case "absolute": - return Sdk.Claimant.predicateBeforeAbsoluteTime; - case "relative": - return Sdk.Claimant.predicateBeforeRelativeTime; - default: - throw new Error(`Predicate ${type.toUpperCase()} method not found.`); - } -} - -// We need to build predicate in the following format: -// Sdk.Claimant.predicateAnd( -// Sdk.Claimant.predicateOr( -// Sdk.Claimant.predicateNot( -// Sdk.Claimant.predicateBeforeRelativeTime("111") -// ), -// Sdk.Claimant.predicateBeforeRelativeTime("222") -// ), -// Sdk.Claimant.predicateBeforeRelativeTime("333") -// ); - -// Lodash flowRight() allows us to make function calls from the last one (time), -// giving an array of parent functions. -export function createPredicate(data) { - function loop(items, callbacksArray = []) { - return flatten( - Object.entries(items).map((item) => { - const [key, value] = item; - - if (typeof value === "string") { - const callback = flowRight([ - ...callbacksArray, - getPredicateMethod(key), - ]); - return callback(value); - } else { - if (isArray(value)) { - const predicates = flatten(value.map((v) => loop(v))); - const callback = flowRight([ - ...callbacksArray, - getPredicateMethod(key), - ]); - return callback(...predicates); - } else { - return loop(value, [...callbacksArray, getPredicateMethod(key)]); - } - } - }), - ); - } - - // Return value is an array, but we need to return an object. - return loop(sanitizePredicateOpts(data))[0]; -} - -function validatePredicateValue(value, key, index) { - if (isArray(value)) { - value.forEach((v, i) => validatePredicateValue(v, key, i)); - } - - if (isEmpty(value)) { - let message; - - if (key === "unconditional") { - return; - } - - switch (key) { - case "conditional": - message = "Conditional predicate is required."; - break; - case "and": - case "or": - message = `${key.toUpperCase()} requires predicate ${++index}.`; - break; - case "not": - message = "NOT requires a predicate."; - break; - case "time": - message = "Time predicate type is required."; - break; - case "absolute": - case "relative": - message = "Time predicate value is required."; - break; - default: - message = `${key.toUpperCase()} is required.`; - } - - throw new Error(message); - } -} - -// Predicate does not have "conditional" and "time" keys, so we need to remove -// them. Returned format: -// { -// and: [ -// or: [{...}, {...}], -// {...}, -// ], -// } -function sanitizePredicateOpts(opts) { - const supportedKeys = [ - "unconditional", - "and", - "or", - "not", - "relative", - "absolute", - ]; - - function getValue(value, key) { - validatePredicateValue(value, key); - return isArray(value) ? flatten(value.map((v) => loop(v))) : loop(value); - } - - function loop(items) { - return flatten( - Object.entries(items).map((item) => { - const [key, value] = item; - - if (typeof value === "string") { - validatePredicateValue(value, key); - return { [key]: value }; - } else { - return supportedKeys.includes(key) - ? { - [key]: getValue(value, key), - } - : getValue(value, key); - } - }), - ); - } - - // Return value is an array, but we need to return an object. - return loop(opts)[0]; -} diff --git a/src/helpers/clickToSelect.ts b/src/helpers/clickToSelect.ts deleted file mode 100644 index 8fc6a921..00000000 --- a/src/helpers/clickToSelect.ts +++ /dev/null @@ -1,15 +0,0 @@ -// DOM helper. When an element has clickToSelect and a users clicks on the element, -// then the whole element will be selected/highlighted. - -// usage: -export const clickToSelect = (event: React.MouseEvent) => { - const range = document.createRange(); - const windowSelection = window.getSelection(); - - range.selectNodeContents(event.target as Node); - - if (windowSelection) { - windowSelection.removeAllRanges(); - windowSelection.addRange(range); - } -}; diff --git a/src/helpers/convertMuxedAccountToEd25519Account.js b/src/helpers/convertMuxedAccountToEd25519Account.js deleted file mode 100644 index fcb7d59e..00000000 --- a/src/helpers/convertMuxedAccountToEd25519Account.js +++ /dev/null @@ -1,11 +0,0 @@ -import { xdr, StrKey } from "@stellar/stellar-sdk"; - -// This function was meant to convert string keys representing muxed accounts -// `M...` to their ED25519 public account `G..` However since SEP23 hasn't been -// rolled out yet, we'll show whatever value we receive without doing any type -// of conversion. Once SEP23 is included in stellar-base, we can update this -// code to show the inner G account of muxed accounts, in the meantime we'll -// just return the same value we receive. -export default function convertMuxedAccountToEd25519Account(muxedAccount) { - return muxedAccount; -} diff --git a/src/helpers/delay.ts b/src/helpers/delay.ts new file mode 100644 index 00000000..dad9adf4 --- /dev/null +++ b/src/helpers/delay.ts @@ -0,0 +1,3 @@ +export const delay = async (ms: number = 500) => { + return new Promise((resolve) => setTimeout(resolve, ms)); +}; diff --git a/src/helpers/delayedAction.ts b/src/helpers/delayedAction.ts new file mode 100644 index 00000000..3e08a403 --- /dev/null +++ b/src/helpers/delayedAction.ts @@ -0,0 +1,12 @@ +export const delayedAction = ({ + action, + delay, +}: { + action: () => void; + delay: number; +}) => { + const t = setTimeout(() => { + action(); + clearTimeout(t); + }, delay); +}; diff --git a/src/helpers/detectXdrType.js b/src/helpers/detectXdrType.js deleted file mode 100644 index e69de29b..00000000 diff --git a/src/helpers/dispatchInNewStack.js b/src/helpers/dispatchInNewStack.js deleted file mode 100644 index d73c7543..00000000 --- a/src/helpers/dispatchInNewStack.js +++ /dev/null @@ -1,9 +0,0 @@ -// Calling `dispatch` inside the `.catch` of `httpRequest` causes problems -// because it silently hides errors down the stack including all the React -// re-rendering happening due to the dispatch. -// By dispatching in a new stack, the dispatch function won't be caught -export default function dispatchInNewStack(dispatch, dispatchObj) { - setTimeout(() => { - dispatch(dispatchObj); - }, 0); -} diff --git a/src/helpers/extrapolateFromXdr.js b/src/helpers/extrapolateFromXdr.js deleted file mode 100644 index 524da002..00000000 --- a/src/helpers/extrapolateFromXdr.js +++ /dev/null @@ -1,238 +0,0 @@ -// This code originally taken from the XDR Viewer https://github.com/stellar/xdr-viewer -// by Stellar Development Foundation under Apache-2.0. - -// This turns a base64 encoded xdr object with it's type, and turns it into an -// object with more detailed information suitable for use in the tree view. - -// Values can be one of three types: -// - undefined -// - string: string values that appear as just plain text -// - object: typed values always with a type and value `{type: 'code', value: 'Foo();'}` - -import { - xdr, - StrKey, - Keypair, - Operation, - scValToNative, - nativeToScVal, -} from "@stellar/stellar-sdk"; -import isArray from "lodash/isArray"; -import isString from "lodash/isString"; -import functionsIn from "lodash/functionsIn"; -import includes from "lodash/includes"; -import without from "lodash/without"; -import { scValByType } from "helpers/sorobanXdrUtils"; - -export default function extrapolateFromXdr(input, type) { - // TODO: Check to see if type exists - // TODO: input validation - - function buildTreeFromObject(object, anchor, name) { - anchor.type = name; - - if (isArray(object)) { - parseArray(anchor, object); - } else if (!hasChildren(object)) { - anchor.value = getValue(object, name); - } else if (object.switch) { - parseArm(anchor, object); - } else { - parseNormal(anchor, object); - } - } - - function parseArray(anchor, object) { - anchor.value = `Array[${object.length}]`; - anchor.nodes = []; - for (var i = 0; i < object.length; i++) { - anchor.nodes.push({}); - buildTreeFromObject( - object[i], - anchor.nodes[anchor.nodes.length - 1], - "[" + i + "]", - ); - } - } - - function parseArm(anchor, object) { - anchor.value = "[" + object.switch().name + "]"; - if (isString(object.arm())) { - anchor.nodes = [{}]; - buildTreeFromObject( - // Soroban or Classic - scValByType(object) ?? object[object.arm()](), - anchor.nodes[anchor.nodes.length - 1], - object.arm(), - ); - } - } - - function parseNormal(anchor, object) { - anchor.nodes = []; - without(functionsIn(object), "toXDR").forEach(function (name) { - anchor.nodes.push({}); - buildTreeFromObject( - object[name](), - anchor.nodes[anchor.nodes.length - 1], - name, - ); - }); - } - - function hasChildren(object) { - // string - if (isString(object)) { - return false; - } - // node buffer - if (object && object._isBuffer) { - return false; - } - var functions = functionsIn(object); - if (functions.length == 0) { - return false; - } - // int64 - if ( - includes(functions, "getLowBits") && - includes(functions, "getHighBits") - ) { - return false; - } - return true; - } - - const amountFields = [ - "amount", - "startingBalance", - "sendMax", - "sendAmount", - "destMin", - "destAmount", - "limit", - ]; - - function getValue(object, name) { - if (includes(amountFields, name)) { - return { - type: "amount", - value: { - parsed: Operation._fromXDRAmount(object), - raw: object.toString(), - }, - }; - } - - if (name === "hint") { - // strkey encoding is using base32 encoding. Encoded public key consists of: - // - // * 1 byte version byte (0x30 encoded as `G`) - // * 32 bytes public key - // * 2 bytes checksum - // - // Because base32 symbols are 5-bit, more than one symbol is needed to represent a single byte. - // Signature Hint is the last 4 bytes of the public key. So we need to try to show as many 5-bit - // chunks as possible included between bytes 30 and 33 (included). - // - // byte 1: ##### ### - // byte 2: ## ##### # - // byte 3: #### #### - // byte 4: # ##### ## - // byte 5: ### ##### <---------- 40 bits / full alignment - // byte 6: ##### ### - // byte 7: ## ##### # - // - // ..... - // - // byte 26: ##### ### - // byte 27: ## ##### # - // byte 28: #### #### full b32 symbols - // byte 29: # ##### ## |--------------------------| - // byte 30: ### 48### | - // byte 31: Signature Hint start | 49### 50# | Signature Hint end - // byte 32: ## 51### 5 | | - // byte 33: 2### 53## - // byte 34: # 54### 55 - // byte 35: ### 56### - // - let hintBytes = new Buffer(object, "base64"); - let partialPublicKey = Buffer.concat([new Buffer(28).fill(0), hintBytes]); - let keypair = new Keypair({ - type: "ed25519", - publicKey: partialPublicKey, - }); - let partialPublicKeyString = - "G" + - new Buffer(46).fill("_").toString() + - keypair.publicKey().substr(47, 5) + - new Buffer(4).fill("_").toString(); - return { type: "code", value: partialPublicKeyString }; - } - - if (name === "ed25519" || name === "sourceAccountEd25519") { - var address = StrKey.encodeEd25519PublicKey(object); - return { type: "code", value: address }; - } - - if ( - name === "assetCode" || - name === "assetCode4" || - name === "assetCode12" - ) { - return object.toString(); - } - - if (name === "contractId" && object) { - return StrKey.encodeContract(object); - } - - if (name === "functionName" || name === "sym") { - return object.toString(); - } - - if (name === "durability") { - return JSON.stringify(object); - } - - if (name === "type") { - return JSON.stringify(object); - } - - if (object && object._isBuffer) { - return { - type: "code", - raw: object, - value: new Buffer(object).toString("base64"), - }; - } - - if (typeof object === "undefined") { - return; - } - - // getValue is a leaf in the recursive xdr extrapolating function meaning that - // whatever this function returns will be in the final result as-is. - // Therefore, we want them in string format so that it displayable in React. - // One example of why we need this is that UnsignedHyper values won't get - // displayed unless we convert it to a string. - if (typeof object.toString === "function") { - return object.toString(); - } - - throw new Error( - "Internal laboratory bug: Encountered value type in XDR viewer that does not have a toString method", - ); - } - - let xdrObject; - try { - xdrObject = xdr[type].fromXDR(input, "base64"); - } catch (error) { - throw new Error("Input XDR could not be parsed"); - } - - let tree = [{}]; - buildTreeFromObject(xdrObject, tree[0], type); - return tree; -} diff --git a/src/helpers/fetchMaintenanceData.ts b/src/helpers/fetchMaintenanceData.ts deleted file mode 100644 index 7c57f9c9..00000000 --- a/src/helpers/fetchMaintenanceData.ts +++ /dev/null @@ -1,12 +0,0 @@ -import { StatusPageScheduled } from "types/types"; - -export const fetchMaintenanceData = async (): Promise< - StatusPageScheduled[] -> => { - const scheduleResponse = await fetch( - "https://9sl3dhr1twv1.statuspage.io/api/v2/summary.json", - ); - const scheduleResponseJson = await scheduleResponse.json(); - - return scheduleResponseJson.scheduled_maintenances; -}; diff --git a/src/helpers/formatTimestamp.ts b/src/helpers/formatTimestamp.ts new file mode 100644 index 00000000..d29a5064 --- /dev/null +++ b/src/helpers/formatTimestamp.ts @@ -0,0 +1,14 @@ +export const formatTimestamp = (timestamp: number) => { + const date = new Date(timestamp); + const dateTimeFormatter = new Intl.DateTimeFormat("en-US", { + month: "short", + day: "numeric", + year: "numeric", + hour: "numeric", + minute: "2-digit", + timeZone: "utc", + timeZoneName: "short", + }); + + return dateTimeFormatter.format(date); +}; diff --git a/src/helpers/getEndpointTemplate.ts b/src/helpers/getEndpointTemplate.ts deleted file mode 100644 index b28018ad..00000000 --- a/src/helpers/getEndpointTemplate.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { getResourceEndpoints } from "helpers/getResourceEndpoints"; - -export const getEndpointTemplate = (resource: string, endpoint: string) => { - let ep = getResourceEndpoints(resource, endpoint); - - if (!ep) { - return; - } - - return ep.path; -}; diff --git a/src/helpers/getRelevantMaintenanceMsg.ts b/src/helpers/getRelevantMaintenanceMsg.ts new file mode 100644 index 00000000..1e7aee5a --- /dev/null +++ b/src/helpers/getRelevantMaintenanceMsg.ts @@ -0,0 +1,20 @@ +import { NetworkType, StatusPageScheduled } from "@/types/types"; + +export const getRelevantMaintenanceMsg = ( + currentNetwork: NetworkType, + allMaintenance?: StatusPageScheduled[], +) => { + if (!allMaintenance) { + return false; + } + + // If we’re on the test network, we care about all scheduled maintenance. If + // we’re on the public network, we only care about public network maintenance. + return allMaintenance.filter((maintenance) => + maintenance.components.some((component) => + currentNetwork === "testnet" + ? true + : component.name === "Stellar Public Network", + ), + ); +}; diff --git a/src/helpers/getResourceEndpoints.ts b/src/helpers/getResourceEndpoints.ts deleted file mode 100644 index ec3b052e..00000000 --- a/src/helpers/getResourceEndpoints.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { endpointsMap } from "data/endpoints"; - -export const getResourceEndpoints = (resource: string, endpoint: string) => { - let res = endpointsMap[resource]; - - if (!res) { - return; - } - - return res.endpoints[endpoint]; -}; diff --git a/src/helpers/getSaveItemNetwork.ts b/src/helpers/getSaveItemNetwork.ts new file mode 100644 index 00000000..8aaa33a3 --- /dev/null +++ b/src/helpers/getSaveItemNetwork.ts @@ -0,0 +1,22 @@ +import { EmptyObj, Network } from "@/types/types"; + +export const getSaveItemNetwork = (network: Network | EmptyObj) => { + return { + id: network.id, + label: network.label, + // Mainnet with custom RPC URL + ...(network.id === "mainnet" && network.rpcUrl + ? { + rpcUrl: network.rpcUrl, + } + : {}), + // Custom network + ...(network.id === "custom" + ? { + horizonUrl: network.horizonUrl, + rpcUrl: network.rpcUrl, + passphrase: network.passphrase, + } + : {}), + }; +}; diff --git a/src/helpers/horizonUrlParser.js b/src/helpers/horizonUrlParser.js deleted file mode 100644 index 7d2995a0..00000000 --- a/src/helpers/horizonUrlParser.js +++ /dev/null @@ -1,145 +0,0 @@ -import routeRecognizer from "route-recognizer"; -import url from "url"; -import each from "lodash/each"; -import assign from "lodash/assign"; -import has from "lodash/has"; - -// routeTable is derived from Horizon init_web.go. `routeTable` is intended to -// look similar to Horizon's code for routing requests. -// The key is the url template with path template names slightly altered to -// match with the Endpoint Setup Pane components in the laboratory. -// Commented out code lines signify endpoints that the Laboratory does not support -let routeTable = { - // r.Get("/", &RootAction{}) - // r.Get("/metrics", &MetricsAction{}) - - // ledger actions - "/ledgers": { r: "ledgers", e: "all" }, - "/ledgers/:ledger": { r: "ledgers", e: "single" }, - "/ledgers/:ledger/transactions": { r: "transactions", e: "for_ledger" }, - "/ledgers/:ledger/operations": { r: "operations", e: "for_ledger" }, - "/ledgers/:ledger/payments": { r: "payments", e: "for_ledger" }, - "/ledgers/:ledger/effects": { r: "effects", e: "for_ledger" }, - - // account actions - "/accounts/:account_id": { r: "accounts", e: "single" }, - "/accounts/:account_id/transactions": { r: "transactions", e: "for_account" }, - "/accounts/:account_id/operations": { r: "operations", e: "for_account" }, - "/accounts/:account_id/payments": { r: "payments", e: "for_account" }, - "/accounts/:account_id/effects": { r: "effects", e: "for_account" }, - "/accounts/:account_id/offers": { r: "offers", e: "for_account" }, - "/accounts/:account_id/trades": { r: "trades", e: "for_account" }, - - // transaction history actions - "/transactions": { r: "transactions", e: "all" }, - "/transactions/:transaction": { r: "transactions", e: "single" }, - "/transactions/:transaction/operations": { - r: "operations", - e: "for_transaction", - }, - "/transactions/:transaction/payments": { - r: "payments", - e: "for_transaction", - }, - "/transactions/:transaction/effects": { r: "effects", e: "for_transaction" }, - - // operation actions - "/operations": { r: "operations", e: "all" }, - "/operations/:operation": { r: "operations", e: "single" }, - "/operations/:operation/effects": { r: "effects", e: "for_operation" }, - - "/payments": { r: "payments", e: "all" }, - "/effects": { r: "effects", e: "all" }, - - // r.Get("/offers/:id", &NotImplementedAction{}) - "/order_book": { r: "order_book", e: "details" }, - "/order_book/trades": { r: "order_book", e: "trades" }, - - // Transaction submission API - // r.Post("/transactions", &TransactionCreateAction{}) - "/paths": { r: "paths", e: "all" }, - - // friendbot - // r.Post("/friendbot", &FriendbotAction{}) - // r.Get("/friendbot", &FriendbotAction{}) - - // r.NotFound(&NotFoundAction{}) -}; - -let router = new routeRecognizer(); -each(routeTable, (resourceEndpoint, template) => { - router.add([{ path: template, handler: resourceEndpoint }]); -}); - -function stripTemplatedCurlyBrackets(inputUrl) { - return inputUrl.replace(/\{.+\}$/, ""); -} - -function horizonUrlParser(inputUrl) { - let parsedPath = url.parse(stripTemplatedCurlyBrackets(inputUrl)).path; - if (parsedPath === null) { - return; - } - - let recognizeResult = router.recognize(parsedPath); - if (typeof recognizeResult === "undefined" || recognizeResult.length === 0) { - return; - } - - // Path params shadow and take higher precedence than query params - let params = assign( - {}, - recognizeResult.queryParams, - recognizeResult[0].params, - ); - laboratorifyParams(params); - - return { - resource: recognizeResult[0].handler.r, - endpoint: recognizeResult[0].handler.e, - params, - }; -} - -// This converts the url params into the internal data structure used in the -// laboratory. For more info, take a look at `../data/endpoints.js` and look at -// the keys named `path`. -// This function mutate the params object passed in. -// - Converts root level items into children of root level objects -function laboratorifyParams(params) { - assignToParam(params, "selling_asset_type", "selling_asset", "type"); - assignToParam(params, "selling_asset_code", "selling_asset", "code"); - assignToParam(params, "selling_asset_issuer", "selling_asset", "issuer"); - - assignToParam(params, "buying_asset_type", "buying_asset", "type"); - assignToParam(params, "buying_asset_code", "buying_asset", "code"); - assignToParam(params, "buying_asset_issuer", "buying_asset", "issuer"); - - assignToParam(params, "destination_asset_type", "buying_asset", "type"); - assignToParam(params, "destination_asset_code", "buying_asset", "code"); - assignToParam(params, "destination_asset_issuer", "buying_asset", "issuer"); -} - -// assignToParam helps the laboratorify process by moving a root level item into -// a object with specified target keys. -// @param {object} params - Object of all params. Will be mutated -// @param {string} source - original key to move. Will be deleted if exists -// @param {string} destObj - object to move into. Will be created if not exist -// @param {string} destKey - key name to move source into -function assignToParam(params, source, destObj, destKey) { - if (!has(params, source)) { - return; - } - if (!has(params, destObj)) { - params[destObj] = {}; - } else if (typeof params[destObj] !== "object") { - console.error( - "Non object already exists in key. This is likely due to tampering of the values in the url", - ); - return; - } - params[destObj][destKey] = params[source]; - delete params[source]; -} - -export default horizonUrlParser; diff --git a/src/helpers/hydration.js b/src/helpers/hydration.js deleted file mode 100644 index 831ebb8b..00000000 --- a/src/helpers/hydration.js +++ /dev/null @@ -1,18 +0,0 @@ -let errorMessage = "Unable to parse values passed in url query parameters"; - -export const rehydrate = function (obj) { - try { - return JSON.parse(new Buffer(obj, "base64").toString()); - } catch (e) { - if (typeof alert !== "undefined") { - alert(errorMessage); - } else { - console.error(errorMessage); - } - return {}; - } -}; - -export const dehydrate = function (obj) { - return new Buffer(JSON.stringify(obj)).toString("base64"); -}; diff --git a/src/helpers/inputNumberValue.ts b/src/helpers/inputNumberValue.ts new file mode 100644 index 00000000..a21da390 --- /dev/null +++ b/src/helpers/inputNumberValue.ts @@ -0,0 +1,7 @@ +export const inputNumberValue = (value: string | undefined) => { + if (!value) { + return undefined; + } + + return isNaN(Number(value)) ? undefined : Number(value); +}; diff --git a/src/helpers/isEmptyObject.ts b/src/helpers/isEmptyObject.ts new file mode 100644 index 00000000..3547627e --- /dev/null +++ b/src/helpers/isEmptyObject.ts @@ -0,0 +1,5 @@ +import { AnyObject } from "@/types/types"; + +export const isEmptyObject = (obj: AnyObject) => { + return Object.keys(obj).length === 0; +}; diff --git a/src/helpers/isMaintenanceRelevant.ts b/src/helpers/isMaintenanceRelevant.ts deleted file mode 100644 index 5d2c4fa6..00000000 --- a/src/helpers/isMaintenanceRelevant.ts +++ /dev/null @@ -1,20 +0,0 @@ -import { Network, StatusPageScheduled } from "types/types"; - -// If we’re on the test network, we care about all scheduled maintenance. If -// we’re on the public network, we only care about public network maintenance. -export const isMaintenanceRelevant = ( - allMaintenance: StatusPageScheduled[] | null | undefined, - currentNetwork: string, -) => { - if (!allMaintenance) { - return false; - } - - return allMaintenance.filter((maintenance) => - maintenance.components.some((component) => - currentNetwork === Network.TEST - ? true - : component.name === "Stellar Public Network", - ), - ); -}; diff --git a/src/helpers/isValidUrl.ts b/src/helpers/isValidUrl.ts new file mode 100644 index 00000000..e08f93fd --- /dev/null +++ b/src/helpers/isValidUrl.ts @@ -0,0 +1,12 @@ +export const isValidUrl = (url: string) => { + if (!url.startsWith("http")) { + return false; + } + + try { + new URL(url); + return true; + } catch (e) { + return false; + } +}; diff --git a/src/helpers/linkBuilder.js b/src/helpers/linkBuilder.js deleted file mode 100644 index b044418d..00000000 --- a/src/helpers/linkBuilder.js +++ /dev/null @@ -1,97 +0,0 @@ -import url from "url"; -import { stateToQueryObj } from "./stateSerializer"; -import SLUG from "../constants/slug"; -import horizonUrlParser from "./horizonUrlParser"; -import TX_TYPES from "../constants/transaction_types"; - -// The linkBuilder attempts to abstract the specific details of the store so that -// consumers of linkBuilder need to know very little to be able to generate a link. - -// These functions will return `undefined` if a link could not be producted with -// the given info - -export function txSignerLink(xdr) { - let query = stateToQueryObj(SLUG.TXSIGNER, { - transactionSigner: { - xdr: xdr, - }, - }); - return hashBuilder(SLUG.TXSIGNER, query); -} - -export function txPostLink(xdr) { - let query = stateToQueryObj(SLUG.TXSUBMITTER, { - xdrViewer: { - input: xdr, - }, - }); - return hashBuilder(SLUG.TXSUBMITTER, query); -} - -export function xdrViewer(xdr, type) { - let query = stateToQueryObj(SLUG.XDRVIEWER, { - xdrViewer: { - input: xdr, - type, - }, - }); - return hashBuilder(SLUG.XDRVIEWER, query); -} - -export function feeBumpTxLink(xdr) { - let query = stateToQueryObj(SLUG.TXBUILDER, { - transactionBuilder: { - feeBumpAttributes: { - innerTxXDR: xdr, - }, - txType: TX_TYPES.FEE_BUMP, - }, - }); - return hashBuilder(SLUG.TXBUILDER, query); -} - -// explorerEndpoint is a helper function that generates a link from values -// mirroring the structure of the endpointExplorer reducer. We should try to -// abstract this with other functions with simpler arguments to reduce -// complexity and dependence on understanding the reducers. -function explorerEndpoint(resource, endpoint, values) { - let query = stateToQueryObj(SLUG.EXPLORER, { - endpointExplorer: { - currentResource: resource, - currentEndpoint: endpoint, - pendingRequest: { - values, - }, - }, - }); - return hashBuilder(SLUG.EXPLORER, query); -} - -export function singleAccount(accountId) { - return explorerEndpoint("accounts", "single", { - account_id: accountId, - }); -} - -export function horizonUrlToExplorerLink(horizonUrl) { - let urlInfo = horizonUrlParser(horizonUrl); - if (typeof urlInfo === "undefined") { - return; - } - - return explorerEndpoint(urlInfo.resource, urlInfo.endpoint, urlInfo.params); -} - -// Simply takes in a slug and a object and converts it into a hash url. -// Example input: -// slug: foo -// query: {happy: 'yes'} -// -// Example returns: #foo?happy=yes -function hashBuilder(slug, query) { - let urlObj = { - pathname: slug, - query: query, - }; - return "#" + url.format(urlObj); -} diff --git a/src/helpers/linkHighlighterRules.js b/src/helpers/linkHighlighterRules.js deleted file mode 100644 index 956d2c38..00000000 --- a/src/helpers/linkHighlighterRules.js +++ /dev/null @@ -1,35 +0,0 @@ -import {xdrViewer, singleAccount, horizonUrlToExplorerLink} from './linkBuilder'; - -// Map of functions specific to JSON property keys that creates urls for a given -// value. -// A function can also return undefined if it doesn't deem the value worthy of -// linking (for example: invalid account ID or keys that have ambiguous names) -let accountIdGenerator = (value) => { - if (value.length === 56) { - return singleAccount(value); - } -}; -let linkHighlighterRules = { - 'envelope_xdr': (value) => { - return xdrViewer(value, 'TransactionEnvelope'); - }, - 'result_xdr': (value) => { - return xdrViewer(value, 'TransactionResult'); - }, - 'result_meta_xdr': (value) => { - return xdrViewer(value, 'TransactionMeta'); - }, - 'fee_meta_xdr': (value) => { - return xdrViewer(value, 'OperationMeta'); - }, - 'id': accountIdGenerator, - 'public_key': accountIdGenerator, - 'account_id': accountIdGenerator, - 'funder': accountIdGenerator, - 'account': accountIdGenerator, - 'source_account': accountIdGenerator, - 'destination_account': accountIdGenerator, - 'href': horizonUrlToExplorerLink, -}; - -export default linkHighlighterRules; diff --git a/src/helpers/localStorageSavedEndpointsHorizon.ts b/src/helpers/localStorageSavedEndpointsHorizon.ts new file mode 100644 index 00000000..95f7463e --- /dev/null +++ b/src/helpers/localStorageSavedEndpointsHorizon.ts @@ -0,0 +1,22 @@ +import { LOCAL_STORAGE_SAVED_ENDPOINTS_HORIZON } from "@/constants/settings"; +import { SavedEndpointHorizon } from "@/types/types"; + +export const localStorageSavedEndpointsHorizon = { + get: () => { + const savedEndpointsString = localStorage.getItem( + LOCAL_STORAGE_SAVED_ENDPOINTS_HORIZON, + ); + return savedEndpointsString + ? (JSON.parse(savedEndpointsString) as SavedEndpointHorizon[]) + : []; + }, + set: (savedEndpoints: SavedEndpointHorizon[]) => { + return localStorage.setItem( + LOCAL_STORAGE_SAVED_ENDPOINTS_HORIZON, + JSON.stringify(savedEndpoints), + ); + }, + remove: () => { + return localStorage.removeItem(LOCAL_STORAGE_SAVED_ENDPOINTS_HORIZON); + }, +}; diff --git a/src/helpers/localStorageSavedNetwork.ts b/src/helpers/localStorageSavedNetwork.ts new file mode 100644 index 00000000..82e41e60 --- /dev/null +++ b/src/helpers/localStorageSavedNetwork.ts @@ -0,0 +1,22 @@ +import { LOCAL_STORAGE_SAVED_NETWORK } from "@/constants/settings"; +import { Network } from "@/types/types"; + +export const localStorageSavedNetwork = { + get: () => { + const savedNetworkString = localStorage.getItem( + LOCAL_STORAGE_SAVED_NETWORK, + ); + return savedNetworkString + ? (JSON.parse(savedNetworkString) as Network) + : null; + }, + set: (network: Network) => { + return localStorage.setItem( + LOCAL_STORAGE_SAVED_NETWORK, + JSON.stringify(network), + ); + }, + remove: () => { + return localStorage.removeItem(LOCAL_STORAGE_SAVED_NETWORK); + }, +}; diff --git a/src/helpers/localStorageSavedTransactions.ts b/src/helpers/localStorageSavedTransactions.ts new file mode 100644 index 00000000..041cba37 --- /dev/null +++ b/src/helpers/localStorageSavedTransactions.ts @@ -0,0 +1,22 @@ +import { LOCAL_STORAGE_SAVED_TRANSACTIONS } from "@/constants/settings"; +import { SavedTransaction } from "@/types/types"; + +export const localStorageSavedTransactions = { + get: () => { + const savedTxnString = localStorage.getItem( + LOCAL_STORAGE_SAVED_TRANSACTIONS, + ); + return savedTxnString + ? (JSON.parse(savedTxnString) as SavedTransaction[]) + : []; + }, + set: (savedTxns: SavedTransaction[]) => { + return localStorage.setItem( + LOCAL_STORAGE_SAVED_TRANSACTIONS, + JSON.stringify(savedTxns), + ); + }, + remove: () => { + return localStorage.removeItem(LOCAL_STORAGE_SAVED_TRANSACTIONS); + }, +}; diff --git a/src/helpers/metrics.js b/src/helpers/metrics.js deleted file mode 100644 index 050826a3..00000000 --- a/src/helpers/metrics.js +++ /dev/null @@ -1,64 +0,0 @@ -/** - * @prettier - */ -import throttle from "lodash/throttle"; - -const METRICS_ENDPOINT = "https://api.amplitude.com/2/httpapi"; -let cache = []; - -const uploadMetrics = throttle(() => { - const toUpload = cache; - cache = []; - if (!window._env_.AMPLITUDE_API_KEY) { - // eslint-disable-next-line no-console - console.log("Not uploading metrics", toUpload); - return; - } - fetch(METRICS_ENDPOINT, { - method: "POST", - headers: { - "Content-Type": "application/json", - }, - body: JSON.stringify({ - api_key: window._env_.AMPLITUDE_API_KEY, - events: toUpload, - }), - }); -}, 500); - -const getUserId = () => { - const storedId = localStorage.getItem("metrics_user_id"); - if (!storedId) { - // Create a random ID by taking the decimal portion of a random number - const newId = Math.random() - .toString() - .split(".")[1]; - localStorage.setItem("metrics_user_id", newId); - return newId; - } - return storedId; -}; - -export function logEvent(type, properties) { - cache.push({ - /* eslint-disable camelcase */ - event_type: type, - event_properties: properties, - user_id: getUserId(), - device_id: window.navigator.userAgent, - /* eslint-enable camelcase */ - }); - uploadMetrics(); -} - -const eventHandlers = []; - -export function addEventHandler(handler) { - eventHandlers.push(handler); -} - -export function broadcastEvent(state, action) { - eventHandlers.forEach((handler) => { - handler(state, action); - }); -} diff --git a/src/helpers/muxedAccount.ts b/src/helpers/muxedAccount.ts new file mode 100644 index 00000000..cbeb9bc4 --- /dev/null +++ b/src/helpers/muxedAccount.ts @@ -0,0 +1,57 @@ +import { MuxedAccountFieldType } from "@/types/types"; + +import { Account, MuxedAccount } from "@stellar/stellar-sdk"; + +export const muxedAccount = { + generate: ({ + baseAddress, + muxedAccountId, + }: { + baseAddress: string; + muxedAccountId: string; + }): Partial => { + let muxedAddress = ""; + let error = ""; + + try { + const muxedAccount = new MuxedAccount( + new Account(baseAddress, "0"), + muxedAccountId, + ); + + muxedAddress = muxedAccount.accountId(); + } catch (e: any) { + error = `Something went wrong. ${e.toString()}`; + } + + return { muxedAddress, error }; + }, + parse: ({ + muxedAddress, + }: { + muxedAddress: string; + }): Partial => { + let baseAddress = ""; + let muxedAccountId = ""; + let error = ""; + + try { + const muxedAccount = MuxedAccount.fromAddress(muxedAddress, "0"); + baseAddress = muxedAccount.baseAccount().accountId(); + muxedAccountId = muxedAccount.id(); + + if (!baseAddress) { + throw new Error("Base account for this muxed account was not found."); + } + + if (!muxedAccountId) { + throw new Error( + "Muxed account ID for this muxed account was not found.", + ); + } + } catch (e: any) { + error = `Something went wrong. ${e.toString()}`; + } + return { id: muxedAccountId, baseAddress, error }; + }, +}; diff --git a/src/helpers/networkLocalStorage.ts b/src/helpers/networkLocalStorage.ts deleted file mode 100644 index aa3c4100..00000000 --- a/src/helpers/networkLocalStorage.ts +++ /dev/null @@ -1,22 +0,0 @@ -import { LOCAL_STORAGE_NETWORK } from "constants/settings"; - -interface NetworkLocalStorageSaveProps { - name: string; - horizonURL?: string; - networkPassphrase?: string; -} - -export const networkLocalStorageSaveValue = ( - values: NetworkLocalStorageSaveProps, -) => { - try { - localStorage.setItem(LOCAL_STORAGE_NETWORK, JSON.stringify(values)); - } catch (e) { - // do nothing - } -}; - -export const networkLocalStorageGetValue = () => { - const value = localStorage.getItem(LOCAL_STORAGE_NETWORK); - return value ? JSON.parse(value) : null; -}; diff --git a/src/helpers/openUrl.ts b/src/helpers/openUrl.ts new file mode 100644 index 00000000..60bea8a8 --- /dev/null +++ b/src/helpers/openUrl.ts @@ -0,0 +1,3 @@ +export const openUrl = (url: string) => { + return window.open(url, "_blank", "noopener,noreferrer"); +}; diff --git a/src/helpers/optionsFlagDetails.ts b/src/helpers/optionsFlagDetails.ts new file mode 100644 index 00000000..4e4aaf08 --- /dev/null +++ b/src/helpers/optionsFlagDetails.ts @@ -0,0 +1,18 @@ +import { OptionFlag } from "@/types/types"; + +export const optionsFlagDetails = (options: OptionFlag[], selected: string[]) => + selected.reduce( + (res, cur: string) => { + const opt = options.find((o) => o.id === cur); + + if (opt?.value) { + return { + total: res.total + Number(opt.value), + selections: [...res.selections, `${opt.label} (${opt.value})`], + }; + } + + return res; + }, + { total: 0, selections: [] } as { total: number; selections: string[] }, + ); diff --git a/src/helpers/parseJsonString.ts b/src/helpers/parseJsonString.ts new file mode 100644 index 00000000..ea7ff6f4 --- /dev/null +++ b/src/helpers/parseJsonString.ts @@ -0,0 +1,11 @@ +export const parseJsonString = (value: any | undefined) => { + if (value) { + try { + return JSON.parse(value) as T; + } catch (e) { + return value; + } + } + + return value; +}; diff --git a/src/helpers/parseToLosslessJson.ts b/src/helpers/parseToLosslessJson.ts new file mode 100644 index 00000000..40ede078 --- /dev/null +++ b/src/helpers/parseToLosslessJson.ts @@ -0,0 +1,12 @@ +import { parse, isNumber } from "lossless-json"; +import { AnyObject } from "@/types/types"; + +export const parseToLosslessJson = (stringObj: string) => { + return parse(stringObj, null, (value) => { + if (isNumber(value)) { + return BigInt(value); + } + + return value; + }) as AnyObject; +}; diff --git a/src/helpers/prism-jsonLinkHighlighter.js b/src/helpers/prism-jsonLinkHighlighter.js deleted file mode 100644 index b65d599b..00000000 --- a/src/helpers/prism-jsonLinkHighlighter.js +++ /dev/null @@ -1,94 +0,0 @@ -// This is a module that creates hyperlinks in a JSON highlighted document -// generated by prism. It is not directly a prism plugin but rather a function -// that works with the HTML string generated by the prism highlighter. - -// The specific rules on how to highlight is in ./linkHighlighterRules.js - -import each from "lodash/each"; -import has from "lodash/has"; -import linkHighlighterRules from "./linkHighlighterRules"; - -// @param {string} code - Valid html generated by prism.js in JSON language mode -// @returns {string} code - Valid html string but with some spans converted to anchors -export default function jsonLinkHighlighter(code) { - let parser = new DOMParser(); - let document = parser.parseFromString(code, "text/html"); - let body = document.childNodes[0].childNodes[1]; - - // Edit the token elements in place - each(body.children, (token, index) => { - if (token.className.indexOf("property") > 0) { - annotatePropertyToken(token); - } - }); - return body.innerHTML; -} - -// Takes in a property highlighted item. If functionality is defined for it's -// corresponding property (only string type supported) and the content is valid, -// then we will turn the value node into a link. -// @param {HTMLElement} propertyToken - The token element of property type (assigned by prism) -let highlightableTokenClasses = { - "token string": true, - "token boolean": true, - "token number": true, -}; -function annotatePropertyToken(propertyToken) { - validatePropertyTokenSiblings(propertyToken); - let valueToken = propertyToken.nextElementSibling.nextElementSibling; - if (!has(highlightableTokenClasses, valueToken.className)) { - return; - } - - let urlGenerator = linkHighlighterRules[unQuote(propertyToken.innerHTML)]; - if (typeof urlGenerator === "undefined") { - return; - } - - let safeUnescapedValueText = valueToken.innerHTML.replace(/\&/g, "&"); - let href = urlGenerator(unQuote(safeUnescapedValueText)); - if (typeof href === "undefined") { - return; - } - nodeToAnchor(valueToken, href); -} - -// Validate the siblings so that the highlighter will fail fast if some unexpected -// changes happen such as the prism output changing. -let validSecondSiblingClasses = { - "token punctuation": true, - "token string": true, - "token boolean": true, - "token number": true, - "token null": true, - "token property": true, // Prism.js incorrectly parses strings with escape sequences -}; -function validatePropertyTokenSiblings(propertyToken) { - let firstSibling = propertyToken.nextElementSibling; - let secondSibling = firstSibling.nextElementSibling; - - if (firstSibling.className !== "token operator") { - throw new Error( - "Prism jsonLinkHighlighter: Unexpected first sibling to property token with class: " + - firstSibling.className, - ); - } - - if (!has(validSecondSiblingClasses, secondSibling.className)) { - throw new Error( - "Prism jsonLinkHighlighter: Unexpected second sibling to property token with class: " + - secondSibling.className, - ); - } -} - -// Converts a span into an anchor. Only preserves className -// @param {HTMLElement} node - Item to be converted to an anchor -// @param {string} href - Url to link to -function nodeToAnchor(node, href) { - node.outerHTML = `${node.innerHTML}`; -} - -function unQuote(input) { - return input.substring(1, input.length - 1); -} diff --git a/src/helpers/prism.js b/src/helpers/prism.js deleted file mode 100644 index 41c94ee3..00000000 --- a/src/helpers/prism.js +++ /dev/null @@ -1,473 +0,0 @@ -/* eslint-disable */ -// DO NOT MAKE EDITS TO THIS FILE -// Instead, just generate a new version from prismjs.com and paste it here - -// We use this over the npm version because it offers more flexibility in choosing -// which languages we can use. - -/* http://prismjs.com/download.html?themes=prism&languages=markup+css+clike+javascript+json */ -var _self = - "undefined" != typeof window - ? window - : "undefined" != typeof WorkerGlobalScope && - self instanceof WorkerGlobalScope - ? self - : {}, - Prism = (function () { - var e = /\blang(?:uage)?-(\w+)\b/i, - t = 0, - n = (_self.Prism = { - util: { - encode: function (e) { - return e instanceof a - ? new a(e.type, n.util.encode(e.content), e.alias) - : "Array" === n.util.type(e) - ? e.map(n.util.encode) - : e - .replace(/&/g, "&") - .replace(/ e.length) break e; - if (!(m instanceof a)) { - u.lastIndex = 0; - var v = u.exec(m), - y = 1; - if (!v && h && p != r.length - 1) { - var b = r[p + 1].matchedStr || r[p + 1], - k = m + b; - if ( - (p < r.length - 2 && - (k += r[p + 2].matchedStr || r[p + 2]), - (u.lastIndex = 0), - (v = u.exec(k)), - !v) - ) - continue; - var w = v.index + (g ? v[1].length : 0); - if (w >= m.length) continue; - var _ = v.index + v[0].length, - P = m.length + b.length; - (y = 3), - P >= _ && ((y = 2), (k = k.slice(0, P))), - (m = k); - } - if (v) { - g && (f = v[1].length); - var w = v.index + f, - v = v[0].slice(f), - _ = w + v.length, - S = m.slice(0, w), - O = m.slice(_), - j = [p, y]; - S && j.push(S); - var A = new a(i, c ? n.tokenize(v, c) : v, d, v); - j.push(A), - O && j.push(O), - Array.prototype.splice.apply(r, j); - } - } - } - } - } - return r; - }, - hooks: { - all: {}, - add: function (e, t) { - var a = n.hooks.all; - (a[e] = a[e] || []), a[e].push(t); - }, - run: function (e, t) { - var a = n.hooks.all[e]; - if (a && a.length) for (var r, l = 0; (r = a[l++]); ) r(t); - }, - }, - }), - a = (n.Token = function (e, t, n, a) { - (this.type = e), - (this.content = t), - (this.alias = n), - (this.matchedStr = a || null); - }); - if ( - ((a.stringify = function (e, t, r) { - if ("string" == typeof e) return e; - if ("Array" === n.util.type(e)) - return e - .map(function (n) { - return a.stringify(n, t, e); - }) - .join(""); - var l = { - type: e.type, - content: a.stringify(e.content, t, r), - tag: "span", - classes: ["token", e.type], - attributes: {}, - language: t, - parent: r, - }; - if ( - ("comment" == l.type && (l.attributes.spellcheck = "true"), e.alias) - ) { - var i = "Array" === n.util.type(e.alias) ? e.alias : [e.alias]; - Array.prototype.push.apply(l.classes, i); - } - n.hooks.run("wrap", l); - var o = ""; - for (var s in l.attributes) - o += (o ? " " : "") + s + '="' + (l.attributes[s] || "") + '"'; - return ( - "<" + - l.tag + - ' class="' + - l.classes.join(" ") + - '" ' + - o + - ">" + - l.content + - "" - ); - }), - !_self.document) - ) - return _self.addEventListener - ? (_self.addEventListener( - "message", - function (e) { - var t = JSON.parse(e.data), - a = t.language, - r = t.code, - l = t.immediateClose; - _self.postMessage(n.highlight(r, n.languages[a], a)), - l && _self.close(); - }, - !1, - ), - _self.Prism) - : _self.Prism; - var r = - document.currentScript || - [].slice.call(document.getElementsByTagName("script")).pop(); - return ( - r && - ((n.filename = r.src), - document.addEventListener && - !r.hasAttribute("data-manual") && - document.addEventListener("DOMContentLoaded", n.highlightAll)), - _self.Prism - ); - })(); -"undefined" != typeof module && module.exports && (module.exports = Prism), - "undefined" != typeof global && (global.Prism = Prism); -(Prism.languages.markup = { - comment: //, - prolog: /<\?[\w\W]+?\?>/, - doctype: //, - cdata: //i, - tag: { - pattern: - /<\/?(?!\d)[^\s>\/=.$<]+(?:\s+[^\s>\/=]+(?:=(?:("|')(?:\\\1|\\?(?!\1)[\w\W])*\1|[^\s'">=]+))?)*\s*\/?>/i, - inside: { - tag: { - pattern: /^<\/?[^\s>\/]+/i, - inside: { punctuation: /^<\/?/, namespace: /^[^\s>\/:]+:/ }, - }, - "attr-value": { - pattern: /=(?:('|")[\w\W]*?(\1)|[^\s>]+)/i, - inside: { punctuation: /[=>"']/ }, - }, - punctuation: /\/?>/, - "attr-name": { - pattern: /[^\s>\/]+/, - inside: { namespace: /^[^\s>\/:]+:/ }, - }, - }, - }, - entity: /&#?[\da-z]{1,8};/i, -}), - Prism.hooks.add("wrap", function (a) { - "entity" === a.type && - (a.attributes.title = a.content.replace(/&/, "&")); - }), - (Prism.languages.xml = Prism.languages.markup), - (Prism.languages.html = Prism.languages.markup), - (Prism.languages.mathml = Prism.languages.markup), - (Prism.languages.svg = Prism.languages.markup); -(Prism.languages.css = { - comment: /\/\*[\w\W]*?\*\//, - atrule: { pattern: /@[\w-]+?.*?(;|(?=\s*\{))/i, inside: { rule: /@[\w-]+/ } }, - url: /url\((?:(["'])(\\(?:\r\n|[\w\W])|(?!\1)[^\\\r\n])*\1|.*?)\)/i, - selector: /[^\{\}\s][^\{\};]*?(?=\s*\{)/, - string: /("|')(\\(?:\r\n|[\w\W])|(?!\1)[^\\\r\n])*\1/, - property: /(\b|\B)[\w-]+(?=\s*:)/i, - important: /\B!important\b/i, - function: /[-a-z0-9]+(?=\()/i, - punctuation: /[(){};:]/, -}), - (Prism.languages.css.atrule.inside.rest = Prism.util.clone( - Prism.languages.css, - )), - Prism.languages.markup && - (Prism.languages.insertBefore("markup", "tag", { - style: { - pattern: /()[\w\W]*?(?=<\/style>)/i, - lookbehind: !0, - inside: Prism.languages.css, - alias: "language-css", - }, - }), - Prism.languages.insertBefore( - "inside", - "attr-value", - { - "style-attr": { - pattern: /\s*style=("|').*?\1/i, - inside: { - "attr-name": { - pattern: /^\s*style/i, - inside: Prism.languages.markup.tag.inside, - }, - punctuation: /^\s*=\s*['"]|['"]\s*$/, - "attr-value": { pattern: /.+/i, inside: Prism.languages.css }, - }, - alias: "language-css", - }, - }, - Prism.languages.markup.tag, - )); -Prism.languages.clike = { - comment: [ - { pattern: /(^|[^\\])\/\*[\w\W]*?\*\//, lookbehind: !0 }, - { pattern: /(^|[^\\:])\/\/.*/, lookbehind: !0 }, - ], - string: { - pattern: /(["'])(\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/, - greedy: !0, - }, - "class-name": { - pattern: - /((?:\b(?:class|interface|extends|implements|trait|instanceof|new)\s+)|(?:catch\s+\())[a-z0-9_\.\\]+/i, - lookbehind: !0, - inside: { punctuation: /(\.|\\)/ }, - }, - keyword: - /\b(if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/, - boolean: /\b(true|false)\b/, - function: /[a-z0-9_]+(?=\()/i, - number: /\b-?(?:0x[\da-f]+|\d*\.?\d+(?:e[+-]?\d+)?)\b/i, - operator: /--?|\+\+?|!=?=?|<=?|>=?|==?=?|&&?|\|\|?|\?|\*|\/|~|\^|%/, - punctuation: /[{}[\];(),.:]/, -}; -(Prism.languages.javascript = Prism.languages.extend("clike", { - keyword: - /\b(as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|var|void|while|with|yield)\b/, - number: - /\b-?(0x[\dA-Fa-f]+|0b[01]+|0o[0-7]+|\d*\.?\d+([Ee][+-]?\d+)?|NaN|Infinity)\b/, - function: /[_$a-zA-Z\xA0-\uFFFF][_$a-zA-Z0-9\xA0-\uFFFF]*(?=\()/i, -})), - Prism.languages.insertBefore("javascript", "keyword", { - regex: { - pattern: - /(^|[^\/])\/(?!\/)(\[.+?]|\\.|[^\/\\\r\n])+\/[gimyu]{0,5}(?=\s*($|[\r\n,.;})]))/, - lookbehind: !0, - greedy: !0, - }, - }), - Prism.languages.insertBefore("javascript", "class-name", { - "template-string": { - pattern: /`(?:\\\\|\\?[^\\])*?`/, - inside: { - interpolation: { - pattern: /\$\{[^}]+\}/, - inside: { - "interpolation-punctuation": { - pattern: /^\$\{|\}$/, - alias: "punctuation", - }, - rest: Prism.languages.javascript, - }, - }, - string: /[\s\S]+/, - }, - }, - }), - Prism.languages.markup && - Prism.languages.insertBefore("markup", "tag", { - script: { - pattern: /()[\w\W]*?(?=<\/script>)/i, - lookbehind: !0, - inside: Prism.languages.javascript, - alias: "language-javascript", - }, - }), - (Prism.languages.js = Prism.languages.javascript); -(Prism.languages.json = { - property: /".*?"(?=\s*:)/gi, - string: /"(?!:)(\\?[^"])*?"(?!:)/g, - number: /\b-?(0x[\dA-Fa-f]+|\d*\.?\d+([Ee]-?\d+)?)\b/g, - punctuation: /[{}[\]);,]/g, - operator: /:/g, - boolean: /\b(true|false)\b/gi, - null: /\bnull\b/gi, -}), - (Prism.languages.jsonp = Prism.languages.json); diff --git a/src/helpers/sanitizeArray.ts b/src/helpers/sanitizeArray.ts new file mode 100644 index 00000000..05d90e1a --- /dev/null +++ b/src/helpers/sanitizeArray.ts @@ -0,0 +1,3 @@ +export const sanitizeArray = (array: any[]) => { + return array.filter((i) => Boolean(i)); +}; diff --git a/src/helpers/sanitizeHtml.ts b/src/helpers/sanitizeHtml.ts index b05cb749..55d0d341 100644 --- a/src/helpers/sanitizeHtml.ts +++ b/src/helpers/sanitizeHtml.ts @@ -1,6 +1,6 @@ -import parse from "html-react-parser"; -import DOMPurify from "dompurify"; - -export const sanitizeHtml = (html: string | Node) => { - return parse(DOMPurify.sanitize(html, { USE_PROFILES: { html: true } })); -}; +import parse from "html-react-parser"; +import DOMPurify from "dompurify"; + +export const sanitizeHtml = (html: string | Node) => { + return parse(DOMPurify.sanitize(html, { USE_PROFILES: { html: true } })); +}; diff --git a/src/helpers/sanitizeObject.ts b/src/helpers/sanitizeObject.ts new file mode 100644 index 00000000..eddece72 --- /dev/null +++ b/src/helpers/sanitizeObject.ts @@ -0,0 +1,19 @@ +import { isEmptyObject } from "@/helpers/isEmptyObject"; +import { AnyObject } from "@/types/types"; + +export const sanitizeObject = ( + obj: T, + noEmptyObj = false, +) => { + return Object.keys(obj).reduce((res, param) => { + const paramValue = obj[param]; + + const emptyObj = noEmptyObj && isEmptyObject(paramValue); + + if (paramValue && !emptyObj) { + return { ...res, [param]: paramValue }; + } + + return res; + }, {} as T); +}; diff --git a/src/helpers/scrollOnAnchorOpen.js b/src/helpers/scrollOnAnchorOpen.js deleted file mode 100644 index e46600f3..00000000 --- a/src/helpers/scrollOnAnchorOpen.js +++ /dev/null @@ -1,43 +0,0 @@ -// scrollOnAnchorOpen is a function that can be used in the onClick of an element. -// When an event bubbles up to this handler with the target being an anchor link, -// this will scroll the user to the top of the page. - -// This will also handle the edgecase to not scroll when the link is targeting -// a different tab. -// It will only scroll the user if the url is now the same as that of the link. - -// Edgecase: This won't detect context menu link opens. - -export default function scrollOnAnchorOpen(event) { - if (isScrollEligible(event)) { - window.scrollTo(0, 0); - event.target.blur(); - } -} - -function isScrollEligible(event, initialWindowLocation) { - if (event.target.tagName !== "A") { - return false; - } // not A tag - if (event.target.target !== "") { - return false; - } // non-empty target attr (such as _blank) - if (typeof event.target.href !== "string") { - return false; - } // target anchor has no href - - // If user used any keyboard modifiers, then they might be opening in a new - // tab or window.. Won't be completely accurate but it should improve the - // experience for the most common cases. It is better to scroll too much than - // too little. - - // NOTE: Another method to achieve this is to check that the window.location.href - // changes before and after. This works great except that links that go to the - // current page also get detected as "not changed". This gets really confusing - // since the click doesn't scroll the window. - if (event.metaKey || event.shiftKey || event.ctrlKey) { - return false; - } - - return true; -} diff --git a/src/helpers/shortenStellarAddress.ts b/src/helpers/shortenStellarAddress.ts new file mode 100644 index 00000000..7f1cf488 --- /dev/null +++ b/src/helpers/shortenStellarAddress.ts @@ -0,0 +1,7 @@ +export const shortenStellarAddress = (address: string, size: number = 8) => { + const slice = Math.ceil(size / 2); + + return `${address.substring(0, slice)}…${address.substring( + address.length - slice, + )}`; +}; diff --git a/src/helpers/simpleRouter.js b/src/helpers/simpleRouter.js deleted file mode 100644 index 08d12559..00000000 --- a/src/helpers/simpleRouter.js +++ /dev/null @@ -1,87 +0,0 @@ -import { connect } from "react-redux"; -import React from "react"; -import url from "url"; -import querystring from "querystring"; -import { updateLocation, loadState, LOAD_STATE } from "../actions/routing"; -import { stateToQueryObj } from "./stateSerializer"; - -// One way data flow for routerMiddleware: redux -> url -export const routerMiddleware = (store) => (next) => (action) => { - let result = next(action); - let state = store.getState(); - - // We will still process on UPDATE_LOCATION because it doesn't affect state - if (action.type === LOAD_STATE) { - return result; - } - - let newUrlObj = parseUrlHash(window.location.hash); - newUrlObj.query = stateToQueryObj(state.routing.location, state); - delete newUrlObj.search; - - // NOTE: We only replace state here since these are only for general state - // changes. By using history.replaceState, the routerListener won't pick up - // on these changes. - let newUrlHash = "#" + url.format(newUrlObj); - if (newUrlHash === "#") { - newUrlHash = window.location.pathname; - } - // eslint-disable-next-line no-restricted-globals - history.replaceState(null, null, newUrlHash); - - return result; -}; - -// One way data flow for RouterListener: url change -> redux -class RouterHashListener extends React.Component { - componentWillUnmount() { - // Just doing our duty of cleanup though it's really not necessary - window.removeEventListener( - "hashchange", - this.hashChangeHandler.bind(this), - false, - ); - } - componentDidMount() { - window.addEventListener( - "hashchange", - this.hashChangeHandler.bind(this), - false, - ); - this.changeProcessor(parseUrlHash(window.location.hash), {}, true); - } - hashChangeHandler(e) { - this.changeProcessor(parseUrlHash(e.newURL), parseUrlHash(e.oldURL)); - } - // @param {UrlObj|object} newUrl - URL object (of the hash) from node `url` - // @param {UrlObj|object} oldUrl - URL object (of the hash) from node `url`. Can be empty object - changeProcessor(newUrl, oldUrl, firstLoad) { - let queryChanged = oldUrl.query !== newUrl.query; - let shouldLoadState = firstLoad || (queryChanged && newUrl.query !== null); - - if (shouldLoadState) { - let newQueryObj = querystring.parse(newUrl.query); - this.props.dispatch(loadState(newUrl.pathname, newQueryObj)); - return; - } else { - this.props.dispatch(updateLocation(newUrl.pathname)); - } - } - render() { - return null; - } -} - -function parseUrlHash(input) { - let hash = url.parse(input).hash || ""; - return url.parse(hash.substr(1)); -} - -export let RouterListener = connect(chooseState, (dispatch) => ({ dispatch }))( - RouterHashListener, -); -function chooseState(state) { - return { - routing: state.routing, - }; -} diff --git a/src/helpers/sorobanXdrUtils.ts b/src/helpers/sorobanXdrUtils.ts deleted file mode 100644 index 3d5ffde6..00000000 --- a/src/helpers/sorobanXdrUtils.ts +++ /dev/null @@ -1,78 +0,0 @@ -import { StrKey, scValToNative, xdr } from "@stellar/stellar-sdk"; - -export const scValByType = (scVal: xdr.ScVal) => { - switch (scVal.switch()) { - case xdr.ScValType.scvAddress(): { - const address = scVal.address(); - const addressType = address.switch(); - if (addressType.name === "scAddressTypeAccount") { - return StrKey.encodeEd25519PublicKey(address.accountId().ed25519()); - } - return StrKey.encodeContract(address.contractId()); - } - - case xdr.ScValType.scvBool(): { - return scVal.b(); - } - - case xdr.ScValType.scvBytes(): { - return JSON.stringify(scVal.bytes().toJSON().data); - } - - case xdr.ScValType.scvContractInstance(): { - const instance = scVal.instance(); - return instance.executable().wasmHash()?.toString("base64"); - } - - case xdr.ScValType.scvError(): { - const error = scVal.error(); - return error.value(); - } - - case xdr.ScValType.scvTimepoint(): - case xdr.ScValType.scvDuration(): - case xdr.ScValType.scvI128(): - case xdr.ScValType.scvI256(): - case xdr.ScValType.scvI32(): - case xdr.ScValType.scvI64(): - case xdr.ScValType.scvU128(): - case xdr.ScValType.scvU256(): - case xdr.ScValType.scvU32(): - case xdr.ScValType.scvU64(): { - return scValToNative(scVal).toString(); - } - - case xdr.ScValType.scvLedgerKeyNonce(): - case xdr.ScValType.scvLedgerKeyContractInstance(): { - if (scVal.switch().name === "scvLedgerKeyNonce") { - const val = scVal.nonceKey().nonce(); - return val.toString(); - } - return scVal.value(); - } - - case xdr.ScValType.scvMap(): { - return JSON.stringify( - scValToNative(scVal), - (_, val) => (typeof val === "bigint" ? val.toString() : val), - 2, - ); - } - - case xdr.ScValType.scvString(): - case xdr.ScValType.scvSymbol(): { - const native = scValToNative(scVal); - if (native.constructor === "Uint8Array") { - return native.toString(); - } - return native; - } - - case xdr.ScValType.scvVoid(): { - return null; - } - - default: - return null; - } -}; diff --git a/src/helpers/stateSerializer.js b/src/helpers/stateSerializer.js deleted file mode 100644 index c4d3dd4e..00000000 --- a/src/helpers/stateSerializer.js +++ /dev/null @@ -1,149 +0,0 @@ -import assign from "lodash/assign"; -import each from "lodash/each"; -import has from "lodash/has"; -import size from "lodash/size"; -import { dehydrate } from "./hydration"; -import SLUG from "../constants/slug"; -import TX_TYPES from "../constants/transaction_types"; - -// The state serializer converts the state relevant to a specific page into anobject. -// This object is then used to build the routing url. - -// It is optional in that if a feature was implemented in just the reducer, it -// can work without needing a state serializer implemented. Without the state -// serializer implemented, the url hash state params will be empty. - -// This does two parts of the 3 part cycle of routing: -// (state) --->[stateToQueryObj()]---> (queryObj) -// (queryObj) --->[queryObjToLoadStatePayload()]---> (loadStateObj) -// (loadStateObj) --->[LOAD_STATE action]--->[redux reducers]---> (state) - -// The state that gets passed here may be an incomplete one. -// Incomplete ones are useful because it lets us build URLs without needing the -// whole state tree (such as in ../helpers/linkBuilder.js). -export function stateToQueryObj(slug, state) { - return assign( - {}, - serializePageSpecificState(slug, state), - serializeNetworkState(state), - ); -} - -function serializeNetworkState(state) { - // Only return something if we were passed the current network - if (has(state, "network")) { - if (state.network.current.name == "custom") { - return { - network: state.network.current.name, - horizonURL: state.network.current.horizonURL, - networkPassphrase: state.network.current.networkPassphrase, - }; - } - - return { network: state.network.current.name }; - } - return {}; -} - -function serializePageSpecificState(slug, state) { - switch (slug) { - case SLUG.EXPLORER: - let endpointsResult = {}; - if (state.endpointExplorer.currentResource) { - endpointsResult.resource = state.endpointExplorer.currentResource; - } - if (state.endpointExplorer.currentEndpoint) { - endpointsResult.endpoint = state.endpointExplorer.currentEndpoint; - } - if (size(state.endpointExplorer.pendingRequest.values) > 0) { - endpointsResult.values = dehydrate( - state.endpointExplorer.pendingRequest.values, - ); - } - return endpointsResult; - case SLUG.TXBUILDER: - let txbuilderResult = {}; - let txbuilderAttributes = assignNonEmpty( - {}, - state.transactionBuilder.attributes, - ); - if (size(txbuilderAttributes) > 0) { - txbuilderResult.attributes = txbuilderAttributes; - } - - let feeBumpAttributes = assignNonEmpty( - {}, - state.transactionBuilder.feeBumpAttributes, - ); - if (size(feeBumpAttributes) > 0) { - txbuilderResult.feeBumpAttributes = feeBumpAttributes; - } - - if (state.transactionBuilder.txType !== TX_TYPES.REGULAR) { - txbuilderResult.txType = state.transactionBuilder.txType; - } - - if (state.transactionBuilder.operations) { - let firstOpEmpty = state.transactionBuilder.operations[0].name === ""; - if (state.transactionBuilder.operations.length > 1 || !firstOpEmpty) { - txbuilderResult.operations = state.transactionBuilder.operations; - } - } - - if ( - has(txbuilderResult, "attributes.memoType") && - txbuilderResult.attributes.memoType === "MEMO_NONE" - ) { - delete txbuilderResult.attributes.memoType; - } - - if (size(txbuilderResult.attributes) === 0) { - delete txbuilderResult.attributes; - } - - if (size(txbuilderResult) === 0) { - return {}; - } - return { - params: dehydrate(txbuilderResult), - }; - case SLUG.TXSIGNER: - // We only want to serialize the imported xdr and not the saved secret key - // to prevent sensitive data being stored in browser history. - let txsignerResult = {}; - if (state.transactionSigner.xdr.length > 0) { - txsignerResult.xdr = state.transactionSigner.xdr; - } - return txsignerResult; - case SLUG.XDRVIEWER: - let xdrViewer = {}; - if (state.xdrViewer.input !== "") { - xdrViewer.input = state.xdrViewer.input; - } - if (state.xdrViewer.type !== "") { - xdrViewer.type = state.xdrViewer.type; - } - return xdrViewer; - case SLUG.TXSUBMITTER: - let txsubmitter = {}; - if (state.xdrViewer.input !== "") { - txsubmitter.input = state.xdrViewer.input; - } - return txsubmitter; - default: - return {}; - } -} - -// Similar to Object.assign except it doesn't copy over non-empty ones such -// as '' or undefined -function assignNonEmpty(targetObj, inputObj) { - each(inputObj, (value, key) => { - if (value === "" || value === undefined) { - return; - } - targetObj[key] = value; - }); - - return targetObj; -} diff --git a/src/helpers/testHelpers.tsx b/src/helpers/testHelpers.tsx deleted file mode 100644 index 4aca939b..00000000 --- a/src/helpers/testHelpers.tsx +++ /dev/null @@ -1,377 +0,0 @@ -import { Provider } from "react-redux"; -import { createStore, applyMiddleware } from "redux"; -import thunk from "redux-thunk"; -import { render as rtlRender } from "@testing-library/react"; -import { HttpResponse, http } from "msw"; -import { setupServer } from "msw/node"; - -import { reducers } from "config/store"; - -/* @testing-library/react helpers */ - -export const render = ( - ui: React.ReactElement, - { - preloadedState, - store = createStore(reducers, preloadedState, applyMiddleware(thunk)), - ...renderOptions - }: any = {}, -) => { - const Wrapper = ({ children }: { children: React.ReactNode }) => { - return {children}; - }; - return rtlRender(ui, { wrapper: Wrapper, ...renderOptions }); -}; - -enum ENDPOINT_RESPONSE { - accounts = "accounts mock response", - single_account = "single account mock response", - all_assets = "all assets mock response", - all_claimable_balances = "all claimable balances mock response", - single_claimable_balance = "single claimable balance mock response", - all_effects = "all effects mock response", - effects_for_account = "effects for account mock response", - effects_for_ledger = "effects for ledger mock response", - effects_for_liquidity_pool = "effects for liquidity pool mock response", - effects_for_operation = "effects for operation mock response", - effects_for_transaction = "effects for transaction mock response", - all_fee_stats = "all fee stats mock response", - all_ledgers = "all ledgers mock response", - single_ledger = "single ledger mock response", - all_liquidity_pools = "all liquidity pools mock response", - single_liquidity_pool = "single liquidity pool mock response", - all_offers = "all offers mock response", - single_offer = "single offer mock response", - offers_for_account = "offers for account mock response", - all_operations = "all operations mock response", - single_operation = "single operation mock response", - operations_for_account = "operations for account mock response", - operations_for_ledger = "operations for ledger mock response", - operations_for_liquidity_pool = "operations for liquidity pool mock response", - operations_for_transaction = "operations for transaction mock response", - order_book_details = "order book details mock response", - find_payment_paths = "find payment paths mock response", - find_strict_receive_payment_paths = "find strict receive payments paths mock response", - find_strict_send_payment_paths = "find strict send payments paths mock response", - all_payments = "all payments mock response", - payments_for_account = "payments for account mock response", - payments_for_ledger = "payments for ledger mock response", - payments_for_transaction = "payments for transaction mock response", - trade_aggregations = "trade aggregations mock response", - all_trades = "all trades mock response", - trades_for_account = "trades for account mock response", - trades_for_liquidity_pool = "trades for liquidity pool mock response", - trades_for_offer = "trades for offer mock response", - all_transactions = "all transactions mock response", - single_transaction = "single transaction mock response", - post_transaction = "post transaction mock response", - transactions_for_account = "transactions for account mock response", - transactions_for_ledger = "transactions for ledger mock response", - transactions_for_liquidity_pool = "transactions for liquidity pool mock response", -} - -const HORIZON_URL = "https://horizon-testnet.stellar.org"; - -const server = setupServer( - // Friendbot - http.get("https://friendbot.stellar.org", () => { - return new HttpResponse(null, { status: 200 }); - }), - // Endpoints: accounts > accounts - http.get(`${HORIZON_URL}/accounts`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.accounts }); - }), - // Endpoints: accounts > single account - http.get(`${HORIZON_URL}/accounts/:accountId`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.single_account }); - }), - // Endpoints: assets > all assets - http.get(`${HORIZON_URL}/assets`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_assets }); - }), - // Endpoints: claimable balances > all claimable balances - http.get(`${HORIZON_URL}/claimable_balances`, () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.all_claimable_balances, - }); - }), - // Endpoints: claimable balances > single claimable balance - http.get(`${HORIZON_URL}/claimable_balances/:claimableBalanceId`, () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.single_claimable_balance, - }); - }), - // Endpoints: effects > all effects - http.get(`${HORIZON_URL}/effects`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_effects }); - }), - // Endpoints: effects > effects for account - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/accounts//effects`, - () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.effects_for_account }); - }, - ), - // Endpoints: effects > effects for ledger - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/ledgers//effects`, - () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.effects_for_ledger }); - }, - ), - // Endpoints: effects > effects for liquidity pool - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/liquidity_pools//effects`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.effects_for_liquidity_pool, - }); - }, - ), - // Endpoints: effects > effects for operation - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/operations//effects`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.effects_for_operation, - }); - }, - ), - // Endpoints: effects > effects for transaction - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/transactions//effects`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.effects_for_transaction, - }); - }, - ), - // Endpoints: fee_stats > all fee_stats - http.get(`${HORIZON_URL}/fee_stats`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_fee_stats }); - }), - // Endpoints: ledger > all ledgers - http.get(`${HORIZON_URL}/ledgers`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_ledgers }); - }), - // Endpoints: ledger > single ledger - http.get(`${HORIZON_URL}/ledgers/:ledger`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.single_ledger }); - }), - // Endpoints: liquidity pools > all liquidity pools - http.get(`${HORIZON_URL}/liquidity_pools`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_liquidity_pools }); - }), - // Endpoints: liquidity pools > single liquidity pool - http.get(`${HORIZON_URL}/liquidity_pools/:liquidity_pool_id`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.single_liquidity_pool }); - }), - // Endpoints: offers > all offers - http.get(`${HORIZON_URL}/offers`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_offers }); - }), - // Endpoints: offers > single offer - http.get(`${HORIZON_URL}/offers/:offerId`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.single_offer }); - }), - // Endpoints: offers > offers for account - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/accounts//offers`, - () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.offers_for_account }); - }, - ), - // Endpoints: operations > all operations - http.get(`${HORIZON_URL}/operations`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_operations }); - }), - // Endpoints: operations > single operation - http.get(`${HORIZON_URL}/operations/:operation`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.single_operation }); - }), - // Endpoints: operations > operations for account - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/accounts//operations`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.operations_for_account, - }); - }, - ), - // Endpoints: operations > operations for ledger - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/ledgers//operations`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.operations_for_ledger, - }); - }, - ), - // Endpoints: operations > operations for liquidity pool - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/liquidity_pools//operations`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.operations_for_liquidity_pool, - }); - }, - ), - // Endpoints: operations > operations for transaction - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/transactions//operations`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.operations_for_transaction, - }); - }, - ), - // Endpoints: order book > details - http.get(`${HORIZON_URL}/order_book`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.order_book_details }); - }), - // Endpoints: paths > find payment paths - http.get(`${HORIZON_URL}/paths`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.find_payment_paths }); - }), - // Endpoints: paths > find strict receive payment paths - http.get(`${HORIZON_URL}/paths/strict-receive`, () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.find_strict_receive_payment_paths, - }); - }), - // Endpoints: paths > find strict send payment paths - http.get(`${HORIZON_URL}/paths/strict-send`, () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.find_strict_send_payment_paths, - }); - }), - // Endpoints: payments > all payments - http.get(`${HORIZON_URL}/payments`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_payments }); - }), - // Endpoints: payments > payments for account - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/accounts//payments`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.payments_for_account, - }); - }, - ), - // Endpoints: payments > payments for ledger - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/ledgers//payments`, - () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.payments_for_ledger }); - }, - ), - // Endpoints: payments > payments for transaction - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/transactions//payments`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.payments_for_transaction, - }); - }, - ), - // Endpoints: trade aggregations > trade aggregations - http.get(`${HORIZON_URL}/trade_aggregations`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.trade_aggregations }); - }), - // Endpoints: trades > all trades - http.get(`${HORIZON_URL}/trades`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_trades }); - }), - // Endpoints: trades > trades for account - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/accounts//trades`, - () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.trades_for_account }); - }, - ), - // Endpoints: trades > trades for liquidity pool - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/liquidity_pools//trades`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.trades_for_liquidity_pool, - }); - }, - ), - // Endpoints: trades > trades for offer - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/offers//trades`, - () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.trades_for_offer }); - }, - ), - // Endpoints: transactions > all transactions - http.get(`${HORIZON_URL}/transactions`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.all_transactions }); - }), - // Endpoints: transactions > single transaction - http.get(`${HORIZON_URL}/transactions/:transaction`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.single_transaction }); - }), - // Endpoints: transactions > post transaction - http.post(`${HORIZON_URL}/transactions`, () => { - return HttpResponse.json({ test: ENDPOINT_RESPONSE.post_transaction }); - }), - // Endpoints: transactions > transactions for account - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/accounts//transactions`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.transactions_for_account, - }); - }, - ), - // Endpoints: transactions > transactions for ledger - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/ledgers//transactions`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.transactions_for_ledger, - }); - }, - ), - // Endpoints: transactions > transactions for liquidity pool - http.get( - // TODO: fix URL to have only one / at the end (missing param) - `${HORIZON_URL}/liquidity_pools//transactions`, - () => { - return HttpResponse.json({ - test: ENDPOINT_RESPONSE.transactions_for_liquidity_pool, - }); - }, - ), - // fallback - http.get("*", () => { - return new HttpResponse(null, { status: 500 }); - // console.error(`No request handler for ${req.url.toString()}`); - }), -); - -beforeAll(() => server.listen()); -afterAll(() => server.close()); -afterEach(() => server.resetHandlers()); - -export { server, http, ENDPOINT_RESPONSE }; diff --git a/src/helpers/trim.ts b/src/helpers/trim.ts new file mode 100644 index 00000000..6d8f75e4 --- /dev/null +++ b/src/helpers/trim.ts @@ -0,0 +1,3 @@ +// Regex explained: https://regexr.com/4v6jg +export const trim = (str: string, c = "\\s") => + str.replace(new RegExp(`^([${c}]*)(.*?)([${c}]*)$`), "$2"); diff --git a/src/helpers/txHelper.ts b/src/helpers/txHelper.ts new file mode 100644 index 00000000..3f547589 --- /dev/null +++ b/src/helpers/txHelper.ts @@ -0,0 +1,285 @@ +import { + FeeBumpTransaction, + Keypair, + StrKey, + Transaction, + TransactionBuilder, + xdr, +} from "@stellar/stellar-sdk"; +import LedgerTransportWebUSB from "@ledgerhq/hw-transport-webusb"; +import LedgerStr from "@ledgerhq/hw-app-str"; +import TrezorConnect, { StellarSignedTx } from "@trezor/connect-web"; +import transformTransaction from "@trezor/connect-plugin-stellar"; + +import { LedgerErrorResponse } from "@/types/types"; + +import { validate } from "@/validate"; + +/* Build Transaction related */ +export type FeeBumpedTxResponse = { + errors: string[]; + xdr: string; +}; + +const buildFeeBumpTx = ({ + innerTxXdr, + maxFee, + sourceAccount, + networkPassphrase, +}: { + innerTxXdr: string; + maxFee: string; + sourceAccount: string; + networkPassphrase: string; +}): FeeBumpedTxResponse => { + const result = { + errors: [] as string[], + xdr: "", + }; + + let innerTx: Transaction; + + try { + innerTx = TransactionBuilder.fromXDR( + innerTxXdr, + networkPassphrase, + ) as Transaction; + } catch (e) { + result.errors.push("Invalid inner transaction XDR."); + return result; + } + + if (typeof innerTx?.operations === "undefined") { + result.errors.push("Inner transaction must be a regular transaction."); + return result; + } + + try { + const feeBumpTx = TransactionBuilder.buildFeeBumpTransaction( + sourceAccount, + maxFee, + innerTx, + networkPassphrase, + ); + result.xdr = feeBumpTx.toEnvelope().toXDR("base64"); + } catch (err) { + if (err instanceof Error) { + result.errors.push(err.message); + } else { + result.errors.push("Unknown error in fee bump tx"); + } + } + return result; +}; + +/* Sign Transaction related */ +interface LedgerApi { + getPublicKey(path: string): Promise<{ publicKey: string }>; + signHash(path: string, hash: Buffer): Promise<{ signature: Buffer }>; + signTransaction( + path: string, + transaction: Buffer, + ): Promise<{ signature: Buffer }>; +} + +const signTx = ({ + txXdr, + signers, + networkPassphrase, + hardWalletSigs, +}: { + txXdr: string; + signers: string[]; + networkPassphrase: string; + hardWalletSigs: xdr.DecoratedSignature[] | []; +}) => { + const validSecretKeys = []; + const validPreimages = []; + + for (let i = 0; i < signers.length; i++) { + const signer = signers[i]; + + if (signer !== null && signer !== undefined && signer !== "") { + const error = validate.getSecretKeyError(signer); + + if (error) { + return { + xdr: undefined, + message: error, + }; + } + + if (!error) { + if (signer.charAt(0) === "S") { + // Secret keys + validSecretKeys.push(signer); + } else { + // Hash preimage + validPreimages.push(signer); + } + } + } + } + + const newTx = TransactionBuilder.fromXDR(txXdr, networkPassphrase); + const existingSigs = newTx.signatures.length; + let addedSigs = 0; + + validSecretKeys.forEach((signer) => { + addedSigs++; + newTx.sign(Keypair.fromSecret(signer)); + }); + validPreimages.forEach((signer) => { + addedSigs++; + newTx.signHashX(Buffer.from(signer, "hex")); + }); + hardWalletSigs.forEach((signer) => { + addedSigs++; + newTx.signatures.push(signer); + }); + + return { + xdr: newTx.toEnvelope().toXDR("base64"), + message: `${addedSigs} signature(s) added; ${ + existingSigs + addedSigs + } signature(s) total`, + }; +}; + +const signWithLedger = async ({ + bipPath, + transaction, + isHash = false, +}: { + bipPath: string; + transaction: FeeBumpTransaction | Transaction; + isHash: boolean; +}): Promise<{ + signature: xdr.DecoratedSignature[] | undefined; + error: string | undefined; +}> => { + const onError = (err: LedgerErrorResponse) => { + let error; + + if (err.message) { + error = err.message; + } else { + switch (err.errorCode) { + case 2: + error = `Couldn't connect to Ledger device. Connection can only be established using a secure connection.`; + break; + case 5: + error = `Connection timeout.`; + break; + default: + error = `Unknown error occurred.`; + } + } + + return error; + }; + + const signTxWithLedger = async (ledgerApi: LedgerApi, isHash: boolean) => { + let ledgerSignature; + + try { + const { publicKey } = await ledgerApi.getPublicKey(bipPath); + + if (isHash) { + const { signature } = await ledgerApi.signHash( + bipPath, + transaction.hash(), + ); + ledgerSignature = signature; + } else { + const { signature } = await ledgerApi.signTransaction( + bipPath, + transaction.signatureBase(), + ); + ledgerSignature = signature; + } + + const keyPair = Keypair.fromPublicKey(publicKey); + const hint = keyPair.signatureHint(); + const decorated = new xdr.DecoratedSignature({ + hint, + signature: ledgerSignature, + }); + + return { signature: [decorated], error: undefined }; + } catch (error) { + const ledgerError = error as LedgerErrorResponse; + return { signature: undefined, error: onError(ledgerError) }; + } + }; + + try { + const transport = await LedgerTransportWebUSB.request(); + const ledgerApi = new LedgerStr(transport); + return await signTxWithLedger(ledgerApi, isHash); + } catch (error) { + const ledgerError = error as LedgerErrorResponse; + return { signature: undefined, error: onError(ledgerError) }; + } +}; + +const signWithTrezor = async ({ + bipPath, + transaction, +}: { + bipPath: string; + transaction: Transaction; +}): Promise<{ + signature: xdr.DecoratedSignature[] | undefined; + error: string | undefined; +}> => { + TrezorConnect.manifest({ + email: "accounts+trezor@stellar.org", + appUrl: "https://lab.stellar.org/", + }); + + try { + const trezorParams = transformTransaction(bipPath, transaction); + const response = await TrezorConnect.stellarSignTransaction(trezorParams); + + if (response.success) { + return { + signature: getTrezorDecoratedSignature(response.payload), + error: undefined, + }; + } else { + const errorPayload = response.payload as { error: string }; + return { + signature: undefined, + error: + errorPayload.error || "Couldn't sign transaction with Trezor device.", + }; + } + } catch (error) { + return { + signature: undefined, + error: `Couldn't sign transaction with Trezor device. Details: ${error}`, + }; + } +}; + +const getTrezorDecoratedSignature = ( + payload: StellarSignedTx, +): xdr.DecoratedSignature[] => { + const signature = Buffer.from(payload.signature, "hex"); + const publicKeyBytes = Buffer.from(payload.publicKey, "hex"); + const encodedPublicKey = StrKey.encodeEd25519PublicKey(publicKeyBytes); + + const keyPair = Keypair.fromPublicKey(encodedPublicKey); + const hint = keyPair.signatureHint(); + const decorated = new xdr.DecoratedSignature({ hint, signature }); + + return [decorated]; +}; + +export const txHelper = { + buildFeeBumpTx, + signTx, + signWithLedger, + signWithTrezor, +}; diff --git a/src/helpers/useFreighter.js b/src/helpers/useFreighter.js deleted file mode 100644 index d3c0a7bc..00000000 --- a/src/helpers/useFreighter.js +++ /dev/null @@ -1,26 +0,0 @@ -/** @format */ -import React from "react"; -import { isConnected, getPublicKey } from "@stellar/freighter-api"; - -export const useFreighter = () => { - const [hasFreighter, setHasFreighter] = React.useState(false); - - React.useEffect(async () => { - setHasFreighter(await isConnected()); - }); - return hasFreighter; -}; - -export const freighterGetPublicKey = async (onUpdate) => { - let freighterPublicKey = ""; - let error = ""; - - try { - const freighterResponse = await getPublicKey(); - freighterPublicKey = freighterResponse; - } catch (e) { - error = e; - } - - return onUpdate(freighterPublicKey || error); -}; diff --git a/src/helpers/validateBase64.ts b/src/helpers/validateBase64.ts deleted file mode 100644 index 3f45d1f2..00000000 --- a/src/helpers/validateBase64.ts +++ /dev/null @@ -1,19 +0,0 @@ -import trim from "lodash/trim"; - -export const validateBase64 = (input: string) => { - input = trim(input); - - if (input === "") { - return { - result: "empty", - }; - } - if (input.match(/^[-A-Za-z0-9+\/=]*$/) === null) { - return { - result: "error", - message: "The input is not valid base64 (a-zA-Z0-9+/=).", - }; - } - - return { result: "success" }; -}; diff --git a/src/helpers/validateTxXdr.ts b/src/helpers/validateTxXdr.ts deleted file mode 100644 index 7507ca91..00000000 --- a/src/helpers/validateTxXdr.ts +++ /dev/null @@ -1,27 +0,0 @@ -import trim from "lodash/trim"; -import * as StellarSdk from "@stellar/stellar-sdk"; -import { validateBase64 } from "./validateBase64"; - -export const validateTxXdr = (input: string) => { - let xdr = StellarSdk.xdr; - input = trim(input); - - let base64Validation = validateBase64(input); - if (base64Validation.result !== "success") { - return base64Validation; - } - - try { - xdr.TransactionEnvelope.fromXDR(input, "base64"); - return { - result: "success", - message: "Valid Transaction Envelope XDR", - }; - } catch (e) { - return { - result: "error", - message: "Unable to parse input XDR into Transaction Envelope", - originalError: e, - }; - } -}; diff --git a/src/helpers/xdr/fraction.ts b/src/helpers/xdr/fraction.ts new file mode 100644 index 00000000..7a12f215 --- /dev/null +++ b/src/helpers/xdr/fraction.ts @@ -0,0 +1,42 @@ +// This content is copied from js-stellar-base (src/util/continued_fraction.js) +import BigNumber from "bignumber.js"; + +const MAX_INT = ((1 << 31) >>> 0) - 1; + +export function best_r(rawNumber: string | number | BigNumber) { + let number = new BigNumber(rawNumber); + let a; + let f; + const fractions = [ + [new BigNumber(0), new BigNumber(1)], + [new BigNumber(1), new BigNumber(0)], + ]; + let i = 2; + + // eslint-disable-next-line no-constant-condition + while (true) { + if (number.gt(MAX_INT)) { + break; + } + a = number.integerValue(BigNumber.ROUND_FLOOR); + f = number.minus(a); + const h = a.times(fractions[i - 1][0]).plus(fractions[i - 2][0]); + const k = a.times(fractions[i - 1][1]).plus(fractions[i - 2][1]); + if (h.gt(MAX_INT) || k.gt(MAX_INT)) { + break; + } + fractions.push([h, k]); + if (f.eq(0)) { + break; + } + number = new BigNumber(1).div(f); + i += 1; + } + const [n, d] = fractions[fractions.length - 1]; + + if (n.isZero() || d.isZero()) { + throw new Error("Couldn't find approximation"); + } + + return [n.toNumber(), d.toNumber()]; +} diff --git a/src/helpers/xdr/utils.ts b/src/helpers/xdr/utils.ts new file mode 100644 index 00000000..572e982f --- /dev/null +++ b/src/helpers/xdr/utils.ts @@ -0,0 +1,36 @@ +// XDR helpers from js-stellar-base +import { xdr } from "@stellar/stellar-sdk"; +import BigNumber from "bignumber.js"; +import { best_r } from "./fraction"; + +const ONE = 10000000; + +function toXDRAmount(value: string) { + // Using BigNumber to handle decimal point values + return BigInt(new BigNumber(value).times(ONE).toString()); +} + +function fromXDRAmount(value: string) { + return new BigNumber(value).div(ONE).toFixed(7); +} + +function toXDRPrice(price: string) { + const approx = best_r(price); + + return { + n: parseInt(approx[0].toString(), 10), + d: parseInt(approx[1].toString(), 10), + }; +} + +function fromXDRPrice(price: xdr.Price) { + const n = new BigNumber(price.n()); + return n.div(new BigNumber(price.d())).toString(); +} + +export const xdrUtils = { + toAmount: toXDRAmount, + fromAmount: fromXDRAmount, + toPrice: toXDRPrice, + fromPrice: fromXDRPrice, +}; diff --git a/src/hooks/useIsSoroban.ts b/src/hooks/useIsSoroban.ts deleted file mode 100644 index 554587cd..00000000 --- a/src/hooks/useIsSoroban.ts +++ /dev/null @@ -1,19 +0,0 @@ -import NETWORK from "constants/network.js"; -import { useRedux } from "hooks/useRedux"; - -export const useIsSoroban = () => { - const { network } = useRedux("network"); - const { horizonURL, networkPassphrase } = network.current; - const url = new URL(horizonURL); - - let isOnFuturenet = false; - if ( - (url.origin === NETWORK.available.futurenet.horizonURL && - networkPassphrase === NETWORK.available.futurenet.networkPassphrase) || - (url.origin === NETWORK.available.test.horizonURL && - networkPassphrase === NETWORK.available.test.networkPassphrase) - ) { - isOnFuturenet = true; - } - return isOnFuturenet; -}; diff --git a/src/hooks/useIsTestingNetwork.ts b/src/hooks/useIsTestingNetwork.ts new file mode 100644 index 00000000..03ec199b --- /dev/null +++ b/src/hooks/useIsTestingNetwork.ts @@ -0,0 +1,7 @@ +import { useStore } from "@/store/useStore"; + +export const useIsTestingNetwork = (): boolean => { + const { network } = useStore(); + + return network.id === "testnet" || network.id === "futurenet"; +}; diff --git a/src/hooks/useIsXdrInit.ts b/src/hooks/useIsXdrInit.ts new file mode 100644 index 00000000..8bb63754 --- /dev/null +++ b/src/hooks/useIsXdrInit.ts @@ -0,0 +1,18 @@ +import { useEffect, useState } from "react"; +import * as StellarXdr from "@/helpers/StellarXdr"; + +export const useIsXdrInit = () => { + const [isReady, setIsReady] = useState(false); + + useEffect(() => { + // Stellar XDR init + const init = async () => { + await StellarXdr.init(); + setIsReady(true); + }; + + init(); + }, []); + + return isReady; +}; diff --git a/src/hooks/usePrevious.ts b/src/hooks/usePrevious.ts new file mode 100644 index 00000000..ea66eb11 --- /dev/null +++ b/src/hooks/usePrevious.ts @@ -0,0 +1,11 @@ +import { useEffect, useRef } from "react"; + +export const usePrevious = (value: T) => { + const ref = useRef(); + + useEffect(() => { + ref.current = value; + }, [value]); + + return ref.current; +}; diff --git a/src/hooks/useRedux.ts b/src/hooks/useRedux.ts deleted file mode 100644 index 115f3a7c..00000000 --- a/src/hooks/useRedux.ts +++ /dev/null @@ -1,29 +0,0 @@ -import isEqual from "lodash/isEqual"; -import pick from "lodash/pick"; -import { useSelector } from "react-redux"; - -/** - * A React hook for accessing Redux state. - * - * react-redux's useStore hook isn't performant, has a weird call signature, - * and doesn't instruct components when to update: - * - * const { stellarAccount } = useStore().getState(); - * - * useSelector is stupidly verbose: - * - * const { - * stellarAccount - * } = useSelector(({ stellarAccount }) => ({ stellarAccount })); - * - * So instead, let's use a clearer API: - * - * const { stellarAccount } = useRedux("stellarAccount"); - * - * @param {string[]} stateProps An array of prop names to get from the state. - * @returns {object} An object map of those prop names to their values. - */ -// TODO: update any types after store refactor -export function useRedux(...keys: any[]) { - return useSelector((state: any) => pick(state, keys), isEqual); -} diff --git a/src/index.html b/src/index.html deleted file mode 100644 index a2385f47..00000000 --- a/src/index.html +++ /dev/null @@ -1,21 +0,0 @@ - - - - - - - - - - - - - - Laboratory - Stellar - - - - -
    - - diff --git a/src/index.tsx b/src/index.tsx deleted file mode 100644 index 203baedb..00000000 --- a/src/index.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import ReactDOM from "react-dom"; -import { App } from "./App"; - -ReactDOM.render(, document.getElementById("root")); diff --git a/src/localStorage.js b/src/localStorage.js deleted file mode 100644 index b6fedf96..00000000 --- a/src/localStorage.js +++ /dev/null @@ -1,20 +0,0 @@ -export const loadState = () => { - try { - const serializerdState = localStorage.getItem("state"); - if (serializerdState === null) { - return undefined; - } - return JSON.parse(serializerdState); - } catch (err) { - return undefined; - } -}; - -export const saveState = (state) => { - try { - const serializerdState = JSON.stringify(state); - localStorage.setItem("state", serializerdState); - } catch (err) { - // Ignore error. - } -}; diff --git a/src/metricsHandlers/README.md b/src/metricsHandlers/README.md deleted file mode 100644 index e6224b4c..00000000 --- a/src/metricsHandlers/README.md +++ /dev/null @@ -1,92 +0,0 @@ -# Usage metrics - -For purposes of improving the tools we provide our users, we track some metrics about how the laboratory is used. We use Amplitude to do so, and data is completely anonymous. Below is a list of what events and properties are collected for each feature. - -## Page navigation - -* changed page - * path - -## Network picker - -* changed horizon url - * horizonUrl - -## Account creator - -* generated new account - * (no properties) -* funded test account: start - * (no properties) -* funded test account: success - * (no properties) -* funded test account: failure - * message - * code - -## Endpoint Explorer - -* changed resource - * resource -* changed endpoint - * resource - * endpoint -* request: start - * template - * resource - * endpoint -* request: success - * template - * resource - * endpoint -* request: stream message - * template - * resource - * endpoint -* request: failed - * detail - * extras - * status -* clicked internal link - * resource - * endpoint - -## Transaction builder - -* changed operation type - * type -* added operation - * (no properties) -* removed operation - * (no properties) -* changed operation attributes - * changedAttributes - * operationType -* began signing transaction - * operations -* view XDR - * operations - -## Transaction signer - -* ledger signature: begin - * (no properties) -* ledger signature: success - * (no properties) -* ledger signature: failed - * error -* add secret - * secretCount -* begin submitting transaction - * (no properties) -* view signed XDR envelope - * (no properties) - -## XDR viewer - -* fetch latest transaction - * (no properties) -* decode XDR: failed - * type -* decode XDR: success - * type diff --git a/src/metricsHandlers/accountCreator.js b/src/metricsHandlers/accountCreator.js deleted file mode 100644 index f6328ab7..00000000 --- a/src/metricsHandlers/accountCreator.js +++ /dev/null @@ -1,49 +0,0 @@ -import { - GENERATE_NEW_KEYPAIR, - START_FRIENDBOT_REQUEST, - FINISH_FRIENDBOT_REQUEST, - GENERATE_MUXED_ACCOUNT, - PARSE_MUXED_ACCOUNT, -} from "../actions/accountCreator"; - -import { logEvent } from "../helpers/metrics"; - -const metricsEvents = { - newAccount: "account creator: generated new account", - fundAccountStart: "account creator: funded test account: begin", - fundAccountSuccess: "account creator: funded test account: success", - fundAccountError: "account creator: funded test account: failed", - generateMuxedAccount: "account creator: generated new muxed account", - parseMuxedAccount: "account creator: parsed muxed account", -}; - -export default function accountCreatorMetrics(state, action) { - const { type, ...actionBody } = action; - switch (type) { - case GENERATE_NEW_KEYPAIR: { - logEvent(metricsEvents.newAccount); - return; - } - case START_FRIENDBOT_REQUEST: { - logEvent(metricsEvents.fundAccountStart); - return; - } - case FINISH_FRIENDBOT_REQUEST: { - if (actionBody.status === "success") { - logEvent(metricsEvents.fundAccountSuccess); - return; - } - const { message, code } = actionBody; - logEvent(metricsEvents.fundAccountError, { message, code }); - return; - } - case GENERATE_MUXED_ACCOUNT: { - logEvent(metricsEvents.generateMuxedAccount); - return; - } - case PARSE_MUXED_ACCOUNT: { - logEvent(metricsEvents.parseMuxedAccount); - return; - } - } -} diff --git a/src/metricsHandlers/endpointExplorer.js b/src/metricsHandlers/endpointExplorer.js deleted file mode 100644 index dd34c510..00000000 --- a/src/metricsHandlers/endpointExplorer.js +++ /dev/null @@ -1,81 +0,0 @@ -import { - CHOOSE_ENDPOINT, - START_REQUEST, - UPDATE_REQUEST, - ERROR_REQUEST, -} from "../actions/endpointExplorer"; -import { LOAD_STATE } from "../actions/routing"; -import { logEvent } from "../helpers/metrics"; - -const metricsEvents = { - changeResource: "endpoint explorer: changed resource", - changeEndpoint: "endpoint explorer: changed endpoint", - startRequest: "endpoint explorer: request: start", - requestFinish: "endpoint explorer: request: success", - requestError: "endpoint explorer: request: failed", - requestStream: "endpoint explorer: request: stream message", -}; - -const getPayload = (state, action) => { - const { pendingRequest, currentResource, currentEndpoint } = - state.endpointExplorer; - const template = pendingRequest.template - ? pendingRequest.template.template - : ""; - - return { - template, - resource: currentResource, - endpoint: currentEndpoint, - }; -}; - -export default function endpointExplorerMetrics(state, action) { - const { type, ...payload } = action; - switch (type) { - case CHOOSE_ENDPOINT: { - const { resource, endpoint } = payload; - - if (endpoint === "") { - logEvent(metricsEvents.changeResource, { resource }); - } else { - logEvent(metricsEvents.changeEndpoint, { resource, endpoint }); - } - return; - } - case START_REQUEST: { - logEvent(metricsEvents.startRequest, getPayload(state, action)); - return; - } - - case UPDATE_REQUEST: { - if (payload.isStreaming) { - logEvent(metricsEvents.requestStream, getPayload(state, action)); - } else { - logEvent(metricsEvents.requestFinish, getPayload(state, action)); - } - return; - } - - case ERROR_REQUEST: { - const { extras = {}, detail = "", status = "" } = payload.body; - logEvent(metricsEvents.requestError, { - detail, - extras: JSON.stringify(extras), - status, - }); - return; - } - - case LOAD_STATE: { - // If we're on the txbuilder and loading state, we might be transitioning - // to another feature with a complete transaction. - if (payload.slug === "explorer") { - logEvent(metricsEvents.signTransaction, { - endpoint: payload.endpoint, - resource: payload.resource, - }); - } - } - } -} diff --git a/src/metricsHandlers/network.js b/src/metricsHandlers/network.js deleted file mode 100644 index d9f7dc1d..00000000 --- a/src/metricsHandlers/network.js +++ /dev/null @@ -1,17 +0,0 @@ -import { SET_PARAMS } from "../actions/network"; -import { logEvent } from "../helpers/metrics"; - -const metricsEvents = { - changeNetwork: "pick network: changed horizon url", -}; - -export default function networkMetrics(state, action) { - const { type, ...payload } = action; - switch (type) { - case SET_PARAMS: { - logEvent(metricsEvents.changeNetwork, { - horizonUrl: payload.params.horizonURL, - }); - } - } -} diff --git a/src/metricsHandlers/routing.js b/src/metricsHandlers/routing.js deleted file mode 100644 index d2804d55..00000000 --- a/src/metricsHandlers/routing.js +++ /dev/null @@ -1,17 +0,0 @@ -import { UPDATE_LOCATION } from "../actions/routing"; -import { logEvent } from "../helpers/metrics"; - -const metricsEvents = { - navigate: "routing: changed page", -}; - -export default function networkMetrics(state, action) { - const { type, ...payload } = action; - switch (type) { - case UPDATE_LOCATION: { - logEvent(metricsEvents.navigate, { - path: payload.slug || "", - }); - } - } -} diff --git a/src/metricsHandlers/transactionBuilder.js b/src/metricsHandlers/transactionBuilder.js deleted file mode 100644 index a1e65108..00000000 --- a/src/metricsHandlers/transactionBuilder.js +++ /dev/null @@ -1,69 +0,0 @@ -import debounce from "lodash/debounce"; -import { - ADD_OPERATION, - REMOVE_OPERATION, - UPDATE_OPERATION_TYPE, - UPDATE_OPERATION_ATTRIBUTES, -} from "../actions/transactionBuilder"; -import { logEvent } from "../helpers/metrics"; -import { LOAD_STATE } from "../actions/routing"; - -const metricsEvents = { - changeOperation: "transaction builder: changed operation type", - addOperation: "transaction builder: added operation", - removeOperation: "transaction builder: removed operation", - updateAttributes: "transaction builder: changed operation attributes", - signTransaction: "transaction builder: began signing transaction", - viewTransaction: "transaction builder: view XDR", -}; - -// "Update attribute" events might fire in quick succession as somebody types -// information in. Aggressively debounce it to minimize duplicates. -const slowLogEvent = debounce(logEvent, 3000); - -export default function networkMetrics(state, action) { - const { type, ...payload } = action; - switch (type) { - case UPDATE_OPERATION_TYPE: { - logEvent(metricsEvents.changeOperation, { - type: payload.newType, - }); - return; - } - case ADD_OPERATION: { - logEvent(metricsEvents.addOperation); - return; - } - case REMOVE_OPERATION: { - logEvent(metricsEvents.removeOperation); - return; - } - case UPDATE_OPERATION_ATTRIBUTES: { - slowLogEvent(metricsEvents.updateAttributes, { - changedAttributes: Object.keys(payload.newAttributes), - operationType: ( - state.transactionBuilder.operations.find( - (o) => o.id === payload.opId, - ) || { name: "" } - ).name, - }); - return; - } - case LOAD_STATE: { - const { location } = state.routing; - // If we're on the txbuilder and loading state, we might be transitioning - // to another feature with a complete transaction. - if (location === "txbuilder") { - if (payload.slug === "txsigner") { - logEvent(metricsEvents.signTransaction, { - operations: state.transactionBuilder.operations.map((o) => o.name), - }); - } else if (payload.slug === "xdr-viewer") { - logEvent(metricsEvents.viewTransaction, { - operations: state.transactionBuilder.operations.map((o) => o.name), - }); - } - } - } - } -} diff --git a/src/metricsHandlers/transactionSigner.js b/src/metricsHandlers/transactionSigner.js deleted file mode 100644 index e8767b8c..00000000 --- a/src/metricsHandlers/transactionSigner.js +++ /dev/null @@ -1,68 +0,0 @@ -import { - LEDGER_WALLET_SIGN_START, - LEDGER_WALLET_SIGN_SUCCESS, - LEDGER_WALLET_SIGN_ERROR, - TREZOR_WALLET_SIGN_START, - TREZOR_WALLET_SIGN_SUCCESS, - TREZOR_WALLET_SIGN_ERROR, - SET_SECRETS, -} from "../actions/transactionSigner"; -import { logEvent } from "../helpers/metrics"; -import { LOAD_STATE } from "../actions/routing"; - -const metricsEvents = { - startLedgerSign: "transaction signer: ledger signature: begin", - ledgerSignSuccess: "transaction signer: ledger signature: success", - ledgerSignFailed: "transaction signer: ledger signature: failed", - startTrezorSign: "transaction signer: trezor signature: begin", - trezorSignSuccess: "transaction signer: trezor signature: success", - trezorSignFailed: "transaction signer: trezor signature: failed", - addSecret: "transaction signer: add secret", - submitTransaction: "transaction signer: begin submitting transaction", -}; - -export default function networkMetrics(state, action) { - const { type, ...payload } = action; - switch (type) { - case LEDGER_WALLET_SIGN_START: { - logEvent(metricsEvents.startLedgerSign); - return; - } - case LEDGER_WALLET_SIGN_SUCCESS: { - logEvent(metricsEvents.ledgerSignSuccess); - return; - } - case LEDGER_WALLET_SIGN_ERROR: { - logEvent(metricsEvents.ledgerSignFailed, { error: payload.error }); - return; - } - case TREZOR_WALLET_SIGN_START: { - logEvent(metricsEvents.startTrezorSign); - return; - } - case TREZOR_WALLET_SIGN_SUCCESS: { - logEvent(metricsEvents.trezorSignSuccess); - return; - } - case TREZOR_WALLET_SIGN_ERROR: { - logEvent(metricsEvents.trezorSignFailed, { error: payload.error }); - return; - } - case SET_SECRETS: { - logEvent(metricsEvents.addSecret, { - secretCount: payload.secrets.length, - }); - return; - } - case LOAD_STATE: { - const { location } = state.routing; - // If we're on the txsigner and loading state, we might be transitioning - // to another feature with a complete transaction. - if (location === "txsigner") { - if (payload.slug === "xdr-viewer") { - logEvent(metricsEvents.submitTransaction); - } - } - } - } -} diff --git a/src/metricsHandlers/xdrViewer.js b/src/metricsHandlers/xdrViewer.js deleted file mode 100644 index 2c8433eb..00000000 --- a/src/metricsHandlers/xdrViewer.js +++ /dev/null @@ -1,17 +0,0 @@ -import { FETCH_LATEST_TX } from "../actions/xdrViewer"; -import { logEvent } from "../helpers/metrics"; - -export const metricsEvents = { - fetchLatestTx: "xdr viewer: fetch latest transaction", - decodeFailed: 'xdr viewer: decode XDR: failed', - decodeSuccess: 'xdr viewer: decode XDR: success', -}; - -export default function networkMetrics(state, action) { - const { type, ...payload } = action; - switch (type) { - case FETCH_LATEST_TX: { - logEvent(metricsEvents.fetchLatestTx); - } - } -} diff --git a/src/middleware.ts b/src/middleware.ts new file mode 100644 index 00000000..0a6d75fd --- /dev/null +++ b/src/middleware.ts @@ -0,0 +1,68 @@ +import { NextRequest, NextResponse } from "next/server"; + +export function middleware(request: NextRequest) { + const nonce = Buffer.from(crypto.randomUUID()).toString("base64"); + + // script-src 'unsafe-eval' is needed for XDR JSON WebAssembly scripts + const cspHeader = ` + default-src 'self'; + script-src 'self' 'nonce-${nonce}' 'strict-dynamic' https: 'unsafe-inline' 'unsafe-eval'; + style-src 'self' https://fonts.googleapis.com ${ + process.env.NODE_ENV === "production" + ? `'nonce-${nonce}'` + : `'unsafe-inline'` + }; + img-src 'self' https://stellar.creit.tech/wallet-icons/ blob: data:; + connect-src 'self' https://9sl3dhr1twv1.statuspage.io/api/v2/ https://stellar-mainnet.liquify.com https://stellar.liquify.com https://soroban-rpc.mainnet.stellar.gateway.fm https://soroban-rpc.testnet.stellar.gateway.fm *.stellar.org; + font-src 'self' https://fonts.gstatic.com/; + object-src 'none'; + base-uri 'self'; + form-action 'self'; + frame-ancestors 'none'; + block-all-mixed-content; + upgrade-insecure-requests; +`; + // Replace newline characters and spaces + const contentSecurityPolicyHeaderValue = cspHeader + .replace(/\s{2,}/g, " ") + .trim(); + + const requestHeaders = new Headers(request.headers); + requestHeaders.set("x-nonce", nonce); + + requestHeaders.set( + "Content-Security-Policy", + contentSecurityPolicyHeaderValue, + ); + + const response = NextResponse.next({ + request: { + headers: requestHeaders, + }, + }); + response.headers.set( + "Content-Security-Policy", + contentSecurityPolicyHeaderValue, + ); + + return response; +} + +export const config = { + matcher: [ + /* + * Match all request paths except for the ones starting with: + * - api (API routes) + * - _next/static (static files) + * - _next/image (image optimization files) + * - favicon.ico (favicon file) + */ + { + source: "/((?!api|_next/static|_next/image|favicon.ico).*)", + missing: [ + { type: "header", key: "next-router-prefetch" }, + { type: "header", key: "purpose", value: "prefetch" }, + ], + }, + ], +}; diff --git a/src/middleware/metrics.js b/src/middleware/metrics.js deleted file mode 100644 index 78d5dba2..00000000 --- a/src/middleware/metrics.js +++ /dev/null @@ -1,8 +0,0 @@ -import { broadcastEvent } from "../helpers/metrics"; - -const metrics = (store) => (next) => (action) => { - broadcastEvent(store.getState(), action); - return next(action); -}; - -export default metrics; diff --git a/src/query/QueryProvider.tsx b/src/query/QueryProvider.tsx new file mode 100644 index 00000000..834b4eac --- /dev/null +++ b/src/query/QueryProvider.tsx @@ -0,0 +1,23 @@ +"use client"; + +import React from "react"; +import { QueryClient, QueryClientProvider } from "@tanstack/react-query"; +import { ReactQueryDevtools } from "@tanstack/react-query-devtools"; + +const queryClient = new QueryClient({ + defaultOptions: { + queries: { + refetchOnWindowFocus: false, + retry: false, + }, + }, +}); + +export const QueryProvider = ({ children }: { children: React.ReactNode }) => { + return ( + + {children} + + + ); +}; diff --git a/src/query/useAccountSequenceNumber.ts b/src/query/useAccountSequenceNumber.ts new file mode 100644 index 00000000..fdd102f0 --- /dev/null +++ b/src/query/useAccountSequenceNumber.ts @@ -0,0 +1,46 @@ +import { MuxedAccount, StrKey } from "@stellar/stellar-sdk"; +import { useQuery } from "@tanstack/react-query"; + +export const useAccountSequenceNumber = ({ + publicKey, + horizonUrl, +}: { + publicKey: string; + horizonUrl: string; +}) => { + const query = useQuery({ + queryKey: ["useAccountSequenceNumber", { publicKey }], + queryFn: async () => { + let sourceAccount = publicKey; + + if (StrKey.isValidMed25519PublicKey(publicKey)) { + const muxedAccount = MuxedAccount.fromAddress(publicKey, "0"); + sourceAccount = muxedAccount.baseAccount().accountId(); + } + + const response = await fetch(`${horizonUrl}/accounts/${sourceAccount}`); + const responseJson = await response.json(); + + if (responseJson?.status === 0) { + throw `Unable to reach server at ${horizonUrl}.`; + } + + if (responseJson?.status?.toString()?.startsWith("4")) { + if (responseJson?.title === "Resource Missing") { + throw "Account not found. Make sure the correct network is selected and the account is funded/created."; + } + + throw ( + responseJson?.extras?.reason || + responseJson?.detail || + "Something went wrong when fetching the transaction sequence number. Please try again." + ); + } + + return (BigInt(responseJson.sequence) + BigInt(1)).toString(); + }, + enabled: false, + }); + + return query; +}; diff --git a/src/query/useEndpoint.ts b/src/query/useEndpoint.ts new file mode 100644 index 00000000..7a743271 --- /dev/null +++ b/src/query/useEndpoint.ts @@ -0,0 +1,55 @@ +import { useQuery } from "@tanstack/react-query"; +import { AnyObject } from "@/types/types"; + +export const useEndpoint = (requestUrl: string, postData?: AnyObject) => { + const query = useQuery({ + queryKey: ["endpoint", "response", postData], + queryFn: async () => { + const endpointResponse = await fetch( + requestUrl, + getPostOptions(postData), + ); + + const endpointResponseJson = await endpointResponse.json(); + + return { + isError: endpointResponseJson?.status?.toString()?.startsWith("4"), + json: endpointResponseJson, + }; + }, + enabled: false, + }); + + return query; +}; + +const getPostOptions = (postData: AnyObject | undefined) => { + let newProps = {}; + + if (postData) { + if (postData.jsonrpc) { + // https://developers.stellar.org/docs/data/rpc + newProps = { + headers: { "Content-Type": "application/json" }, + body: JSON.stringify(postData), + }; + } else { + const formData = new FormData(); + + Object.entries(postData).forEach(([key, value]) => { + formData.append(key, value); + }); + + newProps = { + body: formData, + }; + } + + return { + method: "POST", + ...newProps, + }; + } + + return undefined; +}; diff --git a/src/query/useFriendBot.ts b/src/query/useFriendBot.ts new file mode 100644 index 00000000..3c6aea9a --- /dev/null +++ b/src/query/useFriendBot.ts @@ -0,0 +1,59 @@ +import { useQuery } from "@tanstack/react-query"; +import { EmptyObj, Network } from "@/types/types"; + +import { shortenStellarAddress } from "@/helpers/shortenStellarAddress"; + +export const useFriendBot = ({ + network, + publicKey, + key, +}: { + network: Network | EmptyObj; + publicKey: string; + key: { type: string }; +}) => { + const knownFriendbotURL = + network.id === "futurenet" + ? "https://friendbot-futurenet.stellar.org" + : "https://friendbot.stellar.org"; + + const query = useQuery({ + queryKey: ["friendBot", key], + queryFn: async () => { + if (!network.horizonUrl) { + throw new Error(`Please use a network that supports Horizon`); + } + + try { + const url = + network.id === "custom" + ? `${network.horizonUrl}/friendbot` + : `${knownFriendbotURL}/`; + const response = await fetch(`${url}?addr=${publicKey}`); + + if (!response.ok) { + const errorBody = await response.json(); + + throw new Error("there was an error", { cause: errorBody }); + } + return response; + } catch (e: any) { + if (e.cause.status === 0) { + throw new Error(`Unable to reach Friendbot server at ${network}`); + } else if (e.cause.detail.includes("createAccountAlreadyExist")) { + throw new Error( + `This account is already funded. Therefore, we are unable to fund ${shortenStellarAddress(publicKey)} on the test network.`, + ); + } else { + throw new Error( + `Unable to fund ${shortenStellarAddress(publicKey)} on the test network. Details: ${e.cause.detail}`, + { cause: e }, + ); + } + } + }, + enabled: false, + }); + + return query; +}; diff --git a/src/query/useLatestTxn.ts b/src/query/useLatestTxn.ts new file mode 100644 index 00000000..179ffc82 --- /dev/null +++ b/src/query/useLatestTxn.ts @@ -0,0 +1,24 @@ +import { useQuery } from "@tanstack/react-query"; + +export const useLatestTxn = (horizonUrl: string) => { + const query = useQuery({ + queryKey: ["xdr", "latestTxn"], + queryFn: async () => { + try { + const request = await fetch( + `${horizonUrl}/transactions?limit=1&order=desc`, + ); + const requestResponse = await request.json(); + + return requestResponse._embedded.records[0].envelope_xdr; + } catch (e) { + throw new Error( + `There was a problem fetching the latest transaction: ${e}`, + ); + } + }, + enabled: false, + }); + + return query; +}; diff --git a/src/query/useMaintenanceData.ts b/src/query/useMaintenanceData.ts new file mode 100644 index 00000000..7db29c5c --- /dev/null +++ b/src/query/useMaintenanceData.ts @@ -0,0 +1,22 @@ +import { useQuery } from "@tanstack/react-query"; +import { StatusPageScheduled } from "@/types/types"; + +export const useMaintenanceData = () => { + const query = useQuery({ + queryKey: ["maintenanceData"], + queryFn: async () => { + try { + const scheduleResponse = await fetch( + "https://9sl3dhr1twv1.statuspage.io/api/v2/summary.json", + ); + const scheduleResponseJson = await scheduleResponse.json(); + + return scheduleResponseJson.scheduled_maintenances; + } catch (e) { + throw Error("Failed to fetch testnet reset date."); + } + }, + }); + + return query; +}; diff --git a/src/query/useSimulateTx.ts b/src/query/useSimulateTx.ts new file mode 100644 index 00000000..88754a63 --- /dev/null +++ b/src/query/useSimulateTx.ts @@ -0,0 +1,62 @@ +import { useMutation } from "@tanstack/react-query"; +import { AnyObject } from "@/types/types"; + +type SimulateTxProps = { + rpcUrl: string; + transactionXdr: string; + instructionLeeway?: string; +}; + +export const useSimulateTx = () => { + const mutation = useMutation({ + mutationFn: async ({ + rpcUrl, + transactionXdr, + instructionLeeway, + }: SimulateTxProps) => { + const res = await fetch(rpcUrl, { + method: "POST", + headers: { + "Content-Type": "application/json", + }, + body: JSON.stringify({ + jsonrpc: "2.0", + id: 1, + method: "simulateTransaction", + params: { + transaction: transactionXdr, + ...(instructionLeeway + ? { + resourceConfig: { + instructionLeeway: Number(instructionLeeway), + }, + } + : {}), + }, + }), + }); + + return await res.json(); + }, + }); + + return { + ...mutation, + data: mutation.data as AnyObject, + mutateAsync: async ({ + rpcUrl, + transactionXdr, + instructionLeeway, + }: SimulateTxProps) => { + try { + await mutation.mutateAsync({ + rpcUrl, + transactionXdr, + instructionLeeway, + }); + } catch (e) { + // do nothing + } + }, + }; +}; diff --git a/src/query/useSubmitRpcTx.ts b/src/query/useSubmitRpcTx.ts new file mode 100644 index 00000000..d6ea4b63 --- /dev/null +++ b/src/query/useSubmitRpcTx.ts @@ -0,0 +1,73 @@ +import { useMutation } from "@tanstack/react-query"; +import { SorobanRpc, TransactionBuilder } from "@stellar/stellar-sdk"; +import { delay } from "@/helpers/delay"; +import { SubmitRpcError, SubmitRpcResponse } from "@/types/types"; + +type SubmitRpcTxProps = { + rpcServer: SorobanRpc.Server; + transactionXdr: string; + networkPassphrase: string; +}; + +export const useSubmitRpcTx = () => { + const mutation = useMutation< + SubmitRpcResponse, + SubmitRpcError, + SubmitRpcTxProps + >({ + mutationFn: async ({ + rpcServer, + transactionXdr, + networkPassphrase, + }: SubmitRpcTxProps) => { + const transaction = TransactionBuilder.fromXDR( + transactionXdr, + networkPassphrase, + ); + const sentTx = await rpcServer.sendTransaction(transaction); + + if (sentTx.status !== "PENDING") { + throw { status: sentTx.status, result: sentTx }; + } + + let txResponse; + const MAX_ATTEMPTS = 10; + let attempts = 0; + + while (attempts++ < MAX_ATTEMPTS && txResponse?.status !== "SUCCESS") { + txResponse = await rpcServer.getTransaction(sentTx.hash); + + switch (txResponse.status) { + case "FAILED": + throw { status: "FAILED", result: txResponse }; + case "NOT_FOUND": + await delay(1000); + continue; + case "SUCCESS": + default: + // Do nothing + } + } + + if (attempts >= MAX_ATTEMPTS || txResponse?.status !== "SUCCESS") { + throw { status: "TIMEOUT", result: txResponse }; + } + + const submittedTx = TransactionBuilder.fromXDR( + txResponse.envelopeXdr, + networkPassphrase, + ); + // TS doesn't recognize operations property even though it is there + const operations = (submittedTx as any)?.operations || ([] as any[]); + + return { + hash: sentTx.hash, + result: txResponse, + operationCount: operations.length, + fee: submittedTx.fee, + }; + }, + }); + + return mutation; +}; diff --git a/src/react-app-env.d.ts b/src/react-app-env.d.ts deleted file mode 100644 index 6431bc5f..00000000 --- a/src/react-app-env.d.ts +++ /dev/null @@ -1 +0,0 @@ -/// diff --git a/src/reducers/accountCreator.js b/src/reducers/accountCreator.js deleted file mode 100644 index 1c5d6b4d..00000000 --- a/src/reducers/accountCreator.js +++ /dev/null @@ -1,111 +0,0 @@ -import { combineReducers } from "redux"; -import assign from "lodash/assign"; -import { - GENERATE_NEW_KEYPAIR, - UPDATE_FRIENDBOT_TARGET, - START_FRIENDBOT_REQUEST, - FINISH_FRIENDBOT_REQUEST, - GENERATE_MUXED_ACCOUNT, - UPDATE_GENERATE_MUXED_ACCOUNT_INPUT, - PARSE_MUXED_ACCOUNT, - UPDATE_PARSE_MUXED_ACCOUNT_INPUT, -} from "../actions/accountCreator"; - -function keypairGeneratorResult(state = null, action) { - if (action.type === GENERATE_NEW_KEYPAIR) { - return { - pubKey: action.pubKey, - secretKey: action.secretKey, - }; - } - return state; -} -function keypairGeneratorPubKey(state = "", action) { - if (action.type === GENERATE_NEW_KEYPAIR) { - return action.pubKey; - } - return state; -} -function friendbotTarget(state = "", action) { - if (action.type === UPDATE_FRIENDBOT_TARGET) { - return action.target; - } - return state; -} - -const initialMuxedAccountState = { - gAddress: "", - mAccountId: "", - mAddress: "", - errorMessage: "", -}; -function muxedAccountGenerated(state = initialMuxedAccountState, action) { - if (action.type === GENERATE_MUXED_ACCOUNT) { - return { - ...state, - mAddress: action.mAddress, - errorMessage: action.errorMessage || "", - }; - } - if (action.type === UPDATE_GENERATE_MUXED_ACCOUNT_INPUT) { - return { - ...state, - ...action.input, - errorMessage: "", - mAddress: "", - }; - } - return state; -} -function muxedAccountParsed(state = initialMuxedAccountState, action) { - if (action.type === PARSE_MUXED_ACCOUNT) { - return { - ...state, - gAddress: action.gAddress, - mAccountId: action.mAccountId, - errorMessage: action.errorMessage || "", - }; - } - if (action.type === UPDATE_PARSE_MUXED_ACCOUNT_INPUT) { - return { - ...state, - mAddress: action.mAddress, - errorMessage: "", - gAddress: "", - mAccountId: "", - }; - } - return state; -} - -const defaultRequestState = { - message: "", - code: "", - status: "inital", -}; -function friendbotStatus(state = defaultRequestState, action) { - if (action.type === START_FRIENDBOT_REQUEST) { - return assign({}, defaultRequestState, { - message: action.message, - status: action.status, - }); - } - if (action.type === FINISH_FRIENDBOT_REQUEST) { - return { - message: action.message, - code: action.code, - status: action.status, - }; - } - return state; -} - -const accountCreator = combineReducers({ - keypairGeneratorResult, - keypairGeneratorPubKey, - friendbotTarget, - friendbotStatus, - muxedAccountGenerated, - muxedAccountParsed, -}); -export default accountCreator; diff --git a/src/reducers/endpointExplorer.js b/src/reducers/endpointExplorer.js deleted file mode 100644 index be6eac96..00000000 --- a/src/reducers/endpointExplorer.js +++ /dev/null @@ -1,137 +0,0 @@ -import { combineReducers } from "redux"; -import { - CHOOSE_ENDPOINT, - CHANGE_PENDING_REQUEST_PROPS, - START_REQUEST, - ERROR_REQUEST, - UPDATE_REQUEST, - UPDATE_VALUE, -} from "../actions/endpointExplorer"; -import { LOAD_STATE } from "../actions/routing"; -import { getEndpointTemplate } from "../helpers/getEndpointTemplate"; -import { rehydrate } from "../helpers/hydration"; -import SLUG from "../constants/slug"; - -function currentResource(state = "", action) { - switch (action.type) { - case LOAD_STATE: - if (action.slug === SLUG.EXPLORER && action.queryObj.resource) { - return action.queryObj.resource; - } - break; - case CHOOSE_ENDPOINT: - return action.resource; - } - return state; -} - -function currentEndpoint(state = "", action) { - switch (action.type) { - case LOAD_STATE: - if (action.slug === SLUG.EXPLORER && action.queryObj.endpoint) { - return action.queryObj.endpoint; - } - break; - case CHOOSE_ENDPOINT: - return action.endpoint; - } - return state; -} - -function pendingRequestTemplate(state = "", action) { - switch (action.type) { - case CHOOSE_ENDPOINT: - return getEndpointTemplate(action.resource, action.endpoint) || ""; - default: - return state; - } -} - -function pendingRequestValues(state = {}, action) { - switch (action.type) { - case LOAD_STATE: - if (action.slug === SLUG.EXPLORER && action.queryObj.values) { - return rehydrate(action.queryObj.values); - } - break; - case UPDATE_VALUE: - return Object.assign({}, state, { - [action.param]: action.value, - }); - case CHOOSE_ENDPOINT: - return {}; - } - return state; -} - -const blankResults = { - id: null, - available: false, - body: [], -}; -function results(state, action) { - if (typeof state === "undefined") { - return blankResults; - } - - // Clear the results when a change to the explorer happens - switch (action.type) { - case LOAD_STATE: - if (action.slug === SLUG.EXPLORER) { - return blankResults; - } - return state; - case CHOOSE_ENDPOINT: - case UPDATE_VALUE: - return blankResults; - } - - if (action.type === START_REQUEST) { - return Object.assign({}, state, { - available: true, - id: action.id, - isError: false, - body: [], - }); - } - - if (action.id !== state.id) { - // This action has expired as we've moved on to a new request - // Or, this is likely an irrelevant action - return state; - } - - if (action.type === ERROR_REQUEST) { - let errorContent; - if (action.errorStatus === 0) { - errorContent = "Unable to reach Horizon server."; - } else { - errorContent = JSON.stringify(action.body, null, 2); - } - - return Object.assign({}, state, { - isError: true, - body: [errorContent], - }); - } - - if (action.type === UPDATE_REQUEST) { - return Object.assign({}, state, { - body: [].concat(state.body, JSON.stringify(action.body, null, 2)), - }); - } - - return state; -} - -const endpointExplorer = combineReducers({ - currentResource, - currentEndpoint, - pendingRequest: combineReducers({ - template: pendingRequestTemplate, - values: pendingRequestValues, - }), - results, -}); - -export default endpointExplorer; diff --git a/src/reducers/network.js b/src/reducers/network.js deleted file mode 100644 index 37ff62f0..00000000 --- a/src/reducers/network.js +++ /dev/null @@ -1,68 +0,0 @@ -import { combineReducers } from "redux"; -import { - CHOOSE_NETWORK, - SET_PARAMS, - SHOW_MODAL, - HIDE_MODAL, - UPDATE_MODAL, -} from "../actions/network"; -import NETWORK from "../constants/network"; -import { LOAD_STATE } from "../actions/routing"; - -export const defaultNetwork = { - name: NETWORK.defaultName, - horizonURL: NETWORK.available[NETWORK.defaultName].horizonURL, - networkPassphrase: NETWORK.available[NETWORK.defaultName].networkPassphrase, -}; - -let current = (state = defaultNetwork, action) => { - switch (action.type) { - case LOAD_STATE: - if (action.queryObj.network == "custom") { - return { - name: action.queryObj.network, - horizonURL: action.queryObj.horizonURL, - networkPassphrase: action.queryObj.networkPassphrase, - }; - } - - if ( - action.queryObj.network && - NETWORK.available[action.queryObj.network] - ) { - return Object.assign( - { name: action.queryObj.network }, - NETWORK.available[action.queryObj.network], - ); - } - return state; - case SET_PARAMS: - return action.params; - default: - return state; - } -}; - -function modal(state = { visible: false, values: {} }, action) { - switch (action.type) { - case SHOW_MODAL: - return Object.assign({}, state, { visible: true }); - case HIDE_MODAL: - return Object.assign({}, state, { visible: false }); - case SET_PARAMS: - return { visible: false, values: Object.assign({}, action.params) }; - case UPDATE_MODAL: - let values = state.values; - values[action.key] = action.value; - return { visible: true, values }; - default: - return state; - } -} - -const network = combineReducers({ - current, - modal, -}); - -export default network; diff --git a/src/reducers/routing.js b/src/reducers/routing.js deleted file mode 100644 index 516058ef..00000000 --- a/src/reducers/routing.js +++ /dev/null @@ -1,21 +0,0 @@ -import { combineReducers } from "redux"; -import url from "url"; -import { UPDATE_LOCATION, LOAD_STATE } from "../actions/routing"; - -const routing = combineReducers({ - location, -}); - -export default routing; - -function location(state = "", action) { - switch (action.type) { - case UPDATE_LOCATION: - case LOAD_STATE: - if (action.slug === null) { - return ""; - } - return action.slug; - } - return state; -} diff --git a/src/reducers/transactionBuilder.js b/src/reducers/transactionBuilder.js deleted file mode 100644 index 84e21bc9..00000000 --- a/src/reducers/transactionBuilder.js +++ /dev/null @@ -1,235 +0,0 @@ -import { combineReducers } from "redux"; -import assign from "lodash/assign"; -import filter from "lodash/filter"; -import find from "lodash/find"; -import findIndex from "lodash/findIndex"; -import { BASE_FEE } from "@stellar/stellar-sdk"; -import { - UPDATE_ATTRIBUTES, - FETCH_SEQUENCE_START, - FETCH_SEQUENCE_SUCCESS, - FETCH_SEQUENCE_FAIL, - RESET_TXBUILDER, - FETCH_BASE_FEE_SUCCESS, - FETCH_BASE_FEE_FAIL, - UPDATE_TX_TYPE, - UPDATE_FEE_BUMP_ATTRIBUTE, -} from "../actions/transactionBuilder"; -import { LOAD_STATE } from "../actions/routing"; -import { rehydrate } from "../helpers/hydration"; -import SLUG from "../constants/slug"; -import TX_TYPES from "../constants/transaction_types"; - -const defaultOperations = [ - { - id: 0, - attributes: {}, - name: "", - }, -]; -function operations(state = defaultOperations, action) { - let targetOpIndex, newOps; - switch (action.type) { - case LOAD_STATE: - if (action.slug === SLUG.TXBUILDER) { - if (action.queryObj.params) { - // TODO: validate that this is actually a valid operations object - return ( - rehydrate(action.queryObj.params).operations || defaultOperations - ); - } - return defaultOperations; - } - break; - case "ADD_OPERATION": - return Array.prototype.concat(state, { - id: action.opId, - name: "", - attributes: {}, - }); - case "REMOVE_OPERATION": - return filter(state.slice(), (op) => op.id !== action.opId); - case "DUPLICATE_OPERATION": - let sourceOp = state.find((op) => op.id === action.sourceOpId); - if (undefined === sourceOp) { - return state; - } - return Array.prototype.concat(state, { - id: action.opId, - name: sourceOp.name, - attributes: sourceOp.attributes, - }); - case "REORDER_OPERATION": - return reorderOps(state, action.opId, action.toNth); - case "UPDATE_OPERATION_TYPE": - return updateOperation(state, action.opId, { - name: action.newType, - attributes: {}, - }); - case "UPDATE_OPERATION_ATTRIBUTES": - return updateOperation(state, action.opId, { - attributes: assign( - {}, - getAttributes(state, action.opId), - action.newAttributes, - ), - }); - case RESET_TXBUILDER: - return defaultOperations; - } - return state; -} -function getAttributes(state, opId) { - return find(state, { id: opId }).attributes; -} -function updateOperation(state, opId, newSource) { - let targetOpIndex = findIndex(state, { id: opId }); - let newOps = state.slice(); - newOps[targetOpIndex] = assign({}, newOps[targetOpIndex], newSource); - return newOps; -} -function updateSigner(state, opId, newSource) { - let targetOpIndex = findIndex(state, { id: opId }); - let newOps = state.slice(); - newOps[targetOpIndex] = assign({}, newOps[targetOpIndex], newSource); - return newOps; -} -function reorderOps(state, opId, toNth) { - if (toNth < 1) { - toNth = 1; - } - if (toNth > state.length) { - toNth = state.length; - } - let ops = state.slice(); - let targetOpIndex = findIndex(ops, { id: opId }); - let targetOp = ops[targetOpIndex]; - ops.splice(targetOpIndex, 1); - ops.splice(toNth - 1, 0, targetOp); - return ops; -} - -const defaultAttributes = { - sourceAccount: "", - sequence: "", - // fee is used to track value in the form. User can change it. - fee: BASE_FEE, - // baseFee and minFee are fetched from fee_stats. User cannot change them. - baseFee: BASE_FEE, - minFee: BASE_FEE, - memoType: "", - memoContent: "", - minTime: "", - maxTime: "", -}; - -function attributes(state = defaultAttributes, action) { - switch (action.type) { - case LOAD_STATE: - if (action.queryObj.params) { - return assign( - {}, - defaultAttributes, - rehydrate(action.queryObj.params).attributes, - ); - } - break; - case UPDATE_ATTRIBUTES: - return Object.assign({}, state, action.newAttributes); - case FETCH_SEQUENCE_SUCCESS: - return Object.assign({}, state, { sequence: action.sequence }); - case FETCH_BASE_FEE_SUCCESS: - return Object.assign({}, state, { - fee: action.min_fee, - minFee: action.min_fee, - baseFee: action.base_fee, - }); - case FETCH_BASE_FEE_FAIL: - return Object.assign({}, state, { - fee: defaultAttributes.fee, - minFee: defaultAttributes.fee, - baseFee: defaultAttributes.baseFee, - }); - case RESET_TXBUILDER: - return defaultAttributes; - } - return state; -} - -const defaultFeeBumpAttributes = { - sourceAccount: "", - maxFee: BASE_FEE, - innerTxXDR: "", -}; - -function feeBumpAttributes(state = defaultFeeBumpAttributes, action) { - switch (action.type) { - case LOAD_STATE: - if (action.queryObj.params) { - return assign( - {}, - defaultFeeBumpAttributes, - rehydrate(action.queryObj.params).feeBumpAttributes, - ); - } - break; - case UPDATE_FEE_BUMP_ATTRIBUTE: - return Object.assign({}, state, action.newAttribute); - case FETCH_BASE_FEE_SUCCESS: - return Object.assign({}, state, { - maxFee: action.min_fee, - }); - case FETCH_BASE_FEE_FAIL: - return Object.assign({}, state, { - maxFee: defaultFeeBumpAttributes.maxFee, - }); - case RESET_TXBUILDER: - return defaultFeeBumpAttributes; - } - return state; -} - -function txType(state = TX_TYPES.REGULAR, action) { - switch (action.type) { - case LOAD_STATE: - if (action.queryObj.params) { - const prevTxType = rehydrate(action.queryObj.params).txType; - return [TX_TYPES.REGULAR, TX_TYPES.FEE_BUMP].indexOf(prevTxType) > -1 - ? prevTxType - : TX_TYPES.REGULAR; - } - break; - case UPDATE_TX_TYPE: - return action.txType; - case RESET_TXBUILDER: - return TX_TYPES.REGULAR; - } - return state; -} - -function sequenceFetcherError(state = "", action) { - let payload = action.payload; - if (action.type === FETCH_SEQUENCE_FAIL) { - if (payload.response.data.title === "Resource Missing") { - return `Account not found. Make sure the correct network is selected and the account is funded/created.`; - } - if (payload.status === 0) { - return `Unable to reach server at ${payload.config.url}`; - } - return JSON.stringify(action.payload, null, 2); - } - if (action.type === FETCH_SEQUENCE_START) { - return ""; - } - return state; -} - -const transactionBuilder = combineReducers({ - attributes, - operations, - sequenceFetcherError, - txType, - feeBumpAttributes, -}); - -export default transactionBuilder; diff --git a/src/reducers/transactionSigner.js b/src/reducers/transactionSigner.js deleted file mode 100644 index ce4ac75c..00000000 --- a/src/reducers/transactionSigner.js +++ /dev/null @@ -1,155 +0,0 @@ -import { combineReducers } from "redux"; -import { - IMPORT_FROM_XDR, - CLEAR_TRANSACTION, - SET_SECRETS, - SET_BIP_PATH, - LEDGER_WALLET_SIGN_START, - LEDGER_WALLET_SIGN_ERROR, - LEDGER_WALLET_SIGN_SUCCESS, - TREZOR_WALLET_SIGN_START, - TREZOR_WALLET_SIGN_ERROR, - TREZOR_WALLET_SIGN_SUCCESS, - FREIGHTER_WALLET_SIGN_START, - FREIGHTER_WALLET_SIGN_ERROR, - FREIGHTER_WALLET_SIGN_SUCCESS, - ALBEDO_WALLET_SIGN_START, - ALBEDO_WALLET_SIGN_SUCCESS, - ALBEDO_WALLET_SIGN_ERROR, -} from "../actions/transactionSigner"; -import { LOAD_STATE } from "../actions/routing"; -import { validateTxXdr } from "../helpers/validateTxXdr"; -import SLUG from "../constants/slug"; - -const transactionSigner = combineReducers({ - xdr, - signers, - bipPath, - hardwarewalletStatus, - freighterwalletStatus, - albedowalletStatus, -}); - -export default transactionSigner; - -function xdr(state = "", action) { - switch (action.type) { - case LOAD_STATE: - if (action.slug === SLUG.TXSIGNER && action.queryObj.xdr) { - const validationResult = validateTxXdr(action.queryObj.xdr); - if (validationResult.result === "success") { - return action.queryObj.xdr; - } - console.error(validationResult.message, validationResult.originalError); - // If invalid xdr in the url, then we go back to step zero - return ""; - } - return state; - case IMPORT_FROM_XDR: - return action.xdr; - case CLEAR_TRANSACTION: - return ""; - } - return state; -} - -function signers(state = [""], action) { - switch (action.type) { - case IMPORT_FROM_XDR: - case CLEAR_TRANSACTION: - return [""]; - case SET_SECRETS: - return action.secrets; - } - return state; -} - -function bipPath(state = [], action) { - switch (action.type) { - case LOAD_STATE: - case IMPORT_FROM_XDR: - case CLEAR_TRANSACTION: - return "44'/148'/0'"; - case SET_BIP_PATH: - return action.bipPath; - } - return state; -} - -function hardwarewalletStatus(state = {}, action) { - switch (action.type) { - case IMPORT_FROM_XDR: - case CLEAR_TRANSACTION: - return {}; - case LEDGER_WALLET_SIGN_START: - case TREZOR_WALLET_SIGN_START: - return Object.assign({}, state, { - status: "loading", - message: "Waiting for wallet", - }); - case LEDGER_WALLET_SIGN_ERROR: - case TREZOR_WALLET_SIGN_ERROR: - return Object.assign({}, state, { - status: "failure", - message: "Error:" + JSON.stringify(action.error), - }); - case LEDGER_WALLET_SIGN_SUCCESS: - case TREZOR_WALLET_SIGN_SUCCESS: - return Object.assign({}, state, { - status: "success", - message: "Success!", - signatures: [action.signature], - }); - } - return state; -} - -function freighterwalletStatus(state = {}, action) { - switch (action.type) { - case IMPORT_FROM_XDR: - case CLEAR_TRANSACTION: - return {}; - case FREIGHTER_WALLET_SIGN_START: - return Object.assign({}, state, { - status: "loading", - message: "Waiting for wallet", - }); - case FREIGHTER_WALLET_SIGN_ERROR: - return Object.assign({}, state, { - status: "failure", - message: "Error:" + JSON.stringify(action.error), - }); - case FREIGHTER_WALLET_SIGN_SUCCESS: - return Object.assign({}, state, { - status: "success", - message: "Success!", - signedTx: action.signedTx, - }); - } - return state; -} - -function albedowalletStatus(state = {}, action) { - switch (action.type) { - case IMPORT_FROM_XDR: - case CLEAR_TRANSACTION: - return {}; - case ALBEDO_WALLET_SIGN_START: - return Object.assign({}, state, { - status: "loading", - message: "Waiting for wallet", - }); - case ALBEDO_WALLET_SIGN_ERROR: - return Object.assign({}, state, { - status: "failure", - message: "Error:" + JSON.stringify(action.error), - }); - case ALBEDO_WALLET_SIGN_SUCCESS: - return Object.assign({}, state, { - status: "success", - message: "Success!", - signedTx: action.signedTx, - }); - } - return state; -} diff --git a/src/reducers/xdrViewer.js b/src/reducers/xdrViewer.js deleted file mode 100644 index 0294038d..00000000 --- a/src/reducers/xdrViewer.js +++ /dev/null @@ -1,64 +0,0 @@ -import { combineReducers } from "redux"; -import { UPDATE_XDR_INPUT, UPDATE_XDR_TYPE } from "../actions/xdrViewer"; -import { FETCHED_SIGNERS } from "../constants/fetched_signers"; -import { LOAD_STATE } from "../actions/routing"; -import { SET_PARAMS } from "../actions/network"; -import SLUG from "../constants/slug"; - -const routing = combineReducers({ - input, - type, - fetchedSigners, -}); - -export default routing; - -function input(state = "", action) { - switch (action.type) { - case LOAD_STATE: - if ( - (action.slug === SLUG.XDRVIEWER || action.slug === SLUG.TXSUBMITTER) && - action.queryObj.input - ) { - return action.queryObj.input; - } - break; - case UPDATE_XDR_INPUT: - return action.input; - } - - return state; -} - -function type(state = "TransactionEnvelope", action) { - switch (action.type) { - case LOAD_STATE: - if (action.slug === "xdr-viewer" && action.queryObj.type) { - return action.queryObj.type; - } - break; - case UPDATE_XDR_TYPE: - return action.xdrType; - } - - return state; -} - -function fetchedSigners(state = { state: FETCHED_SIGNERS.NONE }, action) { - switch (action.type) { - case FETCHED_SIGNERS.SUCCESS: - return { - state: FETCHED_SIGNERS.SUCCESS, - data: action.result, - }; - case FETCHED_SIGNERS.NONE: - case FETCHED_SIGNERS.PENDING: - case FETCHED_SIGNERS.FAIL: - case FETCHED_SIGNERS.NOT_EXIST: - return { state: action.type }; - case SET_PARAMS: - return { state: FETCHED_SIGNERS.NONE }; - default: - return state; - } -} diff --git a/src/setupTests.ts b/src/setupTests.ts deleted file mode 100644 index 3a6e59ad..00000000 --- a/src/setupTests.ts +++ /dev/null @@ -1,6 +0,0 @@ -// jest-dom adds custom jest matchers for asserting on DOM nodes. -// allows you to do things like: -// expect(element).toHaveTextContent(/react/i) -// learn more: https://github.com/testing-library/jest-dom -import "@testing-library/jest-dom/extend-expect"; -import "helpers/testHelpers"; diff --git a/src/store/StoreProvider.tsx b/src/store/StoreProvider.tsx new file mode 100644 index 00000000..0d545854 --- /dev/null +++ b/src/store/StoreProvider.tsx @@ -0,0 +1,23 @@ +"use client"; +import { createContext, ReactNode, useState } from "react"; +import { usePathname, useSearchParams } from "next/navigation"; +import { createStore } from "@/store/createStore"; + +export type StoreType = ReturnType; +export const ZustandContext = createContext(null); + +export const StoreProvider = ({ children }: { children: ReactNode }) => { + const pathname = usePathname(); + const searchParams = useSearchParams(); + const url = `${pathname}?${searchParams}`; + + const [store] = useState(() => + createStore({ + url, + }), + ); + + return ( + {children} + ); +}; diff --git a/src/store/createStore.ts b/src/store/createStore.ts new file mode 100644 index 00000000..724e971d --- /dev/null +++ b/src/store/createStore.ts @@ -0,0 +1,529 @@ +import { create } from "zustand"; +import { immer } from "zustand/middleware/immer"; +import { querystring } from "zustand-querystring"; +import { + MemoType, + FeeBumpTransaction, + Transaction, + xdr, +} from "@stellar/stellar-sdk"; + +import { XDR_TYPE_TRANSACTION_ENVELOPE } from "@/constants/settings"; +import { sanitizeObject } from "@/helpers/sanitizeObject"; +import { + AnyObject, + EmptyObj, + Network, + MuxedAccount, + TxnOperation, +} from "@/types/types"; + +export type FeeBumpParams = { + source_account: string; + fee: string; + xdr: string; +}; + +type FeeBumpParamsObj = { + [K in keyof FeeBumpParams]?: FeeBumpParams[K]; +}; + +export type TransactionBuildParams = { + source_account: string; + fee: string; + seq_num: string; + cond: { + time: { + min_time: string; + max_time: string; + }; + }; + memo: + | string + | { + [T in Exclude]?: string; + } + | EmptyObj; +}; + +type TransactionBuildParamsObj = { + [K in keyof TransactionBuildParams]?: TransactionBuildParams[K]; +}; + +export type SignTxActiveView = "import" | "overview"; + +export interface Store { + // Shared + network: Network | EmptyObj; + // isDynamicNetworkSelect flag to indicate network update outside of the dropdown + isDynamicNetworkSelect: boolean; + selectNetwork: (network: Network) => void; + // updateIsDynamicNetworkSelect: + // set to true when updating outside of the network dropdown; + // set to false when changing network from the dropdown, no need to clear it + // in other places because it will stay for the session (not saved in URL) + updateIsDynamicNetworkSelect: (isDynamic: boolean) => void; + resetStoredData: () => void; + + // Account + account: { + publicKey: string | undefined; + secretKey: string | undefined; + + generatedMuxedAccountInput: Partial | EmptyObj; + parsedMuxedAccountInput: string | undefined; + generatedMuxedAccount: MuxedAccount | EmptyObj; + parsedMuxedAccount: MuxedAccount | EmptyObj; + updateKeypair: (publicKey: string, secretKey?: string) => void; + updateGeneratedMuxedAccountInput: (value: Partial) => void; + updateParsedMuxedAccountInput: (value: string) => void; + updateGeneratedMuxedAccount: (value: MuxedAccount) => void; + updateParsedMuxedAccount: (value: MuxedAccount) => void; + reset: () => void; + }; + + // Endpoints + endpoints: { + network: Network | EmptyObj; + currentEndpoint: string | undefined; + params: AnyObject; + saved: { + activeTab: string; + }; + updateNetwork: (network: Network) => void; + updateCurrentEndpoint: (endpoint: string) => void; + updateParams: (params: AnyObject) => void; + updateSavedActiveTab: (tabId: string) => void; + setParams: (params: AnyObject) => void; + resetParams: () => void; + reset: () => void; + }; + + // Transaction + transaction: { + build: { + activeTab: string; + params: TransactionBuildParams; + operations: TxnOperation[]; + xdr: string; + isValid: { + params: boolean; + operations: boolean; + }; + }; + sign: { + activeView: SignTxActiveView; + importTx: FeeBumpTransaction | Transaction | undefined; + importXdr: string; + signedTx: string; + bipPath: string; + hardWalletSigs: xdr.DecoratedSignature[] | []; + }; + simulate: { + instructionLeeway?: string; + triggerOnLaunch?: boolean; + }; + feeBump: FeeBumpParams; + // [Transaction] Build Transaction actions + updateBuildActiveTab: (tabId: string) => void; + updateBuildParams: (params: TransactionBuildParamsObj) => void; + updateBuildOperations: (operations: TxnOperation[]) => void; + updateBuildXdr: (xdr: string) => void; + updateBuildSingleOperation: ( + index: number, + operation: TxnOperation, + ) => void; + updateBuildIsValid: ({ + params, + operations, + }: { + params?: boolean; + operations?: boolean; + }) => void; + setBuildParams: (params: TransactionBuildParamsObj) => void; + resetBuildParams: () => void; + resetBuild: () => void; + // [Transaction] Sign Transaction actions + updateSignActiveView: (viewId: SignTxActiveView) => void; + updateSignImportTx: (tx: FeeBumpTransaction | Transaction) => void; + updateSignImportXdr: (xdr: string) => void; + updateSignedTx: (tx: string) => void; + updateBipPath: (bipPath: string) => void; + updateHardWalletSigs: (signer: xdr.DecoratedSignature[]) => void; + resetSign: () => void; + resetSignHardWalletSigs: () => void; + updateFeeBumpParams: (params: FeeBumpParamsObj) => void; + resetBaseFee: () => void; + // [Transaction] Simulate Transaction actions + updateSimulateInstructionLeeway: (instrLeeway?: string) => void; + updateSimulateTriggerOnLaunch: (trigger: boolean) => void; + }; + + // XDR + xdr: { + blob: string; + jsonString: string; + type: string; + updateXdrBlob: (blob: string) => void; + updateJsonString: (jsonString: string) => void; + updateXdrType: (type: string) => void; + resetXdr: () => void; + resetJsonString: () => void; + }; +} + +interface CreateStoreOptions { + url?: string; +} + +// Initial states +const initEndpointState = { + network: {}, + currentEndpoint: undefined, + params: {}, + saved: { + activeTab: "horizon", + }, +}; + +const initTransactionParamsState = { + source_account: "", + fee: "", + seq_num: "", + cond: { + time: { + min_time: "", + max_time: "", + }, + }, + memo: {}, +}; + +const initTransactionState = { + build: { + activeTab: "params", + params: initTransactionParamsState, + operations: [], + xdr: "", + isValid: { + params: false, + operations: false, + }, + }, + sign: { + activeView: "import" as SignTxActiveView, + importTx: undefined, + importXdr: "", + signedTx: "", + bipPath: "44'/148'/0'", + hardWalletSigs: [], + }, + simulate: { + instructionLeeway: undefined, + triggerOnLaunch: undefined, + }, + feeBump: { + source_account: "", + fee: "", + xdr: "", + }, +}; + +const initAccountState = { + publicKey: undefined, + secretKey: undefined, + generatedMuxedAccountInput: {}, + parsedMuxedAccountInput: undefined, + generatedMuxedAccount: {}, + parsedMuxedAccount: {}, +}; + +const initXdrState = { + blob: "", + jsonString: "", + type: XDR_TYPE_TRANSACTION_ENVELOPE, +}; + +// Store +export const createStore = (options: CreateStoreOptions) => + create()( + // https://github.com/nitedani/zustand-querystring + querystring( + immer((set) => ({ + // Shared + network: {}, + isDynamicNetworkSelect: false, + selectNetwork: (network: Network) => + set((state) => { + state.network = network; + }), + updateIsDynamicNetworkSelect: (isDynamic: boolean) => + set((state) => { + state.isDynamicNetworkSelect = isDynamic; + }), + resetStoredData: () => + set((state) => { + // Add stores that need global reset + state.account = { ...state.account, ...initAccountState }; + state.endpoints = { + ...state.endpoints, + ...initEndpointState, + }; + state.transaction = { + ...state.transaction, + ...initTransactionState, + }; + state.xdr = { + ...state.xdr, + ...initXdrState, + }; + }), + // Account + account: { + ...initAccountState, + updateGeneratedMuxedAccountInput: (value: Partial) => + set((state) => { + state.account.generatedMuxedAccountInput = { + ...state.account.generatedMuxedAccountInput, + ...value, + }; + }), + updateParsedMuxedAccountInput: (value: string) => + set((state) => { + state.account.parsedMuxedAccountInput = value; + }), + updateGeneratedMuxedAccount: (value: MuxedAccount) => + set((state) => { + state.account.generatedMuxedAccount = { + ...state.account.generatedMuxedAccount, + ...value, + }; + }), + updateParsedMuxedAccount: (value: MuxedAccount) => + set((state) => { + state.account.parsedMuxedAccount = { + ...state.account.parsedMuxedAccount, + ...value, + }; + }), + updateKeypair: (publicKey: string, secretKey?: string) => + set((state) => { + state.account.publicKey = publicKey; + state.account.secretKey = secretKey || ""; + }), + reset: () => + set((state) => { + state.account = { ...state.account, ...initAccountState }; + }), + }, + // Endpoints + endpoints: { + ...initEndpointState, + updateNetwork: (network: Network) => + set((state) => { + state.endpoints.network = network; + }), + updateCurrentEndpoint: (endpoint: string) => + set((state) => { + state.endpoints.currentEndpoint = endpoint; + }), + updateParams: (params: AnyObject) => + set((state) => { + state.endpoints.params = sanitizeObject({ + ...state.endpoints.params, + ...params, + }); + }), + updateSavedActiveTab: (tabId: string) => + set((state) => { + state.endpoints.saved.activeTab = tabId; + }), + setParams: (params: AnyObject) => + set((state) => { + state.endpoints.params = params; + }), + resetParams: () => + set((state) => { + state.endpoints.params = {}; + }), + reset: () => + set((state) => { + state.endpoints = { + ...state.endpoints, + ...initEndpointState, + }; + }), + }, + // Transaction + transaction: { + ...initTransactionState, + updateBuildActiveTab: (tabId: string) => + set((state) => { + state.transaction.build.activeTab = tabId; + }), + updateBuildParams: (params: TransactionBuildParamsObj) => + set((state) => { + state.transaction.build.params = { + ...state.transaction.build.params, + ...params, + }; + }), + updateBuildOperations: (operations) => + set((state) => { + state.transaction.build.operations = operations; + }), + updateBuildXdr: (xdr) => + set((state) => { + state.transaction.build.xdr = xdr; + }), + updateBuildSingleOperation: (index, operation) => + set((state) => { + state.transaction.build.operations[index] = operation; + }), + updateBuildIsValid: ({ + params, + operations, + }: { + params?: boolean; + operations?: boolean; + }) => + set((state) => { + if (params !== undefined) { + state.transaction.build.isValid.params = params; + } + if (operations !== undefined) { + state.transaction.build.isValid.operations = operations; + } + }), + setBuildParams: (params: TransactionBuildParamsObj) => + set((state) => { + state.transaction.build.params = { + ...initTransactionParamsState, + ...params, + }; + }), + resetBuildParams: () => + set((state) => { + state.transaction.build.params = initTransactionParamsState; + }), + resetBuild: () => + set((state) => { + state.transaction.build = initTransactionState.build; + }), + updateSignActiveView: (viewId: SignTxActiveView) => + set((state) => { + state.transaction.sign.activeView = viewId; + }), + updateSignImportTx: (tx: FeeBumpTransaction | Transaction) => + set((state) => { + state.transaction.sign.importTx = tx; + }), + updateSignImportXdr: (xdr: string) => + set((state) => { + state.transaction.sign.importXdr = xdr; + }), + updateSignedTx: (tx: string) => + set((state) => { + state.transaction.sign.signedTx = tx; + }), + updateBipPath: (bipPath: string) => + set((state) => { + state.transaction.sign.bipPath = bipPath; + }), + updateHardWalletSigs: (signer: xdr.DecoratedSignature[]) => + set((state) => { + state.transaction.sign.hardWalletSigs = signer; + }), + resetSign: () => + set((state) => { + state.transaction.sign = initTransactionState.sign; + }), + resetSignHardWalletSigs: () => + set((state) => { + state.transaction.sign.hardWalletSigs = + initTransactionState.sign.hardWalletSigs; + }), + updateSimulateInstructionLeeway: (instrLeeway?: string) => + set((state) => { + state.transaction.simulate.instructionLeeway = instrLeeway; + }), + updateSimulateTriggerOnLaunch: (trigger: boolean) => + set((state) => { + state.transaction.simulate.triggerOnLaunch = trigger; + }), + updateFeeBumpParams: (params: FeeBumpParamsObj) => + set((state) => { + state.transaction.feeBump = { + ...state.transaction.feeBump, + ...params, + }; + }), + resetBaseFee: () => + set((state) => { + state.transaction.feeBump = initTransactionState.feeBump; + }), + }, + xdr: { + ...initXdrState, + updateXdrBlob: (blob: string) => + set((state) => { + state.xdr.blob = blob; + }), + updateJsonString: (jsonString: string) => + set((state) => { + state.xdr.jsonString = jsonString; + }), + updateXdrType: (type: string) => + set((state) => { + state.xdr.type = type; + }), + resetXdr: () => + set((state) => { + state.xdr.blob = initXdrState.blob; + state.xdr.type = initXdrState.type; + }), + resetJsonString: () => + set((state) => { + state.xdr.jsonString = initXdrState.jsonString; + state.xdr.type = initXdrState.type; + }), + }, + })), + { + url: options.url, + // Select what to save in query string + select() { + return { + network: true, + account: false, + endpoints: { + params: true, + isStreaming: true, + saved: true, + }, + transaction: { + build: { + activeTab: true, + params: true, + operations: true, + isValid: true, + xdr: false, + }, + sign: { + activeView: true, + importXdr: true, + bipPath: true, + }, + simulate: true, + feeBump: true, + }, + xdr: { + blob: true, + jsonString: true, + type: true, + }, + }; + }, + }, + ), + ); diff --git a/src/store/useStore.ts b/src/store/useStore.ts new file mode 100644 index 00000000..4cdabda8 --- /dev/null +++ b/src/store/useStore.ts @@ -0,0 +1,13 @@ +"use client"; + +import { useContext } from "react"; +import { useStore as useZustandStore } from "zustand"; +import { Store } from "@/store/createStore"; +import { ZustandContext } from "@/store/StoreProvider"; + +export const useStore = (selector?: (state: Store) => T) => { + selector ??= (state) => state as T; + const store = useContext(ZustandContext); + if (!store) throw new Error("Store is missing the provider"); + return useZustandStore(store, selector); +}; diff --git a/src/styles/_AccountCreator.scss b/src/styles/_AccountCreator.scss deleted file mode 100644 index aecab3ec..00000000 --- a/src/styles/_AccountCreator.scss +++ /dev/null @@ -1,31 +0,0 @@ -.AccountCreator { -} - .AccountCreator__container { - max-width: 35em; - } - .AccountCreator__generator__table { - margin-top: 1em; - margin-bottom: 0.5em; - } - .AccountCreator__lead { - margin-top: 1em; - } - .AccountCreator__section { - padding-top: 2em; - padding-bottom: 2em; - } - .AccountCreator__separator { - border-bottom: 1px solid $gray; - } - .AccountCreator__friendbot__alert { - margin-top: 1em; - } - .AccountCreator__spaceTop { - margin-top: 1em; - } - .AccountCreator__label { - margin-bottom: 0.2em; - } - .AccountCreator__note--alert { - color: #d12; - } diff --git a/src/styles/_ClaimantPicker.scss b/src/styles/_ClaimantPicker.scss deleted file mode 100644 index 806e7088..00000000 --- a/src/styles/_ClaimantPicker.scss +++ /dev/null @@ -1,41 +0,0 @@ -.predicateTypeWrapper { - display: flex; - flex-wrap: wrap; - - .optionsTable__pair { - width: calc(100% - 2em); - } - - .predicateWrapper { - width: 50%; - - .optionsTable__pair { - display: block; - margin-top: 0; - margin-bottom: 0; - - .optionsTable__pair__title, - .optionsTable__pair__content { - max-width: 100%; - } - - .optionsTable__pair__title { - padding-bottom: 0; - } - } - } - - .predicateWrapper:nth-child(2) { - border-right: 1px solid $gray; - } - - .predicateTypeWrapper { - .predicateWrapper { - width: 100%; - border-right: none; - border-top: 1px solid $gray; - margin-top: 1em; - // margin: 1em 0.75em; - } - } -} diff --git a/src/styles/_CodeBlock.scss b/src/styles/_CodeBlock.scss deleted file mode 100644 index 2e6caf29..00000000 --- a/src/styles/_CodeBlock.scss +++ /dev/null @@ -1,6 +0,0 @@ -.CodeBlock { - background: $lightestGray; - // CodeBlocks don't have margin. users of CodeBlock must manage manually - margin: 0; - padding: .75em 1em; -} diff --git a/src/styles/_Collapsible.scss b/src/styles/_Collapsible.scss deleted file mode 100644 index 012ce65e..00000000 --- a/src/styles/_Collapsible.scss +++ /dev/null @@ -1,9 +0,0 @@ -.Collapsible { - max-height: 100vh; - overflow: hidden; - transition: max-height 0.4s; - - &.Collapsible__closed { - max-height: 0vh; - } -} diff --git a/src/styles/_EasySelect.scss b/src/styles/_EasySelect.scss deleted file mode 100644 index 0c12b795..00000000 --- a/src/styles/_EasySelect.scss +++ /dev/null @@ -1,7 +0,0 @@ -.EasySelect { - cursor: pointer; - border-bottom: 1px dotted currentColor; -} -.EasySelect__plain { - border-bottom: 0; -} diff --git a/src/styles/_EndpointExplorer.scss b/src/styles/_EndpointExplorer.scss deleted file mode 100644 index 09b10e46..00000000 --- a/src/styles/_EndpointExplorer.scss +++ /dev/null @@ -1,14 +0,0 @@ -.EndpointExplorer { - margin-top: 2em; -} -.EndpointExplorer__picker { - margin-bottom: 2em; -} - -.EndpointExplorer__setup { - margin-bottom: 2em; -} - -.EndpointExplorer__result { - margin-bottom: 4em; -} diff --git a/src/styles/_EndpointPicker.scss b/src/styles/_EndpointPicker.scss deleted file mode 100644 index a979a887..00000000 --- a/src/styles/_EndpointPicker.scss +++ /dev/null @@ -1,24 +0,0 @@ -.EndpointPicker__section { - margin-bottom: 2em; -} -.EndpointPicker__section:last-child { - margin-bottom: 0; -} -.EndpointPicker__section__title { - font-size: $s-scale-3; - margin: 0 0.857em .25em 0.857em; -} -@include r-media(m) { - .EndpointPicker { - @include S-flex-row; - } - .EndpointPicker__section { - @include S-flexItem-noFlex; - margin-right: 2em; - margin-bottom: 0; - } - .EndpointPicker__section:last-child { - margin-right: 0; - margin-bottom: 0; - } -} diff --git a/src/styles/_EndpointResult.scss b/src/styles/_EndpointResult.scss deleted file mode 100644 index 8995dfc4..00000000 --- a/src/styles/_EndpointResult.scss +++ /dev/null @@ -1,67 +0,0 @@ -.EndpointResult { - -} - -.EndpointResult__loading, -.EndpointResult__error, -.EndpointResult__content { - padding: 1em; -} - -.EndpointResult__loading { - border: 1px solid $gray; - border-radius: $s-var-radius; -} - -.EndpointResult__error { - border: 1px solid $s-color-alert; - border-radius: $s-var-radius; -} - -.EndpointResult__tabs { - @include S-flex-row; - border: 1px solid $gray; - padding: 0.5em 1em 0 1em; - background: $lightestGray; -} -.EndpointResult__tabs:first-child { - border-radius: $s-var-radius $s-var-radius 0 0; -} -.EndpointResult__tabs__tab { - position: relative; - margin-right: 1em; - border: 1px solid transparent; - border-bottom: 0; - padding: $so-inputPadding; - background: transparent; - border-radius: $s-var-radius $s-var-radius 0 0; -} -.EndpointResult__tabs__tab:hover { - border: 1px solid $s-color-primary6; - border-bottom: 0; - background: $s-color-primary9; -} -.EndpointResult__tabs__tab.is-current { - border: 1px solid $gray; - border-bottom: 0; - background: $s-color-neutral9; -} -// removes the border under the tab -// feel free to reconsider whether this vs negative margins is a better approach -.EndpointResult__tabs__tab.is-current:after { - content: ''; - display: block; - height: 1px; - background: $s-color-neutral9; - position: absolute; - bottom: -1px; - left: 0; - right: 0; -} - -.EndpointResult__content { - border: 1px solid $gray; - border-top: 0; - border-radius: 0 0 $s-var-radius $s-var-radius; - padding: 1em; -} diff --git a/src/styles/_EndpointSetup.scss b/src/styles/_EndpointSetup.scss deleted file mode 100644 index 7fefc277..00000000 --- a/src/styles/_EndpointSetup.scss +++ /dev/null @@ -1,23 +0,0 @@ -.EndpointSetup__url { - word-break: break-all; -} - .EndpointSetup__url__method { - display: inline-block; - padding: 0.25em 0.5em; - margin-right: 0.5em; - - background: $s-color-neutral8; - border-radius: $s-var-radius; - } - -.EndpointSetup__title { - font-size: $s-scale-3; - margin: 0 0.857em .25em 0.857em; -} - .EndpointSetup__streaming__checkbox { - cursor: pointer; - margin-right: 0.75em; - } - .EndpointSetup__streaming__title { - cursor: pointer; - } diff --git a/src/styles/_HelpMark.scss b/src/styles/_HelpMark.scss deleted file mode 100644 index 46d43e0d..00000000 --- a/src/styles/_HelpMark.scss +++ /dev/null @@ -1,15 +0,0 @@ -.HelpMark { - display: inline-block; - height: 1.25em; - width: 1.25em; - vertical-align: middle; -} -.HelpMark__circle { - fill: $s-color-neutral6; -} -.HelpMark__questionMark { - fill: $s-color-neutral9; -} -.HelpMark:hover .HelpMark__circle { - fill: $purple; -} diff --git a/src/styles/_Introduction.scss b/src/styles/_Introduction.scss deleted file mode 100644 index c1799788..00000000 --- a/src/styles/_Introduction.scss +++ /dev/null @@ -1,10 +0,0 @@ -.Introduction { - margin-top: 2em; - margin-bottom: 2em; -} - .Introduction__container { - max-width: 35em; - } - .Introduction__lead { - margin-top: 1em; - } \ No newline at end of file diff --git a/src/styles/_LaboratoryChrome.scss b/src/styles/_LaboratoryChrome.scss deleted file mode 100644 index 6a133d40..00000000 --- a/src/styles/_LaboratoryChrome.scss +++ /dev/null @@ -1,43 +0,0 @@ -/** - * @prettier - */ -.LaboratoryChrome__header { - justify-content: space-between; -} - -.LaboratoryChrome__siteNavBack { - padding-top: 1.5em; - padding-bottom: 1.5em; - background: $lightestGray; -} - -.LaboratoryChrome__network_reset_alert { - background-color: $black; - color: $white; - border-radius: 0; - border-bottom: 1px solid $white; - margin-bottom: -1px; -} - -.LaboratoryChrome__soroban_alert { - background-color: $purple; - color: $white; - border-radius: 0; - border-bottom: 1px solid $white; - margin-bottom: -1px; -} - -.spacer { - display: inline-block; - width: 2rem; - height: 1px; -} - -.LaboratoryChrome__terms { - padding: 4rem 0; - - a { - text-decoration: none; - color: $s-color-neutral3; - } -} diff --git a/src/styles/_ManualMultiPicker.scss b/src/styles/_ManualMultiPicker.scss deleted file mode 100644 index f569317e..00000000 --- a/src/styles/_ManualMultiPicker.scss +++ /dev/null @@ -1,29 +0,0 @@ -.ManualMultiPicker { -} - .ManualMultiPicker__item { - position: relative; - padding: 0 0.75em 0.75em 0.75em; - border-top: 1px solid $s-color-neutral7; - border-left: 1px solid $s-color-neutral7; - border-right: 1px solid $s-color-neutral7; - } - .ManualMultiPicker__item:first-child { - border-radius: $s-var-radius $s-var-radius 0 0; - } - .ManualMultiPicker__item--last { - border-bottom: 1px solid $s-color-neutral7; - border-radius: 0 0 $s-var-radius $s-var-radius; - } - .ManualMultiPicker__item__infobar { - @include S-flex-row; - padding: 0.5em 0; - justify-content: space-between; - align-items: center; - } - .ManualMultiPicker__item__remove { - font-size: $s-scale-5; - } - .ManualMultiPicker__addNew { - margin-top: 0.75em; - font-size: $s-scale-5; - } diff --git a/src/styles/_MultiPicker.scss b/src/styles/_MultiPicker.scss deleted file mode 100644 index a823188d..00000000 --- a/src/styles/_MultiPicker.scss +++ /dev/null @@ -1,5 +0,0 @@ -.MultiPicker__container { - display: flex; - justify-content: space-between; - align-items: flex-start; -} diff --git a/src/styles/_NetworkPicker.scss b/src/styles/_NetworkPicker.scss deleted file mode 100644 index 85eedbca..00000000 --- a/src/styles/_NetworkPicker.scss +++ /dev/null @@ -1,89 +0,0 @@ -.NetworkPicker { - position: relative; - align-self: flex-start; -} -.NetworkPicker__buttonGroup { - // justify-content: flex-end; -} -.NetworkPicker__button { - font-size: $s-scale-5; - padding: 0.2em 1.5em; -} -.NetworkPicker__url { - position: absolute; - bottom: -26px; - right: 0; - white-space: nowrap; - font-size: $s-scale-5; - color: $s-color-neutral3; -} - -.NetworkPicker .overlay { - position: fixed; - z-index: 100; - left: 0; - top: 0; - width: 100%; - height: 100%; - overflow: auto; - -webkit-animation: fadein 0.4s; - -moz-animation: fadein 0.4s; - -ms-animation: fadein 0.4s; - -o-animation: fadein 0.4s; - animation: fadein 0.4s; - - &.visible { - display: block; - } -} - -@keyframes fadein { - from { opacity: 0; } - to { opacity: 1; } -} - -@-moz-keyframes fadein { - from { opacity: 0; } - to { opacity: 1; } -} - -@-webkit-keyframes fadein { - from { opacity: 0; } - to { opacity: 1; } -} - -@-ms-keyframes fadein { - from { opacity: 0; } - to { opacity: 1; } -} - -@-o-keyframes fadein { - from { opacity: 0; } - to { opacity: 1; } -} - -.NetworkPicker .overlay .modal { - font-weight: 300; - margin: 10% auto; - padding: 20px; - width: 470px; - background-color: white; - color: #586A73; - box-shadow: 0 0 80px #dddddd; - border-radius: .5rem; - - .right { - float: right; - } - - p, button { - margin-top: 1em; - } - - a.close { - color: #000000; - font-size: 25px; - line-height: 20px; - text-decoration: none; - } -} diff --git a/src/styles/_PubKeyPicker.scss b/src/styles/_PubKeyPicker.scss deleted file mode 100644 index a907ff1c..00000000 --- a/src/styles/_PubKeyPicker.scss +++ /dev/null @@ -1,19 +0,0 @@ -/** @format */ -.PubKeyPicker { - position: relative; - - &__activator { - position: absolute; - right: 0; - top: 0; - padding: 0.425em 0.1em; - - svg { - display: block; - } - - path { - fill: #7d00ff; - } - } -} diff --git a/src/styles/_Reskin.scss b/src/styles/_Reskin.scss deleted file mode 100644 index 811859a4..00000000 --- a/src/styles/_Reskin.scss +++ /dev/null @@ -1,142 +0,0 @@ -@font-face { - font-display: block; - font-family: suisse; - src: - url('../assets/suisseintl-regular-webfont.woff') format("woff"), - url('../assets/suisseintl-regular-webfont.woff2') format("woff2"); - font-weight: 400; -} -@font-face { - font-display: block; - font-family: suisse; - src: - url('../assets/suisseintl-semibold-webfont.woff') format("woff"), - url('../assets/suisseintl-semibold-webfont.woff2') format("woff2"); - font-weight: 500; -} - -@font-face { - font-display: swap; - font-family: suisse-mono; - src: - url('../assets/suisseintlmono-regular-webfont.woff') format("woff"), - url('../assets/suisseintlmono-regular-webfont.woff') format("woff2"); - font-weight: 400; -} - -html { - color: #4a4a49; - font-size: 16px; -} -body { - font-family: 'suisse', sans-serif; -} -code, kbd, pre, samp { - font-family: 'suisse-mono', monospace; -} - -.so-logo { - align-items: center; -} -.so-logo__main { - margin: -12px 0 -7px; - line-height: 0; -} -.so-logo__separator { - height: 1em; - border-color: $gray; -} -.so-back { - padding-bottom: 1rem; -} -input, textarea, select, .so-dropdown__select { - border-color: $gray; -} - -.so-dropdown__select { - option { - color: #3a3f43; - } -} - -.buttonList__item.buttonList__item { - background-color: transparent; - border-color: transparent; - - &:hover { - border-color: #AAAAAA; - } -} - -.s-buttonGroup > { - .s-button:not(:last-child):not(:first-child), - .s-buttonGroup__wrapper:not(:last-child):not(:first-child) .s-button { - border-radius: 0; - } - - .s-buttonGroup__wrapper:first-of-type .s-button { - border-top-right-radius: 0; - border-bottom-right-radius: 0; - } - - .s-buttonGroup__wrapper:last-of-type .s-button { - border-top-left-radius: 0; - border-bottom-left-radius: 0; - } -} - -.s-button--light.is-active, -.s-button__light.is-active, -:checked+.s-button--light, -:checked+.s-button__light { - background: $purple; - border: 1px solid $purple; - color: white; -} -.s-button { - background: $purple; - border: 1px solid $purple; -} -.s-button__light, .s-button--light { - background: $white; - border-color: $gray; -} -.s-button__icon { - background: none; - border: none; -} -.s-button.is-disabled, .s-button:disabled{ - background: $gray; - border-color: $gray; -} -.s-button:not(.buttonList__item) { - border-radius: 4rem; - - &:not([disabled]) { - - :checked + & { - border-color: $purple; - } - - :not(:checked) + &.s-button--light { - &:active { - background-color: $lightPurple; - border-color: $lightPurple; - } - } - - &:hover { - background-color: #6400CC; - border-color: #6400CC; - color: $white; - } - } -} -.is-active.is-active { - border-color: #CCCCCC; -} - -.s-alert--info { - background-color: $lightPurple; - border-color: $purple; -} diff --git a/src/styles/_ReskinColors.scss b/src/styles/_ReskinColors.scss deleted file mode 100644 index b247b552..00000000 --- a/src/styles/_ReskinColors.scss +++ /dev/null @@ -1,6 +0,0 @@ -$black: #1E1E1E; -$lightestGray: #FAFAFA; -$gray: #CCCCCC; -$white: #FFFFFF; -$purple: #7D00FF; -$lightPurple: rgba(125, 0, 255, 0.32); diff --git a/src/styles/_SimplePage.scss b/src/styles/_SimplePage.scss deleted file mode 100644 index 1ce521fe..00000000 --- a/src/styles/_SimplePage.scss +++ /dev/null @@ -1,4 +0,0 @@ -.SimplePage__back { - padding-top: 2em; - padding-bottom: 2em; -} diff --git a/src/styles/_TransactionBuilder.scss b/src/styles/_TransactionBuilder.scss deleted file mode 100644 index ccfd1f33..00000000 --- a/src/styles/_TransactionBuilder.scss +++ /dev/null @@ -1,110 +0,0 @@ -.TransactionBuilder { - padding-bottom: 4em; -} -.TransactionBuilder__clearBar { - margin-bottom: 0.5em; -} -@include r-media(l) { - .TransactionBuilder__clearBar { - text-align: right; - } -} - -.TransactionBuilder__result { - padding-top: 2em; - padding-bottom: 2em; - border-top: 1px solid $s-color-neutral7; - border-bottom: 1px solid $s-color-neutral7; - - background: $s-color-neutral8; -} -.TransactionBuilder__result :last-child { - margin-bottom: 0; -} - -.TransactionAttributes { - margin-bottom: 1.5em; -} - -.TransactionOp { - @include S-flex-row; - margin-bottom: 1.5em; -} -.TransactionOp__meta { - @include S-flexItem-noFlex; -} -.TransactionOp__config { - @include S-flexItem-share; -} - -.TransactionOpMeta { - width: 108px; - text-align: center; -} -.TransactionOpMeta__order { - padding-bottom: 0.5em; -} -.TransactionOpMeta__order__input { - height: 72px; - width: 72px; - padding-left: 0; - padding-right: 0; - text-align: center; - font-size: $s-scale-a; -} -.TransactionOpMeta__tally__button { - text-align: center; - width: 72px; - padding: 0.35em 0; - font-size: $s-scale-down1; - margin: 0.25em 0; -} -.TransactionOperations__add { - width: 100%; - padding-left: 108px; - margin-bottom: 1.5em; -} -.TransactionOperations__add__button { - width: 100%; - font-size: $s-scale-3; - padding-top: 0.5em; - padding-bottom: 0.5em; - text-align: center; -} - -.TransactionBuilderResult__code { - margin-top: 0.5em; - margin-bottom: 1.5em; - background: $s-color-neutral9; - cursor: pointer; - word-wrap: break-word; -} -.TransactionBuilderResult__success { - color: $s-color-success; -} -.TransactionBuilderResult__instructions { - margin-bottom: 1em; -} - -.NumberFractionPicker__fraction { - display: flex; - align-items: center; - gap: 0.5em; - - & > div { - flex: 1; - } -} - -.LiquidityPoolAssetPicker { - margin-top: 0.5em; -} - -.LiquidityPoolAssetPicker__item { - margin-bottom: 1em; - padding-left: 1em; -} - -.LiquidityPoolAssetPicker__label { - margin-bottom: 0.25em; -} diff --git a/src/styles/_TransactionSigner.scss b/src/styles/_TransactionSigner.scss deleted file mode 100644 index 9754f68d..00000000 --- a/src/styles/_TransactionSigner.scss +++ /dev/null @@ -1,27 +0,0 @@ -.TransactionSigner { -} - .TransactionSigner__import { - margin-bottom: 2em; - } - .TransactionSigner__overview { - margin-bottom: 2em; - } - .TransactionSigner__keys { - margin-bottom: 2em; - } - .TransactionSigner__result { - margin-bottom: 2em; - } - .TransactionSigner__result :last-child { - margin-bottom: 0; - } - - .TransactionSigner__details { - margin-bottom: 2em; - } - .TransactionSigner__details__title { - font-size: $s-scale-3; - margin-bottom: 0.5em; - } - .TransactionSigner__details__tree { - } diff --git a/src/styles/_TreeView.scss b/src/styles/_TreeView.scss deleted file mode 100644 index e01b3238..00000000 --- a/src/styles/_TreeView.scss +++ /dev/null @@ -1,18 +0,0 @@ -.TreeView { - -} - .TreeView__child { - border-left: 1em solid #F2F2F2; - } - .TreeView__child:hover { - border-left-color: $lightPurple; - } - .TreeView__row { - padding: 0.15em 0.5em; - } - .TreeView__row:hover { - background: $s-color-neutral8; - } - .TreeView__row span { - word-break: break-all - } diff --git a/src/styles/_TxFreighterSign.scss b/src/styles/_TxFreighterSign.scss deleted file mode 100644 index e02df35b..00000000 --- a/src/styles/_TxFreighterSign.scss +++ /dev/null @@ -1,23 +0,0 @@ -.TxLyraSign__result { - padding: 15px 0; - - .CodeBlock { - background: $white; - } - .CodeBlock__code, code { - padding: 0; - } - .token.string { - white-space: break-spaces; - word-break: break-all; - } -} - -.TxLyraSign__result-error { - display: inline-block; - padding-left: 10px; - - code { - color: red; - } -} diff --git a/src/styles/_TxSignerImport.scss b/src/styles/_TxSignerImport.scss deleted file mode 100644 index 8b5721a1..00000000 --- a/src/styles/_TxSignerImport.scss +++ /dev/null @@ -1,10 +0,0 @@ -.TxSignerImport { - -} - .TxSignerImport__title { - font-size: $s-scale-3; - margin-bottom: 0.5em; - } - .TxSignerImport__error { - color: red; - } diff --git a/src/styles/_TxSignerKeys.scss b/src/styles/_TxSignerKeys.scss deleted file mode 100644 index e9b0cd1a..00000000 --- a/src/styles/_TxSignerKeys.scss +++ /dev/null @@ -1,14 +0,0 @@ -.TxSignerKeys__title { - font-size: $s-scale-3; - margin-bottom: 0.5em; -} - -.TxSignerKeys__signBipPath { - margin-top: 0.5em; - - button { - &:not(:last-child) { - margin-right: 0.5em; - } - } -} diff --git a/src/styles/_TxSignerOverview.scss b/src/styles/_TxSignerOverview.scss deleted file mode 100644 index 7c5809f9..00000000 --- a/src/styles/_TxSignerOverview.scss +++ /dev/null @@ -1,22 +0,0 @@ -.TxSignerOverview { - -} - .TxSignerOverview__titleBar { - margin-bottom: 0.5em; - } - .TxSignerOverview__titleBar__title { - font-size: $s-scale-3; - margin-bottom: 0.5em; - } - @include r-media(l) { - .TxSignerOverview__titleBar { - @include S-flex-row; - } - .TxSignerOverview__titleBar__title { - @include S-flexItem-share; - margin-bottom: 0; - } - .TxSignerOverview__titleBar__reset { - @include S-flexItem-noFlex; - } - } diff --git a/src/styles/_TxSignerResult.scss b/src/styles/_TxSignerResult.scss deleted file mode 100644 index 7a0fa00b..00000000 --- a/src/styles/_TxSignerResult.scss +++ /dev/null @@ -1,19 +0,0 @@ -.TxSignerResult { - padding-top: 2em; - padding-bottom: 2em; - border-top: 1px solid $s-color-neutral7; - border-bottom: 1px solid $s-color-neutral7; - - background: $s-color-neutral8; -} - .TxSignerResult__title { - color: $s-color-success; - } - .TxSignerResult__xdr { - cursor: pointer; - margin-bottom: 1.5em; - background: $s-color-neutral9; - } - .TxSignerResult__submit { - margin-top: 1em; - } diff --git a/src/styles/_XdrViewer.scss b/src/styles/_XdrViewer.scss deleted file mode 100644 index 5b9b79a9..00000000 --- a/src/styles/_XdrViewer.scss +++ /dev/null @@ -1,35 +0,0 @@ -.XdrViewer__results { - padding-top: 2em; -} -.XdrViewer__type.so-back { - border-bottom: 1px solid $gray; - padding-bottom: 2em; -} -.XdrViewer__label { - margin-bottom: 0.2em; -} - -.TransactionSubmitter { - margin: 0.75em 0; - max-width: 100%; - - .ResultTitle__success { - color: $s-color-success; - } - .ResultTitle__failure { - color: $s-color-alert; - } - - .TransactionSubmitter__result { - padding-top: 2em; - padding-bottom: 2em; - border-top: 1px solid $s-color-neutral7; - border-bottom: 1px solid $s-color-neutral7; - background: $s-color-neutral8; - } - - .TransactionSubmitter__code { - background: $s-color-neutral9; - word-wrap: break-word; - } -} diff --git a/src/styles/_optionsTable.scss b/src/styles/_optionsTable.scss deleted file mode 100644 index 9057383e..00000000 --- a/src/styles/_optionsTable.scss +++ /dev/null @@ -1,54 +0,0 @@ -.optionsTable { - border: 1px solid $gray; - border-radius: $s-var-radius; -} - .optionsTable__pair, .optionsTable__separator, .optionsTable__blank { - width: auto; - } - .optionsTable__separator, .optionsTable__blank { - @include S-flexItem-full; - } - .optionsTable__pair { - border-radius: $s-var-radius; - @include S-flex-row; - margin: 0.75em 1em; - background: $lightestGray; - border: 1px solid transparent; - } - .optionsTable__pair__title { - min-width: 8em; - max-width: 12em; - @include S-flexItem-1of4; - padding: 1.1em 1em 1em 1em; - } - .optionsTable__pair__title__optional { - font-size: $s-scale-5; - color: $s-color-neutral4; - } - .optionsTable__pair__content { - @include S-flexItem-share; - padding: 0.75em 1em; - } - .optionsTable__pair__content__note { - font-size: $s-scale-5; - margin: 0.75em 0 0 0; - color: $s-color-neutral3; - } - .optionsTable__pair__content__note--alert { - color: $s-color-alert; - } - .optionsTable__pair__content__field { - margin-bottom: 0.5em; - } - .optionsTable__pair__content__field:last-of-type { - margin-bottom: 0; - } - .optionsTable__blank { - padding: 0.75em 1em; - } - .optionsTable__separator { - height: 1px; - margin: 0; - border: 0; - background: $gray; - } diff --git a/src/styles/_pageIntro.scss b/src/styles/_pageIntro.scss deleted file mode 100644 index 0f4ddde5..00000000 --- a/src/styles/_pageIntro.scss +++ /dev/null @@ -1,11 +0,0 @@ -.pageIntro { - margin-top: 2em; - margin-bottom: 2em; - padding: 1em; - - background: $lightestGray; - border-radius: $s-var-radius; -} - .pageIntro :last-child { - margin-bottom: 0; - } diff --git a/src/styles/_picker.scss b/src/styles/_picker.scss deleted file mode 100644 index 285d006c..00000000 --- a/src/styles/_picker.scss +++ /dev/null @@ -1,26 +0,0 @@ -.picker { - -} - .picker--textInput { - width: 100%; - } - .picker--textarea { - display: block; - width: 100%; - max-width: 100%; - min-height: 10em; - } - .picker--breakContent { - word-break: break-all; - } - - // Useful to add some margin to the bottom when there is another picker - // directly below - .picker--spaceBottom { - margin-bottom: 0.5em; - } - - .picker__errorMessage { - margin: 0.35em 0 0.65em 0; - color: $s-color-alert; - } diff --git a/src/styles/_simpleTable.scss b/src/styles/_simpleTable.scss deleted file mode 100644 index 83147341..00000000 --- a/src/styles/_simpleTable.scss +++ /dev/null @@ -1,41 +0,0 @@ -// In narrow viewports, this is just a sequence of divs that take up the whole row -// In large viewports, this is a table -.simpleTable { - border: 1px solid $s-color-neutral6; - border-radius: $s-var-radius; -} - .simpleTable__row:last-child .simpleTable__row__label, - .simpleTable__row:last-child .simpleTable__row__content { - border-bottom: 0; - } - .simpleTable__row__label { - padding: 0.75em 1em 0 1em; - font-weight: bold; - } - .simpleTable__row__content { - padding: 0.75em 1em; - border-bottom: 1px solid $s-color-neutral6; - word-break: break-all; - } - -@include r-media(l) { -.simpleTable { - display: table; - width: 100%; - table-layout:fixed; -} - .simpleTable__row { - display: table-row; - } - .simpleTable__row__label, .simpleTable__row__content { - display: table-cell; - } - .simpleTable__row__label { - width: 25%; - padding: 0.75em 1em; - border-bottom: 1px solid $s-color-neutral6; - } - .simpleTable__row__content { - width: 75%; - } -} diff --git a/src/styles/_xdrInput.scss b/src/styles/_xdrInput.scss deleted file mode 100644 index d3ced3c3..00000000 --- a/src/styles/_xdrInput.scss +++ /dev/null @@ -1,28 +0,0 @@ -.xdrInput { - margin-bottom: 2em; -} - .xdrInput__input { - } - .xdrInput__input__textarea { - display: block; - min-width: 4em; - width: 36em; - max-width: 100%; - min-height: 12em; - margin-bottom: 0; - } - - .xdrInput__message { - @include S-flex-row; - align-items: center; - min-height: 2em; - padding: 0.25em 0.25em; - } - .xdrInput__message__alert { - color: $s-color-alert; - margin-bottom: 0; - } - .xdrInput__message__success { - color: $s-color-success; - margin-bottom: 0; - } diff --git a/src/styles/globals.scss b/src/styles/globals.scss new file mode 100644 index 00000000..10c3e959 --- /dev/null +++ b/src/styles/globals.scss @@ -0,0 +1,627 @@ +@use "./utils.scss" as *; + +// Fonts for SDS +@import url("https://fonts.googleapis.com/css2?family=Inter+Tight&family=Inter:wght@400;500;600&family=Roboto+Mono&display=swap"); + +// TODO: move to SDS when ready +:root { + --sds-gap-xs: #{pxToRem(4px)}; + --sds-gap-sm: #{pxToRem(8px)}; + --sds-gap-md: #{pxToRem(12px)}; + --sds-gap-lg: #{pxToRem(16px)}; + --sds-gap-xl: #{pxToRem(24px)}; + --sds-gap-xxl: #{pxToRem(32px)}; +} + +// Layout +#root { + min-width: auto !important; + min-height: auto !important; + display: block !important; +} + +.LabLayout { + display: grid; + grid-template-columns: 1fr; + grid-template-rows: auto 1fr; + height: 100vh; + overflow: hidden; + min-width: 0; + min-height: 0; + color: var(--sds-clr-gray-11); + background-color: var(--sds-clr-gray-02); + + // =========================================================================== + // Generic + // =========================================================================== + + .Heading, + h1, + h2, + h3, + h4, + h5, + h6 { + color: var(--sds-clr-gray-12); + } + + .success-message { + color: var(--sds-clr-green-11) !important; + } + + // SDS logos have hard coded fill colors, adjusting that here for GitHub icon + .Link--withLogo { + svg { + stroke: transparent; + + g > path { + fill: currentColor; + } + } + } + + // =========================================================================== + // Layout + // =========================================================================== + + // Header + &__header { + display: grid; + background-color: var(--sds-clr-gray-01); + border-bottom: 1px solid var(--sds-clr-gray-06); + + &__main { + display: flex; + align-items: center; + justify-content: space-between; + gap: pxToRem(24px); + padding: pxToRem(8px) pxToRem(32px); + } + + &__settings { + display: flex; + align-items: center; + justify-content: flex-end; + flex: 1; + gap: pxToRem(12px); + } + + &__nav { + display: flex; + align-items: center; + justify-content: space-between; + gap: pxToRem(16px); + + font-size: pxToRem(14px); + line-height: pxToRem(20px); + font-weight: var(--sds-fw-medium); + margin-bottom: -1px; + + & > div { + display: flex; + gap: pxToRem(16px); + flex: 1; + } + + &--secondary { + justify-content: flex-end; + } + } + } + + // Sidebar layout + &__withSidebar { + display: grid; + grid-template-columns: + pxToRem(296px) + 1fr; + overflow: hidden; + } + + // Content + &__container { + padding: pxToRem(32px); + overflow-x: auto; + } + + &__content { + width: clamp(pxToRem(672px), 100%, pxToRem(960px)); + position: relative; + margin: 0 auto; + display: flex; + flex-direction: column; + gap: pxToRem(12px); + min-height: 100%; + } + + // Sideber + &__sidebar { + min-height: 0; + background-color: var(--sds-clr-gray-01); + border-right: 1px solid var(--sds-clr-gray-06); + display: grid; + grid-template-columns: 1fr; + grid-template-rows: 1fr; + + &--top { + overflow-x: auto; + padding: pxToRem(32px); + padding-bottom: pxToRem(16px); + display: flex; + flex-direction: column; + gap: pxToRem(12px); + } + + &__section { + display: flex; + flex-direction: column; + gap: pxToRem(8px); + + &--divider { + border-bottom: 1px solid var(--sds-clr-gray-06); + padding-bottom: pxToRem(16px); + } + } + + &--bottom { + border-top: 1px solid var(--sds-clr-gray-06); + background-color: var(--sds-clr-gray-01); + display: flex; + flex-direction: column; + justify-content: space-between; + + padding-top: pxToRem(16px); + padding-bottom: pxToRem(16px); + padding-left: pxToRem(32px); + padding-right: pxToRem(32px); + + .SidebarLink { + justify-content: flex-start; + } + } + + &__wrapper { + display: flex; + flex-direction: column; + gap: pxToRem(8px); + } + } +} + +.NavLink { + --Nav-navLink-color: var(--sds-clr-gray-11); + + color: var(--Nav-navLink-color); + text-decoration: none; + padding: pxToRem(12px) 0; + transition: + color var(--sds-anim-transition-default), + border-color var(--sds-anim-transition-default); + white-space: nowrap; + + display: flex; + align-items: center; + gap: pxToRem(4px); + + @media (hover: hover) { + &:hover { + --Nav-navLink-color: var(--sds-clr-lilac-11); + } + } + + &--active { + cursor: default; + --Nav-navLink-color: var(--sds-clr-lilac-11); + pointer-events: none; + } + + &__icon { + display: flex; + + // to fix Safari only styling bug + width: pxToRem(14px); + height: pxToRem(14px); + } +} + +.SidebarLink { + --SidebarLink-color: var(--sds-clr-gray-11); + justify-content: space-between; + + font-size: pxToRem(14px); + line-height: pxToRem(20px); + font-weight: var(--sds-fw-medium); + color: var(--SidebarLink-color); + transition: + color var(--sds-anim-transition-default), + font-weight var(--sds-anim-transition-default); + text-decoration: none; + display: flex; + align-items: center; + gap: pxToRem(4px); + + svg { + display: block; + width: pxToRem(16px); + height: pxToRem(16px); + stroke: var(--SidebarLink-color); + } + + @media (hover: hover) { + &:hover { + --SidebarLink-color: var(--sds-clr-lilac-11); + font-weight: var(--sds-fw-semi-bold); + } + } + + &[data-is-active="true"] { + --SidebarLink-color: var(--sds-clr-lilac-11); + cursor: default; + font-weight: var(--sds-fw-semi-bold); + pointer-events: none; + position: relative; + } + + &__toggle { + --SidebarLink-rotate: 0; + cursor: pointer; + + svg { + transition: transform var(--sds-anim-transition-default); + transform: rotate(var(--SidebarLink-rotate)); + } + + // Highlight if nested link is selected + &:has( + ~ .SidebarLink__nestedItemsWrapper + > .SidebarLink__nestedItems + > [data-is-active="true"] + ) { + --SidebarLink-color: var(--sds-clr-gray-12); + font-weight: var(--sds-fw-semi-bold); + } + + // Rotate chevron when expanded + &:has(~ [data-is-expanded="true"]) { + --SidebarLink-rotate: 90deg; + } + + &[data-is-expanded="true"] { + margin-bottom: pxToRem(12px); + } + } + + &--nested, + &__nestedItems { + display: flex; + flex-direction: column; + + .SidebarLink__nestedItemsWrapper { + margin-left: pxToRem(8px); + } + } + + &--nested { + &:has(> [data-is-expanded="true"]) { + gap: pxToRem(12px); + } + } + + &__nestedItems { + overflow: hidden; + gap: pxToRem(12px); + } + + &__nestedItemsWrapper { + display: grid; + grid-template-rows: 0fr; + transition: + grid-template-rows 100ms ease-out, + margin-top 100ms ease-out; + margin-left: pxToRem(16px); + + &[data-is-expanded="true"] { + grid-template-rows: 1fr; + margin-top: pxToRem(0); + } + } +} + +// ============================================================================= +// Pages +// ============================================================================= + +.PageHeader, +.PageFooter { + display: flex; + align-items: center; + justify-content: space-between; + gap: pxToRem(16px); +} + +.PageHeader { + .Link { + --Link-icon-size: pxToRem(14px); + font-size: pxToRem(14px); + font-weight: var(--sds-fw-semi-bold); + + // to fix Safari only styling bug + .Link__icon { + width: pxToRem(14px); + height: pxToRem(14px); + } + } +} + +.PageBody { + display: flex; + flex-direction: column; + gap: pxToRem(16px); + + &__title { + display: flex; + align-items: center; + gap: pxToRem(4px); + + &__icon { + display: block; + width: pxToRem(14px); + height: pxToRem(14px); + + svg { + display: block; + width: 100%; + height: 100%; + stroke: var(--sds-clr-red-09); + } + } + } + + &__content { + display: flex; + flex-direction: column; + gap: pxToRem(16px); + padding: pxToRem(16px); + background-color: var(--sds-clr-gray-03); + border-radius: pxToRem(8px); + + &--error { + border: 1px solid var(--sds-clr-red-06); + } + } + + &__scrollable { + max-width: 100%; + max-height: pxToRem(600px); + overflow: auto; + } +} + +// Maintenance Banner +.MaintenanceBanner { + .Banner__message { + max-width: 100%; + } + + .Banner--primary .Banner__content a { + color: var(--sds-clr-lilac-11); + text-decoration: none; + transition: color var(--sds-anim-transition-default); + + @media (hover: hover) { + &:hover { + color: var(--sds-clr-lilac-12); + } + } + } +} + +// Introduction +.CardText { + display: flex; + flex-direction: column; + gap: pxToRem(12px); + + p { + margin-bottom: 0 !important; + } +} + +.IntroFooter { + flex: 1; + display: flex; + align-items: flex-end; + justify-content: space-between; + gap: pxToRem(12px); + font-size: pxToRem(14px); + line-height: pxToRem(20px); +} + +// Endpoints +.Endpoints { + &__urlBar { + display: flex; + align-items: center; + justify-content: space-between; + gap: pxToRem(8px); + + &__requestMethod { + color: var(--sds-clr-teal-11) !important; + } + } + + &__content { + display: flex; + flex-direction: column; + gap: pxToRem(12px); + } + + .Input--disabled { + input:read-only { + cursor: default; + } + } + + &__txTextarea { + .Textarea textarea { + word-break: break-all; + } + } +} + +// Saved Transactions +.SavedTransactions { + &__name { + &__postMethod { + color: var(--sds-clr-gold-11) !important; + } + } +} + +// Operations +.NumberFractionPicker__fraction__divider { + padding-top: pxToRem(22px); + color: var(--sds-clr-gray-09); +} + +// Create claimable balance +.PredicateTypeWrapper { + .PredicateWrapper { + &__split { + display: grid; + grid-template-columns: 49% 49%; + gap: 2%; + overflow: hidden; + + .PredicateWrapper__split { + display: flex; + gap: 0.5rem; + + & > :nth-child(2) { + border-top: 1px solid var(--sds-clr-gray-06); + padding-top: 0.5rem; + } + } + } + } +} + +// Sign Transaction +.SignTx { + display: flex; + flex-direction: column; + gap: pxToRem(24px); + + &__xdr { + display: flex; + flex-direction: column; + gap: pxToRem(16px); + + .Text { + display: flex; + align-items: center; + gap: pxToRem(4px); + color: var(--sds-clr-gray-12); + } + } + + &__icon { + display: inline-block; + width: pxToRem(14px); + height: pxToRem(14px); + + svg { + display: inline-block; + width: 100%; + height: 100%; + stroke: var(--sds-clr-gray-08); + } + } + + &__FieldViewer, + &__Field { + display: grid; + grid-template-columns: repeat(2, 1fr); + gap: pxToRem(16px); + + .half-width { + grid-template-columns: 1fr 1fr; + } + + .full-width { + grid-column: 1 / 3; + } + } + + &__FieldViewer { + .Textarea textarea, + .Input__container, + .Input__copyButton button, + input { + background: var(--sds-clr-gray-03); + } + } + + &__Signs { + display: flex; + flex-direction: column; + gap: pxToRem(12px); + } + + &__Buttons { + display: flex; + flex-direction: row; + grid-column: 1 / 3; + gap: pxToRem(12px); + justify-content: space-between; + + div { + display: flex; + gap: pxToRem(8px); + } + } + + .Input__container { + .Select__container { + border: 0; + } + input { + flex-shrink: 1; + } + .Input__side-element { + flex: 1 0; + + &:has(.MultiPicker__delete) { + flex: 0; + } + } + } + .Input__buttons { + .Input__container { + padding-right: 0; + } + .hardware-button { + flex-grow: 1; + border-left: 1px solid var(--Input-color-border); + } + .hardware-sign-button { + .Button { + margin-top: pxToRem(25px); + } + } + .Button { + border: 0; + } + } +} + +// to fix Safari only styling bug +.Input, +.RadioPicker, +.Select, +.Box { + .Label__infoButton { + width: pxToRem(16px); + height: pxToRem(16px); + } +} diff --git a/src/styles/main.scss b/src/styles/main.scss deleted file mode 100644 index 02f2d22c..00000000 --- a/src/styles/main.scss +++ /dev/null @@ -1,58 +0,0 @@ -@import 'ReskinColors'; - -@import 'solar-css/lib/index'; -@import '~solar-stellarorg/lib/index'; - -@import 'solar-css/styles/index'; -@import '~solar-stellarorg/styles/index'; - -// External libraries -@import 'prism'; - -// General css modules (these go first to allow for low specificity overwriting for page components) -@import 'optionsTable'; -@import 'simpleTable'; -@import 'pageIntro'; -@import 'xdrInput'; - -@import 'picker'; - @import 'ManualMultiPicker'; - @import 'PubKeyPicker'; - @import 'MultiPicker'; - -// General React components -@import 'TreeView'; -@import 'CodeBlock'; -@import 'Collapsible'; -@import 'EasySelect'; -@import 'HelpMark'; - -// Specific React components -@import 'LaboratoryChrome'; - @import 'NetworkPicker'; - -@import 'Introduction'; - -@import 'AccountCreator'; - -@import 'EndpointExplorer'; - @import 'EndpointPicker'; - @import 'EndpointSetup'; - @import 'EndpointResult'; - -@import 'SimplePage'; - -@import 'TransactionBuilder'; - -@import 'TransactionSigner'; - @import 'TxSignerImport'; - @import 'TxSignerOverview'; - @import 'TxSignerKeys'; - @import 'TxSignerResult'; - -@import 'ClaimantPicker'; - -@import 'XdrViewer'; - -// Unorganized stuffs below: -@import 'Reskin'; diff --git a/src/styles/prism.css b/src/styles/prism.css deleted file mode 100644 index a9b81712..00000000 --- a/src/styles/prism.css +++ /dev/null @@ -1,236 +0,0 @@ -/* http://prismjs.com/download.html?themes=prism-coy&languages=markup+css+clike+javascript */ -/** - * prism.js Coy theme for JavaScript, CoffeeScript, CSS and HTML - * Based on https://github.com/tshedor/workshop-wp-theme (Example: http://workshop.kansan.com/category/sessions/basics or http://workshop.timshedor.com/category/sessions/basics); - * @author Tim Shedor - */ - -code[class*="language-"], -pre[class*="language-"] { - color: black; - background: none; - font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace; - text-align: left; - white-space: pre; - word-spacing: normal; - word-break: normal; - word-wrap: normal; - line-height: 1.5; - - -moz-tab-size: 4; - -o-tab-size: 4; - tab-size: 4; - - -webkit-hyphens: none; - -moz-hyphens: none; - -ms-hyphens: none; - hyphens: none; -} - -/* Code blocks */ -pre[class*="language-"] { - position: relative; - margin: .5em 0; - -webkit-box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf; - -moz-box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf; - box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf; - border-left: 10px solid #358ccb; - background-color: #fdfdfd; - background-image: -webkit-linear-gradient(transparent 50%, rgba(69, 142, 209, 0.04) 50%); - background-image: -moz-linear-gradient(transparent 50%, rgba(69, 142, 209, 0.04) 50%); - background-image: -ms-linear-gradient(transparent 50%, rgba(69, 142, 209, 0.04) 50%); - background-image: -o-linear-gradient(transparent 50%, rgba(69, 142, 209, 0.04) 50%); - background-image: linear-gradient(transparent 50%, rgba(69, 142, 209, 0.04) 50%); - background-size: 3em 3em; - background-origin: content-box; - overflow: visible; - padding: 0; -} - -code[class*="language"] { - max-height: inherit; - height: 100%; - padding: 0 1em; - display: block; - overflow: auto; -} - -/* Margin bottom to accomodate shadow */ -:not(pre) > code[class*="language-"], -pre[class*="language-"] { - background-color: #fdfdfd; - -webkit-box-sizing: border-box; - -moz-box-sizing: border-box; - box-sizing: border-box; - margin-bottom: 1em; -} - -/* Inline code */ -:not(pre) > code[class*="language-"] { - position: relative; - padding: .2em; - -webkit-border-radius: 0.3em; - -moz-border-radius: 0.3em; - -ms-border-radius: 0.3em; - -o-border-radius: 0.3em; - border-radius: 0.3em; - color: #c92c2c; - border: 1px solid rgba(0, 0, 0, 0.1); - display: inline; - white-space: normal; -} - -pre[class*="language-"]:before, -pre[class*="language-"]:after { - content: ''; - z-index: -2; - display: block; - position: absolute; - bottom: 0.75em; - left: 0.18em; - width: 40%; - height: 20%; - max-height: 13em; - -webkit-box-shadow: 0px 13px 8px #979797; - -moz-box-shadow: 0px 13px 8px #979797; - box-shadow: 0px 13px 8px #979797; - -webkit-transform: rotate(-2deg); - -moz-transform: rotate(-2deg); - -ms-transform: rotate(-2deg); - -o-transform: rotate(-2deg); - transform: rotate(-2deg); -} - -:not(pre) > code[class*="language-"]:after, -pre[class*="language-"]:after { - right: 0.75em; - left: auto; - -webkit-transform: rotate(2deg); - -moz-transform: rotate(2deg); - -ms-transform: rotate(2deg); - -o-transform: rotate(2deg); - transform: rotate(2deg); -} - -.token.comment, -.token.block-comment, -.token.prolog, -.token.doctype, -.token.cdata { - color: #7D8B99; -} - -.token.punctuation { - color: #5F6364; -} - -.token.property, -.token.tag, -.token.boolean, -.token.number, -.token.function-name, -.token.constant, -.token.symbol, -.token.deleted { - color: #c92c2c; -} - -.token.selector, -.token.attr-name, -.token.string, -.token.char, -.token.function, -.token.builtin, -.token.inserted { - color: #2f9c0a; -} - -.token.operator, -.token.entity, -.token.url, -.token.variable { - color: #a67f59; - background: rgba(255, 255, 255, 0.5); -} - -.token.atrule, -.token.attr-value, -.token.keyword, -.token.class-name { - color: #1990b8; -} - -.token.regex, -.token.important { - color: #e90; -} - -.language-css .token.string, -.style .token.string { - color: #a67f59; - background: rgba(255, 255, 255, 0.5); -} - -.token.important { - font-weight: normal; -} - -.token.bold { - font-weight: bold; -} -.token.italic { - font-style: italic; -} - -.token.entity { - cursor: help; -} - -.namespace { - opacity: .7; -} - -@media screen and (max-width: 767px) { - pre[class*="language-"]:before, - pre[class*="language-"]:after { - bottom: 14px; - -webkit-box-shadow: none; - -moz-box-shadow: none; - box-shadow: none; - } - -} - -/* Plugin styles */ -.token.tab:not(:empty):before, -.token.cr:before, -.token.lf:before { - color: #e0d7d1; -} - -/* Plugin styles: Line Numbers */ -pre[class*="language-"].line-numbers { - padding-left: 0; -} - -pre[class*="language-"].line-numbers code { - padding-left: 3.8em; -} - -pre[class*="language-"].line-numbers .line-numbers-rows { - left: 0; -} - -/* Plugin styles: Line Highlight */ -pre[class*="language-"][data-line] { - padding-top: 0; - padding-bottom: 0; - padding-left: 0; -} -pre[data-line] code { - position: relative; - padding-left: 4em; -} -pre .line-highlight { - margin-top: 0; -} diff --git a/src/styles/solar-css/lib/_index.scss b/src/styles/solar-css/lib/_index.scss deleted file mode 100644 index 3800430b..00000000 --- a/src/styles/solar-css/lib/_index.scss +++ /dev/null @@ -1,12 +0,0 @@ -@import 'layout.flex'; - -@import 'scale'; - -@import 'theme.colors'; -@import 'theme.variables'; - -@import 'respond.media'; - - -// solar-webApp module -@import 'webapp.base'; diff --git a/src/styles/solar-css/lib/_layout.flex.scss b/src/styles/solar-css/lib/_layout.flex.scss deleted file mode 100644 index cf55daea..00000000 --- a/src/styles/solar-css/lib/_layout.flex.scss +++ /dev/null @@ -1,57 +0,0 @@ -// flex containers -@mixin S-flex-row { - display: flex; - flex-direction: row; -} -@mixin S-flex-rowWrap { - display: flex; - flex-flow: row wrap; -} -@mixin S-flex-col { - display: flex; - flex-direction: column; -} -@mixin S-flex-colWrap { - display: flex; - flex-flow: column wrap; -} - - -// no flexing -@mixin S-flexItem-noFlex { flex: 0 0 auto; } - -// full row -@mixin S-flexItem-full { flex: 12 0 100%; } - -// share sizes (all space distributed) -@mixin S-flexItem-share1 { flex: 1 0 0%; } -@mixin S-flexItem-share2 { flex: 2 0 0%; } -@mixin S-flexItem-share3 { flex: 3 0 0%; } -@mixin S-flexItem-share4 { flex: 4 0 0%; } -@mixin S-flexItem-share6 { flex: 6 0 0%; } -@mixin S-flexItem-share8 { flex: 8 0 0%; } -@mixin S-flexItem-share10 { flex: 10 0 0%; } -@mixin S-flexItem-share { flex: 12 0 0%; } - -// auto sizes (extra space distributed) -@mixin S-flexItem-auto1 { flex: 1 0 auto; } -@mixin S-flexItem-auto2 { flex: 2 0 auto; } -@mixin S-flexItem-auto3 { flex: 3 0 auto; } -@mixin S-flexItem-auto4 { flex: 4 0 auto; } -@mixin S-flexItem-auto6 { flex: 6 0 auto; } -@mixin S-flexItem-auto8 { flex: 8 0 auto; } -@mixin S-flexItem-auto10 { flex: 10 0 auto; } -@mixin S-flexItem-auto { flex: 12 0 auto; } - -// column sizes -@mixin S-flexItem-11of12 { flex: 0 0 91.66666%; } // 11of12 -@mixin S-flexItem-5of6 { flex: 0 0 83.33333%; } // 10of12 -@mixin S-flexItem-3of4 { flex: 0 0 75%; } // 9of12 -@mixin S-flexItem-2of3 { flex: 0 0 66.66666%; } // 8of12 -@mixin S-flexItem-7of12 { flex: 0 0 58.33333%; } // 7of12 -@mixin S-flexItem-1of2 { flex: 0 0 50%; } // 6of12 -@mixin S-flexItem-5of12 { flex: 0 0 41.66666%; } // 5of12 -@mixin S-flexItem-1of3 { flex: 0 0 33.33333%; } // 4of12 -@mixin S-flexItem-1of4 { flex: 0 0 25%; } // 3of12 -@mixin S-flexItem-1of6 { flex: 0 0 16.66666%; } // 2of12 -@mixin S-flexItem-1of12 { flex: 0 0 8.33333%; } // 1of12 diff --git a/src/styles/solar-css/lib/_respond.media.scss b/src/styles/solar-css/lib/_respond.media.scss deleted file mode 100644 index 6e29c9ae..00000000 --- a/src/styles/solar-css/lib/_respond.media.scss +++ /dev/null @@ -1,31 +0,0 @@ -// breakpoint sizes are calculated quadratically -// 20x^2+100x+360 -$r-breakpoint-xs: 360px; -$r-breakpoint-s: 480px; -$r-breakpoint-m: 640px; -$r-breakpoint-l: 840px; -$r-breakpoint-xl: 1080px; -$r-breakpoint-2xl: 1360px; -$r-breakpoint-3xl: 1680px; - - -// Usage example: @include r-media(xl) { .thing { background: pink; } } - -// This is made available through a mixin and not just a breakpoint name since -// it keeps the constraint that breakpoints be min-width -@mixin r-media($size) { - $targetBreakpoint: 0; - - @if $size == xs { $targetBreakpoint: $r-breakpoint-xs; } - @else if $size == s { $targetBreakpoint: $r-breakpoint-s; } - @else if $size == m { $targetBreakpoint: $r-breakpoint-m; } - @else if $size == l { $targetBreakpoint: $r-breakpoint-l; } - @else if $size == xl { $targetBreakpoint: $r-breakpoint-xl; } - @else if $size == 2xl { $targetBreakpoint: $r-breakpoint-2xl; } - @else if $size == 3xl { $targetBreakpoint: $r-breakpoint-3xl; } - @else { @error 'Invalid breakpoint name'; } - - @media (min-width: $targetBreakpoint) { - @content; - } -} diff --git a/src/styles/solar-css/lib/_scale.scss b/src/styles/solar-css/lib/_scale.scss deleted file mode 100644 index 84cd6d58..00000000 --- a/src/styles/solar-css/lib/_scale.scss +++ /dev/null @@ -1,161 +0,0 @@ -// The Solar core default scale uses: -// http://www.modularscale.com/?18,21&px&1.33333333333333333333&js&text -// This basic example assumes that we use two bases and one scale. Themes that wish -// to change this will have to redefine all these variables -// Additionally, themes that want to redefine the type system may choose to use -// the modularscale-sass plugin. However, for defaults, it is an overkill. These -// variables are here to provide a simple common functionality between widgets -// (a main philosophy tenet of solar). -@use "sass:math"; - -$s-scale-base1Px: 18; -$s-scale-base2Px: 21; // bigger than base1 -$s-scale-ratio: 1.33333333333333333333; // more decimals for more precision - - -// Absolute scale -// base2*scale^3 -$s-scale-d: $s-scale-base2Px - * $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio - + px; - -// base1*scale^3 -$s-scale-c: $s-scale-base1Px - * $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio - + px; - -// base2*scale^2 -$s-scale-b: $s-scale-base2Px - * $s-scale-ratio - * $s-scale-ratio - + px; - -// base1*scale^2 -$s-scale-a: $s-scale-base1Px - * $s-scale-ratio - * $s-scale-ratio - + px; - -// base2*scale^1 -$s-scale-1: $s-scale-base2Px - * $s-scale-ratio - + px; - -// base1*scale^1 -$s-scale-2: $s-scale-base1Px - * $s-scale-ratio - + px; - -// base2*scale^0 -$s-scale-3: $s-scale-base2Px - + px; - -// base1*scale^0 -$s-scale-4: $s-scale-base1Px - + px; - -// base2/scale^-1 -$s-scale-5: math.div( - $s-scale-base2Px, - $s-scale-ratio) + px; - -// base1/scale^-1 -$s-scale-6: math.div( - $s-scale-base1Px, - $s-scale-ratio) + px; - -// base2*scale^-2 -$s-scale-7: math.div( - math.div($s-scale-base2Px, $s-scale-ratio), - $s-scale-ratio) + px; - -// base1*scale^-2 -$s-scale-8: math.div( - math.div($s-scale-base1Px, $s-scale-ratio), - $s-scale-ratio) + px; - - - -// Relative scale -// For the same of simplicity, not using exponents -// In this default scale, each time we increase by "one", we are actually going -// up by two levels. For example, inheriting a base font size of $s-scale-3 and -// then using $s-scale-up1, we actually end up at $s-scale-1. Using $s-scale-up1 -// would bring us to $s-scale-b -// -// The usefulness of the relative type scale is not just limited to font sizes. -// These are extremely useful for other elements such as paddings. Sizes like up5 -// have very little usage for font sizes but can be used in paddings relative to -// the -$s-scale-up1raw: $s-scale-ratio; -$s-scale-up2raw: $s-scale-ratio - * $s-scale-ratio; -$s-scale-up3raw: $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio; -$s-scale-up4raw: $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio; -$s-scale-up5raw: $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio - * $s-scale-ratio; -$s-scale-down1raw: math.div( - 1, - $s-scale-ratio); -$s-scale-down2raw: math.div( - math.div(1, $s-scale-ratio), $s-scale-ratio); -$s-scale-down3raw: math.div( - math.div(1, $s-scale-ratio), - math.div($s-scale-ratio, $s-scale-ratio)); -$s-scale-down4raw: math.div( - math.div(1, $s-scale-ratio), - math.div(math.div($s-scale-ratio, $s-scale-ratio), $s-scale-ratio)); -$s-scale-down5raw: math.div( - math.div(math.div(math.div(math.div(1, $s-scale-ratio), $s-scale-ratio), $s-scale-ratio), $s-scale-ratio), $s-scale-ratio); - -$s-scale-up1: $s-scale-up1raw + em; -$s-scale-up2: $s-scale-up2raw + em; -$s-scale-up3: $s-scale-up3raw + em; -$s-scale-up4: $s-scale-up4raw + em; -$s-scale-up5: $s-scale-up5raw + em; -$s-scale-down1: $s-scale-down1raw + em; -$s-scale-down2: $s-scale-down2raw + em; -$s-scale-down3: $s-scale-down3raw + em; -$s-scale-down4: $s-scale-down4raw + em; -$s-scale-down5: $s-scale-down5raw + em; - - -// // tests: -// .s-scale-debug-absolute { -// s-scale-d: $s-scale-d; -// s-scale-c: $s-scale-c; -// s-scale-b: $s-scale-b; -// s-scale-a: $s-scale-a; -// s-scale-1: $s-scale-1; -// s-scale-2: $s-scale-2; -// s-scale-3: $s-scale-3; -// s-scale-4: $s-scale-4; -// s-scale-5: $s-scale-5; -// s-scale-6: $s-scale-6; -// s-scale-7: $s-scale-7; -// s-scale-8: $s-scale-8; -// } -// .s-scale-debug-relative { -// s-scale-up5: $s-scale-up5; -// s-scale-up4: $s-scale-up4; -// s-scale-up3: $s-scale-up3; -// s-scale-up2: $s-scale-up2; -// s-scale-up1: $s-scale-up1; -// s-scale-down1: $s-scale-down1; -// s-scale-down2: $s-scale-down2; -// s-scale-down3: $s-scale-down3; -// s-scale-down4: $s-scale-down4; -// s-scale-down5: $s-scale-down5; -// } diff --git a/src/styles/solar-css/lib/_theme.colors.scss b/src/styles/solar-css/lib/_theme.colors.scss deleted file mode 100644 index c7cfe819..00000000 --- a/src/styles/solar-css/lib/_theme.colors.scss +++ /dev/null @@ -1,54 +0,0 @@ -// important functions for deriving colors -@function whiten($color, $percent) { - @return mix(white, $color, $percent); -} -@function blacken($color, $percent) { - @return mix(black, $color, $percent); -} - -// These should only be used to derive main colors -$s-color-primaryRoot: #08b5e5; // a bright brand color -$s-color-neutralRoot: blacken(#5b6a72, 60%); - -// Themes that override root colors will need to regenerate these -// These color names are stable and will not change -$s-color-neutral1: $s-color-neutralRoot; -$s-color-neutral2: whiten($s-color-neutralRoot, 10%); -$s-color-neutral3: whiten($s-color-neutralRoot, 20%); -$s-color-neutral4: whiten($s-color-neutralRoot, 35%); -$s-color-neutral5: whiten($s-color-neutralRoot, 50%); -$s-color-neutral6: whiten($s-color-neutralRoot, 70%); -$s-color-neutral7: whiten($s-color-neutralRoot, 85%); -$s-color-neutral8: whiten($s-color-neutralRoot, 95%); -$s-color-neutral9: whiten($s-color-neutralRoot, 100%); - -$s-color-primary1: blacken($s-color-primaryRoot, 40%); -$s-color-primary2: blacken($s-color-primaryRoot, 30%); -$s-color-primary3: blacken($s-color-primaryRoot, 20%); -$s-color-primary4: $s-color-primaryRoot; -$s-color-primary5: whiten($s-color-primaryRoot, 20%); -$s-color-primary6: whiten($s-color-primaryRoot, 40%); -$s-color-primary7: whiten($s-color-primaryRoot, 60%); -$s-color-primary8: whiten($s-color-primaryRoot, 80%); -$s-color-primary9: whiten($s-color-primaryRoot, 90%); - -// Lists of all the colors -$s-color-neutralList: neutral1 $s-color-neutral1, neutral2 $s-color-neutral2, - neutral3 $s-color-neutral3, neutral4 $s-color-neutral4, - neutral5 $s-color-neutral5, neutral6 $s-color-neutral6, - neutral7 $s-color-neutral7, neutral8 $s-color-neutral8, - neutral9 $s-color-neutral9; - -$s-color-primaryList: primary1 $s-color-primary1, primary2 $s-color-primary2, - primary3 $s-color-primary3, primary4 $s-color-primary4, - primary5 $s-color-primary5, primary6 $s-color-primary6, - primary7 $s-color-primary7, primary8 $s-color-primary8, - primary9 $s-color-primary9; - -$s-color-listList: $s-color-neutralList $s-color-primaryList; - -// These are saturated colors that can stand alone on a white (#fff) background -$s-color-success: #383; -$s-color-info: #69f; -$s-color-warning: #ee8; -$s-color-alert: #d12; diff --git a/src/styles/solar-css/lib/_theme.variables.scss b/src/styles/solar-css/lib/_theme.variables.scss deleted file mode 100644 index 8a080f1d..00000000 --- a/src/styles/solar-css/lib/_theme.variables.scss +++ /dev/null @@ -1,5 +0,0 @@ -// Widget developers should develop with attention to border radius. - -// There is just one border radius size. If app developers want to use multiple -// sizes, they can do that in their own theme. -$s-var-radius: 3px; diff --git a/src/styles/solar-css/lib/_webapp.base.scss b/src/styles/solar-css/lib/_webapp.base.scss deleted file mode 100644 index aa1e5cd1..00000000 --- a/src/styles/solar-css/lib/_webapp.base.scss +++ /dev/null @@ -1,45 +0,0 @@ -@mixin s-webApp { - @include S-flex-col; - - position: fixed; - top: 0; - right: 0; - bottom: 0; - left: 0; -} -@mixin s-webApp--scrollable { - overflow-y: scroll; -} - -@mixin s-webApp-bar { - @include S-flexItem-noFlex; - @include S-flex-row; -} - -@mixin s-webApp-content { - @include S-flexItem-auto; - - height: 0; - overflow-y: scroll; - -webkit-overflow-scrolling: touch; -} - -@mixin s-webApp__fill { - @include S-flexItem-auto; -} - -// tab bar -@mixin s-webApp-tabBar { - @include S-flex-row; - list-style-type: none; - - li { - @include S-flexItem-auto; - display: inline-block; - text-align: center; - } - - li a { - width: 100%; - } -} diff --git a/src/styles/solar-css/styles/_base.basic-elements.scss b/src/styles/solar-css/styles/_base.basic-elements.scss deleted file mode 100644 index 78a9f6b8..00000000 --- a/src/styles/solar-css/styles/_base.basic-elements.scss +++ /dev/null @@ -1,8 +0,0 @@ -// Not to be confused with the whole category of elements -// This acts as like a lightly opinionated reset - - -ul { - margin: 0; - padding: 0; -} diff --git a/src/styles/solar-css/styles/_base.border-box.scss b/src/styles/solar-css/styles/_base.border-box.scss deleted file mode 100644 index 49802f20..00000000 --- a/src/styles/solar-css/styles/_base.border-box.scss +++ /dev/null @@ -1,6 +0,0 @@ -html { - box-sizing: border-box; -} -*, *:before, *:after { - box-sizing: inherit; -} diff --git a/src/styles/solar-css/styles/_base.normalize.scss b/src/styles/solar-css/styles/_base.normalize.scss deleted file mode 100644 index 5e5e3c89..00000000 --- a/src/styles/solar-css/styles/_base.normalize.scss +++ /dev/null @@ -1,424 +0,0 @@ -/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */ - -/** - * 1. Set default font family to sans-serif. - * 2. Prevent iOS and IE text size adjust after device orientation change, - * without disabling user zoom. - */ - -html { - font-family: sans-serif; /* 1 */ - -ms-text-size-adjust: 100%; /* 2 */ - -webkit-text-size-adjust: 100%; /* 2 */ -} - -/** - * Remove default margin. - */ - -body { - margin: 0; -} - -/* HTML5 display definitions - ========================================================================== */ - -/** - * Correct `block` display not defined for any HTML5 element in IE 8/9. - * Correct `block` display not defined for `details` or `summary` in IE 10/11 - * and Firefox. - * Correct `block` display not defined for `main` in IE 11. - */ - -article, -aside, -details, -figcaption, -figure, -footer, -header, -hgroup, -main, -menu, -nav, -section, -summary { - display: block; -} - -/** - * 1. Correct `inline-block` display not defined in IE 8/9. - * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. - */ - -audio, -canvas, -progress, -video { - display: inline-block; /* 1 */ - vertical-align: baseline; /* 2 */ -} - -/** - * Prevent modern browsers from displaying `audio` without controls. - * Remove excess height in iOS 5 devices. - */ - -audio:not([controls]) { - display: none; - height: 0; -} - -/** - * Address `[hidden]` styling not present in IE 8/9/10. - * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22. - */ - -[hidden], -template { - display: none; -} - -/* Links - ========================================================================== */ - -/** - * Remove the gray background color from active links in IE 10. - */ - -a { - background-color: transparent; -} - -/** - * Improve readability of focused elements when they are also in an - * active/hover state. - */ - -a:active, -a:hover { - outline: 0; -} - -/* Text-level semantics - ========================================================================== */ - -/** - * Address styling not present in IE 8/9/10/11, Safari, and Chrome. - */ - -abbr[title] { - border-bottom: 1px dotted; -} - -/** - * Address style set to `bolder` in Firefox 4+, Safari, and Chrome. - */ - -b, -strong { - font-weight: bold; -} - -/** - * Address styling not present in Safari and Chrome. - */ - -dfn { - font-style: italic; -} - -/** - * Address variable `h1` font-size and margin within `section` and `article` - * contexts in Firefox 4+, Safari, and Chrome. - */ - -h1 { - font-size: 2em; - margin: 0.67em 0; -} - -/** - * Address styling not present in IE 8/9. - */ - -mark { - background: #ff0; - color: #000; -} - -/** - * Address inconsistent and variable font size in all browsers. - */ - -small { - font-size: 80%; -} - -/** - * Prevent `sub` and `sup` affecting `line-height` in all browsers. - */ - -sub, -sup { - font-size: 75%; - line-height: 0; - position: relative; - vertical-align: baseline; -} - -sup { - top: -0.5em; -} - -sub { - bottom: -0.25em; -} - -/* Embedded content - ========================================================================== */ - -/** - * Remove border when inside `a` element in IE 8/9/10. - */ - -img { - border: 0; -} - -/** - * Correct overflow not hidden in IE 9/10/11. - */ - -svg:not(:root) { - overflow: hidden; -} - -/* Grouping content - ========================================================================== */ - -/** - * Address margin not present in IE 8/9 and Safari. - */ - -figure { - margin: 1em 40px; -} - -/** - * Address differences between Firefox and other browsers. - */ - -hr { - box-sizing: content-box; - height: 0; -} - -/** - * Contain overflow in all browsers. - */ - -pre { - overflow: auto; -} - -/** - * Address odd `em`-unit font size rendering in all browsers. - */ - -code, -kbd, -pre, -samp { - font-family: monospace, monospace; - font-size: 1em; -} - -/* Forms - ========================================================================== */ - -/** - * Known limitation: by default, Chrome and Safari on OS X allow very limited - * styling of `select`, unless a `border` property is set. - */ - -/** - * 1. Correct color not being inherited. - * Known issue: affects color of disabled elements. - * 2. Correct font properties not being inherited. - * 3. Address margins set differently in Firefox 4+, Safari, and Chrome. - */ - -button, -input, -optgroup, -select, -textarea { - color: inherit; /* 1 */ - font: inherit; /* 2 */ - margin: 0; /* 3 */ -} - -/** - * Address `overflow` set to `hidden` in IE 8/9/10/11. - */ - -button { - overflow: visible; -} - -/** - * Address inconsistent `text-transform` inheritance for `button` and `select`. - * All other form control elements do not inherit `text-transform` values. - * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. - * Correct `select` style inheritance in Firefox. - */ - -button, -select { - text-transform: none; -} - -/** - * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` - * and `video` controls. - * 2. Correct inability to style clickable `input` types in iOS. - * 3. Improve usability and consistency of cursor style between image-type - * `input` and others. - */ - -button, -html input[type="button"], /* 1 */ -input[type="reset"], -input[type="submit"] { - -webkit-appearance: button; /* 2 */ - cursor: pointer; /* 3 */ -} - -/** - * Re-set default cursor for disabled elements. - */ - -button[disabled], -html input[disabled] { - cursor: default; -} - -/** - * Remove inner padding and border in Firefox 4+. - */ - -button::-moz-focus-inner, -input::-moz-focus-inner { - border: 0; - padding: 0; -} - -/** - * Address Firefox 4+ setting `line-height` on `input` using `!important` in - * the UA stylesheet. - */ - -input { - line-height: normal; -} - -/** - * It's recommended that you don't attempt to style these elements. - * Firefox's implementation doesn't respect box-sizing, padding, or width. - * - * 1. Address box sizing set to `content-box` in IE 8/9/10. - * 2. Remove excess padding in IE 8/9/10. - */ - -input[type="checkbox"], -input[type="radio"] { - box-sizing: border-box; /* 1 */ - padding: 0; /* 2 */ -} - -/** - * Fix the cursor style for Chrome's increment/decrement buttons. For certain - * `font-size` values of the `input`, it causes the cursor style of the - * decrement button to change from `default` to `text`. - */ - -input[type="number"]::-webkit-inner-spin-button, -input[type="number"]::-webkit-outer-spin-button { - height: auto; -} - -/** - * 1. Address `appearance` set to `searchfield` in Safari and Chrome. - * 2. Address `box-sizing` set to `border-box` in Safari and Chrome. - */ - -input[type="search"] { - -webkit-appearance: textfield; /* 1 */ - box-sizing: content-box; /* 2 */ -} - -/** - * Remove inner padding and search cancel button in Safari and Chrome on OS X. - * Safari (but not Chrome) clips the cancel button when the search input has - * padding (and `textfield` appearance). - */ - -input[type="search"]::-webkit-search-cancel-button, -input[type="search"]::-webkit-search-decoration { - -webkit-appearance: none; -} - -/** - * Define consistent border, margin, and padding. - */ - -fieldset { - border: 1px solid #c0c0c0; - margin: 0 2px; - padding: 0.35em 0.625em 0.75em; -} - -/** - * 1. Correct `color` not being inherited in IE 8/9/10/11. - * 2. Remove padding so people aren't caught out if they zero out fieldsets. - */ - -legend { - border: 0; /* 1 */ - padding: 0; /* 2 */ -} - -/** - * Remove default vertical scrollbar in IE 8/9/10/11. - */ - -textarea { - overflow: auto; -} - -/** - * Don't inherit the `font-weight` (applied by a rule above). - * NOTE: the default cannot safely be changed in Chrome and Safari on OS X. - */ - -optgroup { - font-weight: bold; -} - -/* Tables - ========================================================================== */ - -/** - * Remove most spacing between table cells. - */ - -table { - border-collapse: collapse; - border-spacing: 0; -} - -td, -th { - padding: 0; -} diff --git a/src/styles/solar-css/styles/_base.page.scss b/src/styles/solar-css/styles/_base.page.scss deleted file mode 100644 index 578b37df..00000000 --- a/src/styles/solar-css/styles/_base.page.scss +++ /dev/null @@ -1,6 +0,0 @@ -html { - height: 100%; -} -body { - min-height: 100%; -} diff --git a/src/styles/solar-css/styles/_components.alerts.scss b/src/styles/solar-css/styles/_components.alerts.scss deleted file mode 100644 index 7c77644d..00000000 --- a/src/styles/solar-css/styles/_components.alerts.scss +++ /dev/null @@ -1,43 +0,0 @@ -.s-alert { - display: block; - padding: 0.5em 1em; - margin-bottom: 1em; - border-radius: $s-var-radius; -} -.s-alert--warning { - border: 1px solid $s-color-warning; - background: whiten($s-color-warning, 80%); -} -.s-alert--info { - border: 1px solid $s-color-info; - background: whiten($s-color-info, 85%); -} -.s-alert--alert { - border: 1px solid $s-color-alert; - background: whiten($s-color-alert, 80%); -} -.s-alert--success { - border: 1px solid $s-color-success; - background: whiten($s-color-success, 80%); -} -.s-alert__close { - float: right; - border: 1px solid #333; // TODO: color - line-height: 1; - border-radius: 50%; - background: none; -} - - -.s-inputAlert--warning { - border: 1px solid $s-color-warning; -} -.s-inputAlert--info { - border: 1px solid $s-color-info; -} -.s-inputAlert--alert { - border: 1px solid $s-color-alert; -} -.s-inputAlert--success { - border: 1px solid $s-color-success; -} diff --git a/src/styles/solar-css/styles/_elements.links.scss b/src/styles/solar-css/styles/_elements.links.scss deleted file mode 100644 index 5c2782fd..00000000 --- a/src/styles/solar-css/styles/_elements.links.scss +++ /dev/null @@ -1,5 +0,0 @@ -a { - color: inherit; - text-decoration: underline; - cursor: pointer; -} diff --git a/src/styles/solar-css/styles/_forms.base.scss b/src/styles/solar-css/styles/_forms.base.scss deleted file mode 100644 index c4e96a70..00000000 --- a/src/styles/solar-css/styles/_forms.base.scss +++ /dev/null @@ -1,23 +0,0 @@ -// General base stylings -input, -select, -.s-button { - padding: 0; - margin: 0; - border-radius: 0; - background: #fff; - position: relative; - - &:focus { - z-index: 1; - } -} - - -// Base form stylings -input { - border: none; - line-height: 1.5; -} -select { -} diff --git a/src/styles/solar-css/styles/_forms.buttonGroup.scss b/src/styles/solar-css/styles/_forms.buttonGroup.scss deleted file mode 100644 index 24784775..00000000 --- a/src/styles/solar-css/styles/_forms.buttonGroup.scss +++ /dev/null @@ -1,108 +0,0 @@ -// s-buttonGroup usage: -//
    -// A -// B -// C -//
    - -.s-buttonGroup { - @include S-flex-row; -} - -.s-buttonGroup--vertical { - flex-direction: column; -} - -// make sure spacing is correct -.s-buttonGroup > .s-button:not(:last-child), -.s-buttonGroup__wrapper:not(:last-child) { - margin-right: -1px; -} - -.s-buttonGroup--vertical > .s-button:not(:last-child), -.s-buttonGroup--vertical > .s-buttonGroup__wrapper:not(:last-child) { - margin-right: 0; - margin-bottom: -1px; -} - -.s-buttonGroup .s-button, -.s-buttonGroup__wrapper .s-button { - border-radius: 0; -} -.s-buttonGroup > .s-button:first-of-type, -.s-buttonGroup__wrapper:first-of-type .s-button { - border-top-left-radius: $s-var-radius; - border-bottom-left-radius: $s-var-radius; -} -.s-buttonGroup > .s-button:last-of-type, -.s-buttonGroup__wrapper:last-of-type .s-button { - border-top-right-radius: $s-var-radius; - border-bottom-right-radius: $s-var-radius; -} - -.s-buttonGroup--vertical .s-button:first-of-type, -.s-buttonGroup--vertical > .s-buttonGroup__wrapper:first-of-type .s-button { - border-radius: $s-var-radius $s-var-radius 0 0; -} -.s-buttonGroup--vertical > .s-button:last-of-type, -.s-buttonGroup--vertical > .s-buttonGroup__wrapper:last-of-type .s-button { - border-radius: 0 0 $s-var-radius $s-var-radius; -} -.s-buttonGroup--vertical > .s-button:first-of-type:last-of-type, -.s-buttonGroup--vertical > .s-buttonGroup__wrapper:first-of-type:last-of-type .s-button { - // Only element - border-radius: $s-var-radius; -} - -.s-buttonGroup__radio { - position: absolute !important; - clip: rect(0px, 0px, 0px, 0px); - clip-path: inset(0px, 0px, 0px, 0px); -} - - -// .s-buttonGroup can be used with radiobutton inputs. This will allow toggling -// of buttons using pure css - -// Usage #1: input nested inside label -// This approach is simpler and does not require management of the "id" and the -// "for" attribute -//
    -// -// -// -//
    - -// Usage #2: input adjacent to label -// This approach does not nest the input meaning that one must make sure the -// "id" and "for" attribute match. Some say it is better to do it this way due -// to accessibility concerns -//
    -// -// -// -// -// -// -// -// -//
    - -// TO disable a radio element, you have to disable both the input and the label like so: -// -// -// -// -// diff --git a/src/styles/solar-css/styles/_forms.buttons.scss b/src/styles/solar-css/styles/_forms.buttons.scss deleted file mode 100644 index e15ed653..00000000 --- a/src/styles/solar-css/styles/_forms.buttons.scss +++ /dev/null @@ -1,24 +0,0 @@ -p { - margin: 0; - margin-bottom: 1em; -} - -// Some button styles in the common forms.base to consolidate properties -.s-button { - display: inline-block; - margin: 0; - // background: none; - border-radius: $s-var-radius; - cursor: pointer; -} - -.s-button.is-disabled, -.s-button:disabled { - cursor: not-allowed; -} - - -.s-button__min { -} -.s-button__light { -} diff --git a/src/styles/solar-css/styles/_forms.inputGroup.scss b/src/styles/solar-css/styles/_forms.inputGroup.scss deleted file mode 100644 index 1cd8bdf6..00000000 --- a/src/styles/solar-css/styles/_forms.inputGroup.scss +++ /dev/null @@ -1,49 +0,0 @@ - - -.s-inputGroup { - @include S-flex-row(); - flex-wrap: wrap; -} - -// Unfortunately, consumer developers are unable to change classes. They may -// override the flex settings. Stylings should be set on the base item (and not modifiers) much as possible. -.s-inputGroup__item { - @include S-flexItem-auto; -} -// primary flex modifiers -// .s-inputGroup__item--full { -// flex: 12 0 100%; -// } -// .s-inputGroup__item--addon { -// flex: 0 0 auto; -// } - -// auxiliary position modifiers -.s-inputGroup__item--flexEnd { - align-self: flex-end; -} -.s-inputGroup__item--flexStart { - align-self: flex-start; -} -.s-inputGroup__item--tag, -.s-inputGroup__item--tagFlat, -.s-inputGroup__item--tagMin { - align-items: center; - display: flex; -} - - -// border radius is a part of the core solar so that widget developers will -// remember to use the correct radius for special cases such as multi-line inputGroups -.s-inputGroup__item { - border-radius: $s-var-radius; -} -// TODO: figure out how to do this -// .s-inputGroup__item:first-child { -// border-top-left-radius: $s-var-radius; -// border-bottom-left-radius: $s-var-radius; -// } -// .s-inputGroup__item:last-child { -// border-top-right-radius: $s-var-radius; -// border-bottom-right-radius: $s-var-radius; -// } diff --git a/src/styles/solar-css/styles/_index.scss b/src/styles/solar-css/styles/_index.scss deleted file mode 100644 index 0a5e29de..00000000 --- a/src/styles/solar-css/styles/_index.scss +++ /dev/null @@ -1,33 +0,0 @@ -// library-bundle import not necessary - -// core styles -@import 'base.normalize'; -@import 'base.border-box'; -@import 'base.basic-elements'; -@import 'base.page'; - -@import 'typography.base'; - -@import 'elements.links'; - -@import 'components.alerts'; - -@import 'forms.base'; -@import 'forms.buttons'; -@import 'forms.inputGroup'; -@import 'forms.buttonGroup'; - -@import 'lists.inlineList'; -@import 'lists.buttonList'; - -@import 'layout.flex'; - -// INCUBATED theme layers - -// a slightly opinionated base styles aiming for usability and themability -// for basic things that has to do with theming -// theme-starter.index is current broken -// @import 'theme-starter.index'; - -// (likely deprecated) incubated solar-webApp module -@import 'webapp.index'; diff --git a/src/styles/solar-css/styles/_layout.flex.scss b/src/styles/solar-css/styles/_layout.flex.scss deleted file mode 100644 index 34b8732a..00000000 --- a/src/styles/solar-css/styles/_layout.flex.scss +++ /dev/null @@ -1,45 +0,0 @@ -// flex containers (all of them have display: flex) -.S-flex-row { @include S-flex-row; } // flex-direction: row; -.S-flex-rowWrap { @include S-flex-rowWrap; } // flex-flow: row wrap; -.S-flex-col { @include S-flex-col; } // flex-direction: column; -.S-flex-colWrap { @include S-flex-colWrap; } // flex-direction: column wrap; - - -// no flexing -.S-flexItem-noFlex { @include S-flexItem-noFlex; } // flex: 0 0 auto; - -// full row -.S-flexItem-full { @include S-flexItem-full; } // flex: 12 0 100%; - -// share sizes (all space distributed) -.S-flexItem-share1 { @include S-flexItem-share1; } // flex: 1 0 0%; -.S-flexItem-share2 { @include S-flexItem-share2; } // flex: 2 0 0%; -.S-flexItem-share3 { @include S-flexItem-share3; } // flex: 3 0 0%; -.S-flexItem-share4 { @include S-flexItem-share4; } // flex: 4 0 0%; -.S-flexItem-share6 { @include S-flexItem-share6; } // flex: 6 0 0%; -.S-flexItem-share8 { @include S-flexItem-share8; } // flex: 8 0 0%; -.S-flexItem-share10 { @include S-flexItem-share10; } // flex: 10 0 0%; -.S-flexItem-share { @include S-flexItem-share; } // flex: 12 0 0%; - -// auto sizes (extra space distributed) -.S-flexItem-auto1 { @include S-flexItem-auto1; } // flex: 1 0 auto; -.S-flexItem-auto2 { @include S-flexItem-auto2; } // flex: 2 0 auto; -.S-flexItem-auto3 { @include S-flexItem-auto3; } // flex: 3 0 auto; -.S-flexItem-auto4 { @include S-flexItem-auto4; } // flex: 4 0 auto; -.S-flexItem-auto6 { @include S-flexItem-auto6; } // flex: 6 0 auto; -.S-flexItem-auto8 { @include S-flexItem-auto8; } // flex: 8 0 auto; -.S-flexItem-auto10 { @include S-flexItem-auto10; } // flex: 10 0 auto; -.S-flexItem-auto { @include S-flexItem-auto; } // flex: 12 0 auto; - -// column sizes -.S-flexItem-5of6 { @include S-flexItem-11of12; } // flex: 0 0 91.66666%; // 11of12 -.S-flexItem-5of6 { @include S-flexItem-5of6; } // flex: 0 0 83.33333%; // 10of12 -.S-flexItem-3of4 { @include S-flexItem-3of4; } // flex: 0 0 75%; // 9of12 -.S-flexItem-2of3 { @include S-flexItem-2of3; } // flex: 0 0 66.66666%; // 8of12 -.S-flexItem-7of12 { @include S-flexItem-7of12; } // flex: 0 0 58.33333%; // 5of12 -.S-flexItem-1of2 { @include S-flexItem-1of2; } // flex: 0 0 50%; // 6of12 -.S-flexItem-1of3 { @include S-flexItem-5of12; } // flex: 0 0 41.66666%; // 5of12 -.S-flexItem-1of3 { @include S-flexItem-1of3; } // flex: 0 0 33.33333%; // 4of12 -.S-flexItem-1of4 { @include S-flexItem-1of4; } // flex: 0 0 25%; // 3of12 -.S-flexItem-1of6 { @include S-flexItem-1of6; } // flex: 0 0 16.66666%; // 2of12 -.S-flexItem-1of12 { @include S-flexItem-1of12; } // flex: 0 0 8.33333%; // 1of12 diff --git a/src/styles/solar-css/styles/_lists.buttonList.scss b/src/styles/solar-css/styles/_lists.buttonList.scss deleted file mode 100644 index 70239f0f..00000000 --- a/src/styles/solar-css/styles/_lists.buttonList.scss +++ /dev/null @@ -1,27 +0,0 @@ -// .s-buttonList is designed to NOT use a
    • list. Instead, use any element -// with .s-button as a direct child of .s-buttonList. The - - {renderFriendbotMessage()} - {renderFriendbotResultCodeblock()} -
    -
    - ); - } - - return null; -}; diff --git a/src/views/Introduction.tsx b/src/views/Introduction.tsx deleted file mode 100644 index f9a2a2db..00000000 --- a/src/views/Introduction.tsx +++ /dev/null @@ -1,35 +0,0 @@ -export const Introduction = () => { - return ( -
    -
    -
    -
    -

    Stellar Laboratory

    -

    - The Stellar Laboratory is a set of tools that enables people to - try out and learn about the Stellar network. The laboratory can{" "} - build transactions,{" "} - sign them, and{" "} - - submit them to the network - - . It can also{" "} - - make requests to any of the Horizon endpoints - - . -

    - -

    - For Stellar docs, take a look at the{" "} - - Stellar developers site - - . -

    -
    -
    -
    -
    - ); -}; diff --git a/src/views/KeypairGenerator.tsx b/src/views/KeypairGenerator.tsx deleted file mode 100644 index dbaff8ea..00000000 --- a/src/views/KeypairGenerator.tsx +++ /dev/null @@ -1,83 +0,0 @@ -import { useDispatch } from "react-redux"; -import { - generateNewKeypair, - updateFriendbotTarget, -} from "actions/accountCreator.js"; -import NETWORK from "constants/network.js"; -import { useRedux } from "hooks/useRedux"; - -export const KeypairGenerator = () => { - const { accountCreator, network } = useRedux("accountCreator", "network"); - const { keypairGeneratorResult, keypairGeneratorPubKey } = accountCreator; - const baseURL = network.current.horizonURL; - const IS_TESTNET = baseURL === NETWORK.available.test.horizonURL; - const IS_FUTURENET = baseURL === NETWORK.available.futurenet.horizonURL; - - const dispatch = useDispatch(); - - const renderKeypairTable = () => { - if (keypairGeneratorResult !== null) { - return ( -
    -
    -
    Public Key
    -
    - {keypairGeneratorResult.pubKey} -
    -
    - -
    -
    Secret Key
    -
    - {keypairGeneratorResult.secretKey} -
    -
    -
    - ); - } - - return null; - }; - - const renderKeypairGeneratorLink = () => { - if ((IS_TESTNET || IS_FUTURENET) && keypairGeneratorPubKey !== "") { - return ( - - dispatch(updateFriendbotTarget(keypairGeneratorPubKey)) - } - > - Fund this account on the test network using the friendbot tool below - - ); - } - - return null; - }; - - return ( -
    -
    -

    Keypair generator

    - -

    - These keypairs can be used on the Stellar network where one is - required. For example, it can be used as an account master key, - account signer, and/or as a stellar-core node key. -

    - - - - {renderKeypairTable()} - {renderKeypairGeneratorLink()} -
    -
    - ); -}; diff --git a/src/views/MuxedAccount.tsx b/src/views/MuxedAccount.tsx deleted file mode 100644 index 6fd51657..00000000 --- a/src/views/MuxedAccount.tsx +++ /dev/null @@ -1,211 +0,0 @@ -import { useDispatch } from "react-redux"; -import { - generateMuxedAccount, - updateGenerateMuxedAccountInput, - parseMuxedAccount, - updateParseMuxedAccountInput, -} from "actions/accountCreator.js"; -import MuxedKeyPicker from "components/FormComponents/MuxedKeyPicker"; -import PubKeyPicker from "components/FormComponents/PubKeyPicker"; -import PositiveIntPicker from "components/FormComponents/PositiveIntPicker.js"; -import { useRedux } from "hooks/useRedux"; - -const muxedAccountLabel = { - muxedAccountBaseAddress: "Base Account G Address", - muxedAccountId: "Muxed Account ID", - muxedAccountAddress: "Muxed Account M Address", -}; - -export const MuxedAccount = () => { - const { accountCreator } = useRedux("accountCreator"); - const { muxedAccountGenerated, muxedAccountParsed } = accountCreator; - - const dispatch = useDispatch(); - - return ( -
    -
    -

    Muxed Account

    - -

    - Muxed Account types are not yet widely adopted. Don’t use in a - production environment unless you know what you’re doing. -

    - -

    - A muxed (or multiplexed) account (defined in{" "} - - CAP-27 - {" "} - and briefly{" "} - - SEP-23 - - ) is one that resolves a single Stellar G...account to many different - underlying IDs. -

    - -
    -

    Create Multiplexed Account

    - -
    -

    - {muxedAccountLabel.muxedAccountBaseAddress}: -

    - - { - dispatch(updateGenerateMuxedAccountInput({ gAddress })); - }} - data-testid="muxed-create-g-address" - /> -
    - -
    -

    - {muxedAccountLabel.muxedAccountId}: -

    - - { - dispatch(updateGenerateMuxedAccountInput({ mAccountId })); - }} - data-testid="muxed-create-m-id" - /> -
    - - - - {muxedAccountGenerated.errorMessage ? ( -

    - {muxedAccountGenerated.errorMessage} -

    - ) : null} - - {muxedAccountGenerated.mAddress ? ( -
    -
    -
    - {muxedAccountLabel.muxedAccountBaseAddress} -
    -
    - {muxedAccountGenerated.gAddress} -
    -
    -
    -
    - {muxedAccountLabel.muxedAccountId} -
    -
    - {muxedAccountGenerated.mAccountId} -
    -
    -
    -
    - {muxedAccountLabel.muxedAccountAddress} -
    -
    - {muxedAccountGenerated.mAddress} -
    -
    -
    - ) : null} -
    - -
    -

    - Get Muxed Account from M address -

    - -
    - { - dispatch(updateParseMuxedAccountInput(mAddress)); - }} - data-testid="muxed-parse-m-address" - /> -
    - - - - {muxedAccountParsed.errorMessage ? ( -

    - {muxedAccountParsed.errorMessage} -

    - ) : null} - - {muxedAccountParsed.gAddress && muxedAccountParsed.mAccountId ? ( -
    -
    -
    - {muxedAccountLabel.muxedAccountAddress} -
    -
    - {muxedAccountParsed.mAddress} -
    -
    -
    -
    - {muxedAccountLabel.muxedAccountBaseAddress} -
    -
    - {muxedAccountParsed.gAddress} -
    -
    -
    -
    - {muxedAccountLabel.muxedAccountId} -
    -
    - {muxedAccountParsed.mAccountId} -
    -
    -
    - ) : null} -
    -
    -
    - ); -}; diff --git a/src/views/NetworkPicker.js b/src/views/NetworkPicker.js deleted file mode 100644 index b061fbb0..00000000 --- a/src/views/NetworkPicker.js +++ /dev/null @@ -1,152 +0,0 @@ -import React from "react"; -import { connect } from "react-redux"; -import { - chooseNetwork, - setModalVisibility, - updateModal, - setCustomParams, -} from "actions/network.js"; -import NETWORK from "constants/network.js"; -import TextPicker from "components/FormComponents/TextPicker.js"; -import { addEventHandler } from "helpers/metrics.js"; -import networkMetrics from "metricsHandlers/network.js"; -import { - networkLocalStorageSaveValue, - networkLocalStorageGetValue, -} from "helpers/networkLocalStorage"; - -addEventHandler(networkMetrics); - -class NetworkPicker extends React.Component { - componentDidMount() { - const savedValues = networkLocalStorageGetValue(); - - if (savedValues) { - if (savedValues.name === "custom") { - this.props.dispatch(setCustomParams(savedValues)); - } else { - this.props.dispatch(chooseNetwork(savedValues.name)); - } - } - } - - render() { - let { dispatch } = this.props; - let { current, modal } = this.props; - - const setAndSaveNetwork = (network) => { - dispatch(chooseNetwork(network)); - networkLocalStorageSaveValue({ name: network }); - }; - - const saveAndSetCustomNetwork = (values) => { - dispatch(setCustomParams(values)); - networkLocalStorageSaveValue(values); - }; - - let items = Object.keys(NETWORK.available).map((n) => { - return ( - setAndSaveNetwork(n)} - /> - ); - }); - - return ( -
    - {modal.visible ? ( -
    -
    - -
    -

    Horizon URL:

    - - dispatch(updateModal("horizonURL", value)) - } - /> -

    Network Passphrase:

    - - dispatch(updateModal("networkPassphrase", value)) - } - /> - -
    -
    -
    - ) : null} -
    - {items} - dispatch(setModalVisibility(true))} - /> - - {current.horizonURL} -
    - ); - } -} - -const isValidHorizonURL = (u) => { - try { - new URL(u); - return true; - } catch (e) { - return "Value is not a valid URL"; - } -}; - -const NetworkToggle = (props) => { - let { name, onToggle, selected } = props; - return ( - - ); -}; - -export default connect(chooseState)(NetworkPicker); - -function chooseState(state) { - return { - current: state.network.current, - modal: state.network.modal, - }; -} diff --git a/src/views/OperationsBuilder.js b/src/views/OperationsBuilder.js deleted file mode 100644 index a0e3dd05..00000000 --- a/src/views/OperationsBuilder.js +++ /dev/null @@ -1,193 +0,0 @@ -import React from "react"; -import PropTypes from "prop-types"; -import { connect } from "react-redux"; -import map from "lodash/map"; -import PubKeyPicker from "../components/FormComponents/PubKeyPicker"; -import { getOperation } from "../data/operations"; -import { - duplicateOperation, - removeOperation, - updateOperationType, - updateOperationAttributes, - reorderOperation, -} from "../actions/transactionBuilder"; -import { OperationTypePicker } from "../components/FormComponents/OperationTypePicker"; -import OptionsTablePair from "../components/OptionsTable/Pair"; -import HelpMark from "../components/HelpMark"; - -class OperationsBuilder extends React.Component { - constructor() { - super(); - } - render() { - return ( -
    - {map(this.props.ops, (op, index) => { - return operation(this.props.ops, index, this.props.dispatch); - })} -
    - ); - } -} - -// takes in op state from the reducer -let operation = (ops, index, dispatch) => { - let op = ops[index]; - let opConfig = getOperation(op.name); - let operationPane, sourceAccountRow, separator; - let dispatchUpdateOpAtts = (key, value) => { - dispatch( - updateOperationAttributes(op.id, { - [key]: value, - }), - ); - }; - let helpNote, docsLink; - if (opConfig !== undefined) { - operationPane = opConfig.operationPane({ - onUpdate: dispatchUpdateOpAtts, - values: op.attributes, - }); - - helpNote = ( -

    {opConfig.helpNote}

    - ); - docsLink = ( -

    - - See documentation for {opConfig.label} - -

    - ); - - sourceAccountRow = ( - - dispatchUpdateOpAtts("sourceAccount", value)} - /> - - ); - - separator =
    ; - } - - let removeLink; - if (ops.length > 1) { - removeLink = ( - - ); - } - let duplicateLink; - if (ops.length >= 1) { - duplicateLink = ( - - ); - } - - return ( -
    -
    -
    - dispatch(reorderOperation(op.id, value))} - maxLength="2" - className="TransactionOpMeta__order__input" - /> -
    -
    - {duplicateLink} - {removeLink} -
    -
    -
    - - Operation Type{" "} - - - } - > - { - dispatch(updateOperationType(op.id, value)); - }} - /> - {helpNote} - {docsLink} - - {separator} - {operationPane} - {sourceAccountRow} -
    -
    - ); -}; - -export default connect(chooseState)(OperationsBuilder); - -function chooseState(state) { - return { - ops: state.transactionBuilder.operations, - }; -} - -// BlurNumberInput is a controller input component that calls onUpdate only when -// the user unfocuses the input -class BlurNumberInput extends React.Component { - constructor(props) { - super(props); - this.state = { - currentValue: props.value, - }; - } - UNSAFE_componentWillReceiveProps(nextProps) { - this.setState({ - currentValue: nextProps.value, - }); - } - onChange(event) { - this.setState({ - currentValue: event.target.value, - }); - } - onBlur(event) { - this.props.onUpdate(this.state.currentValue); - this.setState({ - currentValue: this.props.value, - }); - } - render() { - return ( - - ); - } -} -BlurNumberInput.propTypes = { - onUpdate: PropTypes.func.isRequired, - value: PropTypes.number.isRequired, -}; diff --git a/src/views/TransactionBuilder.js b/src/views/TransactionBuilder.js deleted file mode 100644 index 6e6ad91a..00000000 --- a/src/views/TransactionBuilder.js +++ /dev/null @@ -1,105 +0,0 @@ -import React from "react"; -import { connect } from "react-redux"; -import TxBuilderAttributes from "views/TxBuilderAttributes.js"; -import { - addOperation, - updateAttributes, - resetTxbuilder, -} from "actions/transactionBuilder.js"; -import OperationsBuilder from "views/OperationsBuilder.js"; -import TxBuilderResult from "views/TxBuilderResult.js"; -import { addEventHandler } from "helpers/metrics.js"; -import transactionBuilderMetrics from "metricsHandlers/transactionBuilder.js"; -import TX_TYPES from "constants/transaction_types.js"; - -addEventHandler(transactionBuilderMetrics); - -class TransactionBuilder extends React.Component { - render() { - let { dispatch } = this.props; - let { attributes, feeBumpAttributes, txType } = this.props.state; - - return ( -
    -
    -
    -
    -

    - The transaction builder lets you build a new Stellar - transaction. -

    -

    - This transaction will start out with no signatures. To make it - into the ledger, this transaction will then need to be signed - and submitted to the network. -

    -
    -

    - dispatch(resetTxbuilder())} - > - Clear form contents and start over - -

    - - {txType === TX_TYPES.REGULAR && ( - - -
    - -
    -
    - )} -
    -
    -
    -
    - -
    -
    -
    - ); - } -} - -export default connect(chooseState)(TransactionBuilder); - -function chooseState(state) { - return { - state: state.transactionBuilder, - }; -} - -function onAttributeUpdate(dispatch, param, value) { - let newAttributes = {}; - switch (param) { - case "sourceAccount": - newAttributes.sourceAccount = value; - break; - case "sequence": - newAttributes.sequence = value; - break; - case "fee": - newAttributes.fee = value; - break; - case "memo": - newAttributes.memoType = value.type; - newAttributes.memoContent = value.content; - break; - case "timebounds": - newAttributes.minTime = value.minTime; - newAttributes.maxTime = value.maxTime; - break; - } - dispatch(updateAttributes(newAttributes)); -} diff --git a/src/views/TransactionSigner.tsx b/src/views/TransactionSigner.tsx deleted file mode 100644 index 6be2a63a..00000000 --- a/src/views/TransactionSigner.tsx +++ /dev/null @@ -1,516 +0,0 @@ -import { useDispatch } from "react-redux"; -import * as StellarSdk from "@stellar/stellar-sdk"; -import { isConnected } from "@stellar/freighter-api"; -import isUndefined from "lodash/isUndefined"; -import map from "lodash/map"; -import { - importFromXdr, - clearTransaction, - setSecrets, - setBIPPath, - signWithLedger, - signWithTrezor, - signWithFreighter, - signWithAlbedo, -} from "actions/transactionSigner.js"; -import TransactionImporter from "components/TransactionImporter.js"; -import { EasySelect } from "components/EasySelect"; -import OptionsTablePair from "components/OptionsTable/Pair.js"; -import SecretKeyPicker from "components/FormComponents/SecretKeyPicker.js"; -import { MultiPicker } from "components/FormComponents/MultiPicker"; -import { BipPathPicker } from "components/FormComponents/BipPathPicker"; -import HelpMark from "components/HelpMark.js"; -import { txPostLink, xdrViewer, feeBumpTxLink } from "helpers/linkBuilder.js"; -import { useRedux } from "hooks/useRedux"; -import { clickToSelect } from "helpers/clickToSelect"; -import scrollOnAnchorOpen from "helpers/scrollOnAnchorOpen.js"; -import { validateTxXdr } from "helpers/validateTxXdr"; -import Libify from "helpers/Libify.js"; -import { addEventHandler } from "helpers/metrics.js"; -import transactionSignerMetrics from "metricsHandlers/transactionSigner.js"; -import { useIsSoroban } from "hooks/useIsSoroban"; - -const { signTransaction } = Libify; - -addEventHandler(transactionSignerMetrics); - -export const TransactionSigner = () => { - const dispatch = useDispatch(); - const { transactionSigner, network } = useRedux( - "transactionSigner", - "network", - ); - const networkPassphrase = network.current.networkPassphrase; - const isSoroban = useIsSoroban(); - - let TransactionBuilder, FeeBumpTransaction, Networks: any; - TransactionBuilder = StellarSdk.TransactionBuilder; - FeeBumpTransaction = StellarSdk.FeeBumpTransaction; - Networks = StellarSdk.Networks; - - const { - xdr, - signers, - bipPath, - hardwarewalletStatus, - freighterwalletStatus, - albedowalletStatus, - } = transactionSigner; - let content; - - if (validateTxXdr(xdr).result !== "success") { - content = ( -
    -
    -
    -

    - Import a transaction envelope in XDR format: -

    - dispatch(importFromXdr(xdr))} - /> -
    -
    -
    - ); - } else { - let walletSigs = hardwarewalletStatus.signatures; - let result = signTransaction( - xdr, - signers, - networkPassphrase, - walletSigs, - isSoroban, - ); - let transaction = TransactionBuilder.fromXDR(xdr, networkPassphrase); - - let infoTable = { - "Signing for": ( -
    -          {networkPassphrase}
    -        
    - ), - "Transaction Envelope XDR": ( - -
    -            {xdr}
    -          
    -
    - ), - "Transaction Hash": ( - -
    -            {transaction.hash().toString("hex")}
    -          
    -
    - ), - }; - - if (transaction instanceof FeeBumpTransaction) { - infoTable = { - ...infoTable, - ...{ - "Fee source account": ( - - {transaction.feeSource} - - ), - "Transaction Fee (stroops)": ( - - {transaction.fee} - - ), - "Number of existing signatures": ( - - {transaction.signatures.length} - - ), - "Inner transaction hash": ( - -
    -                
    -                  {transaction.innerTransaction.hash().toString("hex")}
    -                
    -              
    -
    - ), - "Inner transaction source account": ( - - {transaction.innerTransaction.source} - - ), - "Inner transaction sequence number": ( - - {transaction.innerTransaction.sequence} - - ), - "Inner transaction fee (stroops)": ( - - {transaction.innerTransaction.fee} - - ), - "Inner transaction number of operations": ( - - {transaction.innerTransaction.operations.length} - - ), - "Inner transaction number of existing signatures": ( - - {transaction.innerTransaction.signatures.length} - - ), - }, - }; - } else { - infoTable = { - ...infoTable, - ...{ - "Source account": ( - - {transaction.source} - - ), - "Sequence number": ( - - {transaction.sequence} - - ), - "Transaction Fee (stroops)": ( - {transaction.fee} - ), - "Number of operations": ( - - {transaction.operations.length} - - ), - "Number of existing signatures": ( - - {transaction.signatures.length} - - ), - }, - }; - } - - let codeResult, - submitLink, - xdrLink, - resultTitle, - submitInstructions, - feeBumpLink; - const signedXdr = - freighterwalletStatus.signedTx || - albedowalletStatus.signedTx || - result.xdr; - - if (!isUndefined(signedXdr)) { - codeResult = ( -
    -          {signedXdr}
    -        
    - ); - submitLink = ( - - Submit in Transaction Submitter - - ); - xdrLink = ( - - View in XDR Viewer - - ); - feeBumpLink = ( - - Wrap with Fee Bump - - ); - resultTitle = ( -

    Transaction signed!

    - ); - submitInstructions = ( -

    - Now that this transaction is signed, you can submit it to the network. - Horizon provides an endpoint called Post Transaction that will relay - your transaction to the network and inform you of the result. -

    - ); - } - - let hardwarewalletMessage; - if (hardwarewalletStatus.message) { - let messageAlertType; - if (hardwarewalletStatus.status === "loading") { - messageAlertType = "s-alert--info"; - } else if (hardwarewalletStatus.status === "success") { - messageAlertType = "s-alert--success"; - } else if (hardwarewalletStatus.status === "failure") { - messageAlertType = "s-alert--alert"; - } - - hardwarewalletMessage = ( -
    -
    -
    - {" "} - {hardwarewalletStatus.message}{" "} -
    -
    - ); - } - - let freighterwalletMessage; - if (freighterwalletStatus.message) { - let messageAlertType; - if (freighterwalletStatus.status === "loading") { - messageAlertType = "s-alert--info"; - } else if (freighterwalletStatus.status === "success") { - messageAlertType = "s-alert--success"; - } else if (freighterwalletStatus.status === "failure") { - messageAlertType = "s-alert--alert"; - } - - freighterwalletMessage = ( -
    -
    -
    - {" "} - {freighterwalletStatus.message}{" "} -
    -
    - ); - } - - let albedowalletMessage; - if (albedowalletStatus.message) { - let messageAlertType; - if (albedowalletStatus.status === "loading") { - messageAlertType = "s-alert--info"; - } else if (albedowalletStatus.status === "success") { - messageAlertType = "s-alert--success"; - } else if (albedowalletStatus.status === "failure") { - messageAlertType = "s-alert--alert"; - } - - albedowalletMessage = ( -
    -
    -
    - {" "} - {albedowalletStatus.message}{" "} -
    -
    - ); - } - - content = ( -
    -
    -
    -
    - -
    - {map(infoTable, (content, label) => { - return ( -
    -
    {label}
    -
    {content}
    -
    - ); - })} -
    -
    -
    -
    -
    -

    - Signatures{" "} - -

    -
    - - dispatch(setSecrets(value))} - /> - - - dispatch(setBIPPath(value))} - /> -
    - - - -
    -

    - NOTE: Trezor devices require upper time bounds to be set - (non-zero), otherwise the signature will not be verified. -

    - {hardwarewalletMessage} -
    - {isConnected() && ( - - - {freighterwalletMessage} - - )} - - - {albedowalletMessage} - -
    -
    -
    -
    -
    -
    - {resultTitle} -

    {result.message}

    - {codeResult} - {submitInstructions} - {submitLink} {xdrLink} {feeBumpLink} -
    -
    -
    - ); - } - - return ( -
    -
    -
    -
    -

    - The transaction signer lets you add signatures to a Stellar - transaction. Signatures are used in the network to prove that the - account is authorized to perform the operations in the - transaction. -

    -

    - For simple transactions, you only need one signature from the - correct account. Some advanced transactions may require more than - one signature if there are multiple source accounts or signing - keys. -

    -

    - - Read more about signatures on the developer's site. - -

    -
    -
    -
    - {content} -
    - ); -}; diff --git a/src/views/TransactionSubmitter.tsx b/src/views/TransactionSubmitter.tsx deleted file mode 100644 index 1f5f267f..00000000 --- a/src/views/TransactionSubmitter.tsx +++ /dev/null @@ -1,116 +0,0 @@ -import { useMemo } from "react"; -import { useDispatch } from "react-redux"; -import debounce from "lodash/debounce"; -import { FETCHED_SIGNERS } from "constants/fetched_signers"; -import extrapolateFromXdr from "helpers/extrapolateFromXdr.js"; -import { validateBase64 } from "helpers/validateBase64"; -import { addEventHandler, logEvent } from "helpers/metrics.js"; -import { useRedux } from "hooks/useRedux"; -import xdrViewerMetrics, { metricsEvents } from "metricsHandlers/xdrViewer.js"; -import { TreeView } from "components/TreeView"; -import { TxSubmitterResult } from "components/TxSubmitterResult"; -import { updateXdrInput, fetchSigners } from "actions/xdrViewer.js"; -import { TransactionNode } from "types/types"; - -// XDR decoding doesn't happen in redux, but is pretty much the only thing on -// this page that we care about. Log metrics from the component as well. -addEventHandler(xdrViewerMetrics); - -const tLogEvent = debounce(logEvent, 1000); - -export const TransactionSubmitter = () => { - const dispatch = useDispatch(); - const { xdrViewer, network } = useRedux("xdrViewer", "network"); - const { fetchedSigners, input } = xdrViewer; - const { horizonURL, networkPassphrase } = network.current; - const { error, nodes } = useMemo(() => { - if (input === "") { - return { - error: `Enter a base-64 encoded XDR blob to decode.`, - nodes: null, - }; - } else { - const validation = validateBase64(input); - - if (validation.result === "error") { - return { - error: validation.message, - nodes: null, - }; - } - try { - return { - error: null, - nodes: extrapolateFromXdr(input, "TransactionEnvelope"), - }; - } catch (e) { - console.error(e); - tLogEvent(metricsEvents.decodeFailed, { type: "TransactionEnvelope" }); - return { - error: `Unable to decode input as TransactionEnvelope`, - nodes: null, - }; - } - } - }, [input]); - - // Fetch signers on initial load - if (fetchedSigners.state === FETCHED_SIGNERS.NONE) { - dispatch(fetchSigners(input, horizonURL, networkPassphrase)); - } - - return ( -
    -
    -
    -

    - Input a base-64 encoded TransactionEnvelope: -

    -
    - -
    -
    -
    - -
    -
    - {error && ( -
    -

    - {error} -

    -
    - )} - {nodes && ( - - )} -
    -
    -
    - ); -}; diff --git a/src/views/TxBuilderAttributes.js b/src/views/TxBuilderAttributes.js deleted file mode 100644 index d7ea6cd0..00000000 --- a/src/views/TxBuilderAttributes.js +++ /dev/null @@ -1,352 +0,0 @@ -import React, { useEffect, useState } from "react"; -import { connect } from "react-redux"; -import { StrKey, MuxedAccount } from "@stellar/stellar-sdk"; -import OptionsTablePair from "../components/OptionsTable/Pair"; -import HelpMark from "../components/HelpMark"; -import TxTypePicker from "../components/FormComponents/TxTypePicker"; -import PubKeyPicker from "../components/FormComponents/PubKeyPicker"; -import SequencePicker from "../components/FormComponents/SequencePicker"; -import StroopsPicker from "../components/FormComponents/StroopsPicker"; -import MemoPicker from "../components/FormComponents/MemoPicker"; -import TimeBoundsPicker from "../components/FormComponents/TimeBoundsPicker"; -import NETWORK from "../constants/network"; -import { - fetchSequence, - fetchBaseFee, - updateTxType, - updateFeeBumpAttribute, -} from "../actions/transactionBuilder"; -import TransactionImporter from "../components/TransactionImporter"; -import TX_TYPES from "../constants/transaction_types"; - -function TxBuilderAttributes(props) { - let { - onUpdate, - attributes, - horizonURL, - dispatch, - feeBumpAttributes, - networkPassphrase, - } = props; - const { txType, network } = props.state; - const [networkBaseFee, setNetworkBaseFee] = useState(attributes["baseFee"]); - const [networkMinFee, setNetworkMinFee] = useState(attributes["minFee"]); - - useEffect(() => { - // Don't fetch base fee again if txn has a sequence number (when returning - // to Build Transaction tab). Refetching base fee resets previously set fee. - if (!attributes.sequence) { - dispatch(fetchBaseFee(horizonURL)); - } - }, []); - - useEffect(() => { - setNetworkBaseFee(attributes["baseFee"]); - setNetworkMinFee(attributes["minFee"]); - }, [attributes["baseFee"], attributes["minFee"]]); - - return ( -
    -
    - - Transaction Type{" "} - - - } - > - { - dispatch(updateTxType(value)); - }} - /> - - {txType === TX_TYPES.REGULAR && ( - - - Source Account{" "} - - - } - > - { - onUpdate("sourceAccount", value); - }} - /> -

    - If you don't have an account yet, you can create and fund a test - net account with the{" "} - account creator. -

    -
    - - Transaction Sequence Number{" "} - - - } - > - { - onUpdate("sequence", value); - }} - /> -

    - The transaction sequence number is usually one higher than - current account sequence number. -

    - -
    - - Base Fee{" "} - - - } - > - { - onUpdate("fee", value); - }} - /> -

    - The{" "} - - network base fee - {" "} - is currently set to {networkBaseFee} stroops ( - {networkBaseFee / 1e7} lumens). Based on current network - activity, we suggest setting it to {networkMinFee} stroops. - Final transaction fee is equal to base fee times number of - operations in this transaction. -

    -
    - - Memo{" "} - - - } - > - { - onUpdate("memo", value); - }} - /> - - - Time Bounds{" "} - - - } - > - { - onUpdate("timebounds", value); - }} - /> -

    - Enter{" "} - - unix timestamp - {" "} - values of time bounds when this transaction will be valid. -

    -

    - For regular transactions, it is highly recommended to set{" "} - max_time to get{" "} - - a final result - {" "} - of a transaction in a defined time. -

    -

    - - onUpdate("timebounds", { - maxTime: Math.ceil(new Date().getTime() / 1000) + 5 * 60, - }) - } - > - Set to 5 minutes from now - -
    -

    -
    -
    - )} - {txType === TX_TYPES.FEE_BUMP && ( - - - Source Account{" "} - - - } - > - { - dispatch(updateFeeBumpAttribute({ sourceAccount: value })); - }} - /> -

    - The account responsible for paying the transaction fee. -

    -
    - - Base Fee{" "} - - - } - > - { - dispatch(updateFeeBumpAttribute({ maxFee: value })); - }} - /> -

    - The{" "} - - network base fee - {" "} - is currently set to {networkBaseFee} stroops ( - {networkBaseFee / 1e7} lumens). Based on current network - activity, we suggest setting it to {networkMinFee} stroops. - Final transaction fee is equal to base fee times number of - operations in this transaction. -

    -
    - - Inner Transaction XDR{" "} - - - } - > - { - dispatch(updateFeeBumpAttribute({ innerTxXDR: value })); - }} - /> - -
    - )} -
    -
    - ); -} - -export default connect(chooseState)(TxBuilderAttributes); - -class sequenceFetcherClass extends React.Component { - render() { - let { attributes, sequenceFetcherError } = this.props.state; - let dispatch = this.props.dispatch; - let horizonURL = this.props.horizonURL; - const isMAddress = StrKey.isValidMed25519PublicKey( - attributes.sourceAccount, - ); - if ( - !StrKey.isValidEd25519PublicKey(attributes.sourceAccount) && - !isMAddress - ) { - return null; - } - - let sourceAccount = attributes.sourceAccount; - - if (isMAddress) { - const muxedAccount = new MuxedAccount.fromAddress( - attributes.sourceAccount, - "0", - ); - sourceAccount = muxedAccount.baseAccount().accountId(); - } - - let sequenceErrorMessage; - if (sequenceFetcherError.length > 0) { - sequenceErrorMessage = ( - - {sequenceFetcherError} - - ); - } - - let truncatedAccountId = sourceAccount.substr(0, 10); - - return ( - <> - {isMAddress ? ( -

    - Source account is M address, use base account’s G address to get the - sequence number. -

    - ) : null} - {sequenceErrorMessage} -

    - dispatch(fetchSequence(sourceAccount, horizonURL))} - > - Fetch next sequence number for account starting with " - {truncatedAccountId}" - -
    - - Fetching from: {horizonURL} - -
    -

    - - ); - } -} - -let SequenceFetcher = connect(chooseState)(sequenceFetcherClass); -function chooseState(state) { - return { - state: state.transactionBuilder, - horizonURL: state.network.current.horizonURL, - networkPassphrase: state.network.current.networkPassphrase, - }; -} diff --git a/src/views/TxBuilderResult.js b/src/views/TxBuilderResult.js deleted file mode 100644 index 80552c74..00000000 --- a/src/views/TxBuilderResult.js +++ /dev/null @@ -1,168 +0,0 @@ -import React from "react"; -import { connect } from "react-redux"; -import { isConnected } from "@stellar/freighter-api"; -import reduce from "lodash/reduce"; -import { EasySelect } from "components/EasySelect"; -import Libify from "helpers/Libify.js"; -import { txSignerLink, xdrViewer } from "helpers/linkBuilder.js"; -import scrollOnAnchorOpen from "helpers/scrollOnAnchorOpen.js"; -import TX_TYPES from "constants/transaction_types.js"; - -class TxBuilderResult extends React.Component { - render() { - let { attributes, operations, feeBumpAttributes, txType } = - this.props.state; - - const getRegularTxValidationErrors = () => { - const errors = []; - if (attributes.sourceAccount === "") { - errors.push("Source account ID is a required field"); - } - if (attributes.sequence === "") { - errors.push("Sequence number is a required field"); - } - let memoIsNone = - attributes.memoType === "MEMO_NONE" || attributes.memoType === ""; - if (!memoIsNone && attributes.memoContent === "") { - errors.push("Memo content is required if memo type is selected"); - } - return errors; - }; - - const getFeeBumpTxValidationErrors = () => { - const errors = []; - if (feeBumpAttributes.sourceAccount === "") { - errors.push("Source Account is a required field"); - } - if (feeBumpAttributes.maxFee === "") { - errors.push("Base Fee is a required field"); - } - if (feeBumpAttributes.innerTxXDR === "") { - errors.push("Inner Transaction is a required field"); - } - return errors; - }; - - let validationErrors; - if (txType === TX_TYPES.FEE_BUMP) { - validationErrors = getFeeBumpTxValidationErrors(); - } else { - validationErrors = getRegularTxValidationErrors(); - } - - let finalResult, - errorTitleText, - successTitleText, - signingInstructions, - signingLink, - xdrLink, - transactionBuild; - if (validationErrors.length > 0) { - errorTitleText = "Form validation errors:"; - finalResult = formatErrorList(validationErrors); - } else { - transactionBuild = - txType === TX_TYPES.FEE_BUMP - ? Libify.buildFeeBumpTransaction( - feeBumpAttributes, - this.props.networkPassphrase, - ) - : Libify.buildTransaction( - attributes, - operations, - this.props.networkPassphrase, - ); - - if (transactionBuild.errors.length > 0) { - errorTitleText = `Transaction building errors:`; - finalResult = formatErrorList(transactionBuild.errors); - } else { - successTitleText = `Success! Transaction Envelope XDR:`; - finalResult = ( -
    - Network Passphrase: -
    - {this.props.networkPassphrase} -
    - Hash: -
    - {transactionBuild.hash} -
    - XDR: -
    - {transactionBuild.xdr} -
    - ); - signingInstructions = ( -

    - In order for the transaction to make it into the ledger, a - transaction must be successfully signed and submitted to the - network. The laboratory provides the{" "} - Transaction Signer for signing a - transaction, and the{" "} - - Post Transaction endpoint - {" "} - for submitting one to the network. -

    - ); - signingLink = ( - - Sign in Transaction Signer - - ); - xdrLink = ( - - View in XDR Viewer - - ); - } - } - - let errorTitle = errorTitleText ? ( -

    {errorTitleText}

    - ) : null; - let successTitle = successTitleText ? ( -

    {successTitleText}

    - ) : null; - - return ( -
    - {successTitle} - {errorTitle} -
    -          {finalResult}
    -        
    - {signingInstructions} - {signingLink} {xdrLink} -
    - ); - } -} - -export default connect(chooseState)(TxBuilderResult); - -function chooseState(state) { - return { - state: state.transactionBuilder, - networkPassphrase: state.network.current.networkPassphrase, - }; -} - -function formatErrorList(errors) { - return reduce( - errors, - (result, error) => { - return `${result}- ${error} \n`; - }, - "", - ); -} diff --git a/src/views/XdrViewer.tsx b/src/views/XdrViewer.tsx deleted file mode 100644 index 6867a192..00000000 --- a/src/views/XdrViewer.tsx +++ /dev/null @@ -1,149 +0,0 @@ -import { useDispatch } from "react-redux"; -import * as StellarSdk from "@stellar/stellar-sdk"; -import debounce from "lodash/debounce"; -import functions from "lodash/functions"; -import indexOf from "lodash/indexOf"; -import { FETCHED_SIGNERS } from "constants/fetched_signers"; -import { SelectPicker } from "components/FormComponents/SelectPicker"; -import extrapolateFromXdr from "helpers/extrapolateFromXdr.js"; -import { TreeView } from "components/TreeView"; -import { useRedux } from "hooks/useRedux"; -import { validateBase64 } from "helpers/validateBase64"; -import { - updateXdrInput, - updateXdrType, - fetchLatestTx, - fetchSigners, -} from "actions/xdrViewer.js"; -import { addEventHandler, logEvent } from "helpers/metrics.js"; -import xdrViewerMetrics, { metricsEvents } from "metricsHandlers/xdrViewer.js"; -import { TransactionNode } from "types/types"; - -// XDR decoding doesn't happen in redux, but is pretty much the only thing on -// this page that we care about. Log metrics from the component as well. -addEventHandler(xdrViewerMetrics); - -const tLogEvent = debounce(logEvent, 1000); - -export const XdrViewer = () => { - const dispatch = useDispatch(); - const { xdrViewer, network } = useRedux("xdrViewer", "network"); - const { fetchedSigners, input, type } = xdrViewer; - const { horizonURL, networkPassphrase } = network.current; - // Array of all the xdr types. Then, the most common ones appear at the top - // again for convenience - let xdrTypes = functions(StellarSdk.xdr).sort(); - xdrTypes = [ - "TransactionEnvelope", - "TransactionResult", - "TransactionMeta", - "---", - ].concat(xdrTypes); - const validation = validateBase64(input); - const messageClass = - validation.result === "error" - ? "xdrInput__message__alert" - : "xdrInput__message__success"; - const message =

    {validation.message}

    ; - const xdrTypeIsValid = indexOf(xdrTypes, type) >= 0; - - let treeView; - let errorMessage; - - if (input === "") { - errorMessage =

    Enter a base-64 encoded XDR blob to decode.

    ; - } else if (!xdrTypeIsValid) { - errorMessage =

    Please select a XDR type

    ; - } else { - try { - treeView = ( - - ); - tLogEvent(metricsEvents.decodeSuccess, { type }); - } catch (e) { - console.error(e); - tLogEvent(metricsEvents.decodeFailed, { type }); - errorMessage =

    Unable to decode input as {type}

    ; - } - } - - // Fetch signers on initial load - if ( - input !== "" && - type === "TransactionEnvelope" && - fetchedSigners.state === FETCHED_SIGNERS.NONE - ) { - dispatch(fetchSigners(input, horizonURL, networkPassphrase)); - } - - return ( -
    -
    -
    -
    -

    - - External Data Representation (XDR) - {" "} - is a standardized protocol that the Stellar network uses to encode - data. -

    -

    - The XDR Viewer is a tool that displays contents of a Stellar XDR - blob in a human readable format. -

    -
    -

    - Input a base-64 encoded XDR blob, or{" "} - - dispatch(fetchLatestTx(horizonURL, networkPassphrase)) - } - > - fetch the latest transaction to try it out - - : -

    -
    - -
    -
    {message}
    - -

    XDR type:

    - dispatch(updateXdrType(input))} - items={xdrTypes} - /> -
    -
    -
    -
    - {errorMessage} - {treeView} -
    -
    -
    - ); -}; diff --git a/src/views/__tests__/AccountCreator.test.tsx b/src/views/__tests__/AccountCreator.test.tsx deleted file mode 100644 index cadb64a5..00000000 --- a/src/views/__tests__/AccountCreator.test.tsx +++ /dev/null @@ -1,138 +0,0 @@ -/** - * @jest-environment jsdom - */ -import { fireEvent, screen, waitFor, within } from "@testing-library/react"; -import { render } from "helpers/testHelpers"; -import { AccountCreator } from "views/AccountCreator"; - -const PUBLIC_KEY = "foo"; -const SECRET_KEY = "bar"; -const MUXED_ACCOUNT_ID = 1; -const MUXED_ACCOUNT_CREATED = "baz-1"; -const MUXED_ACCOUNT_PARSED = "baz-2"; - -jest.mock("@stellar/stellar-sdk"); - -// StellarSdk.Keypair.random.mockReturnValue({ -// publicKey: () => PUBLIC_KEY, -// secret: () => SECRET_KEY, -// }); - -// StellarSdk.MuxedAccount.mockImplementation(() => { -// return { -// accountId: jest.fn(() => MUXED_ACCOUNT_CREATED), -// }; -// }); - -// StellarSdk.MuxedAccount.fromAddress.mockImplementation(() => { -// return { -// baseAccount: jest.fn(() => ({ -// accountId: jest.fn(() => MUXED_ACCOUNT_PARSED), -// })), -// id: jest.fn(() => MUXED_ACCOUNT_ID), -// }; -// }); - -beforeEach(() => { - render(); -}); - -test("renders create account page", async () => { - await waitFor(() => screen.queryByTestId("page-account-creator")); - expect(screen.getByTestId("page-account-creator")).toBeInTheDocument(); -}); - -test("keypair generator: generates a keypair on testnet", async () => { - fireEvent.click(screen.getByText(/generate keypair/i)); - await waitFor(() => screen.queryByTestId("publicKey")); - - expect(screen.getByTestId("publicKey")).toHaveTextContent(PUBLIC_KEY); - expect(screen.getByTestId("secretKey")).toHaveTextContent(SECRET_KEY); -}); - -test("friendbot: prefill address when link is clicked", async () => { - const friendbotLinkSelector = - /fund this account on the test network using the friendbot tool below/i; - - fireEvent.click(screen.getByText(/generate keypair/i)); - await waitFor(() => { - fireEvent.click(screen.getByText(friendbotLinkSelector)); - }); - - expect(screen.getByTestId("friendbot-test-account")).toHaveValue(PUBLIC_KEY); -}); - -test("friendbot: account funded successfully", async () => { - const friendbotLinkSelector = - /fund this account on the test network using the friendbot tool below/i; - - fireEvent.click(screen.getByText(/generate keypair/i)); - await waitFor(() => { - fireEvent.click(screen.getByText(friendbotLinkSelector)); - }); - - await waitFor(() => { - fireEvent.click(screen.getByText(/get test network lumens/i)); - }); - - const friendbotContainer = screen.getByTestId("page-friendbot"); - - await waitFor(() => { - within(friendbotContainer).queryByText(/loading/i); - }); - - await waitFor(() => - expect( - within(friendbotContainer).getByText(/successfully funded/i), - ).toBeInTheDocument(), - ); -}); - -test("muxed account: renders on the page", async () => { - await waitFor(() => screen.getByTestId("page-muxed-account")); - expect(screen.getByTestId("page-muxed-account")).toBeInTheDocument(); -}); - -test("muxed account: creates m address", async () => { - const baseAccountInput = screen.getByTestId("muxed-create-g-address"); - const muxedAccountIdInput = screen.getByTestId("muxed-create-m-id"); - const createButton = screen.getByTestId("muxed-create-button"); - - fireEvent.change(baseAccountInput, { target: { value: PUBLIC_KEY } }); - fireEvent.change(muxedAccountIdInput, { - target: { value: MUXED_ACCOUNT_ID }, - }); - fireEvent.click(createButton); - - await waitFor(() => - within(screen.getByTestId("page-muxed-account")).getByText( - MUXED_ACCOUNT_CREATED, - ), - ); - - expect( - within(screen.getByTestId("page-muxed-account")).getByText( - MUXED_ACCOUNT_CREATED, - ), - ).toBeInTheDocument(); -}); - -test("muxed account: parses m address", async () => { - const mAccountInput = screen.getByTestId("muxed-parse-m-address"); - const parseButton = screen.getByTestId("muxed-parse-button"); - - fireEvent.change(mAccountInput, { target: { value: MUXED_ACCOUNT_CREATED } }); - fireEvent.click(parseButton); - - await waitFor(() => - within(screen.getByTestId("page-muxed-account")).getByText( - MUXED_ACCOUNT_PARSED, - ), - ); - - expect( - within(screen.getByTestId("page-muxed-account")).getByText( - MUXED_ACCOUNT_PARSED, - ), - ).toBeInTheDocument(); -}); diff --git a/src/views/__tests__/AppContent.test.tsx b/src/views/__tests__/AppContent.test.tsx deleted file mode 100644 index fb4be1c1..00000000 --- a/src/views/__tests__/AppContent.test.tsx +++ /dev/null @@ -1,63 +0,0 @@ -/** - * @jest-environment jsdom - */ -import { waitFor, screen, within, fireEvent } from "@testing-library/react"; -import { render } from "helpers/testHelpers"; -import { AppContent } from "views/AppContent"; - -jest.spyOn(console, "error").mockImplementation(() => { - // do nothing -}); - -beforeEach(() => { - render(); -}); - -test("renders page header", async () => { - await waitFor(() => screen.getByTestId("page-header")); - - expect(screen.getByTestId("page-header")).toBeInTheDocument(); - expect(screen.getByTestId("network-picker")).toBeInTheDocument(); -}); - -test("shows maintenance banner on test network", async () => { - await waitFor(() => screen.getByTestId("network-picker")); - - const networkPickerEl = screen.getByTestId("network-picker"); - const publicLink = within(networkPickerEl).getByLabelText(/public/i); - const testLink = within(networkPickerEl).getByLabelText(/test/i); - - fireEvent.click(publicLink); - expect(screen.queryByTestId("maintenance-banner")).not.toBeInTheDocument(); - - fireEvent.click(testLink); - await waitFor(() => screen.queryByTestId("maintenance-banner")); - expect(screen.queryByTestId("maintenance-banner")).toBeInTheDocument(); -}); - -test("shows custom network modal", async () => { - await waitFor(() => screen.getByTestId("network-picker")); - - const networkPickerEl = screen.getByTestId("network-picker"); - const customLink = within(networkPickerEl).getByLabelText(/custom/i); - - fireEvent.click(customLink); - await waitFor(() => screen.queryByTestId("network-picker-custom-modal")); - - const customModalEl = screen.queryByTestId("network-picker-custom-modal"); - expect(customModalEl).toBeInTheDocument(); -}); - -test("renders page navigation", async () => { - await waitFor(() => screen.getByTestId("page-navigation")); - - const navigationEl = screen.getByTestId("page-navigation"); - expect(navigationEl).toBeInTheDocument(); - expect(screen.getAllByTestId("page-navigation-link")).toHaveLength(7); -}); - -test("renders page footer", async () => { - await waitFor(() => screen.getByTestId("page-footer")); - - expect(screen.getByTestId("page-footer")).toBeInTheDocument(); -}); diff --git a/src/views/__tests__/EndpointExplorer.test.tsx b/src/views/__tests__/EndpointExplorer.test.tsx deleted file mode 100644 index c82396f2..00000000 --- a/src/views/__tests__/EndpointExplorer.test.tsx +++ /dev/null @@ -1,2128 +0,0 @@ -/** - * @jest-environment jsdom - */ -import { fireEvent, screen, waitFor, within } from "@testing-library/react"; - -import { render, ENDPOINT_RESPONSE } from "helpers/testHelpers"; -import { EndpointExplorer } from "views/EndpointExplorer"; - -let resourceContainer: HTMLElement; - -const TEST_ID_ENDPOINT = "endpoint-explorer-endpoint"; -const TEST_ID_INPUTS = "page-endpoint-inputs"; -const TEST_ID_RESULT_LOADING = "page-endpoint-result-loading"; -const TEST_ID_RESULT_RESPONSE = "page-endpoint-result-response"; - -beforeEach(async () => { - render(); - - await waitFor(() => screen.queryByTestId("endpoint-explorer-resource")); - resourceContainer = screen.getByTestId("endpoint-explorer-resource"); -}); - -test("renders endpoint explorer page", async () => { - await waitFor(() => - expect(screen.getByTestId("page-endpoint-explorer")).toBeInTheDocument(), - ); -}); - -test("renders all resource links", () => { - expect(resourceContainer).toBeInTheDocument(); - expect(within(resourceContainer).getAllByRole("link")).toHaveLength(15); -}); - -describe("accounts", () => { - const RESOURCE_LINK_LABEL = "accounts"; - const SUBMIT_LABEL = "submit"; - let accountsEndpointsContainer: HTMLElement; - let accountsEndpointInputs: HTMLElement; - let accountsEndpointSubmitButton: HTMLElement; - let accountsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - accountsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(accountsEndpointsContainer).getAllByRole("link"), - ).toHaveLength(2); - }); - - // render resource input form with submit + submit response - test("resource: accounts submit with response", async () => { - const accountsButton = within(accountsEndpointsContainer).getByText( - /accounts/i, - ); - - expect(accountsButton).toBeInTheDocument(); - fireEvent.click(accountsButton); - - await waitFor(() => { - accountsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(accountsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - accountsEndpointSubmitButton = within(accountsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(accountsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(accountsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - accountsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(accountsEndpointResponse).toBeInTheDocument(); - expect( - within(accountsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.accounts, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single account submit with response", async () => { - const singleAccountButton = within(accountsEndpointsContainer).getByText( - /single account/i, - ); - - expect(singleAccountButton).toBeInTheDocument(); - fireEvent.click(singleAccountButton); - - await waitFor(() => { - accountsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(accountsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - accountsEndpointSubmitButton = within(accountsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(accountsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(accountsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - accountsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(accountsEndpointResponse).toBeInTheDocument(); - expect( - within(accountsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_account, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("assets", () => { - const RESOURCE_LINK_LABEL = "assets"; - const SUBMIT_LABEL = "submit"; - let assetsEndpointsContainer: HTMLElement; - let assetsEndpointInputs: HTMLElement; - let assetsEndpointSubmitButton: HTMLElement; - let assetsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - assetsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(assetsEndpointsContainer).getAllByRole("link")).toHaveLength( - 1, - ); - }); - - // render resource input form with submit + submit response - test("resource: all assets submit with response", async () => { - const allAssetsButton = within(assetsEndpointsContainer).getByText( - /all assets/i, - ); - - expect(allAssetsButton).toBeInTheDocument(); - fireEvent.click(allAssetsButton); - - await waitFor(() => { - assetsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(assetsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - assetsEndpointSubmitButton = within(assetsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(assetsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(assetsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - assetsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(assetsEndpointResponse).toBeInTheDocument(); - expect( - within(assetsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_assets, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("claimable balances", () => { - const RESOURCE_LINK_LABEL = "claimable balances"; - const SUBMIT_LABEL = "submit"; - let claimableBalancessContainer: HTMLElement; - let claimableBalancesInputs: HTMLElement; - let claimableBalancesSubmitButton: HTMLElement; - let claimableBalancesResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - claimableBalancessContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(claimableBalancessContainer).getAllByRole("link"), - ).toHaveLength(2); - }); - - // render resource input form with submit + submit response - test("resource: all claimable balances submit with response", async () => { - const allClaimableBalancesButton = within( - claimableBalancessContainer, - ).getByText(/all claimable balances/i); - - expect(allClaimableBalancesButton).toBeInTheDocument(); - fireEvent.click(allClaimableBalancesButton); - - await waitFor(() => { - claimableBalancesInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(claimableBalancesInputs).toBeInTheDocument(); - - await waitFor(() => { - claimableBalancesSubmitButton = within(claimableBalancesInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(claimableBalancesSubmitButton).toBeInTheDocument(); - - fireEvent.click(claimableBalancesSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - claimableBalancesResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(claimableBalancesResponse).toBeInTheDocument(); - expect( - within(claimableBalancesResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_claimable_balances, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single claimable balance submit with response", async () => { - const singleClaimableBalanceButton = within( - claimableBalancessContainer, - ).getByText(/single claimable balance/i); - - expect(singleClaimableBalanceButton).toBeInTheDocument(); - fireEvent.click(singleClaimableBalanceButton); - - await waitFor(() => { - claimableBalancesInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(claimableBalancesInputs).toBeInTheDocument(); - - await waitFor(() => { - claimableBalancesSubmitButton = within(claimableBalancesInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(claimableBalancesSubmitButton).toBeInTheDocument(); - - fireEvent.click(claimableBalancesSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - claimableBalancesResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(claimableBalancesResponse).toBeInTheDocument(); - expect( - within(claimableBalancesResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_claimable_balance, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("effects", () => { - const RESOURCE_LINK_LABEL = "effects"; - const SUBMIT_LABEL = "submit"; - let effectsEndpointsContainer: HTMLElement; - let effectsEndpointInputs: HTMLElement; - let effectsEndpointSubmitButton: HTMLElement; - let effectsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - effectsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(effectsEndpointsContainer).getAllByRole("link")).toHaveLength( - 6, - ); - }); - - // render resource input form with submit + submit response - test("resource: all effects submit with response", async () => { - const allEffectsButton = within(effectsEndpointsContainer).getByText( - /all effects/i, - ); - - expect(allEffectsButton).toBeInTheDocument(); - fireEvent.click(allEffectsButton); - - await waitFor(() => { - effectsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(effectsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - effectsEndpointSubmitButton = within(effectsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(effectsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(effectsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - effectsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(effectsEndpointResponse).toBeInTheDocument(); - expect( - within(effectsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_effects, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: effects for account submit with response", async () => { - const effectsForAccountButton = within(effectsEndpointsContainer).getByText( - /effects for account/i, - ); - - expect(effectsForAccountButton).toBeInTheDocument(); - fireEvent.click(effectsForAccountButton); - - await waitFor(() => { - effectsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(effectsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - effectsEndpointSubmitButton = within(effectsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(effectsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(effectsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - effectsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(effectsEndpointResponse).toBeInTheDocument(); - expect( - within(effectsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.effects_for_account, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: effects for ledger submit with response", async () => { - const effectsForLedgerButton = within(effectsEndpointsContainer).getByText( - /effects for ledger/i, - ); - - expect(effectsForLedgerButton).toBeInTheDocument(); - fireEvent.click(effectsForLedgerButton); - - await waitFor(() => { - effectsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(effectsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - effectsEndpointSubmitButton = within(effectsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(effectsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(effectsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - effectsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(effectsEndpointResponse).toBeInTheDocument(); - expect( - within(effectsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.effects_for_ledger, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: effects for liquidity pool submit with response", async () => { - const effectsForLiquidityPoolButton = within( - effectsEndpointsContainer, - ).getByText(/effects for liquidity pool/i); - - expect(effectsForLiquidityPoolButton).toBeInTheDocument(); - fireEvent.click(effectsForLiquidityPoolButton); - - await waitFor(() => { - effectsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(effectsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - effectsEndpointSubmitButton = within(effectsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(effectsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(effectsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - effectsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(effectsEndpointResponse).toBeInTheDocument(); - expect( - within(effectsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.effects_for_liquidity_pool, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: effects for operation submit with response", async () => { - const effectsForOperationButton = within( - effectsEndpointsContainer, - ).getByText(/effects for operation/i); - - expect(effectsForOperationButton).toBeInTheDocument(); - fireEvent.click(effectsForOperationButton); - - await waitFor(() => { - effectsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(effectsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - effectsEndpointSubmitButton = within(effectsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(effectsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(effectsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - effectsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(effectsEndpointResponse).toBeInTheDocument(); - expect( - within(effectsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.effects_for_operation, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: effects for transaction submit with response", async () => { - const effectsForTransactionButton = within( - effectsEndpointsContainer, - ).getByText(/effects for transaction/i); - - expect(effectsForTransactionButton).toBeInTheDocument(); - fireEvent.click(effectsForTransactionButton); - - await waitFor(() => { - effectsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(effectsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - effectsEndpointSubmitButton = within(effectsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(effectsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(effectsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - effectsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(effectsEndpointResponse).toBeInTheDocument(); - expect( - within(effectsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.effects_for_transaction, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("fee_stats", () => { - const RESOURCE_LINK_LABEL = "Fee Stats"; - const SUBMIT_LABEL = "submit"; - let feeStatsEndpointsContainer: HTMLElement; - let feeStatsEndpointInputs: HTMLElement; - let feeStatsEndpointSubmitButton: HTMLElement; - let feeStatsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - feeStatsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(feeStatsEndpointsContainer).getAllByRole("link")).toHaveLength( - 1, - ); - }); - - // render resource input form with submit + submit response - test("resource: all fee_stats submit with response", async () => { - const allFee_StatsButton = within(feeStatsEndpointsContainer).getByText( - /Fee Stats/i, - ); - - expect(allFee_StatsButton).toBeInTheDocument(); - fireEvent.click(allFee_StatsButton); - - await waitFor(() => { - feeStatsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(feeStatsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - feeStatsEndpointSubmitButton = within(feeStatsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(feeStatsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(feeStatsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - feeStatsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(feeStatsEndpointResponse).toBeInTheDocument(); - expect( - within(feeStatsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_fee_stats, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("ledger", () => { - const RESOURCE_LINK_LABEL = "ledger"; - const SUBMIT_LABEL = "submit"; - let ledgerEndpointsContainer: HTMLElement; - let ledgerEndpointInputs: HTMLElement; - let ledgerEndpointSubmitButton: HTMLElement; - let ledgerEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - ledgerEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(ledgerEndpointsContainer).getAllByRole("link")).toHaveLength( - 2, - ); - }); - - // render resource input form with submit + submit response - test("resource: all ledgers submit with response", async () => { - const allLedgersButton = within(ledgerEndpointsContainer).getByText( - /all ledgers/i, - ); - - expect(allLedgersButton).toBeInTheDocument(); - fireEvent.click(allLedgersButton); - - await waitFor(() => { - ledgerEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(ledgerEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - ledgerEndpointSubmitButton = within(ledgerEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(ledgerEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(ledgerEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - ledgerEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(ledgerEndpointResponse).toBeInTheDocument(); - expect( - within(ledgerEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_ledgers, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single ledger submit with response", async () => { - const singleLedgerButton = within(ledgerEndpointsContainer).getByText( - /single ledger/i, - ); - - expect(singleLedgerButton).toBeInTheDocument(); - fireEvent.click(singleLedgerButton); - - await waitFor(() => { - ledgerEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(ledgerEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - ledgerEndpointSubmitButton = within(ledgerEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(ledgerEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(ledgerEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - ledgerEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(ledgerEndpointResponse).toBeInTheDocument(); - expect( - within(ledgerEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_ledger, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("liquidity pools", () => { - const RESOURCE_LINK_LABEL = "liquidity pools"; - const SUBMIT_LABEL = "submit"; - let liquidityPoolsEndpointsContainer: HTMLElement; - let liquidityPoolsEndpointInputs: HTMLElement; - let liquidityPoolsEndpointSubmitButton: HTMLElement; - let liquidityPoolsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - liquidityPoolsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(liquidityPoolsEndpointsContainer).getAllByRole("link"), - ).toHaveLength(2); - }); - - // render resource input form with submit + submit response - test("resource: all liquidity pools submit with response", async () => { - const allLiquidityPoolsButton = within( - liquidityPoolsEndpointsContainer, - ).getByText(/all liquidity pools/i); - - expect(allLiquidityPoolsButton).toBeInTheDocument(); - fireEvent.click(allLiquidityPoolsButton); - - await waitFor(() => { - liquidityPoolsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(liquidityPoolsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - liquidityPoolsEndpointSubmitButton = within( - liquidityPoolsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(liquidityPoolsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(liquidityPoolsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - liquidityPoolsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(liquidityPoolsEndpointResponse).toBeInTheDocument(); - expect( - within(liquidityPoolsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_liquidity_pools, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single liquidity pool submit with response", async () => { - const singleLiquidityPoolButton = within( - liquidityPoolsEndpointsContainer, - ).getByText(/single liquidity pool/i); - - expect(singleLiquidityPoolButton).toBeInTheDocument(); - fireEvent.click(singleLiquidityPoolButton); - - await waitFor(() => { - liquidityPoolsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(liquidityPoolsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - liquidityPoolsEndpointSubmitButton = within( - liquidityPoolsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(liquidityPoolsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(liquidityPoolsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - liquidityPoolsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(liquidityPoolsEndpointResponse).toBeInTheDocument(); - expect( - within(liquidityPoolsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_liquidity_pool, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("offers", () => { - const RESOURCE_LINK_LABEL = "offers"; - const SUBMIT_LABEL = "submit"; - let offersEndpointsContainer: HTMLElement; - let offersEndpointInputs: HTMLElement; - let offersEndpointSubmitButton: HTMLElement; - let offersEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - offersEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(offersEndpointsContainer).getAllByRole("link")).toHaveLength( - 3, - ); - }); - - // render resource input form with submit + submit response - test("resource: all offers submit with response", async () => { - const allOffersButton = within(offersEndpointsContainer).getByText( - /all offers/i, - ); - - expect(allOffersButton).toBeInTheDocument(); - fireEvent.click(allOffersButton); - - await waitFor(() => { - offersEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(offersEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - offersEndpointSubmitButton = within(offersEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(offersEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(offersEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - offersEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(offersEndpointResponse).toBeInTheDocument(); - expect( - within(offersEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_offers, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single offer submit with response", async () => { - const singleOfferButton = within(offersEndpointsContainer).getByText( - /single offer/i, - ); - - expect(singleOfferButton).toBeInTheDocument(); - fireEvent.click(singleOfferButton); - - await waitFor(() => { - offersEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(offersEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - offersEndpointSubmitButton = within(offersEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(offersEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(offersEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - offersEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(offersEndpointResponse).toBeInTheDocument(); - expect( - within(offersEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_offer, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: offers for account submit with response", async () => { - const offersForAccountButton = within(offersEndpointsContainer).getByText( - /offers for account/i, - ); - - expect(offersForAccountButton).toBeInTheDocument(); - fireEvent.click(offersForAccountButton); - - await waitFor(() => { - offersEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(offersEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - offersEndpointSubmitButton = within(offersEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(offersEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(offersEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - offersEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(offersEndpointResponse).toBeInTheDocument(); - expect( - within(offersEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.offers_for_account, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("operations", () => { - const RESOURCE_LINK_LABEL = "operations"; - const SUBMIT_LABEL = "submit"; - let operationsEndpointsContainer: HTMLElement; - let operationsEndpointInputs: HTMLElement; - let operationsEndpointSubmitButton: HTMLElement; - let operationsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - operationsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(operationsEndpointsContainer).getAllByRole("link"), - ).toHaveLength(6); - }); - - // render resource input form with submit + submit response - test("resource: all operations submit with response", async () => { - const allOperationsButton = within(operationsEndpointsContainer).getByText( - /all operations/i, - ); - - expect(allOperationsButton).toBeInTheDocument(); - fireEvent.click(allOperationsButton); - - await waitFor(() => { - operationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(operationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - operationsEndpointSubmitButton = within( - operationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(operationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(operationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - operationsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(operationsEndpointResponse).toBeInTheDocument(); - expect( - within(operationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_operations, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single operation submit with response", async () => { - const singleOperationButton = within( - operationsEndpointsContainer, - ).getByText(/single operation/i); - - expect(singleOperationButton).toBeInTheDocument(); - fireEvent.click(singleOperationButton); - - await waitFor(() => { - operationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(operationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - operationsEndpointSubmitButton = within( - operationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(operationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(operationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - operationsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(operationsEndpointResponse).toBeInTheDocument(); - expect( - within(operationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_operation, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: operations for account submit with response", async () => { - const operationsForAccountButton = within( - operationsEndpointsContainer, - ).getByText(/operations for account/i); - - expect(operationsForAccountButton).toBeInTheDocument(); - fireEvent.click(operationsForAccountButton); - - await waitFor(() => { - operationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(operationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - operationsEndpointSubmitButton = within( - operationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(operationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(operationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - operationsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(operationsEndpointResponse).toBeInTheDocument(); - expect( - within(operationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.operations_for_account, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: operations for ledger submit with response", async () => { - const operationsForLedgerButton = within( - operationsEndpointsContainer, - ).getByText(/operations for ledger/i); - - expect(operationsForLedgerButton).toBeInTheDocument(); - fireEvent.click(operationsForLedgerButton); - - await waitFor(() => { - operationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(operationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - operationsEndpointSubmitButton = within( - operationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(operationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(operationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - operationsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(operationsEndpointResponse).toBeInTheDocument(); - expect( - within(operationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.operations_for_ledger, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: operations for liquidity pool submit with response", async () => { - const operationsForLiquidityPoolButton = within( - operationsEndpointsContainer, - ).getByText(/operations for liquidity pool/i); - - expect(operationsForLiquidityPoolButton).toBeInTheDocument(); - fireEvent.click(operationsForLiquidityPoolButton); - - await waitFor(() => { - operationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(operationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - operationsEndpointSubmitButton = within( - operationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(operationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(operationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - operationsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(operationsEndpointResponse).toBeInTheDocument(); - expect( - within(operationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.operations_for_liquidity_pool, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: operations for transaction submit with response", async () => { - const operationsForTransactionButton = within( - operationsEndpointsContainer, - ).getByText(/operations for transaction/i); - - expect(operationsForTransactionButton).toBeInTheDocument(); - fireEvent.click(operationsForTransactionButton); - - await waitFor(() => { - operationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(operationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - operationsEndpointSubmitButton = within( - operationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(operationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(operationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - operationsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(operationsEndpointResponse).toBeInTheDocument(); - expect( - within(operationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.operations_for_transaction, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("order book", () => { - const RESOURCE_LINK_LABEL = "order book"; - const SUBMIT_LABEL = "submit"; - let orderBookEndpointsContainer: HTMLElement; - let orderBookEndpointInputs: HTMLElement; - let orderBookEndpointSubmitButton: HTMLElement; - let orderBookEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - orderBookEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(orderBookEndpointsContainer).getAllByRole("link"), - ).toHaveLength(1); - }); - - // render resource input form with submit + submit response - test("resource: details submit with response", async () => { - const detailsButton = within(orderBookEndpointsContainer).getByText( - /details/i, - ); - - expect(detailsButton).toBeInTheDocument(); - fireEvent.click(detailsButton); - - await waitFor(() => { - orderBookEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(orderBookEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - orderBookEndpointSubmitButton = within(orderBookEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(orderBookEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(orderBookEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - orderBookEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(orderBookEndpointResponse).toBeInTheDocument(); - expect( - within(orderBookEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.order_book_details, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("paths", () => { - const RESOURCE_LINK_LABEL = "paths"; - const SUBMIT_LABEL = "submit"; - let pathsEndpointsContainer: HTMLElement; - let pathsEndpointInputs: HTMLElement; - let pathsEndpointSubmitButton: HTMLElement; - let pathsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - pathsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(pathsEndpointsContainer).getAllByRole("link")).toHaveLength( - 3, - ); - }); - - // render resource input form with submit + submit response - test("resource: find payment paths submit with response", async () => { - const findPaymentPathsButton = within(pathsEndpointsContainer).getByText( - /find payment paths/i, - ); - - expect(findPaymentPathsButton).toBeInTheDocument(); - fireEvent.click(findPaymentPathsButton); - - await waitFor(() => { - pathsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(pathsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - pathsEndpointSubmitButton = within(pathsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(pathsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(pathsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - pathsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(pathsEndpointResponse).toBeInTheDocument(); - expect( - within(pathsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.find_payment_paths, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: find strict receive payment paths submit with response", async () => { - const findReceivePaymentPathsButton = within( - pathsEndpointsContainer, - ).getByText(/find strict receive payment paths/i); - - expect(findReceivePaymentPathsButton).toBeInTheDocument(); - fireEvent.click(findReceivePaymentPathsButton); - - await waitFor(() => { - pathsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(pathsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - pathsEndpointSubmitButton = within(pathsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(pathsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(pathsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - pathsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(pathsEndpointResponse).toBeInTheDocument(); - expect( - within(pathsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.find_strict_receive_payment_paths, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: find strict send payment paths submit with response", async () => { - const findSendPaymentPathsButton = within( - pathsEndpointsContainer, - ).getByText(/find strict send payment paths/i); - - expect(findSendPaymentPathsButton).toBeInTheDocument(); - fireEvent.click(findSendPaymentPathsButton); - - await waitFor(() => { - pathsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(pathsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - pathsEndpointSubmitButton = within(pathsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(pathsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(pathsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - pathsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(pathsEndpointResponse).toBeInTheDocument(); - expect( - within(pathsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.find_strict_send_payment_paths, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("payments", () => { - const RESOURCE_LINK_LABEL = "payments"; - const SUBMIT_LABEL = "submit"; - let paymentsEndpointsContainer: HTMLElement; - let paymentsEndpointInputs: HTMLElement; - let paymentsEndpointSubmitButton: HTMLElement; - let paymentsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - paymentsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(paymentsEndpointsContainer).getAllByRole("link"), - ).toHaveLength(4); - }); - - // render resource input form with submit + submit response - test("resource: all payments submit with response", async () => { - const allPaymentsButton = within(paymentsEndpointsContainer).getByText( - /all payments/i, - ); - - expect(allPaymentsButton).toBeInTheDocument(); - fireEvent.click(allPaymentsButton); - - await waitFor(() => { - paymentsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(paymentsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - paymentsEndpointSubmitButton = within(paymentsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(paymentsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(paymentsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - paymentsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(paymentsEndpointResponse).toBeInTheDocument(); - expect( - within(paymentsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_payments, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: payments for account submit with response", async () => { - const paymentsForAccountButton = within( - paymentsEndpointsContainer, - ).getByText(/payments for account/i); - - expect(paymentsForAccountButton).toBeInTheDocument(); - fireEvent.click(paymentsForAccountButton); - - await waitFor(() => { - paymentsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(paymentsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - paymentsEndpointSubmitButton = within(paymentsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(paymentsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(paymentsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - paymentsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(paymentsEndpointResponse).toBeInTheDocument(); - expect( - within(paymentsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.payments_for_account, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: payments for ledger submit with response", async () => { - const paymentsForLedgerButton = within( - paymentsEndpointsContainer, - ).getByText(/payments for ledger/i); - - expect(paymentsForLedgerButton).toBeInTheDocument(); - fireEvent.click(paymentsForLedgerButton); - - await waitFor(() => { - paymentsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(paymentsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - paymentsEndpointSubmitButton = within(paymentsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(paymentsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(paymentsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - paymentsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(paymentsEndpointResponse).toBeInTheDocument(); - expect( - within(paymentsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.payments_for_ledger, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: payments for transaction submit with response", async () => { - const paymentsForTransactionButton = within( - paymentsEndpointsContainer, - ).getByText(/payments for transaction/i); - - expect(paymentsForTransactionButton).toBeInTheDocument(); - fireEvent.click(paymentsForTransactionButton); - - await waitFor(() => { - paymentsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(paymentsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - paymentsEndpointSubmitButton = within(paymentsEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(paymentsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(paymentsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - paymentsEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(paymentsEndpointResponse).toBeInTheDocument(); - expect( - within(paymentsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.payments_for_transaction, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("trade aggregations", () => { - const RESOURCE_LINK_LABEL = "trade aggregations"; - const SUBMIT_LABEL = "submit"; - let tradeAggregationsEndpointsContainer: HTMLElement; - let tradeAggregationsEndpointInputs: HTMLElement; - let tradeAggregationsEndpointSubmitButton: HTMLElement; - let tradeAggregationsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - tradeAggregationsEndpointsContainer = - screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(tradeAggregationsEndpointsContainer).getAllByRole("link"), - ).toHaveLength(1); - }); - - // render resource input form with submit + submit response - test("resource: trade aggregations submit with response", async () => { - const tradeAggregationsButton = within( - tradeAggregationsEndpointsContainer, - ).getByText(/trade aggregations/i); - - expect(tradeAggregationsButton).toBeInTheDocument(); - fireEvent.click(tradeAggregationsButton); - - await waitFor(() => { - tradeAggregationsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(tradeAggregationsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - tradeAggregationsEndpointSubmitButton = within( - tradeAggregationsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(tradeAggregationsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(tradeAggregationsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - tradeAggregationsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(tradeAggregationsEndpointResponse).toBeInTheDocument(); - expect( - within(tradeAggregationsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.trade_aggregations, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("trades", () => { - const RESOURCE_LINK_LABEL = "trades"; - const SUBMIT_LABEL = "submit"; - let tradesEndpointsContainer: HTMLElement; - let tradesEndpointInputs: HTMLElement; - let tradesEndpointSubmitButton: HTMLElement; - let tradesEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - tradesEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect(within(tradesEndpointsContainer).getAllByRole("link")).toHaveLength( - 4, - ); - }); - - // render resource input form with submit + submit response - test("resource: all trades submit with response", async () => { - const allTradesButton = within(tradesEndpointsContainer).getByText( - /all trades/i, - ); - - expect(allTradesButton).toBeInTheDocument(); - fireEvent.click(allTradesButton); - - await waitFor(() => { - tradesEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(tradesEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - tradesEndpointSubmitButton = within(tradesEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(tradesEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(tradesEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - tradesEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(tradesEndpointResponse).toBeInTheDocument(); - expect( - within(tradesEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_trades, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: trades for account submit with response", async () => { - const tradesForAccountButton = within(tradesEndpointsContainer).getByText( - /trades for account/i, - ); - - expect(tradesForAccountButton).toBeInTheDocument(); - fireEvent.click(tradesForAccountButton); - - await waitFor(() => { - tradesEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(tradesEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - tradesEndpointSubmitButton = within(tradesEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(tradesEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(tradesEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - tradesEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(tradesEndpointResponse).toBeInTheDocument(); - expect( - within(tradesEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.trades_for_account, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: trades for liquidity pool submit with response", async () => { - const tradesForLiquidityPoolButton = within( - tradesEndpointsContainer, - ).getByText(/trades for liquidity pool/i); - - expect(tradesForLiquidityPoolButton).toBeInTheDocument(); - fireEvent.click(tradesForLiquidityPoolButton); - - await waitFor(() => { - tradesEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(tradesEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - tradesEndpointSubmitButton = within(tradesEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(tradesEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(tradesEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - tradesEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(tradesEndpointResponse).toBeInTheDocument(); - expect( - within(tradesEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.trades_for_liquidity_pool, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: trades for offer submit with response", async () => { - const tradesForOfferButton = within(tradesEndpointsContainer).getByText( - /trades for offer/i, - ); - - expect(tradesForOfferButton).toBeInTheDocument(); - fireEvent.click(tradesForOfferButton); - - await waitFor(() => { - tradesEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(tradesEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - tradesEndpointSubmitButton = within(tradesEndpointInputs).getByText( - RegExp(SUBMIT_LABEL, "i"), - ); - }); - expect(tradesEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(tradesEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - tradesEndpointResponse = screen.getByTestId(TEST_ID_RESULT_RESPONSE); - }); - - expect(tradesEndpointResponse).toBeInTheDocument(); - expect( - within(tradesEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.trades_for_offer, "i"), - ), - ).toBeInTheDocument(); - }); -}); - -describe("transactions", () => { - const RESOURCE_LINK_LABEL = "transactions"; - const SUBMIT_LABEL = "submit"; - let transactionsEndpointsContainer: HTMLElement; - let transactionsEndpointInputs: HTMLElement; - let transactionsEndpointSubmitButton: HTMLElement; - let transactionsEndpointResponse: HTMLElement; - - // select resource - beforeEach(async () => { - fireEvent.click( - within(resourceContainer).getByText(RegExp(RESOURCE_LINK_LABEL, "i")), - ); - await waitFor(() => { - transactionsEndpointsContainer = screen.getByTestId(TEST_ID_ENDPOINT); - }); - }); - - // resource endpoint links - test("renders all endpoint links", () => { - expect( - within(transactionsEndpointsContainer).getAllByRole("link"), - ).toHaveLength(6); - }); - - // render resource input form with submit + submit response - test("resource: all transactions submit with response", async () => { - const allTransactionsButton = within( - transactionsEndpointsContainer, - ).getByText(/all transactions/i); - - expect(allTransactionsButton).toBeInTheDocument(); - fireEvent.click(allTransactionsButton); - - await waitFor(() => { - transactionsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(transactionsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - transactionsEndpointSubmitButton = within( - transactionsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(transactionsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(transactionsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - transactionsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(transactionsEndpointResponse).toBeInTheDocument(); - expect( - within(transactionsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.all_transactions, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: single transaction submit with response", async () => { - const singleTransactionButton = within( - transactionsEndpointsContainer, - ).getByText(/single transaction/i); - - expect(singleTransactionButton).toBeInTheDocument(); - fireEvent.click(singleTransactionButton); - - await waitFor(() => { - transactionsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(transactionsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - transactionsEndpointSubmitButton = within( - transactionsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(transactionsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(transactionsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - transactionsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(transactionsEndpointResponse).toBeInTheDocument(); - expect( - within(transactionsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.single_transaction, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: post transaction submit with response", async () => { - const postTransactionButton = within( - transactionsEndpointsContainer, - ).getByText(/post transaction/i); - - expect(postTransactionButton).toBeInTheDocument(); - fireEvent.click(postTransactionButton); - - await waitFor(() => { - transactionsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(transactionsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - transactionsEndpointSubmitButton = within( - transactionsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(transactionsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(transactionsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - transactionsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(transactionsEndpointResponse).toBeInTheDocument(); - expect( - within(transactionsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.post_transaction, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: transactions for account submit with response", async () => { - const transactionsForAccountButton = within( - transactionsEndpointsContainer, - ).getByText(/transactions for account/i); - - expect(transactionsForAccountButton).toBeInTheDocument(); - fireEvent.click(transactionsForAccountButton); - - await waitFor(() => { - transactionsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(transactionsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - transactionsEndpointSubmitButton = within( - transactionsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(transactionsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(transactionsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - transactionsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(transactionsEndpointResponse).toBeInTheDocument(); - expect( - within(transactionsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.transactions_for_account, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: transactions for ledger submit with response", async () => { - const transactionsForLedgerButton = within( - transactionsEndpointsContainer, - ).getByText(/transactions for ledger/i); - - expect(transactionsForLedgerButton).toBeInTheDocument(); - fireEvent.click(transactionsForLedgerButton); - - await waitFor(() => { - transactionsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(transactionsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - transactionsEndpointSubmitButton = within( - transactionsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(transactionsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(transactionsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - transactionsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(transactionsEndpointResponse).toBeInTheDocument(); - expect( - within(transactionsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.transactions_for_ledger, "i"), - ), - ).toBeInTheDocument(); - }); - - test("resource: transactions for liquidity pool submit with response", async () => { - const transactionsForLiquidityPoolButton = within( - transactionsEndpointsContainer, - ).getByText(/transactions for liquidity pool/i); - - expect(transactionsForLiquidityPoolButton).toBeInTheDocument(); - fireEvent.click(transactionsForLiquidityPoolButton); - - await waitFor(() => { - transactionsEndpointInputs = screen.getByTestId(TEST_ID_INPUTS); - }); - expect(transactionsEndpointInputs).toBeInTheDocument(); - - await waitFor(() => { - transactionsEndpointSubmitButton = within( - transactionsEndpointInputs, - ).getByText(RegExp(SUBMIT_LABEL, "i")); - }); - expect(transactionsEndpointSubmitButton).toBeInTheDocument(); - - fireEvent.click(transactionsEndpointSubmitButton); - - await waitFor(() => - expect(screen.getByTestId(TEST_ID_RESULT_LOADING)).toBeInTheDocument(), - ); - - await waitFor(() => { - transactionsEndpointResponse = screen.getByTestId( - TEST_ID_RESULT_RESPONSE, - ); - }); - - expect(transactionsEndpointResponse).toBeInTheDocument(); - expect( - within(transactionsEndpointResponse).getByText( - RegExp(ENDPOINT_RESPONSE.transactions_for_liquidity_pool, "i"), - ), - ).toBeInTheDocument(); - }); -}); diff --git a/src/views/__tests__/Introduction.test.tsx b/src/views/__tests__/Introduction.test.tsx deleted file mode 100644 index 466d989c..00000000 --- a/src/views/__tests__/Introduction.test.tsx +++ /dev/null @@ -1,12 +0,0 @@ -/** - * @jest-environment jsdom - */ -import { waitFor, screen } from "@testing-library/react"; -import { render } from "helpers/testHelpers"; -import { Introduction } from "views/Introduction"; - -test("renders introduction page", async () => { - render(); - await waitFor(() => screen.getByTestId("page-introduction")); - expect(screen.getByTestId("page-introduction")).toBeInTheDocument(); -}); diff --git a/src/views/__tests__/TransactionSigner.test.tsx b/src/views/__tests__/TransactionSigner.test.tsx deleted file mode 100644 index 10d6b965..00000000 --- a/src/views/__tests__/TransactionSigner.test.tsx +++ /dev/null @@ -1,265 +0,0 @@ -/** - * @jest-environment jsdom - */ -import { Networks, TransactionBuilder } from "@stellar/stellar-sdk"; -import { fireEvent, waitFor, screen } from "@testing-library/react"; -import { render } from "helpers/testHelpers"; -import { TransactionSigner } from "views/TransactionSigner"; -import * as transactionSignerActions from "actions/transactionSigner"; -import { MOCK_SIGNED_TRANSACTION } from "./__mocks__/transactions"; - -jest.mock("@stellar/freighter-api", () => ({ - isConnected: () => new Promise((resolve) => resolve(true)), - signTransaction: () => - new Promise((resolve) => resolve(MOCK_SIGNED_TRANSACTION)), -})); - -jest.mock("@albedo-link/intent", () => ({ - tx: () => - new Promise((resolve) => - resolve({ signed_envelope_xdr: MOCK_SIGNED_TRANSACTION }), - ), -})); - -const SOURCE_KEYPAIR = { - publicKey: "GCQ5VP5V7JP3SCLPZVNWINFWDEY4YDQ2UVI2BSNSGENLPKNTUMK42QUN", - secretKey: "SDBJANOEQHXOC2LWPP2CVYUJK4VR7MXS2ONKKSHHADOCEBAPOGTT4WHP", -}; -const SIGNER_KEYPAIR = { - publicKey: "GDR34X73SODUQJYO4E7IFWPRGGVQMLJFEWISAAIMEEX3LOGBFCDO735C", - secretKey: "SA6QM7HQFTQGI5FRQJVP2Q2URI4W2SIEWPUY2XFDAV4BQD3L5JWJJRQN", -}; -const TRANSACTION_XDR = - "AAAAAgAAAACh2r+1+l+5CW/NW2Q0thkxzA4apVGgybIxGreps6MVzQAAAGQAAWl8AAAAAgAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"; -const FEE_BUMP_XDR = - "AAAABQAAAADjvl/7k4dIJw7hPoLZ8TGrBi0lJZEgAQwhL7W4wSiG7wAAAAAAAADIAAAAAgAAAACh2r+1+l+5CW/NW2Q0thkxzA4apVGgybIxGreps6MVzQAAAGQAAWl8AAAAAgAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA="; -const TRANSACTION = { - network: Networks.TESTNET, - hash: "41720fd1171ffd0a14c5fd9d62e6b47105f9dcda180d5c91065d45fc79bdf670", - source: SOURCE_KEYPAIR.publicKey, - sequence: "397456273571842", -}; - -test("renders TransactionSigner page", async () => { - render(); - await waitFor(() => screen.getByTestId("page-transaction-signer")); - expect(screen.getByTestId("page-transaction-signer")).toBeInTheDocument(); -}); - -test("renders set options transaction from xdr in url param", async () => { - render(, { - preloadedState: { transactionSigner: { xdr: TRANSACTION_XDR } }, - }); - await waitFor(() => - screen.getByTestId("transaction-signer-transaction-overview"), - ); - expect(screen.getByTestId("transaction-signer-network")).toHaveTextContent( - TRANSACTION.network, - ); - expect(screen.getByTestId("transaction-signer-xdr")).toHaveTextContent( - TRANSACTION_XDR, - ); - expect(screen.getByTestId("transaction-signer-hash")).toHaveTextContent( - TRANSACTION.hash, - ); - expect(screen.getByTestId("transaction-signer-source")).toHaveTextContent( - TRANSACTION.source, - ); - expect(screen.getByTestId("transaction-signer-sequence")).toHaveTextContent( - TRANSACTION.sequence, - ); - expect(screen.getByTestId("transaction-signer-op-length")).toHaveTextContent( - "1", - ); - expect(screen.getByTestId("transaction-signer-sig-length")).toHaveTextContent( - "0", - ); - expect( - screen.getByTestId("transaction-signer-signatures"), - ).toBeInTheDocument(); -}); - -test("renders fee bump transaction from xdr in url param", async () => { - render(, { - preloadedState: { transactionSigner: { xdr: FEE_BUMP_XDR } }, - }); - await waitFor(() => - screen.getByTestId("transaction-signer-transaction-overview"), - ); - expect(screen.getByTestId("transaction-signer-network")).toHaveTextContent( - TRANSACTION.network, - ); - expect(screen.getByTestId("transaction-signer-xdr")).toHaveTextContent( - TRANSACTION_XDR, - ); - expect(screen.getByTestId("transaction-signer-inner-hash")).toHaveTextContent( - TRANSACTION.hash, - ); - expect(screen.getByTestId("transaction-signer-fee-source")).toHaveTextContent( - SIGNER_KEYPAIR.publicKey, - ); - expect( - screen.getByTestId("transaction-signer-transaction-fee"), - ).toHaveTextContent("200"); - expect( - screen.getByTestId("transaction-signer-fee-sig-length"), - ).toHaveTextContent("0"); - expect(screen.getByTestId("transaction-signer-inner-hash")).toHaveTextContent( - TRANSACTION.hash, - ); - expect( - screen.getByTestId("transaction-signer-inner-source"), - ).toHaveTextContent(TRANSACTION.source); - expect( - screen.getByTestId("transaction-signer-inner-sequence"), - ).toHaveTextContent(TRANSACTION.sequence); - expect(screen.getByTestId("transaction-signer-inner-fee")).toHaveTextContent( - "100", - ); - expect( - screen.getByTestId("transaction-signer-inner-op-length"), - ).toHaveTextContent("1"); - expect( - screen.getByTestId("transaction-signer-inner-sig-length"), - ).toHaveTextContent("0"); - expect( - screen.getByTestId("transaction-signer-signatures"), - ).toBeInTheDocument(); -}); - -test("renders import textarea to load transaction", async () => { - render(); - await waitFor(() => screen.getByTestId("transaction-importer-input")); - expect(screen.getByTestId("transaction-importer-input")).toBeInTheDocument(); -}); - -test("imports transaction from xdr string", async () => { - render(, { - preloadedState: { transactionSigner: { signers: [""] } }, - }); - fireEvent.change(screen.getByTestId("transaction-importer-input"), { - target: { value: TRANSACTION_XDR }, - }); - fireEvent.click(screen.getByTestId("transaction-importer-button")); - await waitFor(() => - screen.getByTestId("transaction-signer-transaction-overview"), - ); - expect(screen.getByTestId("transaction-signer-network")).toHaveTextContent( - TRANSACTION.network, - ); - expect(screen.getByTestId("transaction-signer-xdr")).toHaveTextContent( - TRANSACTION_XDR, - ); - expect(screen.getByTestId("transaction-signer-hash")).toHaveTextContent( - TRANSACTION.hash, - ); - expect(screen.getByTestId("transaction-signer-source")).toHaveTextContent( - TRANSACTION.source, - ); - expect(screen.getByTestId("transaction-signer-sequence")).toHaveTextContent( - TRANSACTION.sequence, - ); - expect(screen.getByTestId("transaction-signer-op-length")).toHaveTextContent( - "1", - ); - expect(screen.getByTestId("transaction-signer-sig-length")).toHaveTextContent( - "0", - ); - expect( - screen.getByTestId("transaction-signer-signatures"), - ).toBeInTheDocument(); -}); - -test("adds manual signer to transaction", () => { - render(, { - preloadedState: { transactionSigner: { xdr: TRANSACTION_XDR } }, - }); - expect( - screen.queryByText("submit in transaction submitter"), - ).not.toBeInTheDocument(); - fireEvent.change(screen.getByTestId("secret-key-picker"), { - target: { value: SOURCE_KEYPAIR.secretKey }, - }); - expect(screen.getByTestId("transaction-signer-result")).toBeInTheDocument(); - expect(screen.getByTestId("transaction-signer-result")).toHaveTextContent( - MOCK_SIGNED_TRANSACTION, - ); -}); - -test("sign transaction with Ledger", () => { - const signature = TransactionBuilder.fromXDR( - MOCK_SIGNED_TRANSACTION, - Networks.TESTNET, - ).signatures[0]; - - jest.spyOn(transactionSignerActions, "signWithLedger").mockImplementation( - () => (dispatch) => - dispatch({ - type: transactionSignerActions.LEDGER_WALLET_SIGN_SUCCESS, - signature, - }), - ); - - render(, { - preloadedState: { transactionSigner: { xdr: TRANSACTION_XDR } }, - }); - - fireEvent.click(screen.getByTestId("transaction-signer-ledger-sign-button")); - expect(screen.getByTestId("transaction-signer-result")).toBeInTheDocument(); - expect(screen.getByTestId("transaction-signer-result")).toHaveTextContent( - MOCK_SIGNED_TRANSACTION, - ); -}); - -test("sign transaction with Trezor", () => { - const signature = TransactionBuilder.fromXDR( - MOCK_SIGNED_TRANSACTION, - Networks.TESTNET, - ).signatures[0]; - - jest.spyOn(transactionSignerActions, "signWithTrezor").mockImplementation( - () => (dispatch) => - dispatch({ - type: transactionSignerActions.TREZOR_WALLET_SIGN_SUCCESS, - signature, - }), - ); - - render(, { - preloadedState: { transactionSigner: { xdr: TRANSACTION_XDR } }, - }); - - fireEvent.click(screen.getByTestId("transaction-signer-trezor-sign-button")); - expect(screen.getByTestId("transaction-signer-result")).toBeInTheDocument(); - expect(screen.getByTestId("transaction-signer-result")).toHaveTextContent( - MOCK_SIGNED_TRANSACTION, - ); -}); - -test("sign transaction with Freighter", async () => { - render(, { - preloadedState: { transactionSigner: { xdr: TRANSACTION_XDR } }, - }); - - fireEvent.click( - screen.getByTestId("transaction-signer-freighter-sign-button"), - ); - await waitFor(() => screen.getByTestId("transaction-signer-result")); - expect(screen.getByTestId("transaction-signer-result")).toHaveTextContent( - MOCK_SIGNED_TRANSACTION, - ); -}); - -test("sign transaction with Albedo", async () => { - render(, { - preloadedState: { transactionSigner: { xdr: TRANSACTION_XDR } }, - }); - - fireEvent.click( - screen.getByTestId("transaction-signer-freighter-sign-button"), - ); - await waitFor(() => screen.getByTestId("transaction-signer-result")); - expect(screen.getByTestId("transaction-signer-result")).toHaveTextContent( - MOCK_SIGNED_TRANSACTION, - ); -}); diff --git a/src/views/__tests__/TransactionSubmitter.test.tsx b/src/views/__tests__/TransactionSubmitter.test.tsx deleted file mode 100644 index 6da16233..00000000 --- a/src/views/__tests__/TransactionSubmitter.test.tsx +++ /dev/null @@ -1,419 +0,0 @@ -/** - * @jest-environment jsdom - */ - -import { fireEvent, waitFor, screen } from "@testing-library/react"; -import * as StellarSdk from "@stellar/stellar-sdk"; -import { render } from "helpers/testHelpers"; -import { TransactionSubmitter } from "views/TransactionSubmitter"; -import * as extrapolateFromXdr from "helpers/extrapolateFromXdr"; -import * as xdrViewerActions from "actions/xdrViewer"; -import { FETCHED_SIGNERS } from "constants/fetched_signers"; -import { SIGNATURE } from "constants/signature"; -import { - MOCK_SIGNED_TRANSACTION, - MOCK_SIGNATURE_BUFFER, -} from "./__mocks__/transactions"; - -const MOCK_SERVER_RESPONSE_SUCCESS = { - fee_meta_xdr: "fooMetaXdr", - hash: "fooHash", - ledger: 128015, - operation_count: 1, - paging_token: "549820238401536", - result_meta_xdr: "fooResultMetaXdr", - result_xdr: "fooXdr", - successful: true, -}; - -jest.mock("@stellar/stellar-sdk", () => ({ - ...jest.requireActual("@stellar/stellar-sdk"), - Server: jest.fn().mockImplementation(() => ({ - submitTransaction: () => new Promise((resolve) => resolve({})), - })), -})); - -/* extrapolatedFromXdr doesn't work in @react/testing-library (seemingly) because of the difference in the way the browser and node's - engines handle Buffers. - Until it can be refactored to work across engines, we manually mock an extrapolated `MOCK_SIGNED_TRANSACTION` that uses a Buffer for a signature - instead of Uint8Array. */ - -const MOCK_EXTRAPOLATED_SIGNED_TRANSACTION = [ - { - type: "TransactionEnvelope", - value: "[envelopeTypeTx]", - nodes: [ - { - type: "v1", - nodes: [ - { - type: "tx", - nodes: [ - { - type: "sourceAccount", - value: "[keyTypeEd25519]", - nodes: [ - { - type: "ed25519", - value: { - type: "code", - value: - "GCQ5VP5V7JP3SCLPZVNWINFWDEY4YDQ2UVI2BSNSGENLPKNTUMK42QUN", - }, - }, - ], - }, - { type: "fee", value: "100" }, - { type: "seqNum", value: "397456273571842" }, - { - type: "timeBounds", - nodes: [ - { type: "minTime", value: "0" }, - { type: "maxTime", value: "0" }, - ], - }, - { type: "memo", value: "[memoNone]" }, - { - type: "operations", - value: "Array[1]", - nodes: [ - { - type: "[0]", - nodes: [ - { type: "sourceAccount" }, - { - type: "body", - value: "[setOptions]", - nodes: [ - { - type: "setOptionsOp", - nodes: [ - { type: "inflationDest" }, - { type: "clearFlags" }, - { type: "setFlags" }, - { type: "masterWeight" }, - { type: "lowThreshold" }, - { type: "medThreshold" }, - { type: "highThreshold" }, - { type: "homeDomain" }, - { type: "signer" }, - ], - }, - ], - }, - ], - }, - ], - }, - { type: "ext", value: "[undefined]" }, - ], - }, - { - type: "signatures", - value: "Array[1]", - nodes: [ - { - type: "[0]", - nodes: [ - { - type: "hint", - value: { - type: "code", - value: - "G______________________________________________TUMK4____", - }, - }, - { - type: "signature", - value: { - type: "code", - raw: MOCK_SIGNATURE_BUFFER, - value: - "Lv3HnBG8qOLGguHXL2gb/jFJAgyemSlxnf4FeLHEhoff3VQ+1d23Vck4Zqt3Q0CpW88yLWm1/kKN+kAee/6nBg==", - }, - }, - ], - }, - ], - }, - ], - }, - ], - }, -]; - -test("renders TransactionSubmitter page", async () => { - render(); - await waitFor(() => screen.getByTestId("page-transaction-submitter")); - expect(screen.getByTestId("page-transaction-submitter")).toBeInTheDocument(); - expect( - screen.getByTestId("transaction-submitter-submit-btn"), - ).toHaveAttribute("disabled"); -}); - -test("shows error on invalid xdr", () => { - render(); - expect(screen.getByTestId("transaction-submitter-alert")).toHaveTextContent( - "Enter a base-64 encoded XDR blob to decode.", - ); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { value: "foo" }, - }); - expect(screen.getByTestId("transaction-submitter-alert")).toHaveTextContent( - "Unable to decode input as TransactionEnvelope", - ); -}); - -describe("valid signature path", () => { - beforeEach(() => { - jest - .spyOn(extrapolateFromXdr, "default") - .mockReturnValue(MOCK_EXTRAPOLATED_SIGNED_TRANSACTION); - jest.spyOn(xdrViewerActions, "fetchSigners").mockImplementation( - () => (dispatch) => - dispatch({ - type: FETCHED_SIGNERS.SUCCESS, - result: [ - { - isValid: SIGNATURE.VALID, - sig: MOCK_SIGNATURE_BUFFER, - }, - ], - }), - ); - }); - - afterEach(() => { - jest.clearAllMocks(); - }); - - test("shows properly encoded XDR with valid signature", async () => { - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - await waitFor(() => screen.getByTestId("tree-view-signature")); - expect(screen.getByTestId("tree-view-signature")).toHaveStyle( - "color: green", - ); - expect( - screen.getByTestId("transaction-submitter-submit-btn"), - ).not.toHaveAttribute("disabled"); - }); - - test("submits properly encoded XDR with valid signature", async () => { - // @ts-ignore - StellarSdk.Server.mockImplementation(() => ({ - submitTransaction: () => - new Promise((resolve) => resolve(MOCK_SERVER_RESPONSE_SUCCESS)), - })); - - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - fireEvent.click(screen.getByTestId("transaction-submitter-submit-btn")); - await waitFor(() => - screen.getByTestId("transaction-submitter-response-success"), - ); - expect( - screen.getByTestId("transaction-submitter-response-success"), - ).toHaveTextContent("Transaction submitted!"); - expect( - screen.getByTestId("transaction-submitter-response-status"), - ).toHaveTextContent("Transaction succeeded with 1 operation(s)."); - expect( - screen.getByTestId("transaction-submitter-response-hash"), - ).toHaveTextContent(MOCK_SERVER_RESPONSE_SUCCESS.hash); - expect( - screen.getByTestId("transaction-submitter-response-ledger"), - ).toHaveTextContent(MOCK_SERVER_RESPONSE_SUCCESS.ledger.toString()); - expect( - screen.getByTestId("transaction-submitter-response-token"), - ).toHaveTextContent(MOCK_SERVER_RESPONSE_SUCCESS.paging_token); - expect( - screen.getByTestId("transaction-submitter-response-result-xdr"), - ).toHaveTextContent(MOCK_SERVER_RESPONSE_SUCCESS.result_xdr); - expect( - screen.getByTestId("transaction-submitter-response-result-meta-xdr"), - ).toHaveTextContent(MOCK_SERVER_RESPONSE_SUCCESS.result_meta_xdr); - expect( - screen.getByTestId("transaction-submitter-response-fee-meta-xdr"), - ).toHaveTextContent(MOCK_SERVER_RESPONSE_SUCCESS.fee_meta_xdr); - }); - - test("shows memo error on submit", async () => { - // @ts-ignore - StellarSdk.Server.mockImplementation(() => ({ - submitTransaction: () => - new Promise((_resolve, reject) => - reject( - new StellarSdk.AccountRequiresMemoError("memoError", "account1", 2), - ), - ), - })); - - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - fireEvent.click(screen.getByTestId("transaction-submitter-submit-btn")); - await waitFor(() => - screen.getByTestId("transaction-submitter-response-error"), - ); - expect( - screen.getByTestId("transaction-submitter-response-error"), - ).toHaveTextContent("Transaction failed!"); - expect( - screen.getByTestId("transaction-submitter-error-message"), - ).toHaveTextContent("This destination requires a memo."); - expect( - screen.getByTestId("transaction-submitter-error-account-id"), - ).toHaveTextContent("account1"); - expect( - screen.getByTestId("transaction-submitter-error-op-index"), - ).toHaveTextContent("2"); - }); - - test("shows response error on submit", async () => { - // @ts-ignore - StellarSdk.Server.mockImplementation(() => ({ - submitTransaction: () => - new Promise((_resolve, reject) => - reject( - new StellarSdk.BadResponseError("badResponseMsg", { - data: { - extras: { result_xdr: "foo", result_codes: { code: 500 } }, - }, - }), - ), - ), - })); - - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - fireEvent.click(screen.getByTestId("transaction-submitter-submit-btn")); - await waitFor(() => - screen.getByTestId("transaction-submitter-response-error"), - ); - expect( - screen.getByTestId("transaction-submitter-response-error"), - ).toHaveTextContent("Transaction failed!"); - expect( - screen.getByTestId("transaction-submitter-error-message"), - ).toHaveTextContent("badResponseMsg"); - expect( - screen.getByTestId("transaction-submitter-error-code"), - ).toHaveTextContent(`{"code":500}`); - expect( - screen.getByTestId("transaction-submitter-error-xdr"), - ).toHaveTextContent("foo"); - }); - - test("shows no response error on submit", async () => { - // @ts-ignore - StellarSdk.Server.mockImplementation(() => ({ - submitTransaction: () => - new Promise((_resolve, reject) => reject(new Error("noResponseMsg"))), - })); - - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - fireEvent.click(screen.getByTestId("transaction-submitter-submit-btn")); - await waitFor(() => - screen.getByTestId("transaction-submitter-response-error"), - ); - expect( - screen.getByTestId("transaction-submitter-response-error"), - ).toHaveTextContent("Transaction failed!"); - expect( - screen.getByTestId("transaction-submitter-error-message"), - ).toHaveTextContent("An unknown error occurred."); - expect( - screen.getByTestId("transaction-submitter-error-original"), - ).toHaveTextContent("{}"); - }); - - test("shows no response BadResponseError on submit", async () => { - // @ts-ignore - StellarSdk.Server.mockImplementation(() => ({ - submitTransaction: () => - new Promise((_resolve, reject) => - reject(new StellarSdk.BadResponseError("noResponseMsg", "")), - ), - })); - - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - fireEvent.click(screen.getByTestId("transaction-submitter-submit-btn")); - await waitFor(() => - screen.getByTestId("transaction-submitter-response-error"), - ); - expect( - screen.getByTestId("transaction-submitter-response-error"), - ).toHaveTextContent("Transaction failed!"); - expect( - screen.getByTestId("transaction-submitter-error-message"), - ).toHaveTextContent("Received a bad response when submitting."); - expect( - screen.getByTestId("transaction-submitter-error-original"), - ).toHaveTextContent(`"name": "BadResponseError"`); - }); -}); - -test("shows properly encoded XDR with invalid signature", async () => { - const wrongSignature = Buffer.from([ - 45, 253, 199, 156, 17, 188, 168, 226, 198, 130, 225, 215, 47, 104, 27, 254, - 49, 73, 2, 12, 158, 150, 41, 113, 157, 254, 5, 120, 177, 196, 134, 135, 223, - 221, 84, 62, 213, 221, 183, 85, 201, 56, 102, 171, 119, 67, 64, 169, 91, - 207, 50, 45, 105, 181, 254, 66, 141, 250, 64, 30, 123, 254, 167, 5, - ]); - // @ts-ignore - MOCK_EXTRAPOLATED_SIGNED_TRANSACTION[0].nodes[0].nodes[1].nodes[0].nodes[1].value.raw = - wrongSignature; - jest - .spyOn(extrapolateFromXdr, "default") - .mockReturnValue(MOCK_EXTRAPOLATED_SIGNED_TRANSACTION); - jest.spyOn(xdrViewerActions, "fetchSigners").mockImplementation( - () => (dispatch) => - dispatch({ - type: FETCHED_SIGNERS.SUCCESS, - result: [ - { - isValid: SIGNATURE.INVALID, - sig: wrongSignature, - }, - ], - }), - ); - - render(); - fireEvent.change(screen.getByTestId("transaction-submitter-input"), { - target: { - value: MOCK_SIGNED_TRANSACTION, - }, - }); - await waitFor(() => screen.getByTestId("tree-view-signature")); - expect(screen.getByTestId("tree-view-signature")).toHaveStyle("color: red"); - expect( - screen.getByTestId("transaction-submitter-submit-btn"), - ).not.toHaveAttribute("disabled"); -}); diff --git a/src/views/__tests__/XdrViewer.test.tsx b/src/views/__tests__/XdrViewer.test.tsx deleted file mode 100644 index 6b67eda2..00000000 --- a/src/views/__tests__/XdrViewer.test.tsx +++ /dev/null @@ -1,76 +0,0 @@ -/** - * @jest-environment jsdom - */ - -import { fireEvent, waitFor, screen } from "@testing-library/react"; -import { render } from "helpers/testHelpers"; -import { XdrViewer } from "views/XdrViewer"; -import * as extrapolateFromXdr from "helpers/extrapolateFromXdr"; -import * as xdrViewerActions from "actions/xdrViewer"; -import { FETCHED_SIGNERS } from "constants/fetched_signers"; -import { SIGNATURE } from "constants/signature"; -import { - MOCK_SIGNED_TRANSACTION, - MOCK_SIGNATURE_BUFFER, -} from "./__mocks__/transactions"; - -const testNetwork = { - name: "foo", - horizonURL: "https://foo.baz", - networkPassphrase: "bar", -}; - -test("renders XDR Viewer page", async () => { - render(); - await waitFor(() => screen.getByTestId("page-xdr-viewer")); - expect(screen.getByTestId("page-xdr-viewer")).toBeInTheDocument(); - expect(screen.getByTestId("xdr-viewer-results")).toHaveTextContent( - "Enter a base-64 encoded XDR blob to decode.", - ); -}); - -test("shows error on bad input", async () => { - render(); - await waitFor(() => screen.getByTestId("page-xdr-viewer")); - fireEvent.change(screen.getByTestId("xdr-viewer-input"), { - target: { value: "foo" }, - }); - expect(screen.getByTestId("xdr-viewer-results")).toHaveTextContent( - "Unable to decode input as TransactionEnvelope", - ); -}); - -test("extrapolate XDR on input change", async () => { - jest.spyOn(xdrViewerActions, "fetchSigners").mockImplementation( - () => (dispatch) => - dispatch({ - type: FETCHED_SIGNERS.SUCCESS, - result: [ - { - isValid: SIGNATURE.VALID, - sig: MOCK_SIGNATURE_BUFFER, - }, - ], - }), - ); - const extrapolateFromXdrSpy = jest.spyOn(extrapolateFromXdr, "default"); - const fetchSignersSpy = jest.spyOn(xdrViewerActions, "fetchSigners"); - render(, { - preloadedState: { network: { current: testNetwork } }, - }); - await waitFor(() => screen.getByTestId("page-xdr-viewer")); - fireEvent.change(screen.getByTestId("xdr-viewer-input"), { - target: { value: MOCK_SIGNED_TRANSACTION }, - }); - expect(extrapolateFromXdrSpy).toHaveBeenCalledWith( - MOCK_SIGNED_TRANSACTION, - "TransactionEnvelope", - false, - ); - expect(fetchSignersSpy).toHaveBeenCalledWith( - MOCK_SIGNED_TRANSACTION, - testNetwork.horizonURL, - testNetwork.networkPassphrase, - false - ); -}); diff --git a/src/views/__tests__/__mocks__/transactions.ts b/src/views/__tests__/__mocks__/transactions.ts deleted file mode 100644 index 1d209cf8..00000000 --- a/src/views/__tests__/__mocks__/transactions.ts +++ /dev/null @@ -1,9 +0,0 @@ -export const MOCK_SIGNED_TRANSACTION = - "AAAAAgAAAACh2r+1+l+5CW/NW2Q0thkxzA4apVGgybIxGreps6MVzQAAAGQAAWl8AAAAAgAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAABQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABs6MVzQAAAEAu/cecEbyo4saC4dcvaBv+MUkCDJ6ZKXGd/gV4scSGh9/dVD7V3bdVyThmq3dDQKlbzzItabX+Qo36QB57/qcG"; - -export const MOCK_SIGNATURE_BUFFER = Buffer.from([ - 46, 253, 199, 156, 17, 188, 168, 226, 198, 130, 225, 215, 47, 104, 27, 254, - 49, 73, 2, 12, 158, 153, 41, 113, 157, 254, 5, 120, 177, 196, 134, 135, 223, - 221, 84, 62, 213, 221, 183, 85, 201, 56, 102, 171, 119, 67, 64, 169, 91, 207, - 50, 45, 105, 181, 254, 66, 141, 250, 64, 30, 123, 254, 167, 6, -]); diff --git a/test/mocha.opts b/test/mocha.opts deleted file mode 100644 index c5c055fc..00000000 --- a/test/mocha.opts +++ /dev/null @@ -1 +0,0 @@ ---require ./test/test-helper.js \ No newline at end of file diff --git a/test/smoke/routingRoundTrip.js b/test/smoke/routingRoundTrip.js deleted file mode 100644 index 933f4a00..00000000 --- a/test/smoke/routingRoundTrip.js +++ /dev/null @@ -1,142 +0,0 @@ -import { stateToQueryObj } from "../../src/helpers/stateSerializer"; -import SLUG from "../../src/constants/slug"; -import rootReducer from "../../src/reducers/root"; -import { loadState } from "../../src/actions/routing"; -import { dehydrate } from "../../src/helpers/hydration"; - -// The routing system converts the state into a url, which gets converted back -// into the state thus forming an infinite loop. In general, the starting state -// should be the same as the ending state because it indicates the -// serialization, deserialization, and loading process is working correctly. -// @param {string} slug - slug constant -// @param {object} queryObj - the url query object that we start from and end at -// @param {object} (endingqueryObj) - In some situations, we expect the round -// trip to end with more parameters it started with because the routing system -// ensures that some parameters are always set in the url. For example, we -// always have the network setting in the url. -function itCircularlyConvertsState(slug, queryObj, endingQueryObj) { - if (endingQueryObj === undefined) { - // eslint-disable-next-line no-param-reassign - endingQueryObj = queryObj; - } - - it("circularly converts [query obj] to [state] to initial [query obj]", () => { - const resultQueryObj = stateToQueryObj( - slug, - rootReducer(undefined, loadState(slug, queryObj)), - ); - expect(resultQueryObj).to.deep.equal(endingQueryObj); - }); -} - -describe("routing system", () => { - describe("for endpoint explorer", () => { - describe("in an empty scenario", () => { - itCircularlyConvertsState(SLUG.EXPLORER, { - network: "test", - }); - }); - - describe("in a configured scenario", () => { - itCircularlyConvertsState(SLUG.EXPLORER, { - endpoint: "all", - resource: "transactions", - values: dehydrate({ - cursor: 5, - }), - network: "test", - }); - }); - }); - - describe("for transaction builder", () => { - describe("in a default scenario", () => { - itCircularlyConvertsState(SLUG.TXBUILDER, { - network: "test", - params: dehydrate({ - attributes: { fee: "100", baseFee: "100", minFee: "100" }, - feeBumpAttributes: { maxFee: "100" }, - }), - }); - }); - - describe("in a configured scenario", () => { - itCircularlyConvertsState(SLUG.TXBUILDER, { - network: "test", - params: dehydrate({ - attributes: { - sourceAccount: "somewhere", - sequence: "over", - fee: "100", - baseFee: "100", - minFee: "100", - memoType: "MEMO_TEXT", - memoContent: "the", - }, - feeBumpAttributes: { maxFee: "100" }, - txType: "FEE_BUMP", - operations: [ - { - id: 0, - attributes: { - destination: "rainbow", - }, - name: "payment", - }, - ], - }), - }); - }); - }); - - describe("for transaction signer", () => { - describe("in an empty scenario", () => { - itCircularlyConvertsState(SLUG.TXSIGNER, { - network: "test", - }); - }); - - describe("in a configured scenario", () => { - itCircularlyConvertsState(SLUG.TXSIGNER, { - network: "test", - xdr: "AAAAAOviDWZdAxfxZ83i1Dx6ZGbnSM8pxoPMrtc5VuSJSBKsAAAAZAAAAAAAAAABAAAAAAAAAAEAAAAAAAAAAQAAAAAAAAAJAAAAAAAAAAA=", - }); - }); - }); - - describe("for XDR viewer", () => { - describe("in an empty scenario", () => { - itCircularlyConvertsState( - SLUG.XDRVIEWER, - { - network: "test", - }, - { - network: "test", - type: "TransactionEnvelope", - }, - ); - }); - - describe("in a configured scenario", () => { - itCircularlyConvertsState(SLUG.XDRVIEWER, { - network: "test", - type: "TransactionEnvelope", - input: - "AAAAAOviDWZdAxfxZ83i1Dx6ZGbnSM8pxoPMrtc5VuSJSBKsAAAAZAAAAAAAAAABAAAAAAAAAAEAAAAAAAAAAQAAAAAAAAAJAAAAAAAAAAA=", - }); - }); - }); - - describe("for any page", () => { - describe("where network is not specified and should be added ", () => { - itCircularlyConvertsState( - SLUG.EXPLORER, - {}, - { - network: "test", - }, - ); - }); - }); -}); diff --git a/test/test-helper.js b/test/test-helper.js deleted file mode 100644 index 90cd56c3..00000000 --- a/test/test-helper.js +++ /dev/null @@ -1,6 +0,0 @@ -require("@babel/register"); -require("regenerator-runtime/runtime"); - -// eslint-disable-next-line import/newline-after-import -global.chai = require("chai"); -global.expect = global.chai.expect; diff --git a/test/unit/Libify.js b/test/unit/Libify.js deleted file mode 100644 index e93403fa..00000000 --- a/test/unit/Libify.js +++ /dev/null @@ -1,401 +0,0 @@ -import { xdr, Transaction, Operation, Networks } from "@stellar/stellar-sdk"; -import Libify from "../../src/helpers/Libify"; - -describe("Libify.buildTransaction", () => { - // eslint-disable-next-line no-undef - context("when building a simple transaction", () => { - const simpleTransaction = Libify.buildTransaction( - { - sourceAccount: - "GCNZ6DLRLBDUUTXMGKHMCIG44I6VSZ4U6ACY6CSICK5DFVRATYJTAEVT", - sequence: "321", - fee: "42", - memoType: "", - memoContent: "", - }, - [ - { - id: 0, - attributes: { - destination: - "GDCIK56SS6B3WEIY2GVPNI5GA7SLXVDUMLAPJBCVD3MYVUJQX2OLIFBX", - startingBalance: "30", - }, - name: "createAccount", - }, - ], - Networks.TESTNET, - ); - expect(simpleTransaction.errors).to.deep.equal([]); - const decodedTx = new Transaction(simpleTransaction.xdr, Networks.TESTNET); - - it("contains specified source account", () => { - expect(decodedTx.source).to.equal( - "GCNZ6DLRLBDUUTXMGKHMCIG44I6VSZ4U6ACY6CSICK5DFVRATYJTAEVT", - ); - }); - - it("contains specified sequence number", () => { - expect(decodedTx.sequence).to.equal("321"); - }); - - it("contains specified fee", () => { - expect(decodedTx.fee).to.equal("42"); - }); - - it("contains no memo", () => { - expect(decodedTx.memo._type).to.equal("none"); - }); - - it("contains one operation", () => { - expect(decodedTx.operations.length).to.equal(1); - }); - }); - - // eslint-disable-next-line no-undef - context("when building a large transaction", () => { - const largeTransaction = Libify.buildTransaction( - { - sourceAccount: - "GCNZ6DLRLBDUUTXMGKHMCIG44I6VSZ4U6ACY6CSICK5DFVRATYJTAEVT", - sequence: "1", - fee: "150", - memoType: "MEMO_TEXT", - memoContent: ":D", - }, - [ - { - id: 0, - attributes: { - destination: - "GCNZ6DLRLBDUUTXMGKHMCIG44I6VSZ4U6ACY6CSICK5DFVRATYJTAEVT", - startingBalance: "30", - sourceAccount: - "GACHREGNP75WHOD4NC5O2GGCX2HRENUKVDZCVK5OSHVGO6PIQ73AJI2E", - }, - name: "createAccount", - }, - { - id: 1, - name: "payment", - attributes: { - destination: - "GDZMOE7AWFY5KDPZGWTT26J4XFKOHR626KMWSXHXAZHXIPRKO62KUPQX", - asset: { - type: "credit_alphanum4", - code: "ABC", - issuer: - "GDZMOE7AWFY5KDPZGWTT26J4XFKOHR626KMWSXHXAZHXIPRKO62KUPQX", - }, - amount: "50", - }, - }, - { - id: 2, - name: "pathPaymentStrictSend", - attributes: { - destination: - "GARYDU5S4E3HS2XOSDY5ELOCBGGXFLPFQHMO42JIWOMCR5QGFDHBNJEW", - sendAsset: { - type: "credit_alphanum12", - code: "MONSTER", - issuer: - "GCOXOGREKTFJJJP2RTZHRHQC6IB7AHPSBQGUAVIMDMTQNJZSNLCJLT2G", - }, - sendAmount: "5", - path: [ - { - type: "native", - }, - ], - destAsset: { - type: "native", - }, - destMin: "345678", - }, - }, - { - id: 3, - name: "pathPaymentStrictReceive", - attributes: { - destination: - "GARYDU5S4E3HS2XOSDY5ELOCBGGXFLPFQHMO42JIWOMCR5QGFDHBNJEW", - sendAsset: { - type: "credit_alphanum12", - code: "MONSTER", - issuer: - "GCOXOGREKTFJJJP2RTZHRHQC6IB7AHPSBQGUAVIMDMTQNJZSNLCJLT2G", - }, - sendMax: "5", - path: [ - { - type: "native", - }, - ], - destAsset: { - type: "native", - }, - destAmount: "456789", - }, - }, - { - id: 4, - name: "manageSellOffer", - attributes: { - selling: { - type: "native", - }, - buying: { - type: "credit_alphanum12", - code: "ALLTHETHINGS", - issuer: - "GCVUWFL4USUCGHCPCOLPMORYCI5F37IM3CEIQM55IQ3ZNDSYCQIE2534", - }, - amount: "0", - price: "4.417", - offerId: "0", - }, - }, - { - id: 5, - name: "createPassiveSellOffer", - attributes: { - selling: { - type: "native", - }, - buying: { - type: "credit_alphanum4", - code: "GOOD", - issuer: - "GCVUWFL4USUCGHCPCOLPMORYCI5F37IM3CEIQM55IQ3ZNDSYCQIE2534", - }, - amount: "5", - price: "2", - }, - }, - { - id: 6, - name: "setOptions", - attributes: { - inflationDest: - "GAJNYCPCVHNM724OKKJ3UOPLLHP7LUEODUMXLE4RZ74OXAYENY5BV4CZ", - setFlags: 1, - clearFlags: 6, - masterWeight: "1", - lowThreshold: "2", - medThreshold: "3", - signer: { - type: "ed25519PublicKey", - content: - "GA2IKCQR3WNN5W5446MU5UZZW7UIHWQN6UVJCAXRMRH4JV3QSOABQXI4", - weight: "5", - }, - homeDomain: "example.com", - }, - }, - { - id: 7, - name: "changeTrust", - attributes: { - asset: { - type: "credit_alphanum4", - code: "123", - issuer: - "GB6I3Y3F24UMOJ326W3Z4AHRI3VKXNEFSDPZ7CCSHHYD5ML7RDEJYHJR", - }, - }, - }, - { - id: 8, - name: "allowTrust", - attributes: { - trustor: "GB6I3Y3F24UMOJ326W3Z4AHRI3VKXNEFSDPZ7CCSHHYD5ML7RDEJYHJR", - assetCode: "456", - authorize: "1", - }, - }, - { - id: 9, - name: "accountMerge", - attributes: { - destination: - "GD4WIAWVK7TCHDLIVB7YQ3P45PGPPK4RD52FZVS52TJE3224R566G45L", - sourceAccount: - "GDNG66PN7A4OCNY2XOAWL4NVO6ALFRP2RCGOZ2WMGMHBZCWM5RXWVHPU", - }, - }, - { - id: 10, - name: "manageData", - attributes: { - name: "wow", - value: "such test", - }, - }, - { - id: 11, - name: "manageBuyOffer", - attributes: { - selling: { - type: "native", - }, - buying: { - type: "credit_alphanum12", - code: "ALLTHETHINGS", - issuer: - "GCVUWFL4USUCGHCPCOLPMORYCI5F37IM3CEIQM55IQ3ZNDSYCQIE2534", - }, - buyAmount: "0", - price: "4.417", - offerId: "0", - }, - }, - ], - Networks.TESTNET, - ); - const decodedTx = xdr.TransactionEnvelope.fromXDR( - largeTransaction.xdr, - "base64", - ); - const operations = decodedTx.value().tx().operations(); - const opAtIndex = (index) => Operation.fromXDRObject(operations[index]); - - describe("createAccount operation at index 0", () => { - it("is of type createAccount", () => { - expect(opAtIndex(0).type).to.equal("createAccount"); - }); - it("contains source account", () => { - expect(opAtIndex(0)).to.have.property("source"); - }); - it("contains specified destination", () => { - expect(opAtIndex(0).destination).to.equal( - "GCNZ6DLRLBDUUTXMGKHMCIG44I6VSZ4U6ACY6CSICK5DFVRATYJTAEVT", - ); - }); - }); - - describe("payment operation at index 1", () => { - it("is of type payment", () => { - expect(opAtIndex(1).type).to.equal("payment"); - }); - it("contains no source account", () => { - expect(opAtIndex(1)).to.not.have.property("source"); - }); - - it("contains ABC credit", () => { - expect(opAtIndex(1).asset.code).to.equal("ABC"); - }); - }); - - describe("pathPaymentStrictSend operation at index 2", () => { - it("is of type pathPaymentStrictSend", () => { - expect(opAtIndex(2).type).to.equal("pathPaymentStrictSend"); - }); - it("contains native destination assset", () => { - expect(opAtIndex(2).destAsset.code).to.equal("XLM"); - }); - it("contains MONSTER send asset", () => { - expect(opAtIndex(2).sendAsset.code).to.equal("MONSTER"); - }); - }); - - describe("pathPaymentStrictReceive operation at index 3", () => { - it("is of type pathPaymentStrictReceive", () => { - expect(opAtIndex(3).type).to.equal("pathPaymentStrictReceive"); - }); - it("contains native destination assset", () => { - expect(opAtIndex(3).destAsset.code).to.equal("XLM"); - }); - it("contains MONSTER send asset", () => { - expect(opAtIndex(3).sendAsset.code).to.equal("MONSTER"); - }); - }); - - describe("manageSellOffer operation at index 4", () => { - it("is of type manageSellOffer", () => { - expect(opAtIndex(4).type).to.equal("manageSellOffer"); - }); - it("contains specified price", () => { - expect(opAtIndex(4).price).to.equal("4.417"); - }); - }); - - describe("manageBuyOffer operation at index 11", () => { - it("is of type manageBuyOffer", () => { - expect(opAtIndex(11).type).to.equal("manageBuyOffer"); - }); - it("contains specified price", () => { - expect(opAtIndex(11).price).to.equal("4.417"); - }); - }); - - describe("createPassiveSellOffer operation at index 5", () => { - it("is of type createPassiveSellOffer", () => { - expect(opAtIndex(5).type).to.equal("createPassiveSellOffer"); - }); - it("contains specified amount", () => { - expect(opAtIndex(5).amount).to.equal("5.0000000"); - }); - }); - - describe("setOptions operation at index 6", () => { - it("is of type setOptions", () => { - expect(opAtIndex(6).type).to.equal("setOptions"); - }); - it("contains specified clearFlags", () => { - expect(opAtIndex(6).clearFlags).to.equal(6); - }); - it("contains specified signer pubKey", () => { - expect(opAtIndex(6).signer.ed25519PublicKey).to.equal( - "GA2IKCQR3WNN5W5446MU5UZZW7UIHWQN6UVJCAXRMRH4JV3QSOABQXI4", - ); - }); - it("contains specified homeDomain", () => { - expect(opAtIndex(6).homeDomain).to.equal("example.com"); - }); - it("contains no high threshold", () => { - expect(opAtIndex(6).highThreshold).to.be.a("undefined"); - }); - }); - - describe("changeTrust operation at index 7", () => { - it("is of type changeTrust", () => { - expect(opAtIndex(7).type).to.equal("changeTrust"); - }); - it("contains specified asset issuer", () => { - expect(opAtIndex(7).line.issuer).to.equal( - "GB6I3Y3F24UMOJ326W3Z4AHRI3VKXNEFSDPZ7CCSHHYD5ML7RDEJYHJR", - ); - }); - }); - - describe("allowTrust operation at index 8", () => { - it("is of type allowTrust", () => { - expect(opAtIndex(8).type).to.equal("allowTrust"); - }); - it("contains true authorize flag", () => { - expect(opAtIndex(8).authorize).to.equal(1); - }); - }); - - describe("accountMerge operation at index 9", () => { - it("is of type accountMerge", () => { - expect(opAtIndex(9).type).to.equal("accountMerge"); - }); - it("contains merge destination", () => { - expect(opAtIndex(9).destination).to.equal( - "GD4WIAWVK7TCHDLIVB7YQ3P45PGPPK4RD52FZVS52TJE3224R566G45L", - ); - }); - }); - - describe("manageData operation at index 10", () => { - it("is of type manageData", () => { - expect(opAtIndex(10).type).to.equal("manageData"); - }); - it("contains specified value in manageData value", () => { - expect(opAtIndex(10).value.toString()).to.equal("such test"); - }); - }); - }); -}); diff --git a/test/unit/convertMuxedAccountToEd25519Account.js b/test/unit/convertMuxedAccountToEd25519Account.js deleted file mode 100644 index 1790185a..00000000 --- a/test/unit/convertMuxedAccountToEd25519Account.js +++ /dev/null @@ -1,12 +0,0 @@ -import convert from '../../src/helpers/convertMuxedAccountToEd25519Account'; - -describe('convertMuxedAccountToEd25519Account', () => { - it('returns M accounts for now', () => { - expect(convert('MAAAAAAAAAAAAFHU4MODGMHQOYHMPCMPOZ3KIL3ZH34AUH4MH6UG2AJEBFWQOPSVR2RMK')) - .to.equal('MAAAAAAAAAAAAFHU4MODGMHQOYHMPCMPOZ3KIL3ZH34AUH4MH6UG2AJEBFWQOPSVR2RMK'); - }); - it('works with G accounts', () => { - expect(convert('GD2OGHBTGDYHMDWHRGHXM5VEF54T56AKD6GD7KDNAESAS3IHHZKY46XI')) - .to.equal('GD2OGHBTGDYHMDWHRGHXM5VEF54T56AKD6GD7KDNAESAS3IHHZKY46XI'); - }); -}); diff --git a/test/unit/hydration.js b/test/unit/hydration.js deleted file mode 100644 index d1fa6ef1..00000000 --- a/test/unit/hydration.js +++ /dev/null @@ -1,22 +0,0 @@ -import { rehydrate, dehydrate } from "../../src/helpers/hydration"; - -describe("hydration utility", () => { - describe("rehydrate()", () => { - it("converts a base64 JSON string into the correct object", () => { - const rehydrated = rehydrate("eyJmb28iOiJiYXIifQ=="); - expect(rehydrated).to.deep.equal({ foo: "bar" }); - }); - - it("converts an invalid base64 JSON into an empty object", () => { - const rehydrated = rehydrate("AAAAAAA"); - expect(rehydrated).to.deep.equal({}); - }); - }); - - describe("dehydrate()", () => { - it("converts object into correct base64 JSON string", () => { - const rehydrated = dehydrate({ foo: "bar" }); - expect(rehydrated).to.deep.equal("eyJmb28iOiJiYXIifQ=="); - }); - }); -}); diff --git a/test/unit/linkBuilder.js b/test/unit/linkBuilder.js deleted file mode 100644 index 43b53b75..00000000 --- a/test/unit/linkBuilder.js +++ /dev/null @@ -1,80 +0,0 @@ -import { - txSignerLink, - txPostLink, - feeBumpTxLink, - xdrViewer, - singleAccount, - horizonUrlToExplorerLink, -} from "../../src/helpers/linkBuilder"; - -describe("linkBuilder", () => { - describe("txSignerLink()", () => { - it("returns the correct url", () => { - expect(txSignerLink("AG/eK0AAAAAAA=")).to.equal( - "#txsigner?xdr=AG%2FeK0AAAAAAA%3D", - ); - }); - }); - - describe("txPostLink()", () => { - it("returns the correct url", () => { - expect(txPostLink("AG/eK0AAAAAAA=")).to.equal( - "#txsubmitter?input=AG%2FeK0AAAAAAA%3D", - ); - }); - }); - - describe("xdrViewer()", () => { - it("returns the correct url", () => { - expect(xdrViewer("AG/eK0AAAAAAA=", "TransactionEnvelope")).to.equal( - "#xdr-viewer?input=AG%2FeK0AAAAAAA%3D&type=TransactionEnvelope", - ); - }); - }); - - describe("feeBumpTxLink()", () => { - it("returns the correct url", () => { - expect(feeBumpTxLink("AG/eK0AAAAAAA=")).to.equal( - "#txbuilder?params=eyJmZWVCdW1wQXR0cmlidXRlcyI6eyJpbm5lclR4WERSIjoiQUcvZUswQUFBQUFBQT0ifSwidHhUeXBlIjoiRkVFX0JVTVAifQ%3D%3D", - ); - }); - }); - - describe("singleAccount()", () => { - it("returns the correct url", () => { - expect( - singleAccount( - "GAKRI33OWJLTCVGOPKAGTBUOLCRNF2GRX54K2OFNZWPX5Y3LQC2Q77IN", - ), - ).to.equal( - "#explorer?resource=accounts&endpoint=single&values=eyJhY2NvdW50X2lkIjoiR0FLUkkzM09XSkxUQ1ZHT1BLQUdUQlVPTENSTkYyR1JYNTRLMk9GTlpXUFg1WTNMUUMyUTc3SU4ifQ%3D%3D", - ); - }); - }); - - describe("horizonUrlToExplorerLink()", () => { - it("converts a simple horizon link to a endpoint explorer link", () => { - expect( - horizonUrlToExplorerLink( - "https://horizon-testnet.stellar.org/ledgers/1173", - ), - ).to.equal( - "#explorer?resource=ledgers&endpoint=single&values=eyJsZWRnZXIiOiIxMTczIn0%3D", - ); - }); - - it("converts a templated horizon link to a endpoint explorer link", () => { - expect( - horizonUrlToExplorerLink( - "https://horizon-testnet.stellar.org/ledgers/1173/transactions{?cursor,limit,order}", - ), - ).to.equal( - "#explorer?resource=transactions&endpoint=for_ledger&values=eyJsZWRnZXIiOiIxMTczIn0%3D", - ); - }); - - it("converts a non url into undefined", () => { - expect(horizonUrlToExplorerLink("lumens")).to.be.a("undefined"); - }); - }); -}); diff --git a/tests/createAccountPage.test.ts b/tests/createAccountPage.test.ts new file mode 100644 index 00000000..9d4f4877 --- /dev/null +++ b/tests/createAccountPage.test.ts @@ -0,0 +1,70 @@ +import { test, expect } from "@playwright/test"; + +test.describe("Create Account Page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/account/create"); + }); + + test("Loads", async ({ page }) => { + await expect(page.locator("h1")).toHaveText("Keypair Generator"); + }); + + test("Renders 'Generate keypair' and 'Fund account' button", async ({ + page, + }) => { + const buttonContainer = page.getByTestId("createAccount-buttons"); + expect(buttonContainer.getByText("Generate keypair")).toBeVisible; + expect(buttonContainer.getByText("Fund account with Friendbot")) + .toBeVisible; + }); + + test("Test 'Generate keypair' button", async ({ page }) => { + await page.getByRole("button", { name: "Generate keypair" }).click(); + + await expect( + page.locator("input[id='generate-keypair-publickey']"), + ).toHaveValue(/^G/); + await expect( + page.locator("input[id='generate-keypair-secretkey']"), + ).toHaveValue(/^S/); + }); + + test("Successfully funds an account when clicking 'Fund account' with a valid public key", async ({ + page, + }) => { + await page.getByRole("button", { name: "Generate keypair" }).click(); + + const fundButton = page + .getByTestId("fundAccount-button") + .getByText("Fund account with Friendbot"); + + await expect(fundButton).toBeEnabled(); + + // Mock the friendbot api call + await page.route( + "*/**/?addr=GA4X4QMSTEUKWAXXX3TBFRMGWI3O5X5IUUHPKAIH5XKNQ4IBTQ6YSVV3", + async (route) => { + await route.fulfill({ + status: 200, + contentType: "application/json", + body: JSON.stringify({}), + }); + }, + ); + + // Ensure the listener is set up before the action that triggers the request + const responsePromise = page.waitForResponse( + (response) => + response.url().includes("?addr=") && response.status() === 200, + ); + + await fundButton.click(); + + // Wait for the mocked response + await responsePromise; + + // Success is visible + const alertBox = page.getByText(/Successfully funded/); + await expect(alertBox).toBeVisible(); + }); +}); diff --git a/tests/createMuxedAccountPage.test.ts b/tests/createMuxedAccountPage.test.ts new file mode 100644 index 00000000..8b34a165 --- /dev/null +++ b/tests/createMuxedAccountPage.test.ts @@ -0,0 +1,72 @@ +import { test, expect } from "@playwright/test"; + +import { Account, MuxedAccount } from "@stellar/stellar-sdk"; + +test.describe("Create Muxed Account Page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/account/muxed-create"); + }); + + test("Loads", async ({ page }) => { + await expect(page.locator("h1")).toHaveText("Create Multiplexed Account"); + }); + + test("Renders 'Base Account G Address' and 'Muxed Account ID' input field", async ({ + page, + }) => { + expect(page.locator("input[id='muxed-public-key']")).toBeVisible; + expect(page.locator("input[id='muxed-account-iD']")).toBeVisible; + }); + + test("Gets an error with an invalid public key in 'Base Account G Address' field", async ({ + page, + }) => { + const publicKeyInput = page.locator("#muxed-public-key"); + + // Type in an invalid string in 'Public Key' input field + await publicKeyInput.fill("XLKDSFJLSKDJF"); + + await expect(publicKeyInput).toHaveAttribute("aria-invalid", "true"); + await expect( + page.getByText("Base account address should start with G"), + ).toBeVisible(); + }); + + test("Gets an error with a non whole number 'Muxed Account ID' field", async ({ + page, + }) => { + const muxedAccountIdInput = page.locator("#muxed-account-id"); + + await muxedAccountIdInput.fill("XLKDSFJLSKDJF"); + + await expect(muxedAccountIdInput).toHaveAttribute("aria-invalid", "true"); + await expect(page.getByText("Expected a whole number")).toBeVisible(); + }); + + test("Successfully creates a muxed account", async ({ page }) => { + const publicKey = + "GDVOT2ALMUF3G54RBHNJUEV6LOAZCQQCARHEVNUPKGMVPWFC4PFN33QR"; + const muxedId = "2"; + const publicKeyInput = page.locator("#muxed-public-key"); + await publicKeyInput.fill(publicKey); + + const muxedAccountIdInput = page.locator("#muxed-account-id"); + await muxedAccountIdInput.fill(muxedId); + + const createButton = page.getByRole("button").getByText("Create"); + + await expect(publicKeyInput).toHaveAttribute("aria-invalid", "false"); + await expect(muxedAccountIdInput).toHaveAttribute("aria-invalid", "false"); + await expect(createButton).toBeEnabled(); + + await createButton.click(); + + await expect(page.getByTestId("createAccount-success")).toBeVisible(); + + const muxedValue = page.locator("input[id='muxed-account-address-result']"); + + const muxedAccount = new MuxedAccount(new Account(publicKey, "0"), muxedId); + + await expect(muxedValue).toHaveValue(muxedAccount.accountId()); + }); +}); diff --git a/tests/endpointsPage.test.ts b/tests/endpointsPage.test.ts new file mode 100644 index 00000000..bb8bab78 --- /dev/null +++ b/tests/endpointsPage.test.ts @@ -0,0 +1,187 @@ +import { test, expect } from "@playwright/test"; + +test.describe("Endpoints page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/endpoints"); + }); + + test("Loads", async ({ page }) => { + await expect(page.locator("h1")).toHaveText("Endpoints"); + }); + + test("Renders info cards", async ({ page }) => { + await expect(page.locator("h2")).toHaveText([ + "Soroban RPC Endpoints", + "Horizon Endpoints", + ]); + }); + + test.describe("Sidebar", () => { + test("Renders Horizon endpoints", async ({ page }) => { + const sidebar = page.getByTestId("endpoints-sidebar-section"); + + await expect( + sidebar.getByTestId("endpoints-sidebar-subtitle").nth(0), + ).toContainText("RPC Endpoints"); + + await expect( + sidebar.getByTestId("endpoints-sidebar-subtitle").nth(1), + ).toContainText("Horizon Endpoints"); + + const linkToggles = sidebar.getByTestId("endpoints-sidebar-linkToggle"); + + await expect(linkToggles).toHaveCount(17); + + await expect(linkToggles).toContainText([ + "Accounts", + "Assets", + "Claimable Balances", + "Effects", + "Fee Stats", + "Ledgers", + "Liquidity Pools", + "Offers", + "Operations", + "Order Book", + "Paths", + "Payments", + "Trade Aggregations", + "Trades", + "Transactions", + ]); + }); + + test("Dropdown shows correct links on page load", async ({ page }) => { + const sidebar = page.getByTestId("endpoints-sidebar-section"); + + const accountsLink = sidebar + .getByTestId("endpoints-sidebar-linkToggle") + .filter({ hasText: "Accounts" }); + + const parent = sidebar.getByTestId( + "endpoints-sidebar/endpoints/accounts", + ); + await expect(parent).toBeVisible(); + + const linksContainer = parent.getByTestId( + "endpoints-sidebar-linksContainer", + ); + + await expect(linksContainer).toBeHidden(); + await accountsLink.click(); + await expect(linksContainer).toBeVisible(); + + await expect( + linksContainer.getByTestId("endpoints-sidebar-link"), + ).toContainText(["All Accounts", "Single Account"]); + + await expect( + linksContainer + .getByTestId("endpoints-sidebar-link") + .filter({ hasText: "All Accounts" }), + ).toHaveAttribute("href", "/endpoints/accounts"); + }); + }); + + test.describe("All Accounts", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/endpoints/accounts"); + }); + + test("Page loads with correct title and view docs link", async ({ + page, + }) => { + await expect(page.locator("h1")).toHaveText("All Accounts"); + + const docsLink = page.getByTestId("endpoints-docsLink"); + + await expect(docsLink).toContainText("View accounts documentation"); + await expect(docsLink).toHaveAttribute( + "href", + "https://developers.stellar.org/network/horizon/resources/list-all-accounts", + ); + }); + + test("URL and buttons have correct defaults", async ({ page }) => { + await expect(page.getByTestId("endpoints-url")).toHaveValue( + "https://horizon-testnet.stellar.org/accounts/", + ); + await expect(page.getByTestId("endpoints-url-method")).toContainText( + "GET", + ); + await expect(page.getByTestId("endpoints-submitBtn")).toBeEnabled(); + }); + + test("URL updates when inputs change", async ({ page }) => { + await page + .getByLabel("Sponsor(optional)") + .fill("GBV6DGKNXELF3TYU4V3NRCF57Q3477KLUBBINVG5GGR3LJYVQPKPDX4C"); + + await expect(page.getByTestId("endpoints-url")).toHaveValue( + "https://horizon-testnet.stellar.org/accounts/?sponsor=GBV6DGKNXELF3TYU4V3NRCF57Q3477KLUBBINVG5GGR3LJYVQPKPDX4C", + ); + + await page.getByLabel("Limit(optional)").fill("2"); + + await expect(page.getByTestId("endpoints-url")).toHaveValue( + "https://horizon-testnet.stellar.org/accounts/?sponsor=GBV6DGKNXELF3TYU4V3NRCF57Q3477KLUBBINVG5GGR3LJYVQPKPDX4C&limit=2", + ); + }); + }); + + test.describe("Effects for Account", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/endpoints/effects/account"); + }); + + test("Page loads with correct title and view docs link", async ({ + page, + }) => { + await expect(page.locator("h1")).toHaveText("Effects for Account"); + + const docsLink = page.getByTestId("endpoints-docsLink"); + + await expect(docsLink).toContainText( + "View effects for account documentation", + ); + await expect(docsLink).toHaveAttribute( + "href", + "https://developers.stellar.org/network/horizon/resources/get-effects-by-account-id", + ); + }); + + test("URL and buttons have correct defaults", async ({ page }) => { + await expect(page.getByTestId("endpoints-url")).toHaveValue( + "https://horizon-testnet.stellar.org/accounts//effects", + ); + await expect(page.getByTestId("endpoints-url-method")).toContainText( + "GET", + ); + await expect(page.getByTestId("endpoints-submitBtn")).toBeDisabled(); + }); + + test("Filling required field enables submit button", async ({ page }) => { + const accountInput = page.getByLabel("Account ID"); + await accountInput.fill( + "GAXELIT3WH4ALN66AYQAZILPSSZVIQV67R62FACYC6DHNZCLCN45CA2A", + ); + + await expect(accountInput).toHaveAttribute("aria-invalid", "false"); + await expect(page.getByTestId("endpoints-url")).toHaveValue( + "https://horizon-testnet.stellar.org/accounts/GAXELIT3WH4ALN66AYQAZILPSSZVIQV67R62FACYC6DHNZCLCN45CA2A/effects", + ); + await expect(page.getByTestId("endpoints-submitBtn")).toBeEnabled(); + }); + + test("Input with error disables submit button", async ({ page }) => { + const accountInput = page.getByLabel("Account ID"); + await accountInput.fill("abc"); + + await expect(accountInput).toHaveAttribute("aria-invalid", "true"); + await expect(page.getByTestId("endpoints-pageContent")).toContainText( + "Public key is invalid.", + ); + await expect(page.getByTestId("endpoints-submitBtn")).toBeDisabled(); + }); + }); +}); diff --git a/tests/fundAccountPage.test.ts b/tests/fundAccountPage.test.ts new file mode 100644 index 00000000..3a606582 --- /dev/null +++ b/tests/fundAccountPage.test.ts @@ -0,0 +1,226 @@ +import { test, expect } from "@playwright/test"; + +test.describe("[futurenet/testnet] Fund Account Page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/account/fund"); + }); + + test("Shows testnet network in the title by default", async ({ page }) => { + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Testnet", + ); + await expect(page.locator("h1")).toHaveText( + "Friendbot: fund a testnet network account", + ); + }); + + test("Shows futurenet network in the title if I change my network to futurenet", async ({ + page, + }) => { + // Click network selector dropdown button + await page.getByTestId("networkSelector-button").click(); + await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + // Select Futurenet in the dropdown list + await page + .getByTestId("networkSelector-dropdown") + .getByTestId("networkSelector-option") + .filter({ has: page.getByText("Futurenet") }) + .click(); + + // Network Submit button + const submitButton = page.getByTestId("networkSelector-submit-button"); + + // Select 'Futurenet' in the network dropdown list + await expect(submitButton).toHaveText("Switch to Futurenet"); + await expect(submitButton).toBeEnabled(); + + // Click 'Switch to Futurenet' button + await submitButton.click(); + + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Futurenet", + ); + await expect(page.locator("h1")).toHaveText( + "Friendbot: fund a futurenet network account", + ); + }); + + test("By default, 'Public Key' input field is empty and buttons are disabled", async ({ + page, + }) => { + await expect(page.locator("#fund-public-key-input")).toHaveValue(""); + + const getLumenButton = page + .getByTestId("fundAccount-buttons") + .getByText("Get lumens"); + const fillInButton = page + .getByTestId("fundAccount-buttons") + .getByText("Fill in with generated key"); + + await expect(getLumenButton).toBeDisabled(); + await expect(fillInButton).toBeDisabled(); + }); + + test("Gets an error with an invalid public key in 'Public Key' field", async ({ + page, + }) => { + const publicKeyInput = page.locator("#fund-public-key-input"); + + // Type in an invalid string in 'Public Key' input field + await publicKeyInput.fill("XLKDSFJLSKDJF"); + + await expect(publicKeyInput).toHaveAttribute("aria-invalid", "true"); + await expect( + page.getByTestId("fundAccount-buttons").getByText("Get lumens"), + ).toBeDisabled(); + }); + + test("Successfully funds an account when clicking 'Get lumens' with a valid public key", async ({ + page, + }) => { + const publicKeyInput = page.locator("#fund-public-key-input"); + const getLumenButton = page + .getByTestId("fundAccount-buttons") + .getByText("Get lumens"); + + await publicKeyInput.fill( + "GB6D5E2HRVBD6QIOXCE6ILMUFQT45LMSZSKRZUCL4ZK6Q6GCNMTJ2E3C", + ); + + await expect(publicKeyInput).toHaveAttribute("aria-invalid", "false"); + await expect(getLumenButton).toBeEnabled(); + + // Mock the friendbot api call + await page.route( + "*/**/?addr=GB6D5E2HRVBD6QIOXCE6ILMUFQT45LMSZSKRZUCL4ZK6Q6GCNMTJ2E3C", + async (route) => { + await route.fulfill({ + status: 200, + contentType: "application/hal+json", + }); + }, + ); + + // Ensure the listener is set up before the action that triggers the request + const responsePromise = page.waitForResponse( + (response) => + response.url().includes("?addr=") && response.status() === 200, + ); + + await getLumenButton.click(); + + await responsePromise; + + const alertBox = page.getByText(/Successfully funded/); + await expect(alertBox).toBeVisible(); + }); + + test("Gets an error when submitting 'Get lumens' with a public key that's already been funded", async ({ + page, + }) => { + const publicKeyInput = page.locator("#fund-public-key-input"); + const getLumenButton = page + .getByTestId("fundAccount-buttons") + .getByText("Get lumens"); + + // Type in an invalid string in 'Public Key' input field + await publicKeyInput.fill( + "GBX6W44ISK6XTBDDJ5ND6KTJHLYEYHMR4SDG635NRARYVJ3G2YXGDT6Y", + ); + + await expect(publicKeyInput).toHaveAttribute("aria-invalid", "false"); + await expect(getLumenButton).toBeEnabled(); + + // Mock the friendbot api call + await page.route( + "*/**/?addr=GBX6W44ISK6XTBDDJ5ND6KTJHLYEYHMR4SDG635NRARYVJ3G2YXGDT6Y", + async (route) => { + await route.fulfill({ + status: 400, + contentType: "application/problem+json", + body: JSON.stringify({ detail: "createAccountAlreadyExist" }), + }); + }, + ); + + // Ensure the listener is set up before the action that triggers the request + const responsePromise = page.waitForResponse( + (response) => + response.url().includes("?addr=") && response.status() === 400, + ); + + await getLumenButton.click(); + + await responsePromise; + + const alertBox = page.getByText(/This account is already funded/); + await expect(alertBox).toBeVisible(); + }); + + // @TODO when we work on the button disabled for funding account from mainnet + // test("if I switch to 'mainnet' network, I should see 'Not Found' page and no 'Fund account' sidebar", async ({ + // page, + // }) => { + // // Click network selector dropdown button + // await page.getByTestId("networkSelector-button").click(); + // await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + // // Select Mainnet in the dropdown list + // await page + // .getByTestId("networkSelector-dropdown") + // .getByTestId("networkSelector-option") + // .filter({ has: page.getByText("Mainnet") }) + // .click(); + + // // Network Submit button + // const submitButton = page.getByTestId("networkSelector-submit-button"); + + // // Select 'Mainnet' in the network dropdown list + // await expect(submitButton).toHaveText("Switch to Mainnet"); + // await expect(submitButton).toBeEnabled(); + + // // Click 'Switch to Mainnet' button + // await submitButton.click(); + + // await expect(page.getByTestId("networkSelector-button")).toHaveText( + // "Mainnet", + // ); +}); + +test.describe("[mainnet] Fund Account Page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/account"); + + // Switch to mainnet network + await page.getByTestId("networkSelector-button").click(); + await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + // Select Mainnet in the dropdown list + await page + .getByTestId("networkSelector-dropdown") + .getByTestId("networkSelector-option") + .filter({ has: page.getByText("Mainnet") }) + .click(); + + // Network Submit button + const submitButton = page.getByTestId("networkSelector-submit-button"); + + // Click 'Switch to Mainnet' button + await submitButton.click(); + + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Mainnet", + ); + }); + + test("I should see 'Switch Network' page on /account/fund", async ({ + page, + }) => { + await page.goto("http://localhost:3000/account/fund"); + + await expect(page.locator("h1")).toHaveText( + "Friendbot: fund a Futurenet or Testnet network account", + ); + }); +}); diff --git a/tests/introductionPage.test.ts b/tests/introductionPage.test.ts new file mode 100644 index 00000000..8e2c8a9c --- /dev/null +++ b/tests/introductionPage.test.ts @@ -0,0 +1,20 @@ +import { test, expect } from "@playwright/test"; + +test.describe("Introduction Page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/"); + }); + + test("Loads", async ({ page }) => { + await expect(page.locator("h1")).toHaveText("Stellar Lab"); + }); + + test("Renders info cards", async ({ page }) => { + await expect(page.locator("h2")).toHaveText([ + "Stellar Quest", + "Developer Tools", + "Soroban RPC", + "Horizon", + ]); + }); +}); diff --git a/tests/networkSelector.test.ts b/tests/networkSelector.test.ts new file mode 100644 index 00000000..c17d6323 --- /dev/null +++ b/tests/networkSelector.test.ts @@ -0,0 +1,180 @@ +import { test, expect } from "@playwright/test"; + +test.describe("Network selector", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/"); + }); + + test("Defaults to Testnet", async ({ page }) => { + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Testnet", + ); + await expect(page.getByTestId("networkSelector-dropdown")).toBeHidden(); + }); + + test("Shows network dropdown with all selectable network options", async ({ + page, + }) => { + await page.getByTestId("networkSelector-button").click(); + await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + await expect( + page + .getByTestId("networkSelector-dropdown") + .getByTestId("networkSelector-option"), + ).toContainText(["Futurenet", "Testnet", "Mainnet", "Custom"]); + }); + + test("Shows correct network data for the selected network", async ({ + page, + }) => { + await page.getByTestId("networkSelector-button").click(); + await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + // Selected network option + await expect( + page + .getByTestId("networkSelector-dropdown") + .getByTestId("networkSelector-option") + .filter({ has: page.getByText("Testnet") }), + ).toContainText("Selected"); + + // RPC URL + const rpcField = page + .getByTestId("networkSelector-dropdown") + .locator("#rpc-url"); + await expect(rpcField).toHaveValue("https://soroban-testnet.stellar.org"); + await expect(rpcField).toBeDisabled(); + + // Horizon URL + const horizonUrlField = page + .getByTestId("networkSelector-dropdown") + .locator("#network-url"); + await expect(horizonUrlField).toHaveValue( + "https://horizon-testnet.stellar.org", + ); + await expect(horizonUrlField).toBeDisabled(); + + // Network Passphrase + const networkPassphraseField = page + .getByTestId("networkSelector-dropdown") + .locator("#network-passphrase"); + await expect(networkPassphraseField).toHaveValue( + "Test SDF Network ; September 2015", + ); + await expect(networkPassphraseField).toBeDisabled(); + + // Submit button + const submitButton = page.getByTestId("networkSelector-submit-button"); + await expect(submitButton).toHaveText("Switch to Testnet"); + await expect(submitButton).toBeDisabled(); + }); + + test("Updates network data when a different network is selected", async ({ + page, + }) => { + await page.getByTestId("networkSelector-button").click(); + await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + // Selected Futurenet + await page + .getByTestId("networkSelector-dropdown") + .getByTestId("networkSelector-option") + .filter({ has: page.getByText("Futurenet") }) + .click(); + + // RPC URL + const rpcField = page + .getByTestId("networkSelector-dropdown") + .locator("#rpc-url"); + await expect(rpcField).toHaveValue("https://rpc-futurenet.stellar.org"); + await expect(rpcField).toBeDisabled(); + + // Horizon URL + const horizonUrlField = page + .getByTestId("networkSelector-dropdown") + .locator("#network-url"); + await expect(horizonUrlField).toHaveValue( + "https://horizon-futurenet.stellar.org", + ); + await expect(horizonUrlField).toBeDisabled(); + + // Network Passphrase + const networkPassphraseField = page + .getByTestId("networkSelector-dropdown") + .locator("#network-passphrase"); + await expect(networkPassphraseField).toHaveValue( + "Test SDF Future Network ; October 2022", + ); + await expect(networkPassphraseField).toBeDisabled(); + + // Submit button + const submitButton = page.getByTestId("networkSelector-submit-button"); + await expect(submitButton).toHaveText("Switch to Futurenet"); + await expect(submitButton).toBeEnabled(); + + // Network not changed until the submit button is clicked + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Testnet", + ); + + // Click button to change the network + await submitButton.click(); + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Futurenet", + ); + }); + + test("Custom network inputs", async ({ page }) => { + await page.getByTestId("networkSelector-button").click(); + await expect(page.getByTestId("networkSelector-dropdown")).toBeVisible(); + + // Selected Custom network + await page + .getByTestId("networkSelector-dropdown") + .getByTestId("networkSelector-option") + .filter({ has: page.getByText("Custom") }) + .click(); + + // RPC URL + const rpcField = page + .getByTestId("networkSelector-dropdown") + .locator("#rpc-url"); + await expect(rpcField).toHaveValue(""); + await expect(rpcField).toBeEnabled(); + + // Horizon URL + const horizonUrlField = page + .getByTestId("networkSelector-dropdown") + .locator("#network-url"); + await expect(horizonUrlField).toHaveValue(""); + await expect(horizonUrlField).toBeEnabled(); + + // Network Passphrase + const networkPassphraseField = page + .getByTestId("networkSelector-dropdown") + .locator("#network-passphrase"); + await expect(networkPassphraseField).toHaveValue(""); + await expect(networkPassphraseField).toBeEnabled(); + + // Submit button is disabled until inputs are filled + const submitButton = page.getByTestId("networkSelector-submit-button"); + await expect(submitButton).toHaveText("Switch to Custom Network"); + await expect(submitButton).toBeDisabled(); + + // Filled inputs and enabled submit button + await rpcField.fill("https://custom.net"); + await horizonUrlField.fill("https://custom-horizon.net"); + await networkPassphraseField.fill("Custom network passphrase"); + await expect(submitButton).toBeEnabled(); + }); + + test("Selects network from search params", async ({ page }) => { + await page.goto( + "http://localhost:3000/?$=network$id=futurenet&label=Futurenet&horizonUrl=https:////horizon-futurenet.stellar.org&rpcUrl=https:////rpc-futurenet.stellar.org&passphrase=Test%20SDF%20Future%20Network%20/;%20October%202022;;", + ); + await expect(page.getByTestId("networkSelector-button")).toHaveText( + "Futurenet", + ); + }); +}); diff --git a/tests/parseMuxedAccountPage.test.ts b/tests/parseMuxedAccountPage.test.ts new file mode 100644 index 00000000..9bd27e50 --- /dev/null +++ b/tests/parseMuxedAccountPage.test.ts @@ -0,0 +1,32 @@ +import { test, expect } from "@playwright/test"; + +test.describe("Parse Muxed Account Page", () => { + test.beforeEach(async ({ page }) => { + await page.goto("http://localhost:3000/account/muxed-parse"); + }); + + test("Loads", async ({ page }) => { + await expect(page.locator("h1")).toHaveText( + "Get Muxed Account from M address", + ); + }); + + test("Renders 'Muxed Account M Address' input field", async ({ page }) => { + expect(page.locator("input[id='muxed-account-address']")).toBeVisible; + }); + + test("Gets an error with an invalid muxed account key in 'Muxed Account M Address' field", async ({ + page, + }) => { + const publicKeyInput = page.locator("#muxed-account-address"); + + await publicKeyInput.fill( + "GDVOT2ALMUF3G54RBHNJUEV6LOAZCQQCARHEVNUPKGMVPWFC4PFN33QR", + ); + + await expect(publicKeyInput).toHaveAttribute("aria-invalid", "true"); + await expect( + page.getByText("Muxed account address should start with M"), + ).toBeVisible(); + }); +}); diff --git a/tsconfig.json b/tsconfig.json index 63eefae9..9ff63cb6 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,21 +1,35 @@ -{ - "extends": "@stellar/tsconfig", - "compilerOptions": { - "baseUrl": "src/", - "outDir": "./build/", - "target": "es5", - "lib": ["dom", "dom.iterable", "esnext"], - "module": "esnext", - "moduleResolution": "node", - // "noEmit": true, - "jsx": "react-jsx", - "allowSyntheticDefaultImports": true, - "declaration": true, - // "emitDeclarationOnly": true, - "isolatedModules": true, - "allowJs": true, - "esModuleInterop": true - }, - "include": ["src", "test"], - "exclude": ["node_modules", "build"] -} +{ + "extends": "@stellar/tsconfig", + "compilerOptions": { + "target": "es5", + "lib": ["dom", "dom.iterable", "esnext"], + "downlevelIteration": true, + "allowJs": true, + "skipLibCheck": true, + "strict": true, + "noEmit": true, + "esModuleInterop": true, + "module": "esnext", + "moduleResolution": "bundler", + "resolveJsonModule": true, + "isolatedModules": true, + "jsx": "preserve", + "incremental": true, + "plugins": [ + { + "name": "next" + } + ], + "paths": { + "@/*": ["./src/*"] + } + }, + "include": [ + "next-env.d.ts", + "**/*.ts", + "**/*.tsx", + ".next/types/**/*.ts", + "build/types/**/*.ts" + ], + "exclude": ["node_modules"] +} diff --git a/webpack.common.js b/webpack.common.js deleted file mode 100644 index 4c800b8e..00000000 --- a/webpack.common.js +++ /dev/null @@ -1,162 +0,0 @@ -const path = require("path"); -const HtmlWebpackPlugin = require("html-webpack-plugin"); -const { CleanWebpackPlugin } = require("clean-webpack-plugin"); -const ForkTsCheckerWebpackPlugin = require("fork-ts-checker-webpack-plugin"); -const MiniCssExtractPlugin = require("mini-css-extract-plugin"); -const CopyPlugin = require("copy-webpack-plugin"); -const ESLintPlugin = require("eslint-webpack-plugin"); -const ProvidePlugin = require("webpack").ProvidePlugin; -const TsconfigPathsPlugin = require("tsconfig-paths-webpack-plugin"); - -module.exports = { - entry: "./src/index.tsx", - mode: "development", - optimization: { - usedExports: true, - splitChunks: { - cacheGroups: { - source: { - test: /[\\/]src[\\/]/, - name: "source", - chunks: "all", - }, - "vendor-react-redux": { - test: /[\\/]node_modules[\\/](react|react-dom|react-router|react-router-dom|react-redux|redux|redux-thunk|@reduxjs)[\\/]/, - name: "vendor-react-redux", - chunks: "all", - }, - "vendor-stellar": { - test: /[\\/]node_modules[\\/](@stellar|stellar)[\\/]/, - name: "vendor-stellar", - chunks: "all", - }, - "vendor-wallets": { - test: /[\\/]node_modules[\\/](@albedo|@ledgerhq|trezor)[\\/]/, - name: "vendor-wallets", - chunks: "all", - }, - }, - }, - }, - output: { - filename: "static/[name].[contenthash].js", - path: path.resolve(__dirname, "build"), - }, - module: { - rules: [ - { - test: /\.tsx?$/, - exclude: /node_modules/, - use: { - loader: "ts-loader", - options: { - // Disable type checker, we will use it in ForkTsCheckerWebpackPlugin - transpileOnly: true, - }, - }, - }, - { - test: /\.(js|jsx)$/, - exclude: /node_modules/, - loader: "babel-loader", - }, - { - test: /\.(scss|css)$/, - use: [ - process.env.NODE_ENV !== "production" - ? "style-loader" - : MiniCssExtractPlugin.loader, - { - loader: "css-loader", - }, - { - loader: "sass-loader", - options: { - sourceMap: true, - }, - }, - ], - }, - { - test: /\.(png|svg|jpg|jpeg|gif)$/i, - type: "asset/resource", - }, - { - test: /\.svg$/i, - exclude: /node_modules/, - use: [ - { - loader: "@svgr/webpack", - options: { - svgoConfig: { - plugins: { - removeViewBox: false, - }, - }, - }, - }, - { - loader: "file-loader", - options: { - name: "[name].[ext]", - outputPath: "assets/", - }, - }, - ], - }, - { - test: /\.(woff|woff2|eot|ttf|otf)$/i, - type: "asset/resource", - generator: { - filename: "assets/fonts/[name].[ext]", - }, - }, - ], - }, - resolve: { - extensions: [".tsx", ".ts", ".js"], - plugins: [ - // This handles aliases and resolves Design System CSS font paths properly - new TsconfigPathsPlugin({ - configFile: path.resolve(__dirname, "./tsconfig.json"), - }), - ], - // Adding node.js modules - fallback: { - crypto: require.resolve("crypto-browserify"), - stream: require.resolve("stream-browserify"), - assert: require.resolve("assert"), - http: require.resolve("stream-http"), - https: require.resolve("https-browserify"), - os: require.resolve("os-browserify"), - url: require.resolve("url"), - buffer: require.resolve("buffer/"), - querystring: require.resolve("querystring-es3"), - }, - }, - plugins: [ - // Buffer - new ProvidePlugin({ - Buffer: ["buffer", "Buffer"], - }), - new CopyPlugin({ - patterns: [ - { from: "./public", to: "./" }, - { from: "./src/assets", to: "./assets" }, - ], - }), - new MiniCssExtractPlugin({ - filename: "static/[name].[contenthash].css", - chunkFilename: "[id].css", - }), - new CleanWebpackPlugin(), - new HtmlWebpackPlugin({ - template: "./src/index.html", - }), - new ForkTsCheckerWebpackPlugin(), - new ESLintPlugin({ - extensions: [".tsx", ".ts", ".js"], - exclude: "node_modules", - }), - ], -}; diff --git a/webpack.dev.js b/webpack.dev.js deleted file mode 100644 index 6c455c55..00000000 --- a/webpack.dev.js +++ /dev/null @@ -1,15 +0,0 @@ -const path = require("path"); -const { merge } = require("webpack-merge"); -const common = require("./webpack.common.js"); - -module.exports = merge(common, { - mode: "development", - devtool: "cheap-module-source-map", - devServer: { - static: path.join(__dirname, "build"), - historyApiFallback: true, - port: 3000, - open: true, - hot: true, - }, -}); diff --git a/webpack.prod.js b/webpack.prod.js deleted file mode 100644 index 015ba8e8..00000000 --- a/webpack.prod.js +++ /dev/null @@ -1,7 +0,0 @@ -const { merge } = require("webpack-merge"); -const common = require("./webpack.common.js"); - -module.exports = merge(common, { - mode: "production", - devtool: "source-map", -}); diff --git a/yarn.lock b/yarn.lock index 9dc224d9..693316f6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2,47 +2,10 @@ # yarn lockfile v1 -"@albedo-link/intent@^0.11.2": - version "0.11.2" - resolved "https://registry.yarnpkg.com/@albedo-link/intent/-/intent-0.11.2.tgz#af1e8cb2556a846712c87fdd9c0eb21705f177a0" - integrity sha512-RBlbP79zFhboPoHplsiPW4/FsYEvw58Nnz5CQMm8peNCGmWgx5dIiFDmqcgGY5KEbmMGlRTGEFn+XAyka9L9ig== - -"@ampproject/remapping@^2.2.0": - version "2.2.1" - resolved "https://registry.yarnpkg.com/@ampproject/remapping/-/remapping-2.2.1.tgz#99e8e11851128b8702cd57c33684f1d0f260b630" - integrity sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg== - dependencies: - "@jridgewell/gen-mapping" "^0.3.0" - "@jridgewell/trace-mapping" "^0.3.9" - -"@babel/code-frame@7.12.11": - version "7.12.11" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.12.11.tgz#f4ad435aa263db935b8f10f2c552d23fb716a63f" - integrity sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw== - dependencies: - "@babel/highlight" "^7.10.4" - -"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.10.4": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.14.5.tgz#23b08d740e83f49c5e59945fbf1b43e80bbf4edb" - integrity sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw== - dependencies: - "@babel/highlight" "^7.14.5" - -"@babel/code-frame@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.16.7.tgz#44416b6bd7624b998f5b1af5d470856c40138789" - integrity sha512-iAXqUn8IIeBTNd72xsFlgaXHkMBMt6y4HJp1tIaK465CWLT/fG1aqB7ykr95gHHmlBdGbFeWWfyB4NJJ0nmeIg== - dependencies: - "@babel/highlight" "^7.16.7" - -"@babel/code-frame@^7.22.13", "@babel/code-frame@^7.23.5": - version "7.23.5" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.23.5.tgz#9009b69a8c602293476ad598ff53e4562e15c244" - integrity sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA== - dependencies: - "@babel/highlight" "^7.23.4" - chalk "^2.4.2" +"@albedo-link/intent@0.12.0": + version "0.12.0" + resolved "https://registry.yarnpkg.com/@albedo-link/intent/-/intent-0.12.0.tgz#cbc08f24f5d0a1b85ecd4847a9fdac20aece58bf" + integrity sha512-UlGBhi0qASDYOjLrOL4484vQ26Ee3zTK2oAgvPMClOs+1XNk3zbs3dECKZv+wqeSI8SkHow8mXLTa16eVh+dQA== "@babel/code-frame@^7.24.7": version "7.24.7" @@ -52,77 +15,6 @@ "@babel/highlight" "^7.24.7" picocolors "^1.0.0" -"@babel/compat-data@^7.22.6", "@babel/compat-data@^7.23.3", "@babel/compat-data@^7.23.5": - version "7.23.5" - resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.23.5.tgz#ffb878728bb6bdcb6f4510aa51b1be9afb8cfd98" - integrity sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw== - -"@babel/compat-data@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.24.7.tgz#d23bbea508c3883ba8251fb4164982c36ea577ed" - integrity sha512-qJzAIcv03PyaWqxRgO4mSU3lihncDT296vnyuE2O8uA4w3UHWI4S3hgeZd1L8W1Bft40w9JxJ2b412iDUFFRhw== - -"@babel/core@^7.16.0": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.23.6.tgz#8be77cd77c55baadcc1eae1c33df90ab6d2151d4" - integrity sha512-FxpRyGjrMJXh7X3wGLGhNDCRiwpWEF74sKjTLDJSG5Kyvow3QZaG0Adbqzi9ZrVjTWpsX+2cxWXD71NMg93kdw== - dependencies: - "@ampproject/remapping" "^2.2.0" - "@babel/code-frame" "^7.23.5" - "@babel/generator" "^7.23.6" - "@babel/helper-compilation-targets" "^7.23.6" - "@babel/helper-module-transforms" "^7.23.3" - "@babel/helpers" "^7.23.6" - "@babel/parser" "^7.23.6" - "@babel/template" "^7.22.15" - "@babel/traverse" "^7.23.6" - "@babel/types" "^7.23.6" - convert-source-map "^2.0.0" - debug "^4.1.0" - gensync "^1.0.0-beta.2" - json5 "^2.2.3" - semver "^6.3.1" - -"@babel/core@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.24.7.tgz#b676450141e0b52a3d43bc91da86aa608f950ac4" - integrity sha512-nykK+LEK86ahTkX/3TgauT0ikKoNCfKHEaZYTUVupJdTLzGNvrblu4u6fa7DhZONAltdf8e662t/abY8idrd/g== - dependencies: - "@ampproject/remapping" "^2.2.0" - "@babel/code-frame" "^7.24.7" - "@babel/generator" "^7.24.7" - "@babel/helper-compilation-targets" "^7.24.7" - "@babel/helper-module-transforms" "^7.24.7" - "@babel/helpers" "^7.24.7" - "@babel/parser" "^7.24.7" - "@babel/template" "^7.24.7" - "@babel/traverse" "^7.24.7" - "@babel/types" "^7.24.7" - convert-source-map "^2.0.0" - debug "^4.1.0" - gensync "^1.0.0-beta.2" - json5 "^2.2.3" - semver "^6.3.1" - -"@babel/eslint-parser@^7.16.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/eslint-parser/-/eslint-parser-7.23.3.tgz#7bf0db1c53b54da0c8a12627373554a0828479ca" - integrity sha512-9bTuNlyx7oSstodm1cR1bECj4fkiknsDa1YniISkJemMY3DGhJNYBECbe6QD/q54mp2J8VO66jW3/7uP//iFCw== - dependencies: - "@nicolo-ribaudo/eslint-scope-5-internals" "5.1.1-v1" - eslint-visitor-keys "^2.1.0" - semver "^6.3.1" - -"@babel/generator@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.23.6.tgz#9e1fca4811c77a10580d17d26b57b036133f3c2e" - integrity sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw== - dependencies: - "@babel/types" "^7.23.6" - "@jridgewell/gen-mapping" "^0.3.2" - "@jridgewell/trace-mapping" "^0.3.17" - jsesc "^2.5.1" - "@babel/generator@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.24.7.tgz#1654d01de20ad66b4b4d99c135471bc654c55e6d" @@ -133,13 +25,6 @@ "@jridgewell/trace-mapping" "^0.3.25" jsesc "^2.5.1" -"@babel/helper-annotate-as-pure@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.22.5.tgz#e7f06737b197d580a01edf75d97e2c8be99d3882" - integrity sha512-LvBTxu8bQSQkcyKOU+a1btnNFQ1dMAd0R6PyW3arXes06F6QLWLIrd681bxRPIXlrMGR3XYnW9JyML7dP3qgxg== - dependencies: - "@babel/types" "^7.22.5" - "@babel/helper-annotate-as-pure@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.24.7.tgz#5373c7bc8366b12a033b4be1ac13a206c6656aab" @@ -147,73 +32,6 @@ dependencies: "@babel/types" "^7.24.7" -"@babel/helper-builder-binary-assignment-operator-visitor@^7.22.15": - version "7.22.15" - resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.22.15.tgz#5426b109cf3ad47b91120f8328d8ab1be8b0b956" - integrity sha512-QkBXwGgaoC2GtGZRoma6kv7Szfv06khvhFav67ZExau2RaXzy8MpHSMO2PNoP2XtmQphJQRHFfg77Bq731Yizw== - dependencies: - "@babel/types" "^7.22.15" - -"@babel/helper-builder-binary-assignment-operator-visitor@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.24.7.tgz#37d66feb012024f2422b762b9b2a7cfe27c7fba3" - integrity sha512-xZeCVVdwb4MsDBkkyZ64tReWYrLRHlMN72vP7Bdm3OUOuyFZExhsHUUnuWnm2/XOlAJzR0LfPpB56WXZn0X/lA== - dependencies: - "@babel/traverse" "^7.24.7" - "@babel/types" "^7.24.7" - -"@babel/helper-compilation-targets@^7.22.15", "@babel/helper-compilation-targets@^7.22.6", "@babel/helper-compilation-targets@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz#4d79069b16cbcf1461289eccfbbd81501ae39991" - integrity sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ== - dependencies: - "@babel/compat-data" "^7.23.5" - "@babel/helper-validator-option" "^7.23.5" - browserslist "^4.22.2" - lru-cache "^5.1.1" - semver "^6.3.1" - -"@babel/helper-compilation-targets@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.24.7.tgz#4eb6c4a80d6ffeac25ab8cd9a21b5dfa48d503a9" - integrity sha512-ctSdRHBi20qWOfy27RUb4Fhp07KSJ3sXcuSvTrXrc4aG8NSYDo1ici3Vhg9bg69y5bj0Mr1lh0aeEgTvc12rMg== - dependencies: - "@babel/compat-data" "^7.24.7" - "@babel/helper-validator-option" "^7.24.7" - browserslist "^4.22.2" - lru-cache "^5.1.1" - semver "^6.3.1" - -"@babel/helper-create-class-features-plugin@^7.18.6", "@babel/helper-create-class-features-plugin@^7.22.15", "@babel/helper-create-class-features-plugin@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.23.6.tgz#b04d915ce92ce363666f816a884cdcfc9be04953" - integrity sha512-cBXU1vZni/CpGF29iTu4YRbOZt3Wat6zCoMDxRF1MayiEc4URxOj31tT65HUM0CRpMowA3HCJaAOVOUnMf96cw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-function-name" "^7.23.0" - "@babel/helper-member-expression-to-functions" "^7.23.0" - "@babel/helper-optimise-call-expression" "^7.22.5" - "@babel/helper-replace-supers" "^7.22.20" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - "@babel/helper-split-export-declaration" "^7.22.6" - semver "^6.3.1" - -"@babel/helper-create-class-features-plugin@^7.24.5": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.5.tgz#7d19da92c7e0cd8d11c09af2ce1b8e7512a6e723" - integrity sha512-uRc4Cv8UQWnE4NXlYTIIdM7wfFkOqlFztcC/gVXDKohKoVB3OyonfelUBaJzSwpBntZ2KYGF/9S7asCHsXwW6g== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-function-name" "^7.23.0" - "@babel/helper-member-expression-to-functions" "^7.24.5" - "@babel/helper-optimise-call-expression" "^7.22.5" - "@babel/helper-replace-supers" "^7.24.1" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - "@babel/helper-split-export-declaration" "^7.24.5" - semver "^6.3.1" - "@babel/helper-create-class-features-plugin@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.7.tgz#2eaed36b3a1c11c53bdf80d53838b293c52f5b3b" @@ -229,51 +47,6 @@ "@babel/helper-split-export-declaration" "^7.24.7" semver "^6.3.1" -"@babel/helper-create-regexp-features-plugin@^7.18.6", "@babel/helper-create-regexp-features-plugin@^7.22.15", "@babel/helper-create-regexp-features-plugin@^7.22.5": - version "7.22.15" - resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.22.15.tgz#5ee90093914ea09639b01c711db0d6775e558be1" - integrity sha512-29FkPLFjn4TPEa3RE7GpW+qbE8tlsu3jntNYNfcGsc49LphF1PQIiD+vMZ1z1xVOKt+93khA9tc2JBs3kBjA7w== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - regexpu-core "^5.3.1" - semver "^6.3.1" - -"@babel/helper-create-regexp-features-plugin@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.24.7.tgz#be4f435a80dc2b053c76eeb4b7d16dd22cfc89da" - integrity sha512-03TCmXy2FtXJEZfbXDTSqq1fRJArk7lX9DOFC/47VthYcxyIOx+eXQmdo6DOQvrbpIix+KfXwvuXdFDZHxt+rA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - regexpu-core "^5.3.1" - semver "^6.3.1" - -"@babel/helper-define-polyfill-provider@^0.4.4": - version "0.4.4" - resolved "https://registry.yarnpkg.com/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.4.4.tgz#64df615451cb30e94b59a9696022cffac9a10088" - integrity sha512-QcJMILQCu2jm5TFPGA3lCpJJTeEP+mqeXooG/NZbg/h5FTFi6V0+99ahlRsW8/kRLyb24LZVCCiclDedhLKcBA== - dependencies: - "@babel/helper-compilation-targets" "^7.22.6" - "@babel/helper-plugin-utils" "^7.22.5" - debug "^4.1.1" - lodash.debounce "^4.0.8" - resolve "^1.14.2" - -"@babel/helper-define-polyfill-provider@^0.6.1", "@babel/helper-define-polyfill-provider@^0.6.2": - version "0.6.2" - resolved "https://registry.yarnpkg.com/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.6.2.tgz#18594f789c3594acb24cfdb4a7f7b7d2e8bd912d" - integrity sha512-LV76g+C502biUK6AyZ3LK10vDpDyCzZnhZFXkH1L75zHPj68+qc8Zfpx2th+gzwA2MzyK+1g/3EPl62yFnVttQ== - dependencies: - "@babel/helper-compilation-targets" "^7.22.6" - "@babel/helper-plugin-utils" "^7.22.5" - debug "^4.1.1" - lodash.debounce "^4.0.8" - resolve "^1.14.2" - -"@babel/helper-environment-visitor@^7.22.20": - version "7.22.20" - resolved "https://registry.yarnpkg.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz#96159db61d34a29dba454c959f5ae4a649ba9167" - integrity sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA== - "@babel/helper-environment-visitor@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.24.7.tgz#4b31ba9551d1f90781ba83491dd59cf9b269f7d9" @@ -281,14 +54,6 @@ dependencies: "@babel/types" "^7.24.7" -"@babel/helper-function-name@^7.22.5", "@babel/helper-function-name@^7.23.0": - version "7.23.0" - resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz#1f9a3cdbd5b2698a670c30d2735f9af95ed52759" - integrity sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw== - dependencies: - "@babel/template" "^7.22.15" - "@babel/types" "^7.23.0" - "@babel/helper-function-name@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.24.7.tgz#75f1e1725742f39ac6584ee0b16d94513da38dd2" @@ -297,13 +62,6 @@ "@babel/template" "^7.24.7" "@babel/types" "^7.24.7" -"@babel/helper-hoist-variables@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz#c01a007dac05c085914e8fb652b339db50d823bb" - integrity sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw== - dependencies: - "@babel/types" "^7.22.5" - "@babel/helper-hoist-variables@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.24.7.tgz#b4ede1cde2fd89436397f30dc9376ee06b0f25ee" @@ -311,20 +69,6 @@ dependencies: "@babel/types" "^7.24.7" -"@babel/helper-member-expression-to-functions@^7.22.15", "@babel/helper-member-expression-to-functions@^7.23.0": - version "7.23.0" - resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.23.0.tgz#9263e88cc5e41d39ec18c9a3e0eced59a3e7d366" - integrity sha512-6gfrPwh7OuT6gZyJZvd6WbTfrqAo7vm4xCzAXOusKqq/vWdKXphTpj5klHKNmRUU6/QRGlBsyU9mAIPaWHlqJA== - dependencies: - "@babel/types" "^7.23.0" - -"@babel/helper-member-expression-to-functions@^7.24.5": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.24.5.tgz#5981e131d5c7003c7d1fa1ad49e86c9b097ec475" - integrity sha512-4owRteeihKWKamtqg4JmWSsEZU445xpFRXPEwp44HbgbxdWlUV1b4Agg4lkA806Lil5XM/e+FJyS0vj5T6vmcA== - dependencies: - "@babel/types" "^7.24.5" - "@babel/helper-member-expression-to-functions@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.24.7.tgz#67613d068615a70e4ed5101099affc7a41c5225f" @@ -333,13 +77,6 @@ "@babel/traverse" "^7.24.7" "@babel/types" "^7.24.7" -"@babel/helper-module-imports@^7.22.15": - version "7.22.15" - resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz#16146307acdc40cc00c3b2c647713076464bdbf0" - integrity sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w== - dependencies: - "@babel/types" "^7.22.15" - "@babel/helper-module-imports@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz#f2f980392de5b84c3328fc71d38bd81bbb83042b" @@ -348,17 +85,6 @@ "@babel/traverse" "^7.24.7" "@babel/types" "^7.24.7" -"@babel/helper-module-transforms@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz#d7d12c3c5d30af5b3c0fcab2a6d5217773e2d0f1" - integrity sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ== - dependencies: - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-module-imports" "^7.22.15" - "@babel/helper-simple-access" "^7.22.5" - "@babel/helper-split-export-declaration" "^7.22.6" - "@babel/helper-validator-identifier" "^7.22.20" - "@babel/helper-module-transforms@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.24.7.tgz#31b6c9a2930679498db65b685b1698bfd6c7daf8" @@ -370,13 +96,6 @@ "@babel/helper-split-export-declaration" "^7.24.7" "@babel/helper-validator-identifier" "^7.24.7" -"@babel/helper-optimise-call-expression@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.22.5.tgz#f21531a9ccbff644fdd156b4077c16ff0c3f609e" - integrity sha512-HBwaojN0xFRx4yIvpwGqxiV2tUfl7401jlok564NgB9EHS1y6QT17FmKWm4ztqjeVdXLuC4fSvHc5ePpQjoTbw== - dependencies: - "@babel/types" "^7.22.5" - "@babel/helper-optimise-call-expression@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.24.7.tgz#8b0a0456c92f6b323d27cfd00d1d664e76692a0f" @@ -384,62 +103,11 @@ dependencies: "@babel/types" "^7.24.7" -"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.14.5.tgz#5ac822ce97eec46741ab70a517971e443a70c5a9" - integrity sha512-/37qQCE3K0vvZKwoK4XU/irIJQdIfCJuhU5eKnNxpFDsOkgFaUAwbv+RYw6eYgsC0E4hS7r5KqGULUogqui0fQ== - -"@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.20.2", "@babel/helper-plugin-utils@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz#dd7ee3735e8a313b9f7b05a773d892e88e6d7295" - integrity sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg== - -"@babel/helper-plugin-utils@^7.24.0", "@babel/helper-plugin-utils@^7.24.5": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.5.tgz#a924607dd254a65695e5bd209b98b902b3b2f11a" - integrity sha512-xjNLDopRzW2o6ba0gKbkZq5YWEBaK3PCyTOY1K2P/O07LGMhMqlMXPxwN4S5/RhWuCobT8z0jrlKGlYmeR1OhQ== - "@babel/helper-plugin-utils@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.7.tgz#98c84fe6fe3d0d3ae7bfc3a5e166a46844feb2a0" integrity sha512-Rq76wjt7yz9AAc1KnlRKNAi/dMSVWgDRx43FHoJEbcYU6xOWaE2dVPwcdTukJrjxS65GITyfbvEYHvkirZ6uEg== -"@babel/helper-remap-async-to-generator@^7.22.20": - version "7.22.20" - resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.22.20.tgz#7b68e1cb4fa964d2996fd063723fb48eca8498e0" - integrity sha512-pBGyV4uBqOns+0UvhsTO8qgl8hO89PmiDYv+/COyp1aeMcmfrfruz+/nCMFiYyFF/Knn0yfrC85ZzNFjembFTw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-wrap-function" "^7.22.20" - -"@babel/helper-remap-async-to-generator@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.24.7.tgz#b3f0f203628522713849d49403f1a414468be4c7" - integrity sha512-9pKLcTlZ92hNZMQfGCHImUpDOlAgkkpqalWEeftW5FBya75k8Li2ilerxkM/uBEj01iBZXcCIB/bwvDYgWyibA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - "@babel/helper-environment-visitor" "^7.24.7" - "@babel/helper-wrap-function" "^7.24.7" - -"@babel/helper-replace-supers@^7.22.20": - version "7.22.20" - resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.22.20.tgz#e37d367123ca98fe455a9887734ed2e16eb7a793" - integrity sha512-qsW0In3dbwQUbK8kejJ4R7IHVGwHJlV6lpG6UA7a9hSa2YEiAib+N1T2kr6PEeUT+Fl7najmSOS6SmAwCHK6Tw== - dependencies: - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-member-expression-to-functions" "^7.22.15" - "@babel/helper-optimise-call-expression" "^7.22.5" - -"@babel/helper-replace-supers@^7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.24.1.tgz#7085bd19d4a0b7ed8f405c1ed73ccb70f323abc1" - integrity sha512-QCR1UqC9BzG5vZl8BMicmZ28RuUBnHhAMddD8yHFHDRH9lLTZ9uUPehX8ctVPT8l0TKblJidqcgUUKGVrePleQ== - dependencies: - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-member-expression-to-functions" "^7.23.0" - "@babel/helper-optimise-call-expression" "^7.22.5" - "@babel/helper-replace-supers@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.24.7.tgz#f933b7eed81a1c0265740edc91491ce51250f765" @@ -449,13 +117,6 @@ "@babel/helper-member-expression-to-functions" "^7.24.7" "@babel/helper-optimise-call-expression" "^7.24.7" -"@babel/helper-simple-access@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz#4938357dc7d782b80ed6dbb03a0fba3d22b1d5de" - integrity sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w== - dependencies: - "@babel/types" "^7.22.5" - "@babel/helper-simple-access@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz#bcade8da3aec8ed16b9c4953b74e506b51b5edb3" @@ -464,13 +125,6 @@ "@babel/traverse" "^7.24.7" "@babel/types" "^7.24.7" -"@babel/helper-skip-transparent-expression-wrappers@^7.20.0", "@babel/helper-skip-transparent-expression-wrappers@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.22.5.tgz#007f15240b5751c537c40e77abb4e89eeaaa8847" - integrity sha512-tK14r66JZKiC43p8Ki33yLBVJKlQDFoA8GYN67lWCDCqoL6EMMSuM9b+Iff2jHaM/RRFYl7K+iiru7hbRqNx8Q== - dependencies: - "@babel/types" "^7.22.5" - "@babel/helper-skip-transparent-expression-wrappers@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.24.7.tgz#5f8fa83b69ed5c27adc56044f8be2b3ea96669d9" @@ -479,20 +133,6 @@ "@babel/traverse" "^7.24.7" "@babel/types" "^7.24.7" -"@babel/helper-split-export-declaration@^7.22.6": - version "7.22.6" - resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz#322c61b7310c0997fe4c323955667f18fcefb91c" - integrity sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g== - dependencies: - "@babel/types" "^7.22.5" - -"@babel/helper-split-export-declaration@^7.24.5": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.24.5.tgz#b9a67f06a46b0b339323617c8c6213b9055a78b6" - integrity sha512-5CHncttXohrHk8GWOFCcCl4oRD9fKosWlIRgWm4ql9VYioKm52Mk2xsmoohvm7f3JoiLSM5ZgJuRaf5QZZYd3Q== - dependencies: - "@babel/types" "^7.24.5" - "@babel/helper-split-export-declaration@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.24.7.tgz#83949436890e07fa3d6873c61a96e3bbf692d856" @@ -500,119 +140,21 @@ dependencies: "@babel/types" "^7.24.7" -"@babel/helper-string-parser@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz#9478c707febcbbe1ddb38a3d91a2e054ae622d83" - integrity sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ== - -"@babel/helper-string-parser@^7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.24.1.tgz#f99c36d3593db9540705d0739a1f10b5e20c696e" - integrity sha512-2ofRCjnnA9y+wk8b9IAREroeUP02KHp431N2mhKniy2yKIDKpbrHv9eXwm8cBeWQYcJmzv5qKCu65P47eCF7CQ== - "@babel/helper-string-parser@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.24.7.tgz#4d2d0f14820ede3b9807ea5fc36dfc8cd7da07f2" integrity sha512-7MbVt6xrwFQbunH2DNQsAP5sTGxfqQtErvBIvIMi6EQnbgUOuVYanvREcmFrOPhoXBrTtjhhP+lW+o5UfK+tDg== -"@babel/helper-validator-identifier@^7.14.5", "@babel/helper-validator-identifier@^7.14.9": - version "7.14.9" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.9.tgz#6654d171b2024f6d8ee151bf2509699919131d48" - integrity sha512-pQYxPY0UP6IHISRitNe8bsijHex4TWZXi2HwKVsjPiltzlhse2znVcm9Ace510VT1kxIHjGJCZZQBX2gJDbo0g== - -"@babel/helper-validator-identifier@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.16.7.tgz#e8c602438c4a8195751243da9031d1607d247cad" - integrity sha512-hsEnFemeiW4D08A5gUAZxLBTXpZ39P+a+DGDsHw1yxqyQ/jzFEnxf5uTEGp+3bzAbNOxU1paTgYS4ECU/IgfDw== - -"@babel/helper-validator-identifier@^7.22.20": - version "7.22.20" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz#c4ae002c61d2879e724581d96665583dbc1dc0e0" - integrity sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A== - -"@babel/helper-validator-identifier@^7.24.5": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.5.tgz#918b1a7fa23056603506370089bd990d8720db62" - integrity sha512-3q93SSKX2TWCG30M2G2kwaKeTYgEUp5Snjuj8qm729SObL6nbtUldAi37qbxkD5gg3xnBio+f9nqpSepGZMvxA== - "@babel/helper-validator-identifier@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz#75b889cfaf9e35c2aaf42cf0d72c8e91719251db" integrity sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w== -"@babel/helper-validator-option@^7.22.15", "@babel/helper-validator-option@^7.23.5": - version "7.23.5" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz#907a3fbd4523426285365d1206c423c4c5520307" - integrity sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw== - "@babel/helper-validator-option@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.24.7.tgz#24c3bb77c7a425d1742eec8fb433b5a1b38e62f6" integrity sha512-yy1/KvjhV/ZCL+SM7hBrvnZJ3ZuT9OuZgIJAGpPEToANvc3iM6iDvBnRjtElWibHU6n8/LPR/EjX9EtIEYO3pw== -"@babel/helper-wrap-function@^7.22.20": - version "7.22.20" - resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.22.20.tgz#15352b0b9bfb10fc9c76f79f6342c00e3411a569" - integrity sha512-pms/UwkOpnQe/PDAEdV/d7dVCoBbB+R4FvYoHGZz+4VPcg7RtYy2KP7S2lbuWM6FCSgob5wshfGESbC/hzNXZw== - dependencies: - "@babel/helper-function-name" "^7.22.5" - "@babel/template" "^7.22.15" - "@babel/types" "^7.22.19" - -"@babel/helper-wrap-function@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.24.7.tgz#52d893af7e42edca7c6d2c6764549826336aae1f" - integrity sha512-N9JIYk3TD+1vq/wn77YnJOqMtfWhNewNE+DJV4puD2X7Ew9J4JvrzrFDfTfyv5EgEXVy9/Wt8QiOErzEmv5Ifw== - dependencies: - "@babel/helper-function-name" "^7.24.7" - "@babel/template" "^7.24.7" - "@babel/traverse" "^7.24.7" - "@babel/types" "^7.24.7" - -"@babel/helpers@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.23.6.tgz#d03af2ee5fb34691eec0cda90f5ecbb4d4da145a" - integrity sha512-wCfsbN4nBidDRhpDhvcKlzHWCTlgJYUUdSJfzXb2NuBssDSIjc3xcb+znA7l+zYsFljAcGM0aFkN40cR3lXiGA== - dependencies: - "@babel/template" "^7.22.15" - "@babel/traverse" "^7.23.6" - "@babel/types" "^7.23.6" - -"@babel/helpers@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.24.7.tgz#aa2ccda29f62185acb5d42fb4a3a1b1082107416" - integrity sha512-NlmJJtvcw72yRJRcnCmGvSi+3jDEg8qFu3z0AFoymmzLx5ERVWyzd9kVXr7Th9/8yIJi2Zc6av4Tqz3wFs8QWg== - dependencies: - "@babel/template" "^7.24.7" - "@babel/types" "^7.24.7" - -"@babel/highlight@^7.10.4", "@babel/highlight@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.14.5.tgz#6861a52f03966405001f6aa534a01a24d99e8cd9" - integrity sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg== - dependencies: - "@babel/helper-validator-identifier" "^7.14.5" - chalk "^2.0.0" - js-tokens "^4.0.0" - -"@babel/highlight@^7.16.7": - version "7.16.10" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.16.10.tgz#744f2eb81579d6eea753c227b0f570ad785aba88" - integrity sha512-5FnTQLSLswEj6IkgVw5KusNUUFY9ZGqe/TRFnP/BKYHYgfh7tc+C7mwiy95/yNP7Dh9x580Vv8r7u7ZfTBFxdw== - dependencies: - "@babel/helper-validator-identifier" "^7.16.7" - chalk "^2.0.0" - js-tokens "^4.0.0" - -"@babel/highlight@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.23.4.tgz#edaadf4d8232e1a961432db785091207ead0621b" - integrity sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A== - dependencies: - "@babel/helper-validator-identifier" "^7.22.20" - chalk "^2.4.2" - js-tokens "^4.0.0" - "@babel/highlight@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.24.7.tgz#a05ab1df134b286558aae0ed41e6c5f731bf409d" @@ -623,1825 +165,248 @@ js-tokens "^4.0.0" picocolors "^1.0.0" -"@babel/parser@^7.22.15", "@babel/parser@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.23.6.tgz#ba1c9e512bda72a47e285ae42aff9d2a635a9e3b" - integrity sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ== - "@babel/parser@^7.24.7": version "7.24.7" resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.24.7.tgz#9a5226f92f0c5c8ead550b750f5608e766c8ce85" integrity sha512-9uUYRm6OqQrCqQdG1iCBwBPZgN8ciDBro2nIOFaiRz1/BCxaI7CNvQbDHvsArAC7Tw9Hda/B3U+6ui9u4HWXPw== -"@babel/plugin-bugfix-firefox-class-in-computed-class-key@^7.24.7": +"@babel/plugin-syntax-jsx@^7.24.7": version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.24.7.tgz#fd059fd27b184ea2b4c7e646868a9a381bbc3055" - integrity sha512-TiT1ss81W80eQsN+722OaeQMY/G4yTb4G9JrqeiDADs3N8lbPMGldWi9x8tyqCW5NLx1Jh2AvkE6r6QvEltMMQ== + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.7.tgz#39a1fa4a7e3d3d7f34e2acc6be585b718d30e02d" + integrity sha512-6ddciUPe/mpMnOKv/U+RSd2vvVy+Yw/JfBB0ZHYjEZt9NLHmCUylNYlsbqCCS1Bffjlb0fCwC9Vqz+sBz6PsiQ== dependencies: - "@babel/helper-environment-visitor" "^7.24.7" "@babel/helper-plugin-utils" "^7.24.7" -"@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.23.3.tgz#5cd1c87ba9380d0afb78469292c954fee5d2411a" - integrity sha512-iRkKcCqb7iGnq9+3G6rZ+Ciz5VywC4XNRHe57lKM+jOeYAoR0lVqdeeDRfh0tQcTfw/+vBhHn926FmQhLtlFLQ== +"@babel/plugin-syntax-typescript@^7.24.7": + version "7.24.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.7.tgz#58d458271b4d3b6bb27ee6ac9525acbb259bad1c" + integrity sha512-c/+fVeJBB0FeKsFvwytYiUD+LBvhHjGSI0g446PRGdSVGZLRNArBUno2PETbAly3tpiNAQR5XaZ+JslxkotsbA== dependencies: - "@babel/helper-plugin-utils" "^7.22.5" + "@babel/helper-plugin-utils" "^7.24.7" -"@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.24.7": +"@babel/plugin-transform-modules-commonjs@^7.24.7": version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.24.7.tgz#468096ca44bbcbe8fcc570574e12eb1950e18107" - integrity sha512-unaQgZ/iRu/By6tsjMZzpeBZjChYfLYry6HrEXPoz3KmfF0sVBQ1l8zKMQ4xRGLWVsjuvB8nQfjNP/DcfEOCsg== + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.24.7.tgz#9fd5f7fdadee9085886b183f1ad13d1ab260f4ab" + integrity sha512-iFI8GDxtevHJ/Z22J5xQpVqFLlMNstcLXh994xifFwxxGslr2ZXXLWgtBeLctOD63UFDArdvN6Tg8RFw+aEmjQ== dependencies: + "@babel/helper-module-transforms" "^7.24.7" "@babel/helper-plugin-utils" "^7.24.7" + "@babel/helper-simple-access" "^7.24.7" -"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.23.3.tgz#f6652bb16b94f8f9c20c50941e16e9756898dc5d" - integrity sha512-WwlxbfMNdVEpQjZmK5mhm7oSwD3dS6eU+Iwsi4Knl9wAletWem7kaRsGOG+8UEbRyqxY4SS5zvtfXwX+jMxUwQ== +"@babel/plugin-transform-typescript@^7.24.7": + version "7.24.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.7.tgz#b006b3e0094bf0813d505e0c5485679eeaf4a881" + integrity sha512-iLD3UNkgx2n/HrjBesVbYX6j0yqn/sJktvbtKKgcaLIQ4bTTQ8obAypc1VpyHPD2y4Phh9zHOaAt8e/L14wCpw== dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - "@babel/plugin-transform-optional-chaining" "^7.23.3" + "@babel/helper-annotate-as-pure" "^7.24.7" + "@babel/helper-create-class-features-plugin" "^7.24.7" + "@babel/helper-plugin-utils" "^7.24.7" + "@babel/plugin-syntax-typescript" "^7.24.7" -"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.24.7": +"@babel/preset-typescript@^7.23.3": version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.24.7.tgz#e4eabdd5109acc399b38d7999b2ef66fc2022f89" - integrity sha512-+izXIbke1T33mY4MSNnrqhPXDz01WYhEf3yF5NbnUtkiNnm+XBZJl3kNfoK6NKmYlz/D07+l2GWVK/QfDkNCuQ== + resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.24.7.tgz#66cd86ea8f8c014855671d5ea9a737139cbbfef1" + integrity sha512-SyXRe3OdWwIwalxDg5UtJnJQO+YPcTfwiIY2B0Xlddh9o7jpWLvv8X1RthIeDOxQ+O1ML5BLPCONToObyVQVuQ== dependencies: "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-skip-transparent-expression-wrappers" "^7.24.7" - "@babel/plugin-transform-optional-chaining" "^7.24.7" + "@babel/helper-validator-option" "^7.24.7" + "@babel/plugin-syntax-jsx" "^7.24.7" + "@babel/plugin-transform-modules-commonjs" "^7.24.7" + "@babel/plugin-transform-typescript" "^7.24.7" -"@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.23.3.tgz#20c60d4639d18f7da8602548512e9d3a4c8d7098" - integrity sha512-XaJak1qcityzrX0/IU5nKHb34VaibwP3saKqG6a/tppelgllOH13LUann4ZCIBcVOeE6H18K4Vx9QKkVww3z/w== +"@babel/runtime@^7.23.2", "@babel/runtime@^7.24.6": + version "7.24.7" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.24.7.tgz#f4f0d5530e8dbdf59b3451b9b3e594b6ba082e12" + integrity sha512-UwgBRMjJP+xv857DCngvqXI3Iq6J4v0wXmwc6sapg+zyhbwmQX67LUEFrkK5tbyJ30jGuG3ZvWpBiB9LCy1kWw== dependencies: - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-plugin-utils" "^7.22.5" + regenerator-runtime "^0.14.0" -"@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@^7.24.7": +"@babel/template@^7.24.7": version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.24.7.tgz#71b21bb0286d5810e63a1538aa901c58e87375ec" - integrity sha512-utA4HuR6F4Vvcr+o4DnjL8fCOlgRFGbeeBEGNg3ZTrLFw6VWG5XmUrvcQ0FjIYMU2ST4XcR2Wsp7t9qOAPnxMg== + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.24.7.tgz#02efcee317d0609d2c07117cb70ef8fb17ab7315" + integrity sha512-jYqfPrU9JTF0PmPy1tLYHW4Mp4KlgxJD9l2nP9fD6yT/ICi554DmrWBAEYpIelzjHf1msDP3PxJIRt/nFNfBig== dependencies: - "@babel/helper-environment-visitor" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" + "@babel/code-frame" "^7.24.7" + "@babel/parser" "^7.24.7" + "@babel/types" "^7.24.7" -"@babel/plugin-proposal-class-properties@^7.16.0": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz#b110f59741895f7ec21a6fff696ec46265c446a3" - integrity sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ== +"@babel/traverse@^7.24.7": + version "7.24.7" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.24.7.tgz#de2b900163fa741721ba382163fe46a936c40cf5" + integrity sha512-yb65Ed5S/QAcewNPh0nZczy9JdYXkkAbIsEo+P7BE7yO3txAY30Y/oPa3QkQ5It3xVG2kpKMg9MsdxZaO31uKA== dependencies: - "@babel/helper-create-class-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" + "@babel/code-frame" "^7.24.7" + "@babel/generator" "^7.24.7" + "@babel/helper-environment-visitor" "^7.24.7" + "@babel/helper-function-name" "^7.24.7" + "@babel/helper-hoist-variables" "^7.24.7" + "@babel/helper-split-export-declaration" "^7.24.7" + "@babel/parser" "^7.24.7" + "@babel/types" "^7.24.7" + debug "^4.3.1" + globals "^11.1.0" -"@babel/plugin-proposal-decorators@^7.16.4": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.23.6.tgz#b34e9837c4fb0277c6d571581c76595521cf2db4" - integrity sha512-D7Ccq9LfkBFnow3azZGJvZYgcfeqAw3I1e5LoTpj6UKIFQilh8yqXsIGcRIqbBdsPWIz+Ze7ZZfggSj62Qp+Fg== +"@babel/types@^7.24.7": + version "7.24.7" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.24.7.tgz#6027fe12bc1aa724cd32ab113fb7f1988f1f66f2" + integrity sha512-XEFXSlxiG5td2EJRe8vOmRbaXVgfcBlszKujvVmWIK/UpywWljQCfzAv3RQCGujWQ1RD4YYWEAqDXfuJiy8f5Q== dependencies: - "@babel/helper-create-class-features-plugin" "^7.23.6" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-replace-supers" "^7.22.20" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - "@babel/helper-split-export-declaration" "^7.22.6" - "@babel/plugin-syntax-decorators" "^7.23.3" + "@babel/helper-string-parser" "^7.24.7" + "@babel/helper-validator-identifier" "^7.24.7" + to-fast-properties "^2.0.0" -"@babel/plugin-proposal-nullish-coalescing-operator@^7.16.0": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz#fdd940a99a740e577d6c753ab6fbb43fdb9467e1" - integrity sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA== +"@creit-tech/xbull-wallet-connect@github:Creit-Tech/xBull-Wallet-Connect#0.2.0": + version "0.2.0" + resolved "https://codeload.github.com/Creit-Tech/xBull-Wallet-Connect/tar.gz/a93e2e0d97c61bbd83fedcca0c71feef9f28b2d3" dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + rxjs "^7.5.5" + tweetnacl "^1.0.3" + tweetnacl-util "^0.15.1" + +"@creit.tech/stellar-wallets-kit@^0.8.2": + version "0.8.3" + resolved "https://registry.yarnpkg.com/@creit.tech/stellar-wallets-kit/-/stellar-wallets-kit-0.8.3.tgz#738c0f3d994a2c3e90b82e7a039f9ab3386186a4" + integrity sha512-LQ8l0gqMw9FIW2z0+zGjNfHB4MtVPE0yPLFFoWj58dYLpf/L2cqKH4rrJIg5hkrrNbyKHJKWdzlt4bA67IjhRg== + dependencies: + "@albedo-link/intent" "0.12.0" + "@creit-tech/xbull-wallet-connect" "github:Creit-Tech/xBull-Wallet-Connect#0.2.0" + "@lobstrco/signer-extension-api" "1.0.0-beta.0" + "@stellar/freighter-api" "2.0.0" + "@walletconnect/modal" "2.6.2" + "@walletconnect/sign-client" "2.11.2" + events "^3.3.0" + lit "^2.2.4" -"@babel/plugin-proposal-numeric-separator@^7.16.0": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz#899b14fbafe87f053d2c5ff05b36029c62e13c75" - integrity sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" +"@emurgo/cardano-serialization-lib-browser@^11.5.0": + version "11.5.0" + resolved "https://registry.yarnpkg.com/@emurgo/cardano-serialization-lib-browser/-/cardano-serialization-lib-browser-11.5.0.tgz#f2d15b538add436e0aa8b67a1d00ca654a680006" + integrity sha512-qchOJ9NYDUz10tzs5r5QhP9hK0p+ZOlRiBwPdTAxqAYLw/8emYBkQQLaS8T1DF6EkeudyrgS00ym5Trw1fo4iA== -"@babel/plugin-proposal-optional-chaining@^7.16.0": - version "7.21.0" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.21.0.tgz#886f5c8978deb7d30f678b2e24346b287234d3ea" - integrity sha512-p4zeefM72gpmEe2fkUr/OnOXpWEf8nAgk7ZYVqqfFiyIG7oFfVZcCrU64hWn5xp4tQ9LkV4bTIa5rD0KANpKNA== - dependencies: - "@babel/helper-plugin-utils" "^7.20.2" - "@babel/helper-skip-transparent-expression-wrappers" "^7.20.0" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" +"@emurgo/cardano-serialization-lib-nodejs@11.5.0": + version "11.5.0" + resolved "https://registry.yarnpkg.com/@emurgo/cardano-serialization-lib-nodejs/-/cardano-serialization-lib-nodejs-11.5.0.tgz#0662e2a17d7d1e944f8cdb86396133c8edaec059" + integrity sha512-IlVABlRgo9XaTR1NunwZpWcxnfEv04ba2l1vkUz4S1W7Jt36F4CtffP+jPeqBZGnAe+fnUwo0XjIJC3ZTNToNQ== -"@babel/plugin-proposal-private-methods@^7.16.0": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz#5209de7d213457548a98436fa2882f52f4be6bea" - integrity sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA== +"@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": + version "4.4.0" + resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" + integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== dependencies: - "@babel/helper-create-class-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" + eslint-visitor-keys "^3.3.0" -"@babel/plugin-proposal-private-property-in-object@7.21.0-placeholder-for-preset-env.2": - version "7.21.0-placeholder-for-preset-env.2" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0-placeholder-for-preset-env.2.tgz#7844f9289546efa9febac2de4cfe358a050bd703" - integrity sha512-SOSkfJDddaM7mak6cPEpswyTRnuRltl429hMraQEglW+OkovnCzsiszTmsrlY//qLFjCpQDFRvjdm2wA5pPm9w== +"@eslint-community/regexpp@^4.10.0", "@eslint-community/regexpp@^4.6.1": + version "4.10.1" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.1.tgz#361461e5cb3845d874e61731c11cfedd664d83a0" + integrity sha512-Zm2NGpWELsQAD1xsJzGQpYfvICSsFkEpU0jxBjfdC6uNEWXcHnfs9hScFWtXVDVl+rBQJGrl4g1vcKIejpH9dA== -"@babel/plugin-syntax-async-generators@^7.8.4": - version "7.8.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz#a983fb1aeb2ec3f6ed042a210f640e90e786fe0d" - integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== +"@eslint/eslintrc@^2.1.4": + version "2.1.4" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.1.4.tgz#388a269f0f25c1b6adc317b5a2c55714894c70ad" + integrity sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ== dependencies: - "@babel/helper-plugin-utils" "^7.8.0" + ajv "^6.12.4" + debug "^4.3.2" + espree "^9.6.0" + globals "^13.19.0" + ignore "^5.2.0" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.1.2" + strip-json-comments "^3.1.1" -"@babel/plugin-syntax-class-properties@^7.12.13": - version "7.12.13" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz#b5c987274c4a3a82b89714796931a6b53544ae10" - integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== - dependencies: - "@babel/helper-plugin-utils" "^7.12.13" +"@eslint/js@8.57.0": + version "8.57.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-8.57.0.tgz#a5417ae8427873f1dd08b70b3574b453e67b5f7f" + integrity sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g== -"@babel/plugin-syntax-class-static-block@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz#195df89b146b4b78b3bf897fd7a257c84659d406" - integrity sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw== +"@ethereumjs/common@^4.2.0", "@ethereumjs/common@^4.3.0": + version "4.3.0" + resolved "https://registry.yarnpkg.com/@ethereumjs/common/-/common-4.3.0.tgz#5b45eec7dcf521fa4ddaf0b383072fbcf9913553" + integrity sha512-shBNJ0ewcPNTUfZduHiczPmqkfJDn0Dh/9BR5fq7xUFTuIq7Fu1Vx00XDwQVIrpVL70oycZocOhBM6nDO+4FEQ== dependencies: - "@babel/helper-plugin-utils" "^7.14.5" + "@ethereumjs/util" "^9.0.3" -"@babel/plugin-syntax-decorators@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.23.3.tgz#a1d351d6c25bfdcf2e16f99b039101bc0ffcb0ca" - integrity sha512-cf7Niq4/+/juY67E0PbgH0TDhLQ5J7zS8C/Q5FFx+DWyrRa9sUQdTXkjqKu8zGvuqr7vw1muKiukseihU+PJDA== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" +"@ethereumjs/rlp@^5.0.2": + version "5.0.2" + resolved "https://registry.yarnpkg.com/@ethereumjs/rlp/-/rlp-5.0.2.tgz#c89bd82f2f3bec248ab2d517ae25f5bbc4aac842" + integrity sha512-DziebCdg4JpGlEqEdGgXmjqcFoJi+JGulUXwEjsZGAscAQ7MyD/7LE/GVCP29vEQxKc7AAwjT3A2ywHp2xfoCA== -"@babel/plugin-syntax-dynamic-import@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz#62bf98b2da3cd21d626154fc96ee5b3cb68eacb3" - integrity sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ== +"@ethereumjs/tx@^5.2.1": + version "5.3.0" + resolved "https://registry.yarnpkg.com/@ethereumjs/tx/-/tx-5.3.0.tgz#473f351729ef4e30eaa3a3fb5aaccd4405a7ee41" + integrity sha512-uv++XYuIfuqYbvymL3/o14hHuC6zX0nRQ1nI2FHsbkkorLZ2ChEIDqVeeVk7Xc9/jQNU/22sk9qZZkRlsveXxw== dependencies: - "@babel/helper-plugin-utils" "^7.8.0" + "@ethereumjs/common" "^4.3.0" + "@ethereumjs/rlp" "^5.0.2" + "@ethereumjs/util" "^9.0.3" + ethereum-cryptography "^2.1.3" -"@babel/plugin-syntax-export-namespace-from@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz#028964a9ba80dbc094c915c487ad7c4e7a66465a" - integrity sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q== +"@ethereumjs/util@^9.0.3": + version "9.0.3" + resolved "https://registry.yarnpkg.com/@ethereumjs/util/-/util-9.0.3.tgz#c2709e6127a85bbe23a71937ac78358ac93e7241" + integrity sha512-PmwzWDflky+7jlZIFqiGsBPap12tk9zK5SVH9YW2OEnDN7OEhCjUOMzbOqwuClrbkSIkM2ERivd7sXZ48Rh/vg== dependencies: - "@babel/helper-plugin-utils" "^7.8.3" + "@ethereumjs/rlp" "^5.0.2" + ethereum-cryptography "^2.1.3" -"@babel/plugin-syntax-flow@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.23.3.tgz#084564e0f3cc21ea6c70c44cff984a1c0509729a" - integrity sha512-YZiAIpkJAwQXBJLIQbRFayR5c+gJ35Vcz3bg954k7cd73zqjvhacJuL9RbrzPz8qPmZdgqP6EUKwy0PCNhaaPA== +"@fivebinaries/coin-selection@2.2.1": + version "2.2.1" + resolved "https://registry.yarnpkg.com/@fivebinaries/coin-selection/-/coin-selection-2.2.1.tgz#f5329909ac8cd1bf87decdcd054c88a8d69399a0" + integrity sha512-iYFsYr7RY7TEvTqP9NKR4p/yf3Iybf9abUDR7lRjzanGsrLwVsREvIuyE05iRYFrvqarlk+gWRPsdR1N2hUBrg== dependencies: - "@babel/helper-plugin-utils" "^7.22.5" + "@emurgo/cardano-serialization-lib-browser" "^11.5.0" + "@emurgo/cardano-serialization-lib-nodejs" "11.5.0" -"@babel/plugin-syntax-flow@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.24.7.tgz#d1759e84dd4b437cf9fae69b4c06c41d7625bfb7" - integrity sha512-9G8GYT/dxn/D1IIKOUBmGX0mnmj46mGH9NnZyJLwtCpgh5f7D2VbuKodb+2s9m1Yavh1s7ASQN8lf0eqrb1LTw== +"@floating-ui/core@^1.0.0": + version "1.6.2" + resolved "https://registry.yarnpkg.com/@floating-ui/core/-/core-1.6.2.tgz#d37f3e0ac1f1c756c7de45db13303a266226851a" + integrity sha512-+2XpQV9LLZeanU4ZevzRnGFg2neDeKHgFLjP6YLW+tly0IvrhqT4u8enLGjLH3qeh85g19xY5rsAusfwTdn5lg== dependencies: - "@babel/helper-plugin-utils" "^7.24.7" + "@floating-ui/utils" "^0.2.0" -"@babel/plugin-syntax-import-assertions@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.23.3.tgz#9c05a7f592982aff1a2768260ad84bcd3f0c77fc" - integrity sha512-lPgDSU+SJLK3xmFDTV2ZRQAiM7UuUjGidwBywFavObCiZc1BeAAcMtHJKUya92hPHO+at63JJPLygilZard8jw== +"@floating-ui/dom@^1.6.3": + version "1.6.5" + resolved "https://registry.yarnpkg.com/@floating-ui/dom/-/dom-1.6.5.tgz#323f065c003f1d3ecf0ff16d2c2c4d38979f4cb9" + integrity sha512-Nsdud2X65Dz+1RHjAIP0t8z5e2ff/IRbei6BqFrl1urT8sDVzM1HMQ+R0XcU5ceRfyO3I6ayeqIfh+6Wb8LGTw== dependencies: - "@babel/helper-plugin-utils" "^7.22.5" + "@floating-ui/core" "^1.0.0" + "@floating-ui/utils" "^0.2.0" -"@babel/plugin-syntax-import-assertions@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.24.7.tgz#2a0b406b5871a20a841240586b1300ce2088a778" - integrity sha512-Ec3NRUMoi8gskrkBe3fNmEQfxDvY8bgfQpz6jlk/41kX9eUjvpyqWU7PBP/pLAvMaSQjbMNKJmvX57jP+M6bPg== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" +"@floating-ui/utils@^0.2.0": + version "0.2.2" + resolved "https://registry.yarnpkg.com/@floating-ui/utils/-/utils-0.2.2.tgz#d8bae93ac8b815b2bd7a98078cf91e2724ef11e5" + integrity sha512-J4yDIIthosAsRZ5CPYP/jQvUAQtlZTTD/4suA08/FEnlxqW3sKS9iAhgsa9VYLZ6vDHn/ixJgIqRQPotoBjxIw== -"@babel/plugin-syntax-import-attributes@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.23.3.tgz#992aee922cf04512461d7dae3ff6951b90a2dc06" - integrity sha512-pawnE0P9g10xgoP7yKr6CK63K2FMsTE+FZidZO/1PwRdzmAPVs+HS1mAURUsgaoxammTJvULUdIkEK0gOcU2tA== +"@humanwhocodes/config-array@^0.11.14": + version "0.11.14" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.14.tgz#d78e481a039f7566ecc9660b4ea7fe6b1fec442b" + integrity sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg== dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-syntax-import-attributes@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.24.7.tgz#b4f9ea95a79e6912480c4b626739f86a076624ca" - integrity sha512-hbX+lKKeUMGihnK8nvKqmXBInriT3GVjzXKFriV3YC6APGxMbP8RZNFwy91+hocLXq90Mta+HshoB31802bb8A== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-syntax-import-meta@^7.10.4": - version "7.10.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz#ee601348c370fa334d2207be158777496521fd51" - integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== - dependencies: - "@babel/helper-plugin-utils" "^7.10.4" - -"@babel/plugin-syntax-json-strings@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz#01ca21b668cd8218c9e640cb6dd88c5412b2c96a" - integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-jsx@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.23.3.tgz#8f2e4f8a9b5f9aa16067e142c1ac9cd9f810f473" - integrity sha512-EB2MELswq55OHUoRZLGg/zC7QWUKfNLpE57m/S2yr1uEneIgsTgrSzXP3NXEsMkVn76OlaVVnzN+ugObuYGwhg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-syntax-jsx@^7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.1.tgz#3f6ca04b8c841811dbc3c5c5f837934e0d626c10" - integrity sha512-2eCtxZXf+kbkMIsXS4poTvT4Yu5rXiRa+9xGVT56raghjmBTKMpFNc9R4IDiB4emao9eO22Ox7CxuJG7BgExqA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.0" - -"@babel/plugin-syntax-jsx@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.7.tgz#39a1fa4a7e3d3d7f34e2acc6be585b718d30e02d" - integrity sha512-6ddciUPe/mpMnOKv/U+RSd2vvVy+Yw/JfBB0ZHYjEZt9NLHmCUylNYlsbqCCS1Bffjlb0fCwC9Vqz+sBz6PsiQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-syntax-logical-assignment-operators@^7.10.4": - version "7.10.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz#ca91ef46303530448b906652bac2e9fe9941f699" - integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== - dependencies: - "@babel/helper-plugin-utils" "^7.10.4" - -"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz#167ed70368886081f74b5c36c65a88c03b66d1a9" - integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-numeric-separator@^7.10.4": - version "7.10.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz#b9b070b3e33570cd9fd07ba7fa91c0dd37b9af97" - integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== - dependencies: - "@babel/helper-plugin-utils" "^7.10.4" - -"@babel/plugin-syntax-object-rest-spread@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz#60e225edcbd98a640332a2e72dd3e66f1af55871" - integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-optional-catch-binding@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz#6111a265bcfb020eb9efd0fdfd7d26402b9ed6c1" - integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-optional-chaining@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz#4f69c2ab95167e0180cd5336613f8c5788f7d48a" - integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-private-property-in-object@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz#0dc6671ec0ea22b6e94a1114f857970cd39de1ad" - integrity sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-syntax-top-level-await@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz#c1cfdadc35a646240001f06138247b741c34d94c" - integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-syntax-typescript@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.23.3.tgz#24f460c85dbbc983cd2b9c4994178bcc01df958f" - integrity sha512-9EiNjVJOMwCO+43TqoTrgQ8jMwcAd0sWyXi9RPfIsLTj4R2MADDDQXELhffaUx/uJv2AYcxBgPwH6j4TIA4ytQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-syntax-typescript@^7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.1.tgz#b3bcc51f396d15f3591683f90239de143c076844" - integrity sha512-Yhnmvy5HZEnHUty6i++gcfH1/l68AHnItFHnaCv6hn9dNh0hQvvQJsxpi4BMBFN5DLeHBuucT/0DgzXif/OyRw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.0" - -"@babel/plugin-syntax-typescript@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.7.tgz#58d458271b4d3b6bb27ee6ac9525acbb259bad1c" - integrity sha512-c/+fVeJBB0FeKsFvwytYiUD+LBvhHjGSI0g446PRGdSVGZLRNArBUno2PETbAly3tpiNAQR5XaZ+JslxkotsbA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-syntax-unicode-sets-regex@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-unicode-sets-regex/-/plugin-syntax-unicode-sets-regex-7.18.6.tgz#d49a3b3e6b52e5be6740022317580234a6a47357" - integrity sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-arrow-functions@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.23.3.tgz#94c6dcfd731af90f27a79509f9ab7fb2120fc38b" - integrity sha512-NzQcQrzaQPkaEwoTm4Mhyl8jI1huEL/WWIEvudjTCMJ9aBZNpsJbMASx7EQECtQQPS/DcnFpo0FIh3LvEO9cxQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-arrow-functions@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.24.7.tgz#4f6886c11e423bd69f3ce51dbf42424a5f275514" - integrity sha512-Dt9LQs6iEY++gXUwY03DNFat5C2NbO48jj+j/bSAz6b3HgPs39qcPiYt77fDObIcFwj3/C2ICX9YMwGflUoSHQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-async-generator-functions@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.23.4.tgz#93ac8e3531f347fba519b4703f9ff2a75c6ae27a" - integrity sha512-efdkfPhHYTtn0G6n2ddrESE91fgXxjlqLsnUtPWnJs4a4mZIbUaK7ffqKIIUKXSHwcDvaCVX6GXkaJJFqtX7jw== - dependencies: - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-remap-async-to-generator" "^7.22.20" - "@babel/plugin-syntax-async-generators" "^7.8.4" - -"@babel/plugin-transform-async-generator-functions@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.24.7.tgz#7330a5c50e05181ca52351b8fd01642000c96cfd" - integrity sha512-o+iF77e3u7ZS4AoAuJvapz9Fm001PuD2V3Lp6OSE4FYQke+cSewYtnek+THqGRWyQloRCyvWL1OkyfNEl9vr/g== - dependencies: - "@babel/helper-environment-visitor" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-remap-async-to-generator" "^7.24.7" - "@babel/plugin-syntax-async-generators" "^7.8.4" - -"@babel/plugin-transform-async-to-generator@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.23.3.tgz#d1f513c7a8a506d43f47df2bf25f9254b0b051fa" - integrity sha512-A7LFsKi4U4fomjqXJlZg/u0ft/n8/7n7lpffUP/ZULx/DtV9SGlNKZolHH6PE8Xl1ngCc0M11OaeZptXVkfKSw== - dependencies: - "@babel/helper-module-imports" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-remap-async-to-generator" "^7.22.20" - -"@babel/plugin-transform-async-to-generator@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.24.7.tgz#72a3af6c451d575842a7e9b5a02863414355bdcc" - integrity sha512-SQY01PcJfmQ+4Ash7NE+rpbLFbmqA2GPIgqzxfFTL4t1FKRq4zTms/7htKpoCUI9OcFYgzqfmCdH53s6/jn5fA== - dependencies: - "@babel/helper-module-imports" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-remap-async-to-generator" "^7.24.7" - -"@babel/plugin-transform-block-scoped-functions@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.23.3.tgz#fe1177d715fb569663095e04f3598525d98e8c77" - integrity sha512-vI+0sIaPIO6CNuM9Kk5VmXcMVRiOpDh7w2zZt9GXzmE/9KD70CUEVhvPR/etAeNK/FAEkhxQtXOzVF3EuRL41A== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-block-scoped-functions@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.24.7.tgz#a4251d98ea0c0f399dafe1a35801eaba455bbf1f" - integrity sha512-yO7RAz6EsVQDaBH18IDJcMB1HnrUn2FJ/Jslc/WtPPWcjhpUJXU/rjbwmluzp7v/ZzWcEhTMXELnnsz8djWDwQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-block-scoping@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.23.4.tgz#b2d38589531c6c80fbe25e6b58e763622d2d3cf5" - integrity sha512-0QqbP6B6HOh7/8iNR4CQU2Th/bbRtBp4KS9vcaZd1fZ0wSh5Fyssg0UCIHwxh+ka+pNDREbVLQnHCMHKZfPwfw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-block-scoping@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.24.7.tgz#42063e4deb850c7bd7c55e626bf4e7ab48e6ce02" - integrity sha512-Nd5CvgMbWc+oWzBsuaMcbwjJWAcp5qzrbg69SZdHSP7AMY0AbWFqFO0WTFCA1jxhMCwodRwvRec8k0QUbZk7RQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-class-properties@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.23.3.tgz#35c377db11ca92a785a718b6aa4e3ed1eb65dc48" - integrity sha512-uM+AN8yCIjDPccsKGlw271xjJtGii+xQIF/uMPS8H15L12jZTsLfF4o5vNO7d/oUguOyfdikHGc/yi9ge4SGIg== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-class-properties@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.24.7.tgz#256879467b57b0b68c7ddfc5b76584f398cd6834" - integrity sha512-vKbfawVYayKcSeSR5YYzzyXvsDFWU2mD8U5TFeXtbCPLFUqe7GyCgvO6XDHzje862ODrOwy6WCPmKeWHbCFJ4w== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-class-static-block@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.23.4.tgz#2a202c8787a8964dd11dfcedf994d36bfc844ab5" - integrity sha512-nsWu/1M+ggti1SOALj3hfx5FXzAY06fwPJsUZD4/A5e1bWi46VUIWtD+kOX6/IdhXGsXBWllLFDSnqSCdUNydQ== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - -"@babel/plugin-transform-class-static-block@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.24.7.tgz#c82027ebb7010bc33c116d4b5044fbbf8c05484d" - integrity sha512-HMXK3WbBPpZQufbMG4B46A90PkuuhN9vBCb5T8+VAHqvAqvcLi+2cKoukcpmUYkszLhScU3l1iudhrks3DggRQ== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - -"@babel/plugin-transform-classes@^7.23.5": - version "7.23.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.23.5.tgz#e7a75f815e0c534cc4c9a39c56636c84fc0d64f2" - integrity sha512-jvOTR4nicqYC9yzOHIhXG5emiFEOpappSJAl73SDSEDcybD+Puuze8Tnpb9p9qEyYup24tq891gkaygIFvWDqg== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-compilation-targets" "^7.22.15" - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-function-name" "^7.23.0" - "@babel/helper-optimise-call-expression" "^7.22.5" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-replace-supers" "^7.22.20" - "@babel/helper-split-export-declaration" "^7.22.6" - globals "^11.1.0" - -"@babel/plugin-transform-classes@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.24.7.tgz#4ae6ef43a12492134138c1e45913f7c46c41b4bf" - integrity sha512-CFbbBigp8ln4FU6Bpy6g7sE8B/WmCmzvivzUC6xDAdWVsjYTXijpuuGJmYkAaoWAzcItGKT3IOAbxRItZ5HTjw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - "@babel/helper-compilation-targets" "^7.24.7" - "@babel/helper-environment-visitor" "^7.24.7" - "@babel/helper-function-name" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-replace-supers" "^7.24.7" - "@babel/helper-split-export-declaration" "^7.24.7" - globals "^11.1.0" - -"@babel/plugin-transform-computed-properties@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.23.3.tgz#652e69561fcc9d2b50ba4f7ac7f60dcf65e86474" - integrity sha512-dTj83UVTLw/+nbiHqQSFdwO9CbTtwq1DsDqm3CUEtDrZNET5rT5E6bIdTlOftDTDLMYxvxHNEYO4B9SLl8SLZw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/template" "^7.22.15" - -"@babel/plugin-transform-computed-properties@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.24.7.tgz#4cab3214e80bc71fae3853238d13d097b004c707" - integrity sha512-25cS7v+707Gu6Ds2oY6tCkUwsJ9YIDbggd9+cu9jzzDgiNq7hR/8dkzxWfKWnTic26vsI3EsCXNd4iEB6e8esQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/template" "^7.24.7" - -"@babel/plugin-transform-destructuring@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.23.3.tgz#8c9ee68228b12ae3dff986e56ed1ba4f3c446311" - integrity sha512-n225npDqjDIr967cMScVKHXJs7rout1q+tt50inyBCPkyZ8KxeI6d+GIbSBTT/w/9WdlWDOej3V9HE5Lgk57gw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-destructuring@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.24.7.tgz#a097f25292defb6e6cc16d6333a4cfc1e3c72d9e" - integrity sha512-19eJO/8kdCQ9zISOf+SEUJM/bAUIsvY3YDnXZTupUCQ8LgrWnsG/gFB9dvXqdXnRXMAM8fvt7b0CBKQHNGy1mw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-dotall-regex@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.23.3.tgz#3f7af6054882ede89c378d0cf889b854a993da50" - integrity sha512-vgnFYDHAKzFaTVp+mneDsIEbnJ2Np/9ng9iviHw3P/KVcgONxpNULEW/51Z/BaFojG2GI2GwwXck5uV1+1NOYQ== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-dotall-regex@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.24.7.tgz#5f8bf8a680f2116a7207e16288a5f974ad47a7a0" - integrity sha512-ZOA3W+1RRTSWvyqcMJDLqbchh7U4NRGqwRfFSVbOLS/ePIP4vHB5e8T8eXcuqyN1QkgKyj5wuW0lcS85v4CrSw== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-duplicate-keys@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.23.3.tgz#664706ca0a5dfe8d066537f99032fc1dc8b720ce" - integrity sha512-RrqQ+BQmU3Oyav3J+7/myfvRCq7Tbz+kKLLshUmMwNlDHExbGL7ARhajvoBJEvc+fCguPPu887N+3RRXBVKZUA== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-duplicate-keys@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.24.7.tgz#dd20102897c9a2324e5adfffb67ff3610359a8ee" - integrity sha512-JdYfXyCRihAe46jUIliuL2/s0x0wObgwwiGxw/UbgJBr20gQBThrokO4nYKgWkD7uBaqM7+9x5TU7NkExZJyzw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-dynamic-import@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.23.4.tgz#c7629e7254011ac3630d47d7f34ddd40ca535143" - integrity sha512-V6jIbLhdJK86MaLh4Jpghi8ho5fGzt3imHOBu/x0jlBaPYqDoWz4RDXjmMOfnh+JWNaQleEAByZLV0QzBT4YQQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - -"@babel/plugin-transform-dynamic-import@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.24.7.tgz#4d8b95e3bae2b037673091aa09cd33fecd6419f4" - integrity sha512-sc3X26PhZQDb3JhORmakcbvkeInvxz+A8oda99lj7J60QRuPZvNAk9wQlTBS1ZynelDrDmTU4pw1tyc5d5ZMUg== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - -"@babel/plugin-transform-exponentiation-operator@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.23.3.tgz#ea0d978f6b9232ba4722f3dbecdd18f450babd18" - integrity sha512-5fhCsl1odX96u7ILKHBj4/Y8vipoqwsJMh4csSA8qFfxrZDEA4Ssku2DyNvMJSmZNOEBT750LfFPbtrnTP90BQ== - dependencies: - "@babel/helper-builder-binary-assignment-operator-visitor" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-exponentiation-operator@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.24.7.tgz#b629ee22645f412024297d5245bce425c31f9b0d" - integrity sha512-Rqe/vSc9OYgDajNIK35u7ot+KeCoetqQYFXM4Epf7M7ez3lWlOjrDjrwMei6caCVhfdw+mIKD4cgdGNy5JQotQ== - dependencies: - "@babel/helper-builder-binary-assignment-operator-visitor" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-export-namespace-from@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.23.4.tgz#084c7b25e9a5c8271e987a08cf85807b80283191" - integrity sha512-GzuSBcKkx62dGzZI1WVgTWvkkz84FZO5TC5T8dl/Tht/rAla6Dg/Mz9Yhypg+ezVACf/rgDuQt3kbWEv7LdUDQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - -"@babel/plugin-transform-export-namespace-from@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.24.7.tgz#176d52d8d8ed516aeae7013ee9556d540c53f197" - integrity sha512-v0K9uNYsPL3oXZ/7F9NNIbAj2jv1whUEtyA6aujhekLs56R++JDQuzRcP2/z4WX5Vg/c5lE9uWZA0/iUoFhLTA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - -"@babel/plugin-transform-flow-strip-types@^7.16.0": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.23.3.tgz#cfa7ca159cc3306fab526fc67091556b51af26ff" - integrity sha512-26/pQTf9nQSNVJCrLB1IkHUKyPxR+lMrH2QDPG89+Znu9rAMbtrybdbWeE9bb7gzjmE5iXHEY+e0HUwM6Co93Q== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-flow" "^7.23.3" - -"@babel/plugin-transform-flow-strip-types@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.24.7.tgz#ae454e62219288fbb734541ab00389bfb13c063e" - integrity sha512-cjRKJ7FobOH2eakx7Ja+KpJRj8+y+/SiB3ooYm/n2UJfxu0oEaOoxOinitkJcPqv9KxS0kxTGPUaR7L2XcXDXA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-flow" "^7.24.7" - -"@babel/plugin-transform-for-of@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.23.6.tgz#81c37e24171b37b370ba6aaffa7ac86bcb46f94e" - integrity sha512-aYH4ytZ0qSuBbpfhuofbg/e96oQ7U2w1Aw/UQmKT+1l39uEhUPoFS3fHevDc1G0OvewyDudfMKY1OulczHzWIw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - -"@babel/plugin-transform-for-of@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.24.7.tgz#f25b33f72df1d8be76399e1b8f3f9d366eb5bc70" - integrity sha512-wo9ogrDG1ITTTBsy46oGiN1dS9A7MROBTcYsfS8DtsImMkHk9JXJ3EWQM6X2SUw4x80uGPlwj0o00Uoc6nEE3g== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-skip-transparent-expression-wrappers" "^7.24.7" - -"@babel/plugin-transform-function-name@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.23.3.tgz#8f424fcd862bf84cb9a1a6b42bc2f47ed630f8dc" - integrity sha512-I1QXp1LxIvt8yLaib49dRW5Okt7Q4oaxao6tFVKS/anCdEOMtYwWVKoiOA1p34GOWIZjUK0E+zCp7+l1pfQyiw== - dependencies: - "@babel/helper-compilation-targets" "^7.22.15" - "@babel/helper-function-name" "^7.23.0" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-function-name@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.24.7.tgz#6d8601fbffe665c894440ab4470bc721dd9131d6" - integrity sha512-U9FcnA821YoILngSmYkW6FjyQe2TyZD5pHt4EVIhmcTkrJw/3KqcrRSxuOo5tFZJi7TE19iDyI1u+weTI7bn2w== - dependencies: - "@babel/helper-compilation-targets" "^7.24.7" - "@babel/helper-function-name" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-json-strings@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.23.4.tgz#a871d9b6bd171976efad2e43e694c961ffa3714d" - integrity sha512-81nTOqM1dMwZ/aRXQ59zVubN9wHGqk6UtqRK+/q+ciXmRy8fSolhGVvG09HHRGo4l6fr/c4ZhXUQH0uFW7PZbg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-json-strings" "^7.8.3" - -"@babel/plugin-transform-json-strings@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.24.7.tgz#f3e9c37c0a373fee86e36880d45b3664cedaf73a" - integrity sha512-2yFnBGDvRuxAaE/f0vfBKvtnvvqU8tGpMHqMNpTN2oWMKIR3NqFkjaAgGwawhqK/pIN2T3XdjGPdaG0vDhOBGw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-json-strings" "^7.8.3" - -"@babel/plugin-transform-literals@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.23.3.tgz#8214665f00506ead73de157eba233e7381f3beb4" - integrity sha512-wZ0PIXRxnwZvl9AYpqNUxpZ5BiTGrYt7kueGQ+N5FiQ7RCOD4cm8iShd6S6ggfVIWaJf2EMk8eRzAh52RfP4rQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-literals@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.24.7.tgz#36b505c1e655151a9d7607799a9988fc5467d06c" - integrity sha512-vcwCbb4HDH+hWi8Pqenwnjy+UiklO4Kt1vfspcQYFhJdpthSnW8XvWGyDZWKNVrVbVViI/S7K9PDJZiUmP2fYQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-logical-assignment-operators@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.23.4.tgz#e599f82c51d55fac725f62ce55d3a0886279ecb5" - integrity sha512-Mc/ALf1rmZTP4JKKEhUwiORU+vcfarFVLfcFiolKUo6sewoxSEgl36ak5t+4WamRsNr6nzjZXQjM35WsU+9vbg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - -"@babel/plugin-transform-logical-assignment-operators@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.24.7.tgz#a58fb6eda16c9dc8f9ff1c7b1ba6deb7f4694cb0" - integrity sha512-4D2tpwlQ1odXmTEIFWy9ELJcZHqrStlzK/dAOWYyxX3zT0iXQB6banjgeOJQXzEc4S0E0a5A+hahxPaEFYftsw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - -"@babel/plugin-transform-member-expression-literals@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.23.3.tgz#e37b3f0502289f477ac0e776b05a833d853cabcc" - integrity sha512-sC3LdDBDi5x96LA+Ytekz2ZPk8i/Ck+DEuDbRAll5rknJ5XRTSaPKEYwomLcs1AA8wg9b3KjIQRsnApj+q51Ag== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-member-expression-literals@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.24.7.tgz#3b4454fb0e302e18ba4945ba3246acb1248315df" - integrity sha512-T/hRC1uqrzXMKLQ6UCwMT85S3EvqaBXDGf0FaMf4446Qx9vKwlghvee0+uuZcDUCZU5RuNi4781UQ7R308zzBw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-modules-amd@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.23.3.tgz#e19b55436a1416829df0a1afc495deedfae17f7d" - integrity sha512-vJYQGxeKM4t8hYCKVBlZX/gtIY2I7mRGFNcm85sgXGMTBcoV3QdVtdpbcWEbzbfUIUZKwvgFT82mRvaQIebZzw== - dependencies: - "@babel/helper-module-transforms" "^7.23.3" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-modules-amd@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.24.7.tgz#65090ed493c4a834976a3ca1cde776e6ccff32d7" - integrity sha512-9+pB1qxV3vs/8Hdmz/CulFB8w2tuu6EB94JZFsjdqxQokwGa9Unap7Bo2gGBGIvPmDIVvQrom7r5m/TCDMURhg== - dependencies: - "@babel/helper-module-transforms" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-modules-commonjs@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.23.3.tgz#661ae831b9577e52be57dd8356b734f9700b53b4" - integrity sha512-aVS0F65LKsdNOtcz6FRCpE4OgsP2OFnW46qNxNIX9h3wuzaNcSQsJysuMwqSibC98HPrf2vCgtxKNwS0DAlgcA== - dependencies: - "@babel/helper-module-transforms" "^7.23.3" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-simple-access" "^7.22.5" - -"@babel/plugin-transform-modules-commonjs@^7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.24.1.tgz#e71ba1d0d69e049a22bf90b3867e263823d3f1b9" - integrity sha512-szog8fFTUxBfw0b98gEWPaEqF42ZUD/T3bkynW/wtgx2p/XCP55WEsb+VosKceRSd6njipdZvNogqdtI4Q0chw== - dependencies: - "@babel/helper-module-transforms" "^7.23.3" - "@babel/helper-plugin-utils" "^7.24.0" - "@babel/helper-simple-access" "^7.22.5" - -"@babel/plugin-transform-modules-commonjs@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.24.7.tgz#9fd5f7fdadee9085886b183f1ad13d1ab260f4ab" - integrity sha512-iFI8GDxtevHJ/Z22J5xQpVqFLlMNstcLXh994xifFwxxGslr2ZXXLWgtBeLctOD63UFDArdvN6Tg8RFw+aEmjQ== - dependencies: - "@babel/helper-module-transforms" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-simple-access" "^7.24.7" - -"@babel/plugin-transform-modules-systemjs@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.23.3.tgz#fa7e62248931cb15b9404f8052581c302dd9de81" - integrity sha512-ZxyKGTkF9xT9YJuKQRo19ewf3pXpopuYQd8cDXqNzc3mUNbOME0RKMoZxviQk74hwzfQsEe66dE92MaZbdHKNQ== - dependencies: - "@babel/helper-hoist-variables" "^7.22.5" - "@babel/helper-module-transforms" "^7.23.3" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-validator-identifier" "^7.22.20" - -"@babel/plugin-transform-modules-systemjs@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.24.7.tgz#f8012316c5098f6e8dee6ecd58e2bc6f003d0ce7" - integrity sha512-GYQE0tW7YoaN13qFh3O1NCY4MPkUiAH3fiF7UcV/I3ajmDKEdG3l+UOcbAm4zUE3gnvUU+Eni7XrVKo9eO9auw== - dependencies: - "@babel/helper-hoist-variables" "^7.24.7" - "@babel/helper-module-transforms" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-validator-identifier" "^7.24.7" - -"@babel/plugin-transform-modules-umd@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.23.3.tgz#5d4395fccd071dfefe6585a4411aa7d6b7d769e9" - integrity sha512-zHsy9iXX2nIsCBFPud3jKn1IRPWg3Ing1qOZgeKV39m1ZgIdpJqvlWVeiHBZC6ITRG0MfskhYe9cLgntfSFPIg== - dependencies: - "@babel/helper-module-transforms" "^7.23.3" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-modules-umd@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.24.7.tgz#edd9f43ec549099620df7df24e7ba13b5c76efc8" - integrity sha512-3aytQvqJ/h9z4g8AsKPLvD4Zqi2qT+L3j7XoFFu1XBlZWEl2/1kWnhmAbxpLgPrHSY0M6UA02jyTiwUVtiKR6A== - dependencies: - "@babel/helper-module-transforms" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-named-capturing-groups-regex@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.22.5.tgz#67fe18ee8ce02d57c855185e27e3dc959b2e991f" - integrity sha512-YgLLKmS3aUBhHaxp5hi1WJTgOUb/NCuDHzGT9z9WTt3YG+CPRhJs6nprbStx6DnWM4dh6gt7SU3sZodbZ08adQ== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.22.5" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-named-capturing-groups-regex@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.24.7.tgz#9042e9b856bc6b3688c0c2e4060e9e10b1460923" - integrity sha512-/jr7h/EWeJtk1U/uz2jlsCioHkZk1JJZVcc8oQsJ1dUlaJD83f4/6Zeh2aHt9BIFokHIsSeDfhUmju0+1GPd6g== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-new-target@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.23.3.tgz#5491bb78ed6ac87e990957cea367eab781c4d980" - integrity sha512-YJ3xKqtJMAT5/TIZnpAR3I+K+WaDowYbN3xyxI8zxx/Gsypwf9B9h0VB+1Nh6ACAAPRS5NSRje0uVv5i79HYGQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-new-target@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.24.7.tgz#31ff54c4e0555cc549d5816e4ab39241dfb6ab00" - integrity sha512-RNKwfRIXg4Ls/8mMTza5oPF5RkOW8Wy/WgMAp1/F1yZ8mMbtwXW+HDoJiOsagWrAhI5f57Vncrmr9XeT4CVapA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-nullish-coalescing-operator@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.23.4.tgz#45556aad123fc6e52189ea749e33ce090637346e" - integrity sha512-jHE9EVVqHKAQx+VePv5LLGHjmHSJR76vawFPTdlxR/LVJPfOEGxREQwQfjuZEOPTwG92X3LINSh3M40Rv4zpVA== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - -"@babel/plugin-transform-nullish-coalescing-operator@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.24.7.tgz#1de4534c590af9596f53d67f52a92f12db984120" - integrity sha512-Ts7xQVk1OEocqzm8rHMXHlxvsfZ0cEF2yomUqpKENHWMF4zKk175Y4q8H5knJes6PgYad50uuRmt3UJuhBw8pQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - -"@babel/plugin-transform-numeric-separator@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.23.4.tgz#03d08e3691e405804ecdd19dd278a40cca531f29" - integrity sha512-mps6auzgwjRrwKEZA05cOwuDc9FAzoyFS4ZsG/8F43bTLf/TgkJg7QXOrPO1JO599iA3qgK9MXdMGOEC8O1h6Q== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - -"@babel/plugin-transform-numeric-separator@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.24.7.tgz#bea62b538c80605d8a0fac9b40f48e97efa7de63" - integrity sha512-e6q1TiVUzvH9KRvicuxdBTUj4AdKSRwzIyFFnfnezpCfP2/7Qmbb8qbU2j7GODbl4JMkblitCQjKYUaX/qkkwA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - -"@babel/plugin-transform-object-rest-spread@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.23.4.tgz#2b9c2d26bf62710460bdc0d1730d4f1048361b83" - integrity sha512-9x9K1YyeQVw0iOXJlIzwm8ltobIIv7j2iLyP2jIhEbqPRQ7ScNgwQufU2I0Gq11VjyG4gI4yMXt2VFags+1N3g== - dependencies: - "@babel/compat-data" "^7.23.3" - "@babel/helper-compilation-targets" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-transform-parameters" "^7.23.3" - -"@babel/plugin-transform-object-rest-spread@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.24.7.tgz#d13a2b93435aeb8a197e115221cab266ba6e55d6" - integrity sha512-4QrHAr0aXQCEFni2q4DqKLD31n2DL+RxcwnNjDFkSG0eNQ/xCavnRkfCUjsyqGC2OviNJvZOF/mQqZBw7i2C5Q== - dependencies: - "@babel/helper-compilation-targets" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-transform-parameters" "^7.24.7" - -"@babel/plugin-transform-object-super@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.23.3.tgz#81fdb636dcb306dd2e4e8fd80db5b2362ed2ebcd" - integrity sha512-BwQ8q0x2JG+3lxCVFohg+KbQM7plfpBwThdW9A6TMtWwLsbDA01Ek2Zb/AgDN39BiZsExm4qrXxjk+P1/fzGrA== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-replace-supers" "^7.22.20" - -"@babel/plugin-transform-object-super@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.24.7.tgz#66eeaff7830bba945dd8989b632a40c04ed625be" - integrity sha512-A/vVLwN6lBrMFmMDmPPz0jnE6ZGx7Jq7d6sT/Ev4H65RER6pZ+kczlf1DthF5N0qaPHBsI7UXiE8Zy66nmAovg== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-replace-supers" "^7.24.7" - -"@babel/plugin-transform-optional-catch-binding@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.23.4.tgz#318066de6dacce7d92fa244ae475aa8d91778017" - integrity sha512-XIq8t0rJPHf6Wvmbn9nFxU6ao4c7WhghTR5WyV8SrJfUFzyxhCm4nhC+iAp3HFhbAKLfYpgzhJ6t4XCtVwqO5A== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - -"@babel/plugin-transform-optional-catch-binding@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.24.7.tgz#00eabd883d0dd6a60c1c557548785919b6e717b4" - integrity sha512-uLEndKqP5BfBbC/5jTwPxLh9kqPWWgzN/f8w6UwAIirAEqiIVJWWY312X72Eub09g5KF9+Zn7+hT7sDxmhRuKA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - -"@babel/plugin-transform-optional-chaining@^7.23.3", "@babel/plugin-transform-optional-chaining@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.23.4.tgz#6acf61203bdfc4de9d4e52e64490aeb3e52bd017" - integrity sha512-ZU8y5zWOfjM5vZ+asjgAPwDaBjJzgufjES89Rs4Lpq63O300R/kOz30WCLo6BxxX6QVEilwSlpClnG5cZaikTA== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - -"@babel/plugin-transform-optional-chaining@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.24.7.tgz#b8f6848a80cf2da98a8a204429bec04756c6d454" - integrity sha512-tK+0N9yd4j+x/4hxF3F0e0fu/VdcxU18y5SevtyM/PCFlQvXbR0Zmlo2eBrKtVipGNFzpq56o8WsIIKcJFUCRQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-skip-transparent-expression-wrappers" "^7.24.7" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - -"@babel/plugin-transform-parameters@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.23.3.tgz#83ef5d1baf4b1072fa6e54b2b0999a7b2527e2af" - integrity sha512-09lMt6UsUb3/34BbECKVbVwrT9bO6lILWln237z7sLaWnMsTi7Yc9fhX5DLpkJzAGfaReXI22wP41SZmnAA3Vw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-parameters@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.24.7.tgz#5881f0ae21018400e320fc7eb817e529d1254b68" - integrity sha512-yGWW5Rr+sQOhK0Ot8hjDJuxU3XLRQGflvT4lhlSY0DFvdb3TwKaY26CJzHtYllU0vT9j58hc37ndFPsqT1SrzA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-private-methods@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.23.3.tgz#b2d7a3c97e278bfe59137a978d53b2c2e038c0e4" - integrity sha512-UzqRcRtWsDMTLrRWFvUBDwmw06tCQH9Rl1uAjfh6ijMSmGYQ+fpdB+cnqRC8EMh5tuuxSv0/TejGL+7vyj+50g== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-private-methods@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.24.7.tgz#e6318746b2ae70a59d023d5cc1344a2ba7a75f5e" - integrity sha512-COTCOkG2hn4JKGEKBADkA8WNb35TGkkRbI5iT845dB+NyqgO8Hn+ajPbSnIQznneJTa3d30scb6iz/DhH8GsJQ== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-private-property-in-object@^7.23.4": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.23.4.tgz#3ec711d05d6608fd173d9b8de39872d8dbf68bf5" - integrity sha512-9G3K1YqTq3F4Vt88Djx1UZ79PDyj+yKRnUy7cZGSMe+a7jkwD259uKKuUzQlPkGam7R+8RJwh5z4xO27fA1o2A== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-create-class-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - -"@babel/plugin-transform-private-property-in-object@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.24.7.tgz#4eec6bc701288c1fab5f72e6a4bbc9d67faca061" - integrity sha512-9z76mxwnwFxMyxZWEgdgECQglF2Q7cFLm0kMf8pGwt+GSJsY0cONKj/UuO4bOH0w/uAel3ekS4ra5CEAyJRmDA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - "@babel/helper-create-class-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - -"@babel/plugin-transform-property-literals@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.23.3.tgz#54518f14ac4755d22b92162e4a852d308a560875" - integrity sha512-jR3Jn3y7cZp4oEWPFAlRsSWjxKe4PZILGBSd4nis1TsC5qeSpb+nrtihJuDhNI7QHiVbUaiXa0X2RZY3/TI6Nw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-property-literals@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.24.7.tgz#f0d2ed8380dfbed949c42d4d790266525d63bbdc" - integrity sha512-EMi4MLQSHfd2nrCqQEWxFdha2gBCqU4ZcCng4WBGZ5CJL4bBRW0ptdqqDdeirGZcpALazVVNJqRmsO8/+oNCBA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-react-display-name@^7.16.0", "@babel/plugin-transform-react-display-name@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.23.3.tgz#70529f034dd1e561045ad3c8152a267f0d7b6200" - integrity sha512-GnvhtVfA2OAtzdX58FJxU19rhoGeQzyVndw3GgtdECQvQFXPEZIOVULHVZGAYmOgmqjXpVpfocAbSjh99V/Fqw== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-react-display-name@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.24.7.tgz#9caff79836803bc666bcfe210aeb6626230c293b" - integrity sha512-H/Snz9PFxKsS1JLI4dJLtnJgCJRoo0AUm3chP6NYr+9En1JMKloheEiLIhlp5MDVznWo+H3AAC1Mc8lmUEpsgg== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-react-jsx-development@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.22.5.tgz#e716b6edbef972a92165cd69d92f1255f7e73e87" - integrity sha512-bDhuzwWMuInwCYeDeMzyi7TaBgRQei6DqxhbyniL7/VG4RSS7HtSL2QbY4eESy1KJqlWt8g3xeEBGPuo+XqC8A== - dependencies: - "@babel/plugin-transform-react-jsx" "^7.22.5" - -"@babel/plugin-transform-react-jsx-development@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.24.7.tgz#eaee12f15a93f6496d852509a850085e6361470b" - integrity sha512-QG9EnzoGn+Qar7rxuW+ZOsbWOt56FvvI93xInqsZDC5fsekx1AlIO4KIJ5M+D0p0SqSH156EpmZyXq630B8OlQ== - dependencies: - "@babel/plugin-transform-react-jsx" "^7.24.7" - -"@babel/plugin-transform-react-jsx@^7.22.15", "@babel/plugin-transform-react-jsx@^7.22.5": - version "7.23.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.23.4.tgz#393f99185110cea87184ea47bcb4a7b0c2e39312" - integrity sha512-5xOpoPguCZCRbo/JeHlloSkTA8Bld1J/E1/kLfD1nsuiW1m8tduTA1ERCgIZokDflX/IBzKcqR3l7VlRgiIfHA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-module-imports" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-jsx" "^7.23.3" - "@babel/types" "^7.23.4" - -"@babel/plugin-transform-react-jsx@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.24.7.tgz#17cd06b75a9f0e2bd076503400e7c4b99beedac4" - integrity sha512-+Dj06GDZEFRYvclU6k4bme55GKBEWUmByM/eoKuqg4zTNQHiApWRhQph5fxQB2wAEFvRzL1tOEj1RJ19wJrhoA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - "@babel/helper-module-imports" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-jsx" "^7.24.7" - "@babel/types" "^7.24.7" - -"@babel/plugin-transform-react-pure-annotations@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-pure-annotations/-/plugin-transform-react-pure-annotations-7.23.3.tgz#fabedbdb8ee40edf5da96f3ecfc6958e3783b93c" - integrity sha512-qMFdSS+TUhB7Q/3HVPnEdYJDQIk57jkntAwSuz9xfSE4n+3I+vHYCli3HoHawN1Z3RfCz/y1zXA/JXjG6cVImQ== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-react-pure-annotations@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-pure-annotations/-/plugin-transform-react-pure-annotations-7.24.7.tgz#bdd9d140d1c318b4f28b29a00fb94f97ecab1595" - integrity sha512-PLgBVk3fzbmEjBJ/u8kFzOqS9tUeDjiaWud/rRym/yjCo/M9cASPlnrd2ZmmZpQT40fOOrvR8jh+n8jikrOhNA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-regenerator@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.23.3.tgz#141afd4a2057298602069fce7f2dc5173e6c561c" - integrity sha512-KP+75h0KghBMcVpuKisx3XTu9Ncut8Q8TuvGO4IhY+9D5DFEckQefOuIsB/gQ2tG71lCke4NMrtIPS8pOj18BQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - regenerator-transform "^0.15.2" - -"@babel/plugin-transform-regenerator@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.24.7.tgz#021562de4534d8b4b1851759fd7af4e05d2c47f8" - integrity sha512-lq3fvXPdimDrlg6LWBoqj+r/DEWgONuwjuOuQCSYgRroXDH/IdM1C0IZf59fL5cHLpjEH/O6opIRBbqv7ELnuA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - regenerator-transform "^0.15.2" - -"@babel/plugin-transform-reserved-words@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.23.3.tgz#4130dcee12bd3dd5705c587947eb715da12efac8" - integrity sha512-QnNTazY54YqgGxwIexMZva9gqbPa15t/x9VS+0fsEFWplwVpXYZivtgl43Z1vMpc1bdPP2PP8siFeVcnFvA3Cg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-reserved-words@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.24.7.tgz#80037fe4fbf031fc1125022178ff3938bb3743a4" - integrity sha512-0DUq0pHcPKbjFZCfTss/pGkYMfy3vFWydkUBd9r0GHpIyfs2eCDENvqadMycRS9wZCXR41wucAfJHJmwA0UmoQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-runtime@^7.16.4": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.23.6.tgz#bf853cd0a675c16ee33e6ba2a63b536e75e5d754" - integrity sha512-kF1Zg62aPseQ11orDhFRw+aPG/eynNQtI+TyY+m33qJa2cJ5EEvza2P2BNTIA9E5MyqFABHEyY6CPHwgdy9aNg== - dependencies: - "@babel/helper-module-imports" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - babel-plugin-polyfill-corejs2 "^0.4.6" - babel-plugin-polyfill-corejs3 "^0.8.5" - babel-plugin-polyfill-regenerator "^0.5.3" - semver "^6.3.1" - -"@babel/plugin-transform-shorthand-properties@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.23.3.tgz#97d82a39b0e0c24f8a981568a8ed851745f59210" - integrity sha512-ED2fgqZLmexWiN+YNFX26fx4gh5qHDhn1O2gvEhreLW2iI63Sqm4llRLCXALKrCnbN4Jy0VcMQZl/SAzqug/jg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-shorthand-properties@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.24.7.tgz#85448c6b996e122fa9e289746140aaa99da64e73" - integrity sha512-KsDsevZMDsigzbA09+vacnLpmPH4aWjcZjXdyFKGzpplxhbeB4wYtury3vglQkg6KM/xEPKt73eCjPPf1PgXBA== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-spread@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.23.3.tgz#41d17aacb12bde55168403c6f2d6bdca563d362c" - integrity sha512-VvfVYlrlBVu+77xVTOAoxQ6mZbnIq5FM0aGBSFEcIh03qHf+zNqA4DC/3XMUozTg7bZV3e3mZQ0i13VB6v5yUg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-skip-transparent-expression-wrappers" "^7.22.5" - -"@babel/plugin-transform-spread@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.24.7.tgz#e8a38c0fde7882e0fb8f160378f74bd885cc7bb3" - integrity sha512-x96oO0I09dgMDxJaANcRyD4ellXFLLiWhuwDxKZX5g2rWP1bTPkBSwCYv96VDXVT1bD9aPj8tppr5ITIh8hBng== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-skip-transparent-expression-wrappers" "^7.24.7" - -"@babel/plugin-transform-sticky-regex@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.23.3.tgz#dec45588ab4a723cb579c609b294a3d1bd22ff04" - integrity sha512-HZOyN9g+rtvnOU3Yh7kSxXrKbzgrm5X4GncPY1QOquu7epga5MxKHVpYu2hvQnry/H+JjckSYRb93iNfsioAGg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-sticky-regex@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.24.7.tgz#96ae80d7a7e5251f657b5cf18f1ea6bf926f5feb" - integrity sha512-kHPSIJc9v24zEml5geKg9Mjx5ULpfncj0wRpYtxbvKyTtHCYDkVE3aHQ03FrpEo4gEe2vrJJS1Y9CJTaThA52g== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-template-literals@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.23.3.tgz#5f0f028eb14e50b5d0f76be57f90045757539d07" - integrity sha512-Flok06AYNp7GV2oJPZZcP9vZdszev6vPBkHLwxwSpaIqx75wn6mUd3UFWsSsA0l8nXAKkyCmL/sR02m8RYGeHg== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-template-literals@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.24.7.tgz#a05debb4a9072ae8f985bcf77f3f215434c8f8c8" - integrity sha512-AfDTQmClklHCOLxtGoP7HkeMw56k1/bTQjwsfhL6pppo/M4TOBSq+jjBUBLmV/4oeFg4GWMavIl44ZeCtmmZTw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-typeof-symbol@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.23.3.tgz#9dfab97acc87495c0c449014eb9c547d8966bca4" - integrity sha512-4t15ViVnaFdrPC74be1gXBSMzXk3B4Us9lP7uLRQHTFpV5Dvt33pn+2MyyNxmN3VTTm3oTrZVMUmuw3oBnQ2oQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-typeof-symbol@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.24.7.tgz#f074be466580d47d6e6b27473a840c9f9ca08fb0" - integrity sha512-VtR8hDy7YLB7+Pet9IarXjg/zgCMSF+1mNS/EQEiEaUPoFXCVsHG64SIxcaaI2zJgRiv+YmgaQESUfWAdbjzgg== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-typescript@^7.23.3": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.23.6.tgz#aa36a94e5da8d94339ae3a4e22d40ed287feb34c" - integrity sha512-6cBG5mBvUu4VUD04OHKnYzbuHNP8huDsD3EDqqpIpsswTDoqHCjLoHb6+QgsV1WsT2nipRqCPgxD3LXnEO7XfA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-create-class-features-plugin" "^7.23.6" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/plugin-syntax-typescript" "^7.23.3" - -"@babel/plugin-transform-typescript@^7.24.1": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.5.tgz#bcba979e462120dc06a75bd34c473a04781931b8" - integrity sha512-E0VWu/hk83BIFUWnsKZ4D81KXjN5L3MobvevOHErASk9IPwKHOkTgvqzvNo1yP/ePJWqqK2SpUR5z+KQbl6NVw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.22.5" - "@babel/helper-create-class-features-plugin" "^7.24.5" - "@babel/helper-plugin-utils" "^7.24.5" - "@babel/plugin-syntax-typescript" "^7.24.1" - -"@babel/plugin-transform-typescript@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.7.tgz#b006b3e0094bf0813d505e0c5485679eeaf4a881" - integrity sha512-iLD3UNkgx2n/HrjBesVbYX6j0yqn/sJktvbtKKgcaLIQ4bTTQ8obAypc1VpyHPD2y4Phh9zHOaAt8e/L14wCpw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.24.7" - "@babel/helper-create-class-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/plugin-syntax-typescript" "^7.24.7" - -"@babel/plugin-transform-unicode-escapes@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.23.3.tgz#1f66d16cab01fab98d784867d24f70c1ca65b925" - integrity sha512-OMCUx/bU6ChE3r4+ZdylEqAjaQgHAgipgW8nsCfu5pGqDcFytVd91AwRvUJSBZDz0exPGgnjoqhgRYLRjFZc9Q== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-unicode-escapes@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.24.7.tgz#2023a82ced1fb4971630a2e079764502c4148e0e" - integrity sha512-U3ap1gm5+4edc2Q/P+9VrBNhGkfnf+8ZqppY71Bo/pzZmXhhLdqgaUl6cuB07O1+AQJtCLfaOmswiNbSQ9ivhw== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-unicode-property-regex@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.23.3.tgz#19e234129e5ffa7205010feec0d94c251083d7ad" - integrity sha512-KcLIm+pDZkWZQAFJ9pdfmh89EwVfmNovFBcXko8szpBeF8z68kWIPeKlmSOkT9BXJxs2C0uk+5LxoxIv62MROA== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-unicode-property-regex@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.24.7.tgz#9073a4cd13b86ea71c3264659590ac086605bbcd" - integrity sha512-uH2O4OV5M9FZYQrwc7NdVmMxQJOCCzFeYudlZSzUAHRFeOujQefa92E74TQDVskNHCzOXoigEuoyzHDhaEaK5w== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-unicode-regex@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.23.3.tgz#26897708d8f42654ca4ce1b73e96140fbad879dc" - integrity sha512-wMHpNA4x2cIA32b/ci3AfwNgheiva2W0WUKWTK7vBHBhDKfPsc5cFGNWm69WBqpwd86u1qwZ9PWevKqm1A3yAw== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-unicode-regex@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.24.7.tgz#dfc3d4a51127108099b19817c0963be6a2adf19f" - integrity sha512-hlQ96MBZSAXUq7ltkjtu3FJCCSMx/j629ns3hA3pXnBXjanNP0LHi+JpPeA81zaWgVK1VGH95Xuy7u0RyQ8kMg== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/plugin-transform-unicode-sets-regex@^7.23.3": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.23.3.tgz#4fb6f0a719c2c5859d11f6b55a050cc987f3799e" - integrity sha512-W7lliA/v9bNR83Qc3q1ip9CQMZ09CcHDbHfbLRDNuAhn1Mvkr1ZNF7hPmztMQvtTGVLJ9m8IZqWsTkXOml8dbw== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.22.15" - "@babel/helper-plugin-utils" "^7.22.5" - -"@babel/plugin-transform-unicode-sets-regex@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.24.7.tgz#d40705d67523803a576e29c63cef6e516b858ed9" - integrity sha512-2G8aAvF4wy1w/AGZkemprdGMRg5o6zPNhbHVImRz3lss55TYCBd6xStN19rt8XJHq20sqV0JbyWjOWwQRwV/wg== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - -"@babel/preset-env@^7.16.4": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.23.6.tgz#ad0ea799d5a3c07db5b9a172819bbd444092187a" - integrity sha512-2XPn/BqKkZCpzYhUUNZ1ssXw7DcXfKQEjv/uXZUXgaebCMYmkEsfZ2yY+vv+xtXv50WmL5SGhyB6/xsWxIvvOQ== - dependencies: - "@babel/compat-data" "^7.23.5" - "@babel/helper-compilation-targets" "^7.23.6" - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-validator-option" "^7.23.5" - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.23.3" - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.23.3" - "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly" "^7.23.3" - "@babel/plugin-proposal-private-property-in-object" "7.21.0-placeholder-for-preset-env.2" - "@babel/plugin-syntax-async-generators" "^7.8.4" - "@babel/plugin-syntax-class-properties" "^7.12.13" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - "@babel/plugin-syntax-import-assertions" "^7.23.3" - "@babel/plugin-syntax-import-attributes" "^7.23.3" - "@babel/plugin-syntax-import-meta" "^7.10.4" - "@babel/plugin-syntax-json-strings" "^7.8.3" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - "@babel/plugin-syntax-top-level-await" "^7.14.5" - "@babel/plugin-syntax-unicode-sets-regex" "^7.18.6" - "@babel/plugin-transform-arrow-functions" "^7.23.3" - "@babel/plugin-transform-async-generator-functions" "^7.23.4" - "@babel/plugin-transform-async-to-generator" "^7.23.3" - "@babel/plugin-transform-block-scoped-functions" "^7.23.3" - "@babel/plugin-transform-block-scoping" "^7.23.4" - "@babel/plugin-transform-class-properties" "^7.23.3" - "@babel/plugin-transform-class-static-block" "^7.23.4" - "@babel/plugin-transform-classes" "^7.23.5" - "@babel/plugin-transform-computed-properties" "^7.23.3" - "@babel/plugin-transform-destructuring" "^7.23.3" - "@babel/plugin-transform-dotall-regex" "^7.23.3" - "@babel/plugin-transform-duplicate-keys" "^7.23.3" - "@babel/plugin-transform-dynamic-import" "^7.23.4" - "@babel/plugin-transform-exponentiation-operator" "^7.23.3" - "@babel/plugin-transform-export-namespace-from" "^7.23.4" - "@babel/plugin-transform-for-of" "^7.23.6" - "@babel/plugin-transform-function-name" "^7.23.3" - "@babel/plugin-transform-json-strings" "^7.23.4" - "@babel/plugin-transform-literals" "^7.23.3" - "@babel/plugin-transform-logical-assignment-operators" "^7.23.4" - "@babel/plugin-transform-member-expression-literals" "^7.23.3" - "@babel/plugin-transform-modules-amd" "^7.23.3" - "@babel/plugin-transform-modules-commonjs" "^7.23.3" - "@babel/plugin-transform-modules-systemjs" "^7.23.3" - "@babel/plugin-transform-modules-umd" "^7.23.3" - "@babel/plugin-transform-named-capturing-groups-regex" "^7.22.5" - "@babel/plugin-transform-new-target" "^7.23.3" - "@babel/plugin-transform-nullish-coalescing-operator" "^7.23.4" - "@babel/plugin-transform-numeric-separator" "^7.23.4" - "@babel/plugin-transform-object-rest-spread" "^7.23.4" - "@babel/plugin-transform-object-super" "^7.23.3" - "@babel/plugin-transform-optional-catch-binding" "^7.23.4" - "@babel/plugin-transform-optional-chaining" "^7.23.4" - "@babel/plugin-transform-parameters" "^7.23.3" - "@babel/plugin-transform-private-methods" "^7.23.3" - "@babel/plugin-transform-private-property-in-object" "^7.23.4" - "@babel/plugin-transform-property-literals" "^7.23.3" - "@babel/plugin-transform-regenerator" "^7.23.3" - "@babel/plugin-transform-reserved-words" "^7.23.3" - "@babel/plugin-transform-shorthand-properties" "^7.23.3" - "@babel/plugin-transform-spread" "^7.23.3" - "@babel/plugin-transform-sticky-regex" "^7.23.3" - "@babel/plugin-transform-template-literals" "^7.23.3" - "@babel/plugin-transform-typeof-symbol" "^7.23.3" - "@babel/plugin-transform-unicode-escapes" "^7.23.3" - "@babel/plugin-transform-unicode-property-regex" "^7.23.3" - "@babel/plugin-transform-unicode-regex" "^7.23.3" - "@babel/plugin-transform-unicode-sets-regex" "^7.23.3" - "@babel/preset-modules" "0.1.6-no-external-plugins" - babel-plugin-polyfill-corejs2 "^0.4.6" - babel-plugin-polyfill-corejs3 "^0.8.5" - babel-plugin-polyfill-regenerator "^0.5.3" - core-js-compat "^3.31.0" - semver "^6.3.1" - -"@babel/preset-env@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.24.7.tgz#ff067b4e30ba4a72f225f12f123173e77b987f37" - integrity sha512-1YZNsc+y6cTvWlDHidMBsQZrZfEFjRIo/BZCT906PMdzOyXtSLTgqGdrpcuTDCXyd11Am5uQULtDIcCfnTc8fQ== - dependencies: - "@babel/compat-data" "^7.24.7" - "@babel/helper-compilation-targets" "^7.24.7" - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-validator-option" "^7.24.7" - "@babel/plugin-bugfix-firefox-class-in-computed-class-key" "^7.24.7" - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.24.7" - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.24.7" - "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly" "^7.24.7" - "@babel/plugin-proposal-private-property-in-object" "7.21.0-placeholder-for-preset-env.2" - "@babel/plugin-syntax-async-generators" "^7.8.4" - "@babel/plugin-syntax-class-properties" "^7.12.13" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - "@babel/plugin-syntax-import-assertions" "^7.24.7" - "@babel/plugin-syntax-import-attributes" "^7.24.7" - "@babel/plugin-syntax-import-meta" "^7.10.4" - "@babel/plugin-syntax-json-strings" "^7.8.3" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - "@babel/plugin-syntax-top-level-await" "^7.14.5" - "@babel/plugin-syntax-unicode-sets-regex" "^7.18.6" - "@babel/plugin-transform-arrow-functions" "^7.24.7" - "@babel/plugin-transform-async-generator-functions" "^7.24.7" - "@babel/plugin-transform-async-to-generator" "^7.24.7" - "@babel/plugin-transform-block-scoped-functions" "^7.24.7" - "@babel/plugin-transform-block-scoping" "^7.24.7" - "@babel/plugin-transform-class-properties" "^7.24.7" - "@babel/plugin-transform-class-static-block" "^7.24.7" - "@babel/plugin-transform-classes" "^7.24.7" - "@babel/plugin-transform-computed-properties" "^7.24.7" - "@babel/plugin-transform-destructuring" "^7.24.7" - "@babel/plugin-transform-dotall-regex" "^7.24.7" - "@babel/plugin-transform-duplicate-keys" "^7.24.7" - "@babel/plugin-transform-dynamic-import" "^7.24.7" - "@babel/plugin-transform-exponentiation-operator" "^7.24.7" - "@babel/plugin-transform-export-namespace-from" "^7.24.7" - "@babel/plugin-transform-for-of" "^7.24.7" - "@babel/plugin-transform-function-name" "^7.24.7" - "@babel/plugin-transform-json-strings" "^7.24.7" - "@babel/plugin-transform-literals" "^7.24.7" - "@babel/plugin-transform-logical-assignment-operators" "^7.24.7" - "@babel/plugin-transform-member-expression-literals" "^7.24.7" - "@babel/plugin-transform-modules-amd" "^7.24.7" - "@babel/plugin-transform-modules-commonjs" "^7.24.7" - "@babel/plugin-transform-modules-systemjs" "^7.24.7" - "@babel/plugin-transform-modules-umd" "^7.24.7" - "@babel/plugin-transform-named-capturing-groups-regex" "^7.24.7" - "@babel/plugin-transform-new-target" "^7.24.7" - "@babel/plugin-transform-nullish-coalescing-operator" "^7.24.7" - "@babel/plugin-transform-numeric-separator" "^7.24.7" - "@babel/plugin-transform-object-rest-spread" "^7.24.7" - "@babel/plugin-transform-object-super" "^7.24.7" - "@babel/plugin-transform-optional-catch-binding" "^7.24.7" - "@babel/plugin-transform-optional-chaining" "^7.24.7" - "@babel/plugin-transform-parameters" "^7.24.7" - "@babel/plugin-transform-private-methods" "^7.24.7" - "@babel/plugin-transform-private-property-in-object" "^7.24.7" - "@babel/plugin-transform-property-literals" "^7.24.7" - "@babel/plugin-transform-regenerator" "^7.24.7" - "@babel/plugin-transform-reserved-words" "^7.24.7" - "@babel/plugin-transform-shorthand-properties" "^7.24.7" - "@babel/plugin-transform-spread" "^7.24.7" - "@babel/plugin-transform-sticky-regex" "^7.24.7" - "@babel/plugin-transform-template-literals" "^7.24.7" - "@babel/plugin-transform-typeof-symbol" "^7.24.7" - "@babel/plugin-transform-unicode-escapes" "^7.24.7" - "@babel/plugin-transform-unicode-property-regex" "^7.24.7" - "@babel/plugin-transform-unicode-regex" "^7.24.7" - "@babel/plugin-transform-unicode-sets-regex" "^7.24.7" - "@babel/preset-modules" "0.1.6-no-external-plugins" - babel-plugin-polyfill-corejs2 "^0.4.10" - babel-plugin-polyfill-corejs3 "^0.10.4" - babel-plugin-polyfill-regenerator "^0.6.1" - core-js-compat "^3.31.0" - semver "^6.3.1" - -"@babel/preset-flow@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/preset-flow/-/preset-flow-7.24.7.tgz#eef5cb8e05e97a448fc50c16826f5612fe512c06" - integrity sha512-NL3Lo0NorCU607zU3NwRyJbpaB6E3t0xtd3LfAQKDfkeX4/ggcDXvkmkW42QWT5owUeW/jAe4hn+2qvkV1IbfQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-validator-option" "^7.24.7" - "@babel/plugin-transform-flow-strip-types" "^7.24.7" - -"@babel/preset-modules@0.1.6-no-external-plugins": - version "0.1.6-no-external-plugins" - resolved "https://registry.yarnpkg.com/@babel/preset-modules/-/preset-modules-0.1.6-no-external-plugins.tgz#ccb88a2c49c817236861fee7826080573b8a923a" - integrity sha512-HrcgcIESLm9aIR842yhJ5RWan/gebQUJ6E/E5+rf0y9o6oj7w0Br+sWuL6kEQ/o/AdfvR1Je9jG18/gnpwjEyA== - dependencies: - "@babel/helper-plugin-utils" "^7.0.0" - "@babel/types" "^7.4.4" - esutils "^2.0.2" - -"@babel/preset-react@^7.16.0": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/preset-react/-/preset-react-7.23.3.tgz#f73ca07e7590f977db07eb54dbe46538cc015709" - integrity sha512-tbkHOS9axH6Ysf2OUEqoSZ6T3Fa2SrNH6WTWSPBboxKzdxNc9qOICeLXkNG0ZEwbQ1HY8liwOce4aN/Ceyuq6w== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-validator-option" "^7.22.15" - "@babel/plugin-transform-react-display-name" "^7.23.3" - "@babel/plugin-transform-react-jsx" "^7.22.15" - "@babel/plugin-transform-react-jsx-development" "^7.22.5" - "@babel/plugin-transform-react-pure-annotations" "^7.23.3" - -"@babel/preset-react@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/preset-react/-/preset-react-7.24.7.tgz#480aeb389b2a798880bf1f889199e3641cbb22dc" - integrity sha512-AAH4lEkpmzFWrGVlHaxJB7RLH21uPQ9+He+eFLWHmF9IuFQVugz8eAsamaW0DXRrTfco5zj1wWtpdcXJUOfsag== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-validator-option" "^7.24.7" - "@babel/plugin-transform-react-display-name" "^7.24.7" - "@babel/plugin-transform-react-jsx" "^7.24.7" - "@babel/plugin-transform-react-jsx-development" "^7.24.7" - "@babel/plugin-transform-react-pure-annotations" "^7.24.7" - -"@babel/preset-typescript@^7.16.0": - version "7.23.3" - resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.23.3.tgz#14534b34ed5b6d435aa05f1ae1c5e7adcc01d913" - integrity sha512-17oIGVlqz6CchO9RFYn5U6ZpWRZIngayYCtrPRSgANSwC2V1Jb+iP74nVxzzXJte8b8BYxrL1yY96xfhTBrNNQ== - dependencies: - "@babel/helper-plugin-utils" "^7.22.5" - "@babel/helper-validator-option" "^7.22.15" - "@babel/plugin-syntax-jsx" "^7.23.3" - "@babel/plugin-transform-modules-commonjs" "^7.23.3" - "@babel/plugin-transform-typescript" "^7.23.3" - -"@babel/preset-typescript@^7.23.3": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.24.1.tgz#89bdf13a3149a17b3b2a2c9c62547f06db8845ec" - integrity sha512-1DBaMmRDpuYQBPWD8Pf/WEwCrtgRHxsZnP4mIy9G/X+hFfbI47Q2G4t1Paakld84+qsk2fSsUPMKg71jkoOOaQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.0" - "@babel/helper-validator-option" "^7.23.5" - "@babel/plugin-syntax-jsx" "^7.24.1" - "@babel/plugin-transform-modules-commonjs" "^7.24.1" - "@babel/plugin-transform-typescript" "^7.24.1" - -"@babel/preset-typescript@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.24.7.tgz#66cd86ea8f8c014855671d5ea9a737139cbbfef1" - integrity sha512-SyXRe3OdWwIwalxDg5UtJnJQO+YPcTfwiIY2B0Xlddh9o7jpWLvv8X1RthIeDOxQ+O1ML5BLPCONToObyVQVuQ== - dependencies: - "@babel/helper-plugin-utils" "^7.24.7" - "@babel/helper-validator-option" "^7.24.7" - "@babel/plugin-syntax-jsx" "^7.24.7" - "@babel/plugin-transform-modules-commonjs" "^7.24.7" - "@babel/plugin-transform-typescript" "^7.24.7" - -"@babel/register@^7.24.6": - version "7.24.6" - resolved "https://registry.yarnpkg.com/@babel/register/-/register-7.24.6.tgz#59e21dcc79e1d04eed5377633b0f88029a6bef9e" - integrity sha512-WSuFCc2wCqMeXkz/i3yfAAsxwWflEgbVkZzivgAmXl/MxrXeoYFZOOPllbC8R8WTF7u61wSRQtDVZ1879cdu6w== - dependencies: - clone-deep "^4.0.1" - find-cache-dir "^2.0.0" - make-dir "^2.1.0" - pirates "^4.0.6" - source-map-support "^0.5.16" - -"@babel/regjsgen@^0.8.0": - version "0.8.0" - resolved "https://registry.yarnpkg.com/@babel/regjsgen/-/regjsgen-0.8.0.tgz#f0ba69b075e1f05fb2825b7fad991e7adbb18310" - integrity sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA== - -"@babel/runtime-corejs3@^7.10.2": - version "7.15.3" - resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.15.3.tgz#28754263988198f2a928c09733ade2fb4d28089d" - integrity sha512-30A3lP+sRL6ml8uhoJSs+8jwpKzbw8CqBvDc1laeptxPm5FahumJxirigcbD2qTs71Sonvj1cyZB0OKGAmxQ+A== - dependencies: - core-js-pure "^3.16.0" - regenerator-runtime "^0.13.4" - -"@babel/runtime@^7.10.2", "@babel/runtime@^7.12.5", "@babel/runtime@^7.8.4", "@babel/runtime@^7.9.2": - version "7.15.3" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.15.3.tgz#2e1c2880ca118e5b2f9988322bd8a7656a32502b" - integrity sha512-OvwMLqNXkCXSz1kSm58sEsNuhqOx/fKpnUnKnFB5v8uDda5bLNEHNgKPvhDN6IU0LDcnHQ90LlJ0Q6jnyBSIBA== - dependencies: - regenerator-runtime "^0.13.4" - -"@babel/runtime@^7.15.4": - version "7.16.3" - resolved "https://registry.npmmirror.com/@babel/runtime/download/@babel/runtime-7.16.3.tgz?cache=0&sync_timestamp=1636494819594&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2F%40babel%2Fruntime%2Fdownload%2F%40babel%2Fruntime-7.16.3.tgz#b86f0db02a04187a3c17caa77de69840165d42d5" - integrity sha512-WBwekcqacdY2e9AF/Q7WLFUWmdJGJTkbjqTjoMDgXkVZ3ZRUvOPsLb5KdwISoQVsbP+DQzVZW4Zhci0DvpbNTQ== - dependencies: - regenerator-runtime "^0.13.4" - -"@babel/runtime@^7.16.3", "@babel/runtime@^7.23.2": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.23.6.tgz#c05e610dc228855dc92ef1b53d07389ed8ab521d" - integrity sha512-zHd0eUrf5GZoOWVCXp6koAKQTfZV07eit6bGPmJgnZdnSAvvZee6zniW2XMF7Cmc4ISOOnPy3QaSiIJGJkVEDQ== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/runtime@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.24.7.tgz#f4f0d5530e8dbdf59b3451b9b3e594b6ba082e12" - integrity sha512-UwgBRMjJP+xv857DCngvqXI3Iq6J4v0wXmwc6sapg+zyhbwmQX67LUEFrkK5tbyJ30jGuG3ZvWpBiB9LCy1kWw== - dependencies: - regenerator-runtime "^0.14.0" - -"@babel/template@^7.22.15": - version "7.22.15" - resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.22.15.tgz#09576efc3830f0430f4548ef971dde1350ef2f38" - integrity sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w== - dependencies: - "@babel/code-frame" "^7.22.13" - "@babel/parser" "^7.22.15" - "@babel/types" "^7.22.15" - -"@babel/template@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.24.7.tgz#02efcee317d0609d2c07117cb70ef8fb17ab7315" - integrity sha512-jYqfPrU9JTF0PmPy1tLYHW4Mp4KlgxJD9l2nP9fD6yT/ICi554DmrWBAEYpIelzjHf1msDP3PxJIRt/nFNfBig== - dependencies: - "@babel/code-frame" "^7.24.7" - "@babel/parser" "^7.24.7" - "@babel/types" "^7.24.7" - -"@babel/traverse@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.23.6.tgz#b53526a2367a0dd6edc423637f3d2d0f2521abc5" - integrity sha512-czastdK1e8YByZqezMPFiZ8ahwVMh/ESl9vPgvgdB9AmFMGP5jfpFax74AQgl5zj4XHzqeYAg2l8PuUeRS1MgQ== - dependencies: - "@babel/code-frame" "^7.23.5" - "@babel/generator" "^7.23.6" - "@babel/helper-environment-visitor" "^7.22.20" - "@babel/helper-function-name" "^7.23.0" - "@babel/helper-hoist-variables" "^7.22.5" - "@babel/helper-split-export-declaration" "^7.22.6" - "@babel/parser" "^7.23.6" - "@babel/types" "^7.23.6" - debug "^4.3.1" - globals "^11.1.0" - -"@babel/traverse@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.24.7.tgz#de2b900163fa741721ba382163fe46a936c40cf5" - integrity sha512-yb65Ed5S/QAcewNPh0nZczy9JdYXkkAbIsEo+P7BE7yO3txAY30Y/oPa3QkQ5It3xVG2kpKMg9MsdxZaO31uKA== - dependencies: - "@babel/code-frame" "^7.24.7" - "@babel/generator" "^7.24.7" - "@babel/helper-environment-visitor" "^7.24.7" - "@babel/helper-function-name" "^7.24.7" - "@babel/helper-hoist-variables" "^7.24.7" - "@babel/helper-split-export-declaration" "^7.24.7" - "@babel/parser" "^7.24.7" - "@babel/types" "^7.24.7" + "@humanwhocodes/object-schema" "^2.0.2" debug "^4.3.1" - globals "^11.1.0" - -"@babel/types@^7.22.15", "@babel/types@^7.22.19", "@babel/types@^7.22.5", "@babel/types@^7.23.0", "@babel/types@^7.23.4", "@babel/types@^7.23.6": - version "7.23.6" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.23.6.tgz#be33fdb151e1f5a56877d704492c240fc71c7ccd" - integrity sha512-+uarb83brBzPKN38NX1MkB6vb6+mwvR6amUulqAE7ccQw1pEl+bCia9TbdG1lsnFP7lZySvUn37CHyXQdfTwzg== - dependencies: - "@babel/helper-string-parser" "^7.23.4" - "@babel/helper-validator-identifier" "^7.22.20" - to-fast-properties "^2.0.0" - -"@babel/types@^7.24.5": - version "7.24.5" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.24.5.tgz#7661930afc638a5383eb0c4aee59b74f38db84d7" - integrity sha512-6mQNsaLeXTw0nxYUYu+NSa4Hx4BlF1x1x8/PMFbiR+GBSr+2DkECc69b8hgy2frEodNcvPffeH8YfWd3LI6jhQ== - dependencies: - "@babel/helper-string-parser" "^7.24.1" - "@babel/helper-validator-identifier" "^7.24.5" - to-fast-properties "^2.0.0" - -"@babel/types@^7.24.7": - version "7.24.7" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.24.7.tgz#6027fe12bc1aa724cd32ab113fb7f1988f1f66f2" - integrity sha512-XEFXSlxiG5td2EJRe8vOmRbaXVgfcBlszKujvVmWIK/UpywWljQCfzAv3RQCGujWQ1RD4YYWEAqDXfuJiy8f5Q== - dependencies: - "@babel/helper-string-parser" "^7.24.7" - "@babel/helper-validator-identifier" "^7.24.7" - to-fast-properties "^2.0.0" - -"@babel/types@^7.4.4": - version "7.15.0" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.15.0.tgz#61af11f2286c4e9c69ca8deb5f4375a73c72dcbd" - integrity sha512-OBvfqnllOIdX4ojTHpwZbpvz4j3EWyjkZEdmjH0/cgsd6QOdSgU8rLSk6ard/pcW7rlmjdVSX/AWOaORR1uNOQ== - dependencies: - "@babel/helper-validator-identifier" "^7.14.9" - to-fast-properties "^2.0.0" - -"@bundled-es-modules/cookie@^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@bundled-es-modules/cookie/-/cookie-2.0.0.tgz#c3b82703969a61cf6a46e959a012b2c257f6b164" - integrity sha512-Or6YHg/kamKHpxULAdSqhGqnWFneIXu1NKvvfBBzKGwpVsYuFIQ5aBPHDnnoR3ghW1nvSkALd+EF9iMtY7Vjxw== - dependencies: - cookie "^0.5.0" + minimatch "^3.0.5" -"@bundled-es-modules/statuses@^1.0.1": +"@humanwhocodes/module-importer@^1.0.1": version "1.0.1" - resolved "https://registry.yarnpkg.com/@bundled-es-modules/statuses/-/statuses-1.0.1.tgz#761d10f44e51a94902c4da48675b71a76cc98872" - integrity sha512-yn7BklA5acgcBr+7w064fGV+SGIFySjCKpqjcWgBAIfrAkY+4GQTJJHQMeT3V/sgz23VTEVV8TtOmkvJAhFVfg== - dependencies: - statuses "^2.0.1" - -"@discoveryjs/json-ext@^0.5.0": - version "0.5.7" - resolved "https://registry.yarnpkg.com/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz#1d572bfbbe14b7704e0ba0f39b74815b84870d70" - integrity sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw== - -"@emurgo/cardano-serialization-lib-browser@^11.5.0": - version "11.5.0" - resolved "https://registry.yarnpkg.com/@emurgo/cardano-serialization-lib-browser/-/cardano-serialization-lib-browser-11.5.0.tgz#f2d15b538add436e0aa8b67a1d00ca654a680006" - integrity sha512-qchOJ9NYDUz10tzs5r5QhP9hK0p+ZOlRiBwPdTAxqAYLw/8emYBkQQLaS8T1DF6EkeudyrgS00ym5Trw1fo4iA== - -"@emurgo/cardano-serialization-lib-nodejs@11.5.0": - version "11.5.0" - resolved "https://registry.yarnpkg.com/@emurgo/cardano-serialization-lib-nodejs/-/cardano-serialization-lib-nodejs-11.5.0.tgz#0662e2a17d7d1e944f8cdb86396133c8edaec059" - integrity sha512-IlVABlRgo9XaTR1NunwZpWcxnfEv04ba2l1vkUz4S1W7Jt36F4CtffP+jPeqBZGnAe+fnUwo0XjIJC3ZTNToNQ== - -"@es-joy/jsdoccomment@~0.41.0": - version "0.41.0" - resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.41.0.tgz#4a2f7db42209c0425c71a1476ef1bdb6dcd836f6" - integrity sha512-aKUhyn1QI5Ksbqcr3fFJj16p99QdjUxXAEuFst1Z47DRyoiMwivIH9MV/ARcJOCXVjPfjITciej8ZD2O/6qUmw== - dependencies: - comment-parser "1.4.1" - esquery "^1.5.0" - jsdoc-type-pratt-parser "~4.0.0" - -"@eslint-community/eslint-utils@^4.2.0": - version "4.4.0" - resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" - integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== - dependencies: - eslint-visitor-keys "^3.3.0" - -"@eslint-community/regexpp@^4.4.0": - version "4.10.0" - resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.0.tgz#548f6de556857c8bb73bbee70c35dc82a2e74d63" - integrity sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA== - -"@eslint/eslintrc@^0.4.3": - version "0.4.3" - resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c" - integrity sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw== - dependencies: - ajv "^6.12.4" - debug "^4.1.1" - espree "^7.3.0" - globals "^13.9.0" - ignore "^4.0.6" - import-fresh "^3.2.1" - js-yaml "^3.13.1" - minimatch "^3.0.4" - strip-json-comments "^3.1.1" - -"@ethereumjs/common@^4.2.0", "@ethereumjs/common@^4.3.0": - version "4.3.0" - resolved "https://registry.yarnpkg.com/@ethereumjs/common/-/common-4.3.0.tgz#5b45eec7dcf521fa4ddaf0b383072fbcf9913553" - integrity sha512-shBNJ0ewcPNTUfZduHiczPmqkfJDn0Dh/9BR5fq7xUFTuIq7Fu1Vx00XDwQVIrpVL70oycZocOhBM6nDO+4FEQ== - dependencies: - "@ethereumjs/util" "^9.0.3" - -"@ethereumjs/rlp@^5.0.2": - version "5.0.2" - resolved "https://registry.yarnpkg.com/@ethereumjs/rlp/-/rlp-5.0.2.tgz#c89bd82f2f3bec248ab2d517ae25f5bbc4aac842" - integrity sha512-DziebCdg4JpGlEqEdGgXmjqcFoJi+JGulUXwEjsZGAscAQ7MyD/7LE/GVCP29vEQxKc7AAwjT3A2ywHp2xfoCA== - -"@ethereumjs/tx@^5.2.1": - version "5.3.0" - resolved "https://registry.yarnpkg.com/@ethereumjs/tx/-/tx-5.3.0.tgz#473f351729ef4e30eaa3a3fb5aaccd4405a7ee41" - integrity sha512-uv++XYuIfuqYbvymL3/o14hHuC6zX0nRQ1nI2FHsbkkorLZ2ChEIDqVeeVk7Xc9/jQNU/22sk9qZZkRlsveXxw== - dependencies: - "@ethereumjs/common" "^4.3.0" - "@ethereumjs/rlp" "^5.0.2" - "@ethereumjs/util" "^9.0.3" - ethereum-cryptography "^2.1.3" - -"@ethereumjs/util@^9.0.3": - version "9.0.3" - resolved "https://registry.yarnpkg.com/@ethereumjs/util/-/util-9.0.3.tgz#c2709e6127a85bbe23a71937ac78358ac93e7241" - integrity sha512-PmwzWDflky+7jlZIFqiGsBPap12tk9zK5SVH9YW2OEnDN7OEhCjUOMzbOqwuClrbkSIkM2ERivd7sXZ48Rh/vg== - dependencies: - "@ethereumjs/rlp" "^5.0.2" - ethereum-cryptography "^2.1.3" - -"@fivebinaries/coin-selection@2.2.1": - version "2.2.1" - resolved "https://registry.yarnpkg.com/@fivebinaries/coin-selection/-/coin-selection-2.2.1.tgz#f5329909ac8cd1bf87decdcd054c88a8d69399a0" - integrity sha512-iYFsYr7RY7TEvTqP9NKR4p/yf3Iybf9abUDR7lRjzanGsrLwVsREvIuyE05iRYFrvqarlk+gWRPsdR1N2hUBrg== - dependencies: - "@emurgo/cardano-serialization-lib-browser" "^11.5.0" - "@emurgo/cardano-serialization-lib-nodejs" "11.5.0" - -"@gar/promisify@^1.0.1", "@gar/promisify@^1.1.3": - version "1.1.3" - resolved "https://registry.yarnpkg.com/@gar/promisify/-/promisify-1.1.3.tgz#555193ab2e3bb3b6adc3d551c9c030d9e860daf6" - integrity sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw== - -"@humanwhocodes/config-array@^0.5.0": - version "0.5.0" - resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.5.0.tgz#1407967d4c6eecd7388f83acf1eaf4d0c6e58ef9" - integrity sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg== - dependencies: - "@humanwhocodes/object-schema" "^1.2.0" - debug "^4.1.1" - minimatch "^3.0.4" - -"@humanwhocodes/object-schema@^1.2.0": - version "1.2.0" - resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.0.tgz#87de7af9c231826fdd68ac7258f77c429e0e5fcf" - integrity sha512-wdppn25U8z/2yiaT6YGquE6X8sSv7hNMWSXYSSU1jGv/yd6XqjXgTDJ8KP4NgjTXfJ3GbRjeeb8RTV7a/VpM+w== - -"@inquirer/confirm@^3.0.0": - version "3.1.9" - resolved "https://registry.yarnpkg.com/@inquirer/confirm/-/confirm-3.1.9.tgz#1bc384bc8267827ec75d0684e189692bb4dda38b" - integrity sha512-UF09aejxCi4Xqm6N/jJAiFXArXfi9al52AFaSD+2uIHnhZGtd1d6lIGTRMPouVSJxbGEi+HkOWSYaiEY/+szUw== - dependencies: - "@inquirer/core" "^8.2.2" - "@inquirer/type" "^1.3.3" - -"@inquirer/core@^8.2.2": - version "8.2.2" - resolved "https://registry.yarnpkg.com/@inquirer/core/-/core-8.2.2.tgz#797b1e71b920c9788b9d26d89c8b334149852d52" - integrity sha512-K8SuNX45jEFlX3EBJpu9B+S2TISzMPGXZIuJ9ME924SqbdW6Pt6fIkKvXg7mOEOKJ4WxpQsxj0UTfcL/A434Ww== - dependencies: - "@inquirer/figures" "^1.0.3" - "@inquirer/type" "^1.3.3" - "@types/mute-stream" "^0.0.4" - "@types/node" "^20.12.13" - "@types/wrap-ansi" "^3.0.0" - ansi-escapes "^4.3.2" - chalk "^4.1.2" - cli-spinners "^2.9.2" - cli-width "^4.1.0" - mute-stream "^1.0.0" - signal-exit "^4.1.0" - strip-ansi "^6.0.1" - wrap-ansi "^6.2.0" - -"@inquirer/figures@^1.0.3": - version "1.0.3" - resolved "https://registry.yarnpkg.com/@inquirer/figures/-/figures-1.0.3.tgz#1227cc980f88e6d6ab85abadbf164f5038041edd" - integrity sha512-ErXXzENMH5pJt5/ssXV0DfWUZqly8nGzf0UcBV9xTnP+KyffE2mqyxIMBrZ8ijQck2nU0TQm40EQB53YreyWHw== - -"@inquirer/type@^1.3.3": - version "1.3.3" - resolved "https://registry.yarnpkg.com/@inquirer/type/-/type-1.3.3.tgz#26b2628630fd2381c7fa1e3ab396feb9bbc575da" - integrity sha512-xTUt0NulylX27/zMx04ZYar/kr1raaiFTVvQ5feljQsiAgdm0WPj4S73/ye0fbslh+15QrIuDvfCXTek7pMY5A== - -"@jest/schemas@^29.6.3": - version "29.6.3" - resolved "https://registry.yarnpkg.com/@jest/schemas/-/schemas-29.6.3.tgz#430b5ce8a4e0044a7e3819663305a7b3091c8e03" - integrity sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA== - dependencies: - "@sinclair/typebox" "^0.27.8" + resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" + integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== -"@jest/types@^27.0.6": - version "27.0.6" - resolved "https://registry.yarnpkg.com/@jest/types/-/types-27.0.6.tgz#9a992bc517e0c49f035938b8549719c2de40706b" - integrity sha512-aSquT1qa9Pik26JK5/3rvnYb4bGtm1VFNesHKmNTwmPIgOrixvhL2ghIvFRNEpzy3gU+rUgjIF/KodbkFAl++g== - dependencies: - "@types/istanbul-lib-coverage" "^2.0.0" - "@types/istanbul-reports" "^3.0.0" - "@types/node" "*" - "@types/yargs" "^16.0.0" - chalk "^4.0.0" - -"@jest/types@^29.6.3": - version "29.6.3" - resolved "https://registry.yarnpkg.com/@jest/types/-/types-29.6.3.tgz#1131f8cf634e7e84c5e77bab12f052af585fba59" - integrity sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw== - dependencies: - "@jest/schemas" "^29.6.3" - "@types/istanbul-lib-coverage" "^2.0.0" - "@types/istanbul-reports" "^3.0.0" - "@types/node" "*" - "@types/yargs" "^17.0.8" - chalk "^4.0.0" +"@humanwhocodes/object-schema@^2.0.2": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz#4a2868d75d6d6963e423bcf90b7fd1be343409d3" + integrity sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA== -"@jridgewell/gen-mapping@^0.3.0", "@jridgewell/gen-mapping@^0.3.2": - version "0.3.3" - resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz#7e02e6eb5df901aaedb08514203b096614024098" - integrity sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ== +"@isaacs/cliui@^8.0.2": + version "8.0.2" + resolved "https://registry.yarnpkg.com/@isaacs/cliui/-/cliui-8.0.2.tgz#b37667b7bc181c168782259bab42474fbf52b550" + integrity sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA== dependencies: - "@jridgewell/set-array" "^1.0.1" - "@jridgewell/sourcemap-codec" "^1.4.10" - "@jridgewell/trace-mapping" "^0.3.9" + string-width "^5.1.2" + string-width-cjs "npm:string-width@^4.2.0" + strip-ansi "^7.0.1" + strip-ansi-cjs "npm:strip-ansi@^6.0.1" + wrap-ansi "^8.1.0" + wrap-ansi-cjs "npm:wrap-ansi@^7.0.0" "@jridgewell/gen-mapping@^0.3.5": version "0.3.5" @@ -2453,42 +418,21 @@ "@jridgewell/trace-mapping" "^0.3.24" "@jridgewell/resolve-uri@^3.1.0": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz#c08679063f279615a3326583ba3a90d1d82cc721" - integrity sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA== - -"@jridgewell/set-array@^1.0.1": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@jridgewell/set-array/-/set-array-1.1.2.tgz#7c6cf998d6d20b914c0a55a91ae928ff25965e72" - integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw== + version "3.1.2" + resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz#7a0ee601f60f99a20c7c7c5ff0c80388c1189bd6" + integrity sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw== "@jridgewell/set-array@^1.2.1": version "1.2.1" resolved "https://registry.yarnpkg.com/@jridgewell/set-array/-/set-array-1.2.1.tgz#558fb6472ed16a4c850b889530e6b36438c49280" integrity sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A== -"@jridgewell/source-map@^0.3.3": - version "0.3.5" - resolved "https://registry.yarnpkg.com/@jridgewell/source-map/-/source-map-0.3.5.tgz#a3bb4d5c6825aab0d281268f47f6ad5853431e91" - integrity sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ== - dependencies: - "@jridgewell/gen-mapping" "^0.3.0" - "@jridgewell/trace-mapping" "^0.3.9" - "@jridgewell/sourcemap-codec@^1.4.10", "@jridgewell/sourcemap-codec@^1.4.14": version "1.4.15" resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32" integrity sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg== -"@jridgewell/trace-mapping@^0.3.17", "@jridgewell/trace-mapping@^0.3.9": - version "0.3.20" - resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.20.tgz#72e45707cf240fa6b081d0366f8265b0cd10197f" - integrity sha512-R8LcPeWZol2zR8mmH3JeKQ6QRCFb7XgUhV9ZlGhHLGyg4wpPiPZNQOOWhFZhxKw8u//yTbNGI42Bx/3paXEQ+Q== - dependencies: - "@jridgewell/resolve-uri" "^3.1.0" - "@jridgewell/sourcemap-codec" "^1.4.14" - -"@jridgewell/trace-mapping@^0.3.20", "@jridgewell/trace-mapping@^0.3.24", "@jridgewell/trace-mapping@^0.3.25": +"@jridgewell/trace-mapping@^0.3.24", "@jridgewell/trace-mapping@^0.3.25": version "0.3.25" resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz#15f190e98895f3fc23276ee14bc76b675c2e50f0" integrity sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ== @@ -2546,69 +490,166 @@ resolved "https://registry.yarnpkg.com/@ledgerhq/logs/-/logs-6.12.0.tgz#ad903528bf3687a44da435d7b2479d724d374f5d" integrity sha512-ExDoj1QV5eC6TEbMdLUMMk9cfvNKhhv5gXol4SmULRVCx/3iyCPhJ74nsb3S0Vb+/f+XujBEj3vQn5+cwS0fNA== -"@leichtgewicht/ip-codec@^2.0.1": - version "2.0.4" - resolved "https://registry.yarnpkg.com/@leichtgewicht/ip-codec/-/ip-codec-2.0.4.tgz#b2ac626d6cb9c8718ab459166d4bb405b8ffa78b" - integrity sha512-Hcv+nVC0kZnQ3tD9GVu5xSMR4VVYOteQIr/hwFPVEvPdlXqgGEuRjiheChHgdM+JyqdgNcmzZOX/tnl0JOiI7A== +"@lit-labs/ssr-dom-shim@^1.0.0", "@lit-labs/ssr-dom-shim@^1.1.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@lit-labs/ssr-dom-shim/-/ssr-dom-shim-1.2.0.tgz#353ce4a76c83fadec272ea5674ede767650762fd" + integrity sha512-yWJKmpGE6lUURKAaIltoPIE/wrbY3TEkqQt+X0m+7fQNnAv0keydnYvbiJFP1PnMhizmIWRWOG5KLhYyc/xl+g== + +"@lit/reactive-element@^1.3.0", "@lit/reactive-element@^1.6.0": + version "1.6.3" + resolved "https://registry.yarnpkg.com/@lit/reactive-element/-/reactive-element-1.6.3.tgz#25b4eece2592132845d303e091bad9b04cdcfe03" + integrity sha512-QuTgnG52Poic7uM1AN5yJ09QMe0O28e10XzSvWDz02TJiiKee4stsiownEIadWm8nYzyDAyT+gKzUoZmiWQtsQ== + dependencies: + "@lit-labs/ssr-dom-shim" "^1.0.0" + +"@lobstrco/signer-extension-api@1.0.0-beta.0": + version "1.0.0-beta.0" + resolved "https://registry.yarnpkg.com/@lobstrco/signer-extension-api/-/signer-extension-api-1.0.0-beta.0.tgz#785b9ba93b879f7d7f61998ae94de409b8d6f8aa" + integrity sha512-16V34W9MyTgunGvgkzv1JmV+k59OjNWCrNOH+KH+6vWamcGDGBnFhvRgGEarEhINYITMGkdqEvaEy7qTD5s5cw== "@mobily/ts-belt@^3.13.1": version "3.13.1" resolved "https://registry.yarnpkg.com/@mobily/ts-belt/-/ts-belt-3.13.1.tgz#8f8ce2a2eca41d88c2ca70c84d0f47d0f7f5cd5f" integrity sha512-K5KqIhPI/EoCTbA6CGbrenM9s41OouyK8A03fGJJcla/zKucsgLbz8HNbeseoLarRPgyWJsUyCYqFhI7t3Ra9Q== -"@mswjs/cookies@^1.1.0": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@mswjs/cookies/-/cookies-1.1.1.tgz#8b519e2bd8f1577c530beed44a25578eb9a6e72c" - integrity sha512-W68qOHEjx1iD+4VjQudlx26CPIoxmIAtK4ZCexU0/UJBG6jYhcuyzKJx+Iw8uhBIGd9eba64XgWVgo20it1qwA== - -"@mswjs/interceptors@^0.29.0": - version "0.29.1" - resolved "https://registry.yarnpkg.com/@mswjs/interceptors/-/interceptors-0.29.1.tgz#e77fc58b5188569041d0440b25c9e9ebb1ccd60a" - integrity sha512-3rDakgJZ77+RiQUuSK69t1F0m8BQKA8Vh5DCS5V0DWvNY67zob2JhhQrhCO0AKLGINTRSFd1tBaHcJTkhefoSw== - dependencies: - "@open-draft/deferred-promise" "^2.2.0" - "@open-draft/logger" "^0.3.0" - "@open-draft/until" "^2.0.0" - is-node-process "^1.2.0" - outvariant "^1.2.1" - strict-event-emitter "^0.5.1" - -"@nicolo-ribaudo/eslint-scope-5-internals@5.1.1-v1": - version "5.1.1-v1" - resolved "https://registry.yarnpkg.com/@nicolo-ribaudo/eslint-scope-5-internals/-/eslint-scope-5-internals-5.1.1-v1.tgz#dbf733a965ca47b1973177dc0bb6c889edcfb129" - integrity sha512-54/JRvkLIzzDWshCWfuhadfrfZVPiElY8Fcgmg1HroEly/EDSszzhBAsarCux+D/kOslTRquNzuyGSmUSTTHGg== - dependencies: - eslint-scope "5.1.1" - -"@noble/curves@1.3.0", "@noble/curves@~1.3.0": - version "1.3.0" - resolved "https://registry.yarnpkg.com/@noble/curves/-/curves-1.3.0.tgz#01be46da4fd195822dab821e72f71bf4aeec635e" - integrity sha512-t01iSXPuN+Eqzb4eBX0S5oubSqXbK/xXa1Ne18Hj8f9pStxztHCE2gfboSp/dZRLSqfuLpRK2nDXDK+W9puocA== - dependencies: - "@noble/hashes" "1.3.3" - -"@noble/curves@^1.4.0": +"@motionone/animation@^10.15.1", "@motionone/animation@^10.18.0": + version "10.18.0" + resolved "https://registry.yarnpkg.com/@motionone/animation/-/animation-10.18.0.tgz#868d00b447191816d5d5cf24b1cafa144017922b" + integrity sha512-9z2p5GFGCm0gBsZbi8rVMOAJCtw1WqBTIPw3ozk06gDvZInBPIsQcHgYogEJ4yuHJ+akuW8g1SEIOpTOvYs8hw== + dependencies: + "@motionone/easing" "^10.18.0" + "@motionone/types" "^10.17.1" + "@motionone/utils" "^10.18.0" + tslib "^2.3.1" + +"@motionone/dom@^10.16.2", "@motionone/dom@^10.16.4": + version "10.18.0" + resolved "https://registry.yarnpkg.com/@motionone/dom/-/dom-10.18.0.tgz#7fd25dac04cab72def6d2b92b8e0cdc091576527" + integrity sha512-bKLP7E0eyO4B2UaHBBN55tnppwRnaE3KFfh3Ps9HhnAkar3Cb69kUCJY9as8LrccVYKgHA+JY5dOQqJLOPhF5A== + dependencies: + "@motionone/animation" "^10.18.0" + "@motionone/generators" "^10.18.0" + "@motionone/types" "^10.17.1" + "@motionone/utils" "^10.18.0" + hey-listen "^1.0.8" + tslib "^2.3.1" + +"@motionone/easing@^10.18.0": + version "10.18.0" + resolved "https://registry.yarnpkg.com/@motionone/easing/-/easing-10.18.0.tgz#7b82f6010dfee3a1bb0ee83abfbaff6edae0c708" + integrity sha512-VcjByo7XpdLS4o9T8t99JtgxkdMcNWD3yHU/n6CLEz3bkmKDRZyYQ/wmSf6daum8ZXqfUAgFeCZSpJZIMxaCzg== + dependencies: + "@motionone/utils" "^10.18.0" + tslib "^2.3.1" + +"@motionone/generators@^10.18.0": + version "10.18.0" + resolved "https://registry.yarnpkg.com/@motionone/generators/-/generators-10.18.0.tgz#fe09ab5cfa0fb9a8884097feb7eb60abeb600762" + integrity sha512-+qfkC2DtkDj4tHPu+AFKVfR/C30O1vYdvsGYaR13W/1cczPrrcjdvYCj0VLFuRMN+lP1xvpNZHCRNM4fBzn1jg== + dependencies: + "@motionone/types" "^10.17.1" + "@motionone/utils" "^10.18.0" + tslib "^2.3.1" + +"@motionone/svelte@^10.16.2": + version "10.16.4" + resolved "https://registry.yarnpkg.com/@motionone/svelte/-/svelte-10.16.4.tgz#5daf117cf5b2576fc6dd487c5e0500938a742470" + integrity sha512-zRVqk20lD1xqe+yEDZhMYgftsuHc25+9JSo+r0a0OWUJFocjSV9D/+UGhX4xgJsuwB9acPzXLr20w40VnY2PQA== + dependencies: + "@motionone/dom" "^10.16.4" + tslib "^2.3.1" + +"@motionone/types@^10.15.1", "@motionone/types@^10.17.1": + version "10.17.1" + resolved "https://registry.yarnpkg.com/@motionone/types/-/types-10.17.1.tgz#cf487badbbdc9da0c2cb86ffc1e5d11147c6e6fb" + integrity sha512-KaC4kgiODDz8hswCrS0btrVrzyU2CSQKO7Ps90ibBVSQmjkrt2teqta6/sOG59v7+dPnKMAg13jyqtMKV2yJ7A== + +"@motionone/utils@^10.15.1", "@motionone/utils@^10.18.0": + version "10.18.0" + resolved "https://registry.yarnpkg.com/@motionone/utils/-/utils-10.18.0.tgz#a59ff8932ed9009624bca07c56b28ef2bb2f885e" + integrity sha512-3XVF7sgyTSI2KWvTf6uLlBJ5iAgRgmvp3bpuOiQJvInd4nZ19ET8lX5unn30SlmRH7hXbBbH+Gxd0m0klJ3Xtw== + dependencies: + "@motionone/types" "^10.17.1" + hey-listen "^1.0.8" + tslib "^2.3.1" + +"@motionone/vue@^10.16.2": + version "10.16.4" + resolved "https://registry.yarnpkg.com/@motionone/vue/-/vue-10.16.4.tgz#07d09e3aa5115ca0bcc0076cb9e5322775277c09" + integrity sha512-z10PF9JV6SbjFq+/rYabM+8CVlMokgl8RFGvieSGNTmrkQanfHn+15XBrhG3BgUfvmTeSeyShfOHpG0i9zEdcg== + dependencies: + "@motionone/dom" "^10.16.4" + tslib "^2.3.1" + +"@next/env@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/env/-/env-14.2.4.tgz#5546813dc4f809884a37d257b254a5ce1b0248d7" + integrity sha512-3EtkY5VDkuV2+lNmKlbkibIJxcO4oIHEhBWne6PaAp+76J9KoSsGvNikp6ivzAT8dhhBMYrm6op2pS1ApG0Hzg== + +"@next/eslint-plugin-next@14.2.4", "@next/eslint-plugin-next@^14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/eslint-plugin-next/-/eslint-plugin-next-14.2.4.tgz#c7f965cb76f0b454e726ef0f69157c4fb4e28f53" + integrity sha512-svSFxW9f3xDaZA3idQmlFw7SusOuWTpDTAeBlO3AEPDltrraV+lqs7mAc6A27YdnpQVVIA3sODqUAAHdWhVWsA== + dependencies: + glob "10.3.10" + +"@next/swc-darwin-arm64@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.2.4.tgz#da9f04c34a3d5f0b8401ed745768420e4a604036" + integrity sha512-AH3mO4JlFUqsYcwFUHb1wAKlebHU/Hv2u2kb1pAuRanDZ7pD/A/KPD98RHZmwsJpdHQwfEc/06mgpSzwrJYnNg== + +"@next/swc-darwin-x64@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-darwin-x64/-/swc-darwin-x64-14.2.4.tgz#46dedb29ec5503bf171a72a3ecb8aac6e738e9d6" + integrity sha512-QVadW73sWIO6E2VroyUjuAxhWLZWEpiFqHdZdoQ/AMpN9YWGuHV8t2rChr0ahy+irKX5mlDU7OY68k3n4tAZTg== + +"@next/swc-linux-arm64-gnu@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.2.4.tgz#c9697ab9eb422bd1d7ffd0eb0779cc2aefa9d4a1" + integrity sha512-KT6GUrb3oyCfcfJ+WliXuJnD6pCpZiosx2X3k66HLR+DMoilRb76LpWPGb4tZprawTtcnyrv75ElD6VncVamUQ== + +"@next/swc-linux-arm64-musl@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.2.4.tgz#cbbceb2008571c743b5a310a488d2e166d200a75" + integrity sha512-Alv8/XGSs/ytwQcbCHwze1HmiIkIVhDHYLjczSVrf0Wi2MvKn/blt7+S6FJitj3yTlMwMxII1gIJ9WepI4aZ/A== + +"@next/swc-linux-x64-gnu@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.2.4.tgz#d79184223f857bacffb92f643cb2943a43632568" + integrity sha512-ze0ShQDBPCqxLImzw4sCdfnB3lRmN3qGMB2GWDRlq5Wqy4G36pxtNOo2usu/Nm9+V2Rh/QQnrRc2l94kYFXO6Q== + +"@next/swc-linux-x64-musl@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.2.4.tgz#6b6c3e5ac02ca5e63394d280ec8ee607491902df" + integrity sha512-8dwC0UJoc6fC7PX70csdaznVMNr16hQrTDAMPvLPloazlcaWfdPogq+UpZX6Drqb1OBlwowz8iG7WR0Tzk/diQ== + +"@next/swc-win32-arm64-msvc@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.2.4.tgz#dbad3906e870dba84c5883d9d4c4838472e0697f" + integrity sha512-jxyg67NbEWkDyvM+O8UDbPAyYRZqGLQDTPwvrBBeOSyVWW/jFQkQKQ70JDqDSYg1ZDdl+E3nkbFbq8xM8E9x8A== + +"@next/swc-win32-ia32-msvc@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.2.4.tgz#6074529b91ba49132922ce89a2e16d25d2ec235d" + integrity sha512-twrmN753hjXRdcrZmZttb/m5xaCBFa48Dt3FbeEItpJArxriYDunWxJn+QFXdJ3hPkm4u7CKxncVvnmgQMY1ag== + +"@next/swc-win32-x64-msvc@14.2.4": + version "14.2.4" + resolved "https://registry.yarnpkg.com/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.4.tgz#e65a1c6539a671f97bb86d5183d6e3a1733c29c7" + integrity sha512-tkLrjBzqFTP8DVrAAQmZelEahfR9OxWpFR++vAI9FBhCiIxtwHwBHC23SBHCTURBtwB4kc/x44imVOnkKGNVGg== + +"@noble/curves@1.4.0", "@noble/curves@^1.4.0", "@noble/curves@~1.4.0": version "1.4.0" resolved "https://registry.yarnpkg.com/@noble/curves/-/curves-1.4.0.tgz#f05771ef64da724997f69ee1261b2417a49522d6" integrity sha512-p+4cb332SFCrReJkCYe8Xzm0OWi4Jji5jVdIZRL/PmacmDkFNw6MrrV+gGpiPxLHbV+zKFRywUWbaseT+tZRXg== dependencies: "@noble/hashes" "1.4.0" -"@noble/hashes@1.3.3", "@noble/hashes@~1.3.2": - version "1.3.3" - resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.3.3.tgz#39908da56a4adc270147bb07968bf3b16cfe1699" - integrity sha512-V7/fPHgl+jsVPXqqeOzT8egNj2iBIVt+ECeMMG8TdcnTikP3oaBtUVqpT/gYCR68aEBJSF+XbYUxStjbFMqIIA== - -"@noble/hashes@1.4.0", "@noble/hashes@^1.4.0": +"@noble/hashes@1.4.0", "@noble/hashes@^1.2.0", "@noble/hashes@^1.4.0", "@noble/hashes@~1.4.0": version "1.4.0" resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.4.0.tgz#45814aa329f30e4fe0ba49426f49dfccdd066426" integrity sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg== -"@noble/hashes@^1.2.0": - version "1.3.2" - resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.3.2.tgz#6f26dbc8fbc7205873ce3cee2f690eba0d421b39" - integrity sha512-MVC8EAQp7MvEcm30KWENFjgR+Mkmf+D189XJTkFIlwohU5hcBbn1ZkKq7KVTi2Hme3PMGF390DaL52beVrIihQ== - "@nodelib/fs.scandir@2.1.5": version "2.1.5" resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" @@ -2622,7 +663,7 @@ resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== -"@nodelib/fs.walk@^1.2.3": +"@nodelib/fs.walk@^1.2.3", "@nodelib/fs.walk@^1.2.8": version "1.2.8" resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== @@ -2630,79 +671,133 @@ "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" -"@npmcli/fs@^1.0.0": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@npmcli/fs/-/fs-1.1.1.tgz#72f719fe935e687c56a4faecf3c03d06ba593257" - integrity sha512-8KG5RD0GVP4ydEzRn/I4BNDuxDtqVbOdm8675T49OIG/NGhaK0pjPX7ZcDlvKYbA+ulvVK3ztfcF4uBdOxuJbQ== - dependencies: - "@gar/promisify" "^1.0.1" - semver "^7.3.5" +"@parcel/watcher-android-arm64@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-android-arm64/-/watcher-android-arm64-2.4.1.tgz#c2c19a3c442313ff007d2d7a9c2c1dd3e1c9ca84" + integrity sha512-LOi/WTbbh3aTn2RYddrO8pnapixAziFl6SMxHM69r3tvdSm94JtCenaKgk1GRg5FJ5wpMCpHeW+7yqPlvZv7kg== -"@npmcli/fs@^2.1.0": - version "2.1.2" - resolved "https://registry.yarnpkg.com/@npmcli/fs/-/fs-2.1.2.tgz#a9e2541a4a2fec2e69c29b35e6060973da79b865" - integrity sha512-yOJKRvohFOaLqipNtwYB9WugyZKhC/DZC4VYPmpaCzDBrA8YpK3qHZ8/HGscMnE4GqbkLNuVcCnxkeQEdGt6LQ== - dependencies: - "@gar/promisify" "^1.1.3" - semver "^7.3.5" +"@parcel/watcher-darwin-arm64@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-darwin-arm64/-/watcher-darwin-arm64-2.4.1.tgz#c817c7a3b4f3a79c1535bfe54a1c2818d9ffdc34" + integrity sha512-ln41eihm5YXIY043vBrrHfn94SIBlqOWmoROhsMVTSXGh0QahKGy77tfEywQ7v3NywyxBBkGIfrWRHm0hsKtzA== -"@npmcli/move-file@^1.0.1": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-1.1.2.tgz#1a82c3e372f7cae9253eb66d72543d6b8685c674" - integrity sha512-1SUf/Cg2GzGDyaf15aR9St9TWlb+XvbZXWpDx8YKs7MLzMH/BCeopv+y9vzrzgkfykCGuWOlSu3mZhj2+FQcrg== - dependencies: - mkdirp "^1.0.4" - rimraf "^3.0.2" +"@parcel/watcher-darwin-x64@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-darwin-x64/-/watcher-darwin-x64-2.4.1.tgz#1a3f69d9323eae4f1c61a5f480a59c478d2cb020" + integrity sha512-yrw81BRLjjtHyDu7J61oPuSoeYWR3lDElcPGJyOvIXmor6DEo7/G2u1o7I38cwlcoBHQFULqF6nesIX3tsEXMg== -"@npmcli/move-file@^2.0.0": - version "2.0.1" - resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-2.0.1.tgz#26f6bdc379d87f75e55739bab89db525b06100e4" - integrity sha512-mJd2Z5TjYWq/ttPLLGqArdtnC74J6bOzg4rMDnN+p1xTacZ2yPRCk2y0oSWQtygLR9YVQXgOcONrwtnk3JupxQ== - dependencies: - mkdirp "^1.0.4" - rimraf "^3.0.2" +"@parcel/watcher-freebsd-x64@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-freebsd-x64/-/watcher-freebsd-x64-2.4.1.tgz#0d67fef1609f90ba6a8a662bc76a55fc93706fc8" + integrity sha512-TJa3Pex/gX3CWIx/Co8k+ykNdDCLx+TuZj3f3h7eOjgpdKM+Mnix37RYsYU4LHhiYJz3DK5nFCCra81p6g050w== -"@open-draft/deferred-promise@^2.2.0": - version "2.2.0" - resolved "https://registry.yarnpkg.com/@open-draft/deferred-promise/-/deferred-promise-2.2.0.tgz#4a822d10f6f0e316be4d67b4d4f8c9a124b073bd" - integrity sha512-CecwLWx3rhxVQF6V4bAgPS5t+So2sTbPgAzafKkVizyi7tlwpcFpdFqq+wqF2OwNBmqFuu6tOyouTuxgpMfzmA== +"@parcel/watcher-linux-arm-glibc@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm-glibc/-/watcher-linux-arm-glibc-2.4.1.tgz#ce5b340da5829b8e546bd00f752ae5292e1c702d" + integrity sha512-4rVYDlsMEYfa537BRXxJ5UF4ddNwnr2/1O4MHM5PjI9cvV2qymvhwZSFgXqbS8YoTk5i/JR0L0JDs69BUn45YA== + +"@parcel/watcher-linux-arm64-glibc@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm64-glibc/-/watcher-linux-arm64-glibc-2.4.1.tgz#6d7c00dde6d40608f9554e73998db11b2b1ff7c7" + integrity sha512-BJ7mH985OADVLpbrzCLgrJ3TOpiZggE9FMblfO65PlOCdG++xJpKUJ0Aol74ZUIYfb8WsRlUdgrZxKkz3zXWYA== + +"@parcel/watcher-linux-arm64-musl@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-arm64-musl/-/watcher-linux-arm64-musl-2.4.1.tgz#bd39bc71015f08a4a31a47cd89c236b9d6a7f635" + integrity sha512-p4Xb7JGq3MLgAfYhslU2SjoV9G0kI0Xry0kuxeG/41UfpjHGOhv7UoUDAz/jb1u2elbhazy4rRBL8PegPJFBhA== + +"@parcel/watcher-linux-x64-glibc@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-x64-glibc/-/watcher-linux-x64-glibc-2.4.1.tgz#0ce29966b082fb6cdd3de44f2f74057eef2c9e39" + integrity sha512-s9O3fByZ/2pyYDPoLM6zt92yu6P4E39a03zvO0qCHOTjxmt3GHRMLuRZEWhWLASTMSrrnVNWdVI/+pUElJBBBg== + +"@parcel/watcher-linux-x64-musl@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-linux-x64-musl/-/watcher-linux-x64-musl-2.4.1.tgz#d2ebbf60e407170bb647cd6e447f4f2bab19ad16" + integrity sha512-L2nZTYR1myLNST0O632g0Dx9LyMNHrn6TOt76sYxWLdff3cB22/GZX2UPtJnaqQPdCRoszoY5rcOj4oMTtp5fQ== -"@open-draft/logger@^0.3.0": - version "0.3.0" - resolved "https://registry.yarnpkg.com/@open-draft/logger/-/logger-0.3.0.tgz#2b3ab1242b360aa0adb28b85f5d7da1c133a0954" - integrity sha512-X2g45fzhxH238HKO4xbSr7+wBS8Fvw6ixhTDuvLd5mqh6bJJCFAPwU9mPDxbcrRtfxv4u5IHCEH77BmxvXmmxQ== +"@parcel/watcher-wasm@^2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-wasm/-/watcher-wasm-2.4.1.tgz#c4353e4fdb96ee14389856f7f6f6d21b7dcef9e1" + integrity sha512-/ZR0RxqxU/xxDGzbzosMjh4W6NdYFMqq2nvo2b8SLi7rsl/4jkL8S5stIikorNkdR50oVDvqb/3JT05WM+CRRA== dependencies: - is-node-process "^1.2.0" - outvariant "^1.4.0" + is-glob "^4.0.3" + micromatch "^4.0.5" + napi-wasm "^1.1.0" -"@open-draft/until@^2.0.0", "@open-draft/until@^2.1.0": - version "2.1.0" - resolved "https://registry.yarnpkg.com/@open-draft/until/-/until-2.1.0.tgz#0acf32f470af2ceaf47f095cdecd40d68666efda" - integrity sha512-U69T3ItWHvLwGg5eJ0n3I62nWuE6ilHlmz7zM0npLBRvPRd7e6NYmg54vvRtP5mZG7kZqZCFVdsTWo7BPtBujg== +"@parcel/watcher-win32-arm64@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-win32-arm64/-/watcher-win32-arm64-2.4.1.tgz#eb4deef37e80f0b5e2f215dd6d7a6d40a85f8adc" + integrity sha512-Uq2BPp5GWhrq/lcuItCHoqxjULU1QYEcyjSO5jqqOK8RNFDBQnenMMx4gAl3v8GiWa59E9+uDM7yZ6LxwUIfRg== + +"@parcel/watcher-win32-ia32@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-win32-ia32/-/watcher-win32-ia32-2.4.1.tgz#94fbd4b497be39fd5c8c71ba05436927842c9df7" + integrity sha512-maNRit5QQV2kgHFSYwftmPBxiuK5u4DXjbXx7q6eKjq5dsLXZ4FJiVvlcw35QXzk0KrUecJmuVFbj4uV9oYrcw== + +"@parcel/watcher-win32-x64@2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher-win32-x64/-/watcher-win32-x64-2.4.1.tgz#4bf920912f67cae5f2d264f58df81abfea68dadf" + integrity sha512-+DvS92F9ezicfswqrvIRM2njcYJbd5mb9CUgtrHCHmvn7pPPa+nMDRu1o1bYYz/l5IB2NVGNJWiH7h1E58IF2A== + +"@parcel/watcher@^2.4.1": + version "2.4.1" + resolved "https://registry.yarnpkg.com/@parcel/watcher/-/watcher-2.4.1.tgz#a50275151a1bb110879c6123589dba90c19f1bf8" + integrity sha512-HNjmfLQEVRZmHRET336f20H/8kOozUGwk7yajvsonjNxbj2wBTK1WsQuHkD5yYh9RxFGL2EyDHryOihOwUoKDA== + dependencies: + detect-libc "^1.0.3" + is-glob "^4.0.3" + micromatch "^4.0.5" + node-addon-api "^7.0.0" + optionalDependencies: + "@parcel/watcher-android-arm64" "2.4.1" + "@parcel/watcher-darwin-arm64" "2.4.1" + "@parcel/watcher-darwin-x64" "2.4.1" + "@parcel/watcher-freebsd-x64" "2.4.1" + "@parcel/watcher-linux-arm-glibc" "2.4.1" + "@parcel/watcher-linux-arm64-glibc" "2.4.1" + "@parcel/watcher-linux-arm64-musl" "2.4.1" + "@parcel/watcher-linux-x64-glibc" "2.4.1" + "@parcel/watcher-linux-x64-musl" "2.4.1" + "@parcel/watcher-win32-arm64" "2.4.1" + "@parcel/watcher-win32-ia32" "2.4.1" + "@parcel/watcher-win32-x64" "2.4.1" + +"@pkgjs/parseargs@^0.11.0": + version "0.11.0" + resolved "https://registry.yarnpkg.com/@pkgjs/parseargs/-/parseargs-0.11.0.tgz#a77ea742fab25775145434eb1d2328cf5013ac33" + integrity sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg== + +"@playwright/test@^1.43.1": + version "1.44.1" + resolved "https://registry.yarnpkg.com/@playwright/test/-/test-1.44.1.tgz#cc874ec31342479ad99838040e99b5f604299bcb" + integrity sha512-1hZ4TNvD5z9VuhNJ/walIjvMVvYkZKf71axoF/uiAqpntQJXpG64dlXhoDXE3OczPuTuvjf/M5KWFg5VAVUS3Q== + dependencies: + playwright "1.44.1" "@protobufjs/aspromise@^1.1.1", "@protobufjs/aspromise@^1.1.2": version "1.1.2" - resolved "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz#9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf" + resolved "https://registry.yarnpkg.com/@protobufjs/aspromise/-/aspromise-1.1.2.tgz#9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf" integrity sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ== "@protobufjs/base64@^1.1.2": version "1.1.2" - resolved "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz#4c85730e59b9a1f1f349047dbf24296034bb2735" + resolved "https://registry.yarnpkg.com/@protobufjs/base64/-/base64-1.1.2.tgz#4c85730e59b9a1f1f349047dbf24296034bb2735" integrity sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg== "@protobufjs/codegen@^2.0.4": version "2.0.4" - resolved "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz#7ef37f0d010fb028ad1ad59722e506d9262815cb" + resolved "https://registry.yarnpkg.com/@protobufjs/codegen/-/codegen-2.0.4.tgz#7ef37f0d010fb028ad1ad59722e506d9262815cb" integrity sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg== "@protobufjs/eventemitter@^1.1.0": version "1.1.0" - resolved "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz#355cbc98bafad5978f9ed095f397621f1d066b70" + resolved "https://registry.yarnpkg.com/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz#355cbc98bafad5978f9ed095f397621f1d066b70" integrity sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q== "@protobufjs/fetch@^1.1.0": version "1.1.0" - resolved "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz#ba99fb598614af65700c1619ff06d454b0d84c45" + resolved "https://registry.yarnpkg.com/@protobufjs/fetch/-/fetch-1.1.0.tgz#ba99fb598614af65700c1619ff06d454b0d84c45" integrity sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ== dependencies: "@protobufjs/aspromise" "^1.1.1" @@ -2710,81 +805,61 @@ "@protobufjs/float@^1.0.2": version "1.0.2" - resolved "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz#5e9e1abdcb73fc0a7cb8b291df78c8cbd97b87d1" + resolved "https://registry.yarnpkg.com/@protobufjs/float/-/float-1.0.2.tgz#5e9e1abdcb73fc0a7cb8b291df78c8cbd97b87d1" integrity sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ== "@protobufjs/inquire@^1.1.0": version "1.1.0" - resolved "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz#ff200e3e7cf2429e2dcafc1140828e8cc638f089" + resolved "https://registry.yarnpkg.com/@protobufjs/inquire/-/inquire-1.1.0.tgz#ff200e3e7cf2429e2dcafc1140828e8cc638f089" integrity sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q== "@protobufjs/path@^1.1.2": version "1.1.2" - resolved "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz#6cc2b20c5c9ad6ad0dccfd21ca7673d8d7fbf68d" + resolved "https://registry.yarnpkg.com/@protobufjs/path/-/path-1.1.2.tgz#6cc2b20c5c9ad6ad0dccfd21ca7673d8d7fbf68d" integrity sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA== "@protobufjs/pool@^1.1.0": version "1.1.0" - resolved "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz#09fd15f2d6d3abfa9b65bc366506d6ad7846ff54" + resolved "https://registry.yarnpkg.com/@protobufjs/pool/-/pool-1.1.0.tgz#09fd15f2d6d3abfa9b65bc366506d6ad7846ff54" integrity sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw== "@protobufjs/utf8@^1.1.0": version "1.1.0" - resolved "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz#a777360b5b39a1a2e5106f8e858f2fd2d060c570" + resolved "https://registry.yarnpkg.com/@protobufjs/utf8/-/utf8-1.1.0.tgz#a777360b5b39a1a2e5106f8e858f2fd2d060c570" integrity sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw== -"@reduxjs/toolkit@^1.7.2": - version "1.7.2" - resolved "https://registry.yarnpkg.com/@reduxjs/toolkit/-/toolkit-1.7.2.tgz#b428aaef92582379464f9de698dbb71957eafb02" - integrity sha512-wwr3//Ar8ZhM9bS58O+HCIaMlR4Y6SNHfuszz9hKnQuFIKvwaL3Kmjo6fpDKUOjo4Lv54Yi299ed8rofCJ/Vjw== - dependencies: - immer "^9.0.7" - redux "^4.1.2" - redux-thunk "^2.4.1" - reselect "^4.1.5" - -"@rushstack/eslint-patch@^1.1.0": - version "1.6.0" - resolved "https://registry.yarnpkg.com/@rushstack/eslint-patch/-/eslint-patch-1.6.0.tgz#1898e7a7b943680d757417a47fb10f5fcc230b39" - integrity sha512-2/U3GXA6YiPYQDLGwtGlnNgKYBSwCFIHf8Y9LUY5VATHdtbLlU0Y1R3QoBnT0aB4qv/BEiVVsj7LJXoQCgJ2vA== +"@rushstack/eslint-patch@^1.3.3": + version "1.10.3" + resolved "https://registry.yarnpkg.com/@rushstack/eslint-patch/-/eslint-patch-1.10.3.tgz#391d528054f758f81e53210f1a1eebcf1a8b1d20" + integrity sha512-qC/xYId4NMebE6w/V33Fh9gWxLgURiNYgVNObbJl2LZv0GUUItCcCqC5axQSwRaAgaxl2mELq1rMzlswaQ0Zxg== -"@scure/base@~1.1.4": +"@scure/base@~1.1.6": version "1.1.6" resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.6.tgz#8ce5d304b436e4c84f896e0550c83e4d88cb917d" integrity sha512-ok9AWwhcgYuGG3Zfhyqg+zwl+Wn5uE+dwC0NV/2qQkx4dABbb/bx96vWu8NSj+BNjjSjno+JRYRjle1jV08k3g== -"@scure/bip32@1.3.3": - version "1.3.3" - resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.3.3.tgz#a9624991dc8767087c57999a5d79488f48eae6c8" - integrity sha512-LJaN3HwRbfQK0X1xFSi0Q9amqOgzQnnDngIt+ZlsBC3Bm7/nE7K0kwshZHyaru79yIVRv/e1mQAjZyuZG6jOFQ== +"@scure/bip32@1.4.0": + version "1.4.0" + resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.4.0.tgz#4e1f1e196abedcef395b33b9674a042524e20d67" + integrity sha512-sVUpc0Vq3tXCkDGYVWGIZTRfnvu8LoTDaev7vbwh0omSvVORONr960MQWdKqJDCReIEmTj3PAr73O3aoxz7OPg== dependencies: - "@noble/curves" "~1.3.0" - "@noble/hashes" "~1.3.2" - "@scure/base" "~1.1.4" + "@noble/curves" "~1.4.0" + "@noble/hashes" "~1.4.0" + "@scure/base" "~1.1.6" -"@scure/bip39@1.2.2": - version "1.2.2" - resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.2.2.tgz#f3426813f4ced11a47489cbcf7294aa963966527" - integrity sha512-HYf9TUXG80beW+hGAt3TRM8wU6pQoYur9iNypTROm42dorCGmLnFe3eWjz3gOq6G62H2WRh0FCzAR1PI+29zIA== +"@scure/bip39@1.3.0": + version "1.3.0" + resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.3.0.tgz#0f258c16823ddd00739461ac31398b4e7d6a18c3" + integrity sha512-disdg7gHuTDZtY+ZdkmLpPCk7fxZSu3gBiEGuoC1XYxv9cGx3Z6cpTggCgW6odSOOIXCiDjuGejW+aJKCY/pIQ== dependencies: - "@noble/hashes" "~1.3.2" - "@scure/base" "~1.1.4" - -"@sinclair/typebox@^0.27.8": - version "0.27.8" - resolved "https://registry.yarnpkg.com/@sinclair/typebox/-/typebox-0.27.8.tgz#6667fac16c436b5434a387a34dedb013198f6e6e" - integrity sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA== + "@noble/hashes" "~1.4.0" + "@scure/base" "~1.1.6" "@sinclair/typebox@^0.31.28": version "0.31.28" resolved "https://registry.yarnpkg.com/@sinclair/typebox/-/typebox-0.31.28.tgz#b68831e7bc7d09daac26968ea32f42bedc968ede" integrity sha512-/s55Jujywdw/Jpan+vsy6JZs1z2ZTGxTmbZTPiuSL2wz9mfzA2gN1zzaqmvfi4pq+uOt7Du85fkiwv5ymW84aQ== -"@socket.io/component-emitter@~3.1.0": - version "3.1.2" - resolved "https://registry.yarnpkg.com/@socket.io/component-emitter/-/component-emitter-3.1.2.tgz#821f8442f4175d8f0467b9daf26e3a18e2d02af2" - integrity sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA== - "@solana/buffer-layout@^4.0.1": version "4.0.1" resolved "https://registry.yarnpkg.com/@solana/buffer-layout/-/buffer-layout-4.0.1.tgz#b996235eaec15b1e0b5092a8ed6028df77fa6c15" @@ -2793,11 +868,11 @@ buffer "~6.0.3" "@solana/web3.js@^1.90.2", "@solana/web3.js@^1.91.6": - version "1.93.0" - resolved "https://registry.yarnpkg.com/@solana/web3.js/-/web3.js-1.93.0.tgz#4b6975020993cec2f6626e4f2bf559ca042df8db" - integrity sha512-suf4VYwWxERz4tKoPpXCRHFRNst7jmcFUaD65kII+zg9urpy5PeeqgLV6G5eWGzcVzA9tZeXOju1A1Y+0ojEVw== + version "1.92.3" + resolved "https://registry.yarnpkg.com/@solana/web3.js/-/web3.js-1.92.3.tgz#8880b446c0ec30fc552e1d501bd8db2780a1f70c" + integrity sha512-NVBWvb9zdJIAx6X+caXaIICCEQfQaQ8ygykCjJW4u2z/sIKcvPj3ZIIllnx0MWMc3IxGq15ozGYDOQIMbwUcHw== dependencies: - "@babel/runtime" "^7.24.7" + "@babel/runtime" "^7.24.6" "@noble/curves" "^1.4.0" "@noble/hashes" "^1.4.0" "@solana/buffer-layout" "^4.0.1" @@ -2810,35 +885,170 @@ fast-stable-stringify "^1.0.0" jayson "^4.1.0" node-fetch "^2.7.0" - rpc-websockets "^9.0.0" + rpc-websockets "^8.0.1" superstruct "^1.0.4" -"@stellar/eslint-config@^2.1.2": - version "2.1.2" - resolved "https://registry.yarnpkg.com/@stellar/eslint-config/-/eslint-config-2.1.2.tgz#95c223d10a5dfc2c89486e76cc7c9f1b56df3564" - integrity sha512-5aUkncDMmx0SvVlZD4rld5snGKt3mc0Gno1Jik3Pp31HUmpgrkRUD3ZZekEOqB9mDKadZhQZNNsS0jhyuXaayw== +"@stablelib/aead@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/aead/-/aead-1.0.1.tgz#c4b1106df9c23d1b867eb9b276d8f42d5fc4c0c3" + integrity sha512-q39ik6sxGHewqtO0nP4BuSe3db5G1fEJE8ukvngS2gLkBXyy6E7pLubhbYgnkDFv6V8cWaxcE4Xn0t6LWcJkyg== -"@stellar/freighter-api@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@stellar/freighter-api/-/freighter-api-1.4.0.tgz#f53ab58792733caa1fe33d60050ec24164e331f3" - integrity sha512-/ANu1/4mnReUvrSDveKj5XhrnafEssESF/lVdOR1v0ja02kFuhsdsw3anzdz0NvPaPbFgPmjU+v9t9R8KN6r+g== +"@stablelib/binary@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/binary/-/binary-1.0.1.tgz#c5900b94368baf00f811da5bdb1610963dfddf7f" + integrity sha512-ClJWvmL6UBM/wjkvv/7m5VP3GMr9t0osr4yVgLZsLCOz4hGN9gIAFEqnJ0TsSMAN+n840nf2cHZnA5/KFqHC7Q== + dependencies: + "@stablelib/int" "^1.0.1" -"@stellar/js-xdr@^3.1.1": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@stellar/js-xdr/-/js-xdr-3.1.1.tgz#be0ff90c8a861d6e1101bca130fa20e74d5599bb" - integrity sha512-3gnPjAz78htgqsNEDkEsKHKosV2BF2iZkoHCNxpmZwUxiPsw+2VaXMed8RRMe0rGk3d5GZe7RrSba8zV80J3Ag== +"@stablelib/bytes@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/bytes/-/bytes-1.0.1.tgz#0f4aa7b03df3080b878c7dea927d01f42d6a20d8" + integrity sha512-Kre4Y4kdwuqL8BR2E9hV/R5sOrUj6NanZaZis0V6lX5yzqC3hBuVSDXUIBqQv/sCpmuWRiHLwqiT1pqqjuBXoQ== -"@stellar/prettier-config@^1.2.0": - version "1.2.0" - resolved "https://registry.yarnpkg.com/@stellar/prettier-config/-/prettier-config-1.2.0.tgz#b27c411e0c4c63b2d76332c239084e682c37468f" - integrity sha512-oL9qJ7+7aWnImpbcldroQrvtMCZ9yx4JL/tmDZ860RpBQd2ahkc8bX6/k2ehFK8gpb9ltYu4mtU49wufUuYhGg== +"@stablelib/chacha20poly1305@1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/chacha20poly1305/-/chacha20poly1305-1.0.1.tgz#de6b18e283a9cb9b7530d8767f99cde1fec4c2ee" + integrity sha512-MmViqnqHd1ymwjOQfghRKw2R/jMIGT3wySN7cthjXCBdO+qErNPUBnRzqNpnvIwg7JBCg3LdeCZZO4de/yEhVA== + dependencies: + "@stablelib/aead" "^1.0.1" + "@stablelib/binary" "^1.0.1" + "@stablelib/chacha" "^1.0.1" + "@stablelib/constant-time" "^1.0.1" + "@stablelib/poly1305" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/chacha@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/chacha/-/chacha-1.0.1.tgz#deccfac95083e30600c3f92803a3a1a4fa761371" + integrity sha512-Pmlrswzr0pBzDofdFuVe1q7KdsHKhhU24e8gkEwnTGOmlC7PADzLVxGdn2PoNVBBabdg0l/IfLKg6sHAbTQugg== + dependencies: + "@stablelib/binary" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/constant-time@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/constant-time/-/constant-time-1.0.1.tgz#bde361465e1cf7b9753061b77e376b0ca4c77e35" + integrity sha512-tNOs3uD0vSJcK6z1fvef4Y+buN7DXhzHDPqRLSXUel1UfqMB1PWNsnnAezrKfEwTLpN0cGH2p9NNjs6IqeD0eg== + +"@stablelib/ed25519@^1.0.2": + version "1.0.3" + resolved "https://registry.yarnpkg.com/@stablelib/ed25519/-/ed25519-1.0.3.tgz#f8fdeb6f77114897c887bb6a3138d659d3f35996" + integrity sha512-puIMWaX9QlRsbhxfDc5i+mNPMY+0TmQEskunY1rZEBPi1acBCVQAhnsk/1Hk50DGPtVsZtAWQg4NHGlVaO9Hqg== + dependencies: + "@stablelib/random" "^1.0.2" + "@stablelib/sha512" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/hash@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/hash/-/hash-1.0.1.tgz#3c944403ff2239fad8ebb9015e33e98444058bc5" + integrity sha512-eTPJc/stDkdtOcrNMZ6mcMK1e6yBbqRBaNW55XA1jU8w/7QdnCF0CmMmOD1m7VSkBR44PWrMHU2l6r8YEQHMgg== + +"@stablelib/hkdf@1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/hkdf/-/hkdf-1.0.1.tgz#b4efd47fd56fb43c6a13e8775a54b354f028d98d" + integrity sha512-SBEHYE16ZXlHuaW5RcGk533YlBj4grMeg5TooN80W3NpcHRtLZLLXvKyX0qcRFxf+BGDobJLnwkvgEwHIDBR6g== + dependencies: + "@stablelib/hash" "^1.0.1" + "@stablelib/hmac" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/hmac@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/hmac/-/hmac-1.0.1.tgz#3d4c1b8cf194cb05d28155f0eed8a299620a07ec" + integrity sha512-V2APD9NSnhVpV/QMYgCVMIYKiYG6LSqw1S65wxVoirhU/51ACio6D4yDVSwMzuTJXWZoVHbDdINioBwKy5kVmA== + dependencies: + "@stablelib/constant-time" "^1.0.1" + "@stablelib/hash" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/int@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/int/-/int-1.0.1.tgz#75928cc25d59d73d75ae361f02128588c15fd008" + integrity sha512-byr69X/sDtDiIjIV6m4roLVWnNNlRGzsvxw+agj8CIEazqWGOQp2dTYgQhtyVXV9wpO6WyXRQUzLV/JRNumT2w== + +"@stablelib/keyagreement@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/keyagreement/-/keyagreement-1.0.1.tgz#4612efb0a30989deb437cd352cee637ca41fc50f" + integrity sha512-VKL6xBwgJnI6l1jKrBAfn265cspaWBPAPEc62VBQrWHLqVgNRE09gQ/AnOEyKUWrrqfD+xSQ3u42gJjLDdMDQg== + dependencies: + "@stablelib/bytes" "^1.0.1" + +"@stablelib/poly1305@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/poly1305/-/poly1305-1.0.1.tgz#93bfb836c9384685d33d70080718deae4ddef1dc" + integrity sha512-1HlG3oTSuQDOhSnLwJRKeTRSAdFNVB/1djy2ZbS35rBSJ/PFqx9cf9qatinWghC2UbfOYD8AcrtbUQl8WoxabA== + dependencies: + "@stablelib/constant-time" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/random@^1.0.1", "@stablelib/random@^1.0.2": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@stablelib/random/-/random-1.0.2.tgz#2dece393636489bf7e19c51229dd7900eddf742c" + integrity sha512-rIsE83Xpb7clHPVRlBj8qNe5L8ISQOzjghYQm/dZ7VaM2KHYwMW5adjQjrzTZCchFnNCNhkwtnOBa9HTMJCI8w== + dependencies: + "@stablelib/binary" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/sha256@1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/sha256/-/sha256-1.0.1.tgz#77b6675b67f9b0ea081d2e31bda4866297a3ae4f" + integrity sha512-GIIH3e6KH+91FqGV42Kcj71Uefd/QEe7Dy42sBTeqppXV95ggCcxLTk39bEr+lZfJmp+ghsR07J++ORkRELsBQ== + dependencies: + "@stablelib/binary" "^1.0.1" + "@stablelib/hash" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/sha512@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/sha512/-/sha512-1.0.1.tgz#6da700c901c2c0ceacbd3ae122a38ac57c72145f" + integrity sha512-13gl/iawHV9zvDKciLo1fQ8Bgn2Pvf7OV6amaRVKiq3pjQ3UmEpXxWiAfV8tYjUpeZroBxtyrwtdooQT/i3hzw== + dependencies: + "@stablelib/binary" "^1.0.1" + "@stablelib/hash" "^1.0.1" + "@stablelib/wipe" "^1.0.1" + +"@stablelib/wipe@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@stablelib/wipe/-/wipe-1.0.1.tgz#d21401f1d59ade56a62e139462a97f104ed19a36" + integrity sha512-WfqfX/eXGiAd3RJe4VU2snh/ZPwtSjLG4ynQ/vYzvghTh7dHFcI1wl+nrkWG6lGhukOxOsUHfv8dUXr58D0ayg== -"@stellar/stellar-base@^12.0.0": - version "12.0.0" - resolved "https://registry.yarnpkg.com/@stellar/stellar-base/-/stellar-base-12.0.0.tgz#d46e2a45b756c3e5b4b8f82f224fcc467dac3ade" - integrity sha512-uGpahDFFXbE39myOmBnEZSjVys4yUkQ/ASNuYENGyS8MNdfA0TS7DPWkiO6t17P+rW+FRV1zmumJtjRHwxxMdw== +"@stablelib/x25519@^1.0.3": + version "1.0.3" + resolved "https://registry.yarnpkg.com/@stablelib/x25519/-/x25519-1.0.3.tgz#13c8174f774ea9f3e5e42213cbf9fc68a3c7b7fd" + integrity sha512-KnTbKmUhPhHavzobclVJQG5kuivH+qDLpe84iRqX3CLrKp881cF160JvXJ+hjn1aMyCwYOKeIZefIH/P5cJoRw== + dependencies: + "@stablelib/keyagreement" "^1.0.1" + "@stablelib/random" "^1.0.2" + "@stablelib/wipe" "^1.0.1" + +"@stellar/design-system@^2.0.0-beta.15": + version "2.0.0-beta.15" + resolved "https://registry.yarnpkg.com/@stellar/design-system/-/design-system-2.0.0-beta.15.tgz#431976a02faf29fa6e671b78e7ddb6c8cc1d73f4" + integrity sha512-jISw5zR/WCvbQspFe+TyuipoHDYAO7PQdlfu6Wpqmc4Gvc6g5O2hhbthn6mtF+wlsv6X3oz0Un6+FWPFnUVKiQ== + dependencies: + "@floating-ui/dom" "^1.6.3" + bignumber.js "^9.1.2" + lodash "^4.17.21" + react-copy-to-clipboard "^5.1.0" + tslib "^2.6.2" + +"@stellar/freighter-api@2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@stellar/freighter-api/-/freighter-api-2.0.0.tgz#488915a4aa0cec8c9a3fc84ef31e21cd5ec41343" + integrity sha512-j/R7MLPL8S3QhwOEdAxSl7MgWBTXWlOXQKQyXR8mPk1JMKKR4tF8e4U+Fs9TPQH0HZoYqfVDvLOOUrTMMY058Q== + +"@stellar/js-xdr@^3.1.2": + version "3.1.2" + resolved "https://registry.yarnpkg.com/@stellar/js-xdr/-/js-xdr-3.1.2.tgz#db7611135cf21e989602fd72f513c3bed621bc74" + integrity sha512-VVolPL5goVEIsvuGqDc5uiKxV03lzfWdvYg1KikvwheDmTBO68CKDji3bAZ/kppZrx5iTA8z3Ld5yuytcvhvOQ== + +"@stellar/stellar-base@^12.1.0": + version "12.1.0" + resolved "https://registry.yarnpkg.com/@stellar/stellar-base/-/stellar-base-12.1.0.tgz#45b55a38738ed267e0d55a1fee3c4153c82d0fa6" + integrity sha512-pWwn+XWP5NotmIteZNuJzHeNn9DYSqH3lsYbtFUoSYy1QegzZdi9D8dK6fJ2fpBAnf/rcDjHgHOw3gtHaQFVbg== dependencies: - "@stellar/js-xdr" "^3.1.1" + "@stellar/js-xdr" "^3.1.2" base32.js "^0.1.0" bignumber.js "^9.1.2" buffer "^6.0.3" @@ -2847,12 +1057,12 @@ optionalDependencies: sodium-native "^4.1.1" -"@stellar/stellar-sdk@^12.0.1": - version "12.0.1" - resolved "https://registry.yarnpkg.com/@stellar/stellar-sdk/-/stellar-sdk-12.0.1.tgz#0ded98bdd606cc2dc491ba6095a30530d690380d" - integrity sha512-0+YXUTS2LpZ+Of383hSYVpsRl9BJ3X9lHcj05ouS3VkVL9BH7w+Par8RHPkiHS6lLYn3gWRgaJauTebkamY/Jw== +"@stellar/stellar-sdk@^12.2.0": + version "12.2.0" + resolved "https://registry.yarnpkg.com/@stellar/stellar-sdk/-/stellar-sdk-12.2.0.tgz#c449bc52be282c7706aabbd257acbc5aec3345b3" + integrity sha512-Wy5sDOqb5JvAC76f4sQIV6Pe3JNyZb0PuyVNjwt3/uWsjtxRkFk6s2yTHTefBLWoR+mKxDjO7QfzhycF1v8FXQ== dependencies: - "@stellar/stellar-base" "^12.0.0" + "@stellar/stellar-base" "^12.1.0" axios "^1.7.2" bignumber.js "^9.1.2" eventsource "^2.0.2" @@ -2860,71 +1070,52 @@ toml "^3.0.0" urijs "^1.19.1" +"@stellar/stellar-xdr-json-web@^0.0.1": + version "0.0.1" + resolved "https://registry.yarnpkg.com/@stellar/stellar-xdr-json-web/-/stellar-xdr-json-web-0.0.1.tgz#04084e085a5360b5de106247c5731d87778a5fc1" + integrity sha512-mu9Y4fNZ25tuNQoK3vrd48MQivD2UxnwupQRcqs1kM5ncJIAHzNqV9s2E1U76g5vapvO5oE3Xhn9p5nU+gECdw== + "@stellar/tsconfig@^1.0.2": version "1.0.2" resolved "https://registry.yarnpkg.com/@stellar/tsconfig/-/tsconfig-1.0.2.tgz#18e9b1a1d6076e116bb405d11fc034401155292d" integrity sha512-lC51QSlYRM8K3oGe0/WGPq+p9+u+yPzwZXSKrZXKOe4sq79vzfiqFbQyp5enOffFzXlahcDyTgY67mBOkJytfw== -"@swc/helpers@^0.5.11": - version "0.5.11" - resolved "https://registry.yarnpkg.com/@swc/helpers/-/helpers-0.5.11.tgz#5bab8c660a6e23c13b2d23fcd1ee44a2db1b0cb7" - integrity sha512-YNlnKRWF2sVojTpIyzwou9XoTNbzbzONwRhOoniEioF1AtaitTvVZblaQRrAzChWQ1bLYyYSWzM18y4WwgzJ+A== +"@swc/counter@^0.1.3": + version "0.1.3" + resolved "https://registry.yarnpkg.com/@swc/counter/-/counter-0.1.3.tgz#cc7463bd02949611c6329596fccd2b0ec782b0e9" + integrity sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ== + +"@swc/helpers@0.5.5": + version "0.5.5" + resolved "https://registry.yarnpkg.com/@swc/helpers/-/helpers-0.5.5.tgz#12689df71bfc9b21c4f4ca00ae55f2f16c8b77c0" + integrity sha512-KGYxvIOXcceOAbEk4bi/dVLEK9z8sZ0uBB3Il5b1rhfClSpcX0yfRO0KmTkqR2cnQDymwLB+25ZyMzICg/cm/A== dependencies: + "@swc/counter" "^0.1.3" tslib "^2.4.0" -"@testing-library/dom@^8.0.0": - version "8.1.0" - resolved "https://registry.yarnpkg.com/@testing-library/dom/-/dom-8.1.0.tgz#f8358b1883844ea569ba76b7e94582168df5370d" - integrity sha512-kmW9alndr19qd6DABzQ978zKQ+J65gU2Rzkl8hriIetPnwpesRaK4//jEQyYh8fEALmGhomD/LBQqt+o+DL95Q== - dependencies: - "@babel/code-frame" "^7.10.4" - "@babel/runtime" "^7.12.5" - "@types/aria-query" "^4.2.0" - aria-query "^4.2.2" - chalk "^4.1.0" - dom-accessibility-api "^0.5.6" - lz-string "^1.4.4" - pretty-format "^27.0.2" - -"@testing-library/jest-dom@^5.16.2": - version "5.16.2" - resolved "https://registry.yarnpkg.com/@testing-library/jest-dom/-/jest-dom-5.16.2.tgz#f329b36b44aa6149cd6ced9adf567f8b6aa1c959" - integrity sha512-6ewxs1MXWwsBFZXIk4nKKskWANelkdUehchEOokHsN8X7c2eKXGw+77aRV63UU8f/DTSVUPLaGxdrj4lN7D/ug== - dependencies: - "@babel/runtime" "^7.9.2" - "@types/testing-library__jest-dom" "^5.9.1" - aria-query "^5.0.0" - chalk "^3.0.0" - css "^3.0.0" - css.escape "^1.5.1" - dom-accessibility-api "^0.5.6" - lodash "^4.17.15" - redent "^3.0.0" +"@tanstack/query-core@5.45.0": + version "5.45.0" + resolved "https://registry.yarnpkg.com/@tanstack/query-core/-/query-core-5.45.0.tgz#47a662d311c2588867341238960ec21dc7f0714e" + integrity sha512-RVfIZQmFUTdjhSAAblvueimfngYyfN6HlwaJUPK71PKd7yi43Vs1S/rdimmZedPWX/WGppcq/U1HOj7O7FwYxw== -"@testing-library/react@^12.1.2": - version "12.1.2" - resolved "https://registry.yarnpkg.com/@testing-library/react/-/react-12.1.2.tgz#f1bc9a45943461fa2a598bb4597df1ae044cfc76" - integrity sha512-ihQiEOklNyHIpo2Y8FREkyD1QAea054U0MVbwH1m8N9TxeFz+KoJ9LkqoKqJlzx2JDm56DVwaJ1r36JYxZM05g== - dependencies: - "@babel/runtime" "^7.12.5" - "@testing-library/dom" "^8.0.0" +"@tanstack/query-devtools@5.37.1": + version "5.37.1" + resolved "https://registry.yarnpkg.com/@tanstack/query-devtools/-/query-devtools-5.37.1.tgz#8dcfa1488b4f2e353be7eede6691b0ad9197183b" + integrity sha512-XcG4IIHIv0YQKrexTqo2zogQWR1Sz672tX2KsfE9kzB+9zhx44vRKH5si4WDILE1PIWQpStFs/NnrDQrBAUQpg== -"@testing-library/user-event@^13.5.0": - version "13.5.0" - resolved "https://registry.yarnpkg.com/@testing-library/user-event/-/user-event-13.5.0.tgz#69d77007f1e124d55314a2b73fd204b333b13295" - integrity sha512-5Kwtbo3Y/NowpkbRuSepbyMFkZmHgD+vPzYB/RJ4oxt5Gj/avFFBYjhw27cqSVPVw/3a67NK1PbiIr9k4Gwmdg== +"@tanstack/react-query-devtools@^5.45.1": + version "5.45.1" + resolved "https://registry.yarnpkg.com/@tanstack/react-query-devtools/-/react-query-devtools-5.45.1.tgz#bea7ba0ffd509f0930237c2df7feba9209f76aa6" + integrity sha512-4mrbk1g5jqlqh0pifZNsKzy7FtgeqgwzMICL4d6IJGayrrcrKq9K4N/OzRNbgRWrTn6YTY63qcAcKo+NJU2QMw== dependencies: - "@babel/runtime" "^7.12.5" - -"@tootallnate/once@1": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82" - integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== + "@tanstack/query-devtools" "5.37.1" -"@tootallnate/once@2": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-2.0.0.tgz#f544a148d3ab35801c1f633a7441fd87c2e484bf" - integrity sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A== +"@tanstack/react-query@^5.45.1": + version "5.45.1" + resolved "https://registry.yarnpkg.com/@tanstack/react-query/-/react-query-5.45.1.tgz#a0ac6bb89b4a2c2b0251f6647a0a370d86f05347" + integrity sha512-mYYfJujKg2kxmkRRjA6nn4YKG3ITsKuH22f1kteJ5IuVQqgKUgbaSQfYwVP0gBS05mhwxO03HVpD0t7BMN7WOA== + dependencies: + "@tanstack/query-core" "5.45.0" "@trezor/analytics@1.0.17": version "1.0.17" @@ -2993,7 +1184,7 @@ dependencies: bignumber.js "^9.1.2" -"@trezor/connect-web@^9.2.4": +"@trezor/connect-web@^9.2.2": version "9.2.4" resolved "https://registry.yarnpkg.com/@trezor/connect-web/-/connect-web-9.2.4.tgz#3d79ec291aa5317bdd132da0b0ab91b3f2d50f61" integrity sha512-BatNwWzkg7hYLYhkJIuAbV74Uw1l0Lee0Xp+2XdR7muuXPBVs5GbqlFfI0DE6SM8oVvzvvAFufXW/zfYd0iTGA== @@ -3107,746 +1298,432 @@ varuint-bitcoin "^1.1.2" wif "^4.0.0" -"@types/aria-query@^4.2.0": - version "4.2.2" - resolved "https://registry.yarnpkg.com/@types/aria-query/-/aria-query-4.2.2.tgz#ed4e0ad92306a704f9fb132a0cfcf77486dbe2bc" - integrity sha512-HnYpAE1Y6kRyKM/XkEuiRQhTHvkzMBurTHnpFLYLBGPIylZNPs9jJcuOOYWxPLJCSEtmZT0Y8rHDokKN7rRTig== - -"@types/body-parser@*": - version "1.19.5" - resolved "https://registry.yarnpkg.com/@types/body-parser/-/body-parser-1.19.5.tgz#04ce9a3b677dc8bd681a17da1ab9835dc9d3ede4" - integrity sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg== - dependencies: - "@types/connect" "*" - "@types/node" "*" - -"@types/bonjour@^3.5.9": - version "3.5.13" - resolved "https://registry.yarnpkg.com/@types/bonjour/-/bonjour-3.5.13.tgz#adf90ce1a105e81dd1f9c61fdc5afda1bfb92956" - integrity sha512-z9fJ5Im06zvUL548KvYNecEVlA7cVDkGUi6kZusb04mpyEFKCIZJvloCcmpmLaIahDpOQGHaHmG6imtPMmPXGQ== - dependencies: - "@types/node" "*" - -"@types/connect-history-api-fallback@^1.3.5": - version "1.5.4" - resolved "https://registry.yarnpkg.com/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.5.4.tgz#7de71645a103056b48ac3ce07b3520b819c1d5b3" - integrity sha512-n6Cr2xS1h4uAulPRdlw6Jl6s1oG8KrVilPN2yUITEs+K48EzMJJ3W1xy8K5eWuFvjp3R74AOIGSmp2UfBJ8HFw== - dependencies: - "@types/express-serve-static-core" "*" - "@types/node" "*" - -"@types/connect@*", "@types/connect@^3.4.33": +"@types/connect@^3.4.33": version "3.4.38" resolved "https://registry.yarnpkg.com/@types/connect/-/connect-3.4.38.tgz#5ba7f3bc4fbbdeaff8dded952e5ff2cc53f8d858" integrity sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug== dependencies: "@types/node" "*" -"@types/cookie@^0.4.1": - version "0.4.1" - resolved "https://registry.yarnpkg.com/@types/cookie/-/cookie-0.4.1.tgz#bfd02c1f2224567676c1545199f87c3a861d878d" - integrity sha512-XW/Aa8APYr6jSVVA1y/DEIZX0/GMKLEVekNG727R8cs56ahETkRAy/3DR7+fJyh7oUgGwNQaRfXCun0+KbWY7Q== - -"@types/cookie@^0.6.0": - version "0.6.0" - resolved "https://registry.yarnpkg.com/@types/cookie/-/cookie-0.6.0.tgz#eac397f28bf1d6ae0ae081363eca2f425bedf0d5" - integrity sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA== - -"@types/cors@^2.8.12": - version "2.8.17" - resolved "https://registry.yarnpkg.com/@types/cors/-/cors-2.8.17.tgz#5d718a5e494a8166f569d986794e49c48b216b2b" - integrity sha512-8CGDvrBj1zgo2qE+oS3pOCyYNqCPryMWY2bGfwA0dcfopWGgxs+78df0Rs3rc9THP4JkOhLsAa+15VdpAqkcUA== - dependencies: - "@types/node" "*" - -"@types/dompurify@^2.3.3": - version "2.3.3" - resolved "https://registry.yarnpkg.com/@types/dompurify/-/dompurify-2.3.3.tgz#c24c92f698f77ed9cc9d9fa7888f90cf2bfaa23f" - integrity sha512-nnVQSgRVuZ/843oAfhA25eRSNzUFcBPk/LOiw5gm8mD9/X7CNcbRkQu/OsjCewO8+VIYfPxUnXvPEVGenw14+w== +"@types/dompurify@^3.0.5": + version "3.0.5" + resolved "https://registry.yarnpkg.com/@types/dompurify/-/dompurify-3.0.5.tgz#02069a2fcb89a163bacf1a788f73cb415dd75cb7" + integrity sha512-1Wg0g3BtQF7sSb27fJQAKck1HECM6zV1EB66j8JH9i3LCjYabJa0FSdiSgsD5K/RbrsR0SiraKacLB+T8ZVYAg== dependencies: "@types/trusted-types" "*" -"@types/eslint-scope@^3.7.3": - version "3.7.7" - resolved "https://registry.yarnpkg.com/@types/eslint-scope/-/eslint-scope-3.7.7.tgz#3108bd5f18b0cdb277c867b3dd449c9ed7079ac5" - integrity sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg== - dependencies: - "@types/eslint" "*" - "@types/estree" "*" - -"@types/eslint@*": - version "8.44.8" - resolved "https://registry.yarnpkg.com/@types/eslint/-/eslint-8.44.8.tgz#f4fe1dab9b3d3dd98082d4b9f80e59ab40f1261c" - integrity sha512-4K8GavROwhrYl2QXDXm0Rv9epkA8GBFu0EI+XrrnnuCl7u8CWBRusX7fXJfanhZTDWSAL24gDI/UqXyUM0Injw== - dependencies: - "@types/estree" "*" - "@types/json-schema" "*" - -"@types/eslint@^8.56.10": - version "8.56.10" - resolved "https://registry.yarnpkg.com/@types/eslint/-/eslint-8.56.10.tgz#eb2370a73bf04a901eeba8f22595c7ee0f7eb58d" - integrity sha512-Shavhk87gCtY2fhXDctcfS3e6FdxWkCx1iUZ9eEUbh7rTqlZT0/IzOkCOVt0fCjcFuZ9FPYfuezTBImfHCDBGQ== - dependencies: - "@types/estree" "*" - "@types/json-schema" "*" - -"@types/estree@*": - version "0.0.50" - resolved "https://registry.yarnpkg.com/@types/estree/-/estree-0.0.50.tgz#1e0caa9364d3fccd2931c3ed96fdbeaa5d4cca83" - integrity sha512-C6N5s2ZFtuZRj54k2/zyRhNDjJwwcViAM3Nbm8zjBpbqAdZ00mr0CFxvSKeO8Y/e03WVFLpQMdHYVfUd6SB+Hw== - -"@types/estree@^1.0.5": - version "1.0.5" - resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.5.tgz#a6ce3e556e00fd9895dd872dd172ad0d4bd687f4" - integrity sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw== - -"@types/express-serve-static-core@*", "@types/express-serve-static-core@^4.17.33": - version "4.17.41" - resolved "https://registry.yarnpkg.com/@types/express-serve-static-core/-/express-serve-static-core-4.17.41.tgz#5077defa630c2e8d28aa9ffc2c01c157c305bef6" - integrity sha512-OaJ7XLaelTgrvlZD8/aa0vvvxZdUmlCn6MtWeB7TkiKW70BQLc9XEPpDLPdbo52ZhXUCrznlWdCHWxJWtdyajA== - dependencies: - "@types/node" "*" - "@types/qs" "*" - "@types/range-parser" "*" - "@types/send" "*" - -"@types/express@*", "@types/express@^4.17.13": - version "4.17.21" - resolved "https://registry.yarnpkg.com/@types/express/-/express-4.17.21.tgz#c26d4a151e60efe0084b23dc3369ebc631ed192d" - integrity sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ== - dependencies: - "@types/body-parser" "*" - "@types/express-serve-static-core" "^4.17.33" - "@types/qs" "*" - "@types/serve-static" "*" - -"@types/glob@^7.1.1": - version "7.1.4" - resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.1.4.tgz#ea59e21d2ee5c517914cb4bc8e4153b99e566672" - integrity sha512-w+LsMxKyYQm347Otw+IfBXOv9UWVjpHpCDdbBMt8Kz/xbvCYNjP+0qPh91Km3iKfSRLBB0P7fAMf0KHrPu+MyA== - dependencies: - "@types/minimatch" "*" - "@types/node" "*" - -"@types/hoist-non-react-statics@^3.3.0": - version "3.3.1" - resolved "https://registry.yarnpkg.com/@types/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz#1124aafe5118cb591977aeb1ceaaed1070eb039f" - integrity sha512-iMIqiko6ooLrTh1joXodJK5X9xeEALT1kM5G3ZLhD3hszxBdIEd5C75U834D9mLcINgD4OyZf5uQXjkuYydWvA== - dependencies: - "@types/react" "*" - hoist-non-react-statics "^3.3.0" - -"@types/html-minifier-terser@^6.0.0": - version "6.1.0" - resolved "https://registry.yarnpkg.com/@types/html-minifier-terser/-/html-minifier-terser-6.1.0.tgz#4fc33a00c1d0c16987b1a20cf92d20614c55ac35" - integrity sha512-oh/6byDPnL1zeNXFrDXFLyZjkr1MsBG667IM792caf1L2UPOOMf65NFzjUH/ltyfwjAGfs1rsX1eftK0jC/KIg== - -"@types/http-errors@*": - version "2.0.4" - resolved "https://registry.yarnpkg.com/@types/http-errors/-/http-errors-2.0.4.tgz#7eb47726c391b7345a6ec35ad7f4de469cf5ba4f" - integrity sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA== - -"@types/http-proxy@^1.17.8": - version "1.17.14" - resolved "https://registry.yarnpkg.com/@types/http-proxy/-/http-proxy-1.17.14.tgz#57f8ccaa1c1c3780644f8a94f9c6b5000b5e2eec" - integrity sha512-SSrD0c1OQzlFX7pGu1eXxSEjemej64aaNPRhhVYUGqXh0BtldAAx37MG8btcumvpgKyZp1F5Gn3JkktdxiFv6w== - dependencies: - "@types/node" "*" - -"@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0": - version "2.0.3" - resolved "https://registry.yarnpkg.com/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.3.tgz#4ba8ddb720221f432e443bd5f9117fd22cfd4762" - integrity sha512-sz7iLqvVUg1gIedBOvlkxPlc8/uVzyS5OwGz1cKjXzkl3FpL3al0crU8YGU1WoHkxn0Wxbw5tyi6hvzJKNzFsw== - -"@types/istanbul-lib-report@*": - version "3.0.0" - resolved "https://registry.yarnpkg.com/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#c14c24f18ea8190c118ee7562b7ff99a36552686" - integrity sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg== - dependencies: - "@types/istanbul-lib-coverage" "*" - -"@types/istanbul-reports@^3.0.0": - version "3.0.1" - resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz#9153fe98bba2bd565a63add9436d6f0d7f8468ff" - integrity sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw== - dependencies: - "@types/istanbul-lib-report" "*" - -"@types/jest@*": - version "27.0.1" - resolved "https://registry.yarnpkg.com/@types/jest/-/jest-27.0.1.tgz#fafcc997da0135865311bb1215ba16dba6bdf4ca" - integrity sha512-HTLpVXHrY69556ozYkcq47TtQJXpcWAWfkoqz+ZGz2JnmZhzlRjprCIyFnetSy8gpDWwTTGBcRVv1J1I1vBrHw== - dependencies: - jest-diff "^27.0.0" - pretty-format "^27.0.0" - -"@types/jest@^27.4.0": - version "27.4.0" - resolved "https://registry.yarnpkg.com/@types/jest/-/jest-27.4.0.tgz#037ab8b872067cae842a320841693080f9cb84ed" - integrity sha512-gHl8XuC1RZ8H2j5sHv/JqsaxXkDDM9iDOgu0Wp8sjs4u/snb2PVehyWXJPr+ORA0RPpgw231mnutWI1+0hgjIQ== - dependencies: - jest-diff "^27.0.0" - pretty-format "^27.0.0" - -"@types/json-schema@*", "@types/json-schema@^7.0.8": - version "7.0.9" - resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.9.tgz#97edc9037ea0c38585320b28964dde3b39e4660d" - integrity sha512-qcUXuemtEu+E5wZSJHNxUXeCZhAfXKQ41D+duX+VYPde7xyEVZci+/oXKJL13tnRs9lR2pr4fod59GT6/X1/yQ== - -"@types/json-schema@^7.0.9": - version "7.0.15" - resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841" - integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA== - "@types/json5@^0.0.29": version "0.0.29" resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" integrity sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ== -"@types/lodash@^4.14.136": - version "4.14.182" - resolved "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.182.tgz#05301a4d5e62963227eaafe0ce04dd77c54ea5c2" - integrity sha512-/THyiqyQAP9AfARo4pF+aCGcyiQ94tX/Is2I7HofNRqoYLgN1PBoOWu2/zTA5zMxzP5EFutMtWtGAFRKUe961Q== - -"@types/lodash@^4.17.5": +"@types/lodash@^4.14.136", "@types/lodash@^4.17.0": version "4.17.5" resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.17.5.tgz#e6c29b58e66995d57cd170ce3e2a61926d55ee04" integrity sha512-MBIOHVZqVqgfro1euRDWX7OO0fBVUUMrN6Pwm8LQsz8cWhEpihlvR70ENj3f40j58TNxZaWv2ndSkInykNBBJw== -"@types/mime@*": - version "3.0.4" - resolved "https://registry.yarnpkg.com/@types/mime/-/mime-3.0.4.tgz#2198ac274de6017b44d941e00261d5bc6a0e0a45" - integrity sha512-iJt33IQnVRkqeqC7PzBHPTC6fDlRNRW8vjrgqtScAhrmMwe8c4Eo7+fUGTa+XdWrpEgpyKWMYmi2dIwMAYRzPw== - -"@types/mime@^1": - version "1.3.5" - resolved "https://registry.yarnpkg.com/@types/mime/-/mime-1.3.5.tgz#1ef302e01cf7d2b5a0fa526790c9123bf1d06690" - integrity sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w== - -"@types/minimatch@*": - version "3.0.5" - resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.5.tgz#1001cc5e6a3704b83c236027e77f2f58ea010f40" - integrity sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ== - -"@types/minimist@^1.2.0": - version "1.2.5" - resolved "https://registry.yarnpkg.com/@types/minimist/-/minimist-1.2.5.tgz#ec10755e871497bcd83efe927e43ec46e8c0747e" - integrity sha512-hov8bUuiLiyFPGyFPE1lwWhmzYbirOXQNNo40+y3zow8aFVTeyn3VWL0VFFfdNddA8S4Vf0Tc062rzyNr7Paag== - -"@types/mute-stream@^0.0.4": - version "0.0.4" - resolved "https://registry.yarnpkg.com/@types/mute-stream/-/mute-stream-0.0.4.tgz#77208e56a08767af6c5e1237be8888e2f255c478" - integrity sha512-CPM9nzrCPPJHQNA9keH9CVkVI+WR5kMa+7XEs5jcGQ0VoAGnLv242w8lIVgwAEfmE4oufJRaTc9PNLQl0ioAow== - dependencies: - "@types/node" "*" - -"@types/node-forge@^1.3.0": - version "1.3.10" - resolved "https://registry.yarnpkg.com/@types/node-forge/-/node-forge-1.3.10.tgz#62a19d4f75a8b03290578c2b04f294b1a5a71b07" - integrity sha512-y6PJDYN4xYBxwd22l+OVH35N+1fCYWiuC3aiP2SlXVE6Lo7SS+rSx9r89hLxrP4pn6n1lBGhHJ12pj3F3Mpttw== - dependencies: - "@types/node" "*" - -"@types/node@*", "@types/node@^16.0.1": - version "16.6.2" - resolved "https://registry.yarnpkg.com/@types/node/-/node-16.6.2.tgz#331b7b9f8621c638284787c5559423822fdffc50" - integrity sha512-LSw8TZt12ZudbpHc6EkIyDM3nHVWKYrAvGy6EAJfNfjusbwnThqjqxUKKRwuV3iWYeW/LYMzNgaq3MaLffQ2xA== - -"@types/node@>=10.0.0", "@types/node@^20.12.13": +"@types/node@*", "@types/node@>=13.7.0", "@types/node@^20.12.7": version "20.14.2" resolved "https://registry.yarnpkg.com/@types/node/-/node-20.14.2.tgz#a5f4d2bcb4b6a87bffcaa717718c5a0f208f4a18" integrity sha512-xyu6WAMVwv6AKFLB+e/7ySZVr/0zLCzOa7rSpq6jNwpqOrUbcACDWC+53d4n2QHOnDou0fbIsg8wZu/sxrnI4Q== dependencies: undici-types "~5.26.4" -"@types/node@>=13.7.0": - version "18.0.0" - resolved "https://registry.npmjs.org/@types/node/-/node-18.0.0.tgz#67c7b724e1bcdd7a8821ce0d5ee184d3b4dd525a" - integrity sha512-cHlGmko4gWLVI27cGJntjs/Sj8th9aYwplmZFwmmgYQQvL5NUsgVJG7OddLvNfLqYS31KFN0s3qlaD9qCaxACA== - "@types/node@^12.12.54": version "12.20.55" resolved "https://registry.yarnpkg.com/@types/node/-/node-12.20.55.tgz#c329cbd434c42164f846b909bd6f85b5537f6240" integrity sha512-J8xLz7q2OFulZ2cyGTLE1TbbZcjpno7FaN6zdJNrgAdrJ+DZzh/uFR6YrTb4C+nXakvud8Q4+rbhoIWlYQbUFQ== -"@types/normalize-package-data@^2.4.0": - version "2.4.1" - resolved "https://registry.yarnpkg.com/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz#d3357479a0fdfdd5907fe67e17e0a85c906e1301" - integrity sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw== - -"@types/parse-json@^4.0.0": - version "4.0.0" - resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" - integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== - "@types/prop-types@*": - version "15.7.4" - resolved "https://registry.yarnpkg.com/@types/prop-types/-/prop-types-15.7.4.tgz#fcf7205c25dff795ee79af1e30da2c9790808f11" - integrity sha512-rZ5drC/jWjrArrS8BR6SIr4cWpW09RNTYt9AMZo3Jwwif+iacXAqgVjm0B0Bv/S1jhDXKHqRVNCbACkJ89RAnQ== - -"@types/qs@*": - version "6.9.10" - resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.10.tgz#0af26845b5067e1c9a622658a51f60a3934d51e8" - integrity sha512-3Gnx08Ns1sEoCrWssEgTSJs/rsT2vhGP+Ja9cnnk9k4ALxinORlQneLXFeFKOTJMOeZUFD1s7w+w2AphTpvzZw== - -"@types/range-parser@*": - version "1.2.7" - resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.7.tgz#50ae4353eaaddc04044279812f52c8c65857dbcb" - integrity sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ== - -"@types/react-dom@^17.0.11": - version "17.0.11" - resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-17.0.11.tgz#e1eadc3c5e86bdb5f7684e00274ae228e7bcc466" - integrity sha512-f96K3k+24RaLGVu/Y2Ng3e1EbZ8/cVJvypZWd7cy0ofCBaf2lcM46xNhycMZ2xGwbBjRql7hOlZ+e2WlJ5MH3Q== - dependencies: - "@types/react" "*" - -"@types/react-loadable@^5.5.11": - version "5.5.11" - resolved "https://registry.yarnpkg.com/@types/react-loadable/-/react-loadable-5.5.11.tgz#a9b23334251fbdfb32b94c120a09e301e606f07f" - integrity sha512-/tq2IJ853MoIFRBmqVOxnGsRRjER5TmEKzsZtaAkiXAWoDeKgR/QNOT1vd9k0p9h/F616X21cpNh3hu4RutzRQ== - dependencies: - "@types/react" "*" - "@types/webpack" "^4" - -"@types/react-redux@^7.1.20": - version "7.1.22" - resolved "https://registry.yarnpkg.com/@types/react-redux/-/react-redux-7.1.22.tgz#0eab76a37ef477cc4b53665aeaf29cb60631b72a" - integrity sha512-GxIA1kM7ClU73I6wg9IRTVwSO9GS+SAKZKe0Enj+82HMU6aoESFU2HNAdNi3+J53IaOHPiUfT3kSG4L828joDQ== - dependencies: - "@types/hoist-non-react-statics" "^3.3.0" - "@types/react" "*" - hoist-non-react-statics "^3.3.0" - redux "^4.0.0" + version "15.7.12" + resolved "https://registry.yarnpkg.com/@types/prop-types/-/prop-types-15.7.12.tgz#12bb1e2be27293c1406acb6af1c3f3a1481d98c6" + integrity sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q== -"@types/react-redux@^7.1.33": - version "7.1.33" - resolved "https://registry.yarnpkg.com/@types/react-redux/-/react-redux-7.1.33.tgz#53c5564f03f1ded90904e3c90f77e4bd4dc20b15" - integrity sha512-NF8m5AjWCkert+fosDsN3hAlHzpjSiXlVy9EgQEmLoBhaNXbmyeGs/aj5dQzKuF+/q+S7JQagorGDW8pJ28Hmg== +"@types/react-dom@^18.3.0": + version "18.3.0" + resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-18.3.0.tgz#0cbc818755d87066ab6ca74fbedb2547d74a82b0" + integrity sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg== dependencies: - "@types/hoist-non-react-statics" "^3.3.0" "@types/react" "*" - hoist-non-react-statics "^3.3.0" - redux "^4.0.0" - -"@types/react@*": - version "17.0.18" - resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.18.tgz#4109cbbd901be9582e5e39e3d77acd7b66bb7fbe" - integrity sha512-YTLgu7oS5zvSqq49X5Iue5oAbVGhgPc5Au29SJC4VeE17V6gASoOxVkUDy9pXFMRFxCWCD9fLeweNFizo3UzOg== - dependencies: - "@types/prop-types" "*" - "@types/scheduler" "*" - csstype "^3.0.2" -"@types/react@^17.0.39": - version "17.0.39" - resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.39.tgz#d0f4cde092502a6db00a1cded6e6bf2abb7633ce" - integrity sha512-UVavlfAxDd/AgAacMa60Azl7ygyQNRwC/DsHZmKgNvPmRR5p70AJ5Q9EAmL2NWOJmeV+vVUI4IAP7GZrN8h8Ug== +"@types/react@*", "@types/react@^18.3.1": + version "18.3.3" + resolved "https://registry.yarnpkg.com/@types/react/-/react-18.3.3.tgz#9679020895318b0915d7a3ab004d92d33375c45f" + integrity sha512-hti/R0pS0q1/xx+TsI73XIqk26eBsISZ2R0wUijXIngRK9R/e7Xw/cXVxQK7R5JjW+SV4zGcn5hXjudkN/pLIw== dependencies: "@types/prop-types" "*" - "@types/scheduler" "*" csstype "^3.0.2" -"@types/retry@0.12.0": - version "0.12.0" - resolved "https://registry.yarnpkg.com/@types/retry/-/retry-0.12.0.tgz#2b35eccfcee7d38cd72ad99232fbd58bffb3c84d" - integrity sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA== +"@types/trusted-types@*", "@types/trusted-types@^2.0.2": + version "2.0.7" + resolved "https://registry.yarnpkg.com/@types/trusted-types/-/trusted-types-2.0.7.tgz#baccb07a970b91707df3a3e8ba6896c57ead2d11" + integrity sha512-ScaPdn1dQczgbl0QFTeTOmVHFULt394XJgOQNoyVhZ6r2vLnMLJfBPd53SB52T/3G36VI1/g2MZaX0cwDuXsfw== -"@types/scheduler@*": - version "0.16.2" - resolved "https://registry.yarnpkg.com/@types/scheduler/-/scheduler-0.16.2.tgz#1a62f89525723dde24ba1b01b092bf5df8ad4d39" - integrity sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew== +"@types/w3c-web-usb@^1.0.6": + version "1.0.10" + resolved "https://registry.yarnpkg.com/@types/w3c-web-usb/-/w3c-web-usb-1.0.10.tgz#cf89cccd2d93b6245e784c19afe0a9f5038d4528" + integrity sha512-CHgUI5kTc/QLMP8hODUHhge0D4vx+9UiAwIGiT0sTy/B2XpdX1U5rJt6JSISgr6ikRT7vxV9EVAFeYZqUnl1gQ== -"@types/semver@^7.3.12": - version "7.5.6" - resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.5.6.tgz#c65b2bfce1bec346582c07724e3f8c1017a20339" - integrity sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A== +"@types/web@^0.0.138": + version "0.0.138" + resolved "https://registry.yarnpkg.com/@types/web/-/web-0.0.138.tgz#52ca1e688275a0b82a5522a7accaaa182aa029b1" + integrity sha512-oQD74hl+cNCZdSWIupJCXZ2azTuB3MJ/mrWlgYt+v4pD7/Dr78gl5hKAdieZNf9NrAqwUez79bHtnFVSNSscWA== -"@types/send@*": - version "0.17.4" - resolved "https://registry.yarnpkg.com/@types/send/-/send-0.17.4.tgz#6619cd24e7270793702e4e6a4b958a9010cfc57a" - integrity sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA== +"@types/ws@^7.2.0", "@types/ws@^7.4.4": + version "7.4.7" + resolved "https://registry.yarnpkg.com/@types/ws/-/ws-7.4.7.tgz#f7c390a36f7a0679aa69de2d501319f4f8d9b702" + integrity sha512-JQbbmxZTZehdc2iszGKs5oC3NFnjeay7mtAWrdt7qNtAVK0g19muApzAy4bm9byz79xa2ZnO/BOBC2R8RC5Lww== dependencies: - "@types/mime" "^1" "@types/node" "*" -"@types/serve-index@^1.9.1": - version "1.9.4" - resolved "https://registry.yarnpkg.com/@types/serve-index/-/serve-index-1.9.4.tgz#e6ae13d5053cb06ed36392110b4f9a49ac4ec898" - integrity sha512-qLpGZ/c2fhSs5gnYsQxtDEq3Oy8SXPClIXkW5ghvAvsNuVSA8k+gCONcUCS/UjLEYvYps+e8uBtfgXgvhwfNug== +"@typescript-eslint/eslint-plugin@^7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.13.1.tgz#cdc521c8bca38b55585cf30db787fb2abad3f9fd" + integrity sha512-kZqi+WZQaZfPKnsflLJQCz6Ze9FFSMfXrrIOcyargekQxG37ES7DJNpJUE9Q/X5n3yTIP/WPutVNzgknQ7biLg== dependencies: - "@types/express" "*" + "@eslint-community/regexpp" "^4.10.0" + "@typescript-eslint/scope-manager" "7.13.1" + "@typescript-eslint/type-utils" "7.13.1" + "@typescript-eslint/utils" "7.13.1" + "@typescript-eslint/visitor-keys" "7.13.1" + graphemer "^1.4.0" + ignore "^5.3.1" + natural-compare "^1.4.0" + ts-api-utils "^1.3.0" -"@types/serve-static@*", "@types/serve-static@^1.13.10": - version "1.15.5" - resolved "https://registry.yarnpkg.com/@types/serve-static/-/serve-static-1.15.5.tgz#15e67500ec40789a1e8c9defc2d32a896f05b033" - integrity sha512-PDRk21MnK70hja/YF8AHfC7yIsiQHn1rcXx7ijCFBX/k+XQJhQT/gw3xekXKJvx+5SXaMMS8oqQy09Mzvz2TuQ== +"@typescript-eslint/parser@^5.4.2 || ^6.0.0 || 7.0.0 - 7.2.0": + version "7.2.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-7.2.0.tgz#44356312aea8852a3a82deebdacd52ba614ec07a" + integrity sha512-5FKsVcHTk6TafQKQbuIVkXq58Fnbkd2wDL4LB7AURN7RUOu1utVP+G8+6u3ZhEroW3DF6hyo3ZEXxgKgp4KeCg== dependencies: - "@types/http-errors" "*" - "@types/mime" "*" - "@types/node" "*" + "@typescript-eslint/scope-manager" "7.2.0" + "@typescript-eslint/types" "7.2.0" + "@typescript-eslint/typescript-estree" "7.2.0" + "@typescript-eslint/visitor-keys" "7.2.0" + debug "^4.3.4" -"@types/sockjs@^0.3.33": - version "0.3.36" - resolved "https://registry.yarnpkg.com/@types/sockjs/-/sockjs-0.3.36.tgz#ce322cf07bcc119d4cbf7f88954f3a3bd0f67535" - integrity sha512-MK9V6NzAS1+Ud7JV9lJLFqW85VbC9dq3LmwZCuBe4wBDgKC0Kj/jd8Xl+nSviU+Qc3+m7umHHyHg//2KSa0a0Q== +"@typescript-eslint/scope-manager@7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-7.13.1.tgz#c08041206904bf36f0e6997efdb0ca775e0c452e" + integrity sha512-adbXNVEs6GmbzaCpymHQ0MB6E4TqoiVbC0iqG3uijR8ZYfpAXMGttouQzF4Oat3P2GxDVIrg7bMI/P65LiQZdg== dependencies: - "@types/node" "*" + "@typescript-eslint/types" "7.13.1" + "@typescript-eslint/visitor-keys" "7.13.1" -"@types/source-list-map@*": - version "0.1.2" - resolved "https://registry.yarnpkg.com/@types/source-list-map/-/source-list-map-0.1.2.tgz#0078836063ffaf17412349bba364087e0ac02ec9" - integrity sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA== +"@typescript-eslint/scope-manager@7.2.0": + version "7.2.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-7.2.0.tgz#cfb437b09a84f95a0930a76b066e89e35d94e3da" + integrity sha512-Qh976RbQM/fYtjx9hs4XkayYujB/aPwglw2choHmf3zBjB4qOywWSdt9+KLRdHubGcoSwBnXUH2sR3hkyaERRg== + dependencies: + "@typescript-eslint/types" "7.2.0" + "@typescript-eslint/visitor-keys" "7.2.0" -"@types/statuses@^2.0.4": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@types/statuses/-/statuses-2.0.5.tgz#f61ab46d5352fd73c863a1ea4e1cef3b0b51ae63" - integrity sha512-jmIUGWrAiwu3dZpxntxieC+1n/5c3mjrImkmOSQ2NC5uP6cYO4aAZDdSmRcI5C1oiTmqlZGHC+/NmJrKogbP5A== +"@typescript-eslint/type-utils@7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-7.13.1.tgz#63bec3f1fb43cf0bc409cbdb88ef96d118ca8632" + integrity sha512-aWDbLu1s9bmgPGXSzNCxELu+0+HQOapV/y+60gPXafR8e2g1Bifxzevaa+4L2ytCWm+CHqpELq4CSoN9ELiwCg== + dependencies: + "@typescript-eslint/typescript-estree" "7.13.1" + "@typescript-eslint/utils" "7.13.1" + debug "^4.3.4" + ts-api-utils "^1.3.0" -"@types/tapable@^1": - version "1.0.8" - resolved "https://registry.yarnpkg.com/@types/tapable/-/tapable-1.0.8.tgz#b94a4391c85666c7b73299fd3ad79d4faa435310" - integrity sha512-ipixuVrh2OdNmauvtT51o3d8z12p6LtFW9in7U79der/kwejjdNchQC5UMn5u/KxNoM7VHHOs/l8KS8uHxhODQ== +"@typescript-eslint/types@7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.13.1.tgz#787db283bd0b58751094c90d5b58bbf5e9fc9bd8" + integrity sha512-7K7HMcSQIAND6RBL4kDl24sG/xKM13cA85dc7JnmQXw2cBDngg7c19B++JzvJHRG3zG36n9j1i451GBzRuHchw== -"@types/testing-library__jest-dom@^5.9.1": - version "5.14.1" - resolved "https://registry.yarnpkg.com/@types/testing-library__jest-dom/-/testing-library__jest-dom-5.14.1.tgz#014162a5cee6571819d48e999980694e2f657c3c" - integrity sha512-Gk9vaXfbzc5zCXI9eYE9BI5BNHEp4D3FWjgqBE/ePGYElLAP+KvxBcsdkwfIVvezs605oiyd/VrpiHe3Oeg+Aw== - dependencies: - "@types/jest" "*" +"@typescript-eslint/types@7.2.0": + version "7.2.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.2.0.tgz#0feb685f16de320e8520f13cca30779c8b7c403f" + integrity sha512-XFtUHPI/abFhm4cbCDc5Ykc8npOKBSJePY3a3s+lwumt7XWJuzP5cZcfZ610MIPHjQjNsOLlYK8ASPaNG8UiyA== -"@types/trusted-types@*": - version "2.0.2" - resolved "https://registry.yarnpkg.com/@types/trusted-types/-/trusted-types-2.0.2.tgz#fc25ad9943bcac11cceb8168db4f275e0e72e756" - integrity sha512-F5DIZ36YVLE+PN+Zwws4kJogq47hNgX3Nx6WyDJ3kcplxyke3XIzB8uK5n/Lpm1HBsbGzd6nmGehL8cPekP+Tg== +"@typescript-eslint/typescript-estree@7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-7.13.1.tgz#3412841b130e070db2f675e3d9b8cb1ae49e1c3f" + integrity sha512-uxNr51CMV7npU1BxZzYjoVz9iyjckBduFBP0S5sLlh1tXYzHzgZ3BR9SVsNed+LmwKrmnqN3Kdl5t7eZ5TS1Yw== + dependencies: + "@typescript-eslint/types" "7.13.1" + "@typescript-eslint/visitor-keys" "7.13.1" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + minimatch "^9.0.4" + semver "^7.6.0" + ts-api-utils "^1.3.0" -"@types/uglify-js@*": - version "3.13.1" - resolved "https://registry.yarnpkg.com/@types/uglify-js/-/uglify-js-3.13.1.tgz#5e889e9e81e94245c75b6450600e1c5ea2878aea" - integrity sha512-O3MmRAk6ZuAKa9CHgg0Pr0+lUOqoMLpc9AS4R8ano2auvsg7IE8syF3Xh/NPr26TWklxYcqoEEFdzLLs1fV9PQ== +"@typescript-eslint/typescript-estree@7.2.0": + version "7.2.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-7.2.0.tgz#5beda2876c4137f8440c5a84b4f0370828682556" + integrity sha512-cyxS5WQQCoBwSakpMrvMXuMDEbhOo9bNHHrNcEWis6XHx6KF518tkF1wBvKIn/tpq5ZpUYK7Bdklu8qY0MsFIA== dependencies: - source-map "^0.6.1" + "@typescript-eslint/types" "7.2.0" + "@typescript-eslint/visitor-keys" "7.2.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + minimatch "9.0.3" + semver "^7.5.4" + ts-api-utils "^1.0.1" -"@types/uri-templates@^0.1.34": - version "0.1.34" - resolved "https://registry.yarnpkg.com/@types/uri-templates/-/uri-templates-0.1.34.tgz#be9b6fb7d205c641e4bf1c46776f84e9b26ad631" - integrity sha512-13v4r/Op3iEO1y6FvEHQjrUNnrNyO67SigdFC9n80sVfsrM2AWJRNYbE1pBs4/p87I7z1J979JGeLAo3rM1L/Q== +"@typescript-eslint/utils@7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-7.13.1.tgz#611083379caa0d3a2c09d126c65065a3e4337ba2" + integrity sha512-h5MzFBD5a/Gh/fvNdp9pTfqJAbuQC4sCN2WzuXme71lqFJsZtLbjxfSk4r3p02WIArOF9N94pdsLiGutpDbrXQ== + dependencies: + "@eslint-community/eslint-utils" "^4.4.0" + "@typescript-eslint/scope-manager" "7.13.1" + "@typescript-eslint/types" "7.13.1" + "@typescript-eslint/typescript-estree" "7.13.1" -"@types/uuid@^8.3.4": - version "8.3.4" - resolved "https://registry.yarnpkg.com/@types/uuid/-/uuid-8.3.4.tgz#bd86a43617df0594787d38b735f55c805becf1bc" - integrity sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw== +"@typescript-eslint/visitor-keys@7.13.1": + version "7.13.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-7.13.1.tgz#9c229a795a919db61f2d7f2337ef584ac05fbe96" + integrity sha512-k/Bfne7lrP7hcb7m9zSsgcBmo+8eicqqfNAJ7uUY+jkTFpKeH2FSkWpFRtimBxgkyvqfu9jTPRbYOvud6isdXA== + dependencies: + "@typescript-eslint/types" "7.13.1" + eslint-visitor-keys "^3.4.3" -"@types/w3c-web-usb@^1.0.6": - version "1.0.10" - resolved "https://registry.yarnpkg.com/@types/w3c-web-usb/-/w3c-web-usb-1.0.10.tgz#cf89cccd2d93b6245e784c19afe0a9f5038d4528" - integrity sha512-CHgUI5kTc/QLMP8hODUHhge0D4vx+9UiAwIGiT0sTy/B2XpdX1U5rJt6JSISgr6ikRT7vxV9EVAFeYZqUnl1gQ== +"@typescript-eslint/visitor-keys@7.2.0": + version "7.2.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-7.2.0.tgz#5035f177752538a5750cca1af6044b633610bf9e" + integrity sha512-c6EIQRHhcpl6+tO8EMR+kjkkV+ugUNXOmeASA1rlzkd8EPIriavpWoiEz1HR/VLhbVIdhqnV6E7JZm00cBDx2A== + dependencies: + "@typescript-eslint/types" "7.2.0" + eslint-visitor-keys "^3.4.1" -"@types/web@^0.0.138": - version "0.0.138" - resolved "https://registry.yarnpkg.com/@types/web/-/web-0.0.138.tgz#52ca1e688275a0b82a5522a7accaaa182aa029b1" - integrity sha512-oQD74hl+cNCZdSWIupJCXZ2azTuB3MJ/mrWlgYt+v4pD7/Dr78gl5hKAdieZNf9NrAqwUez79bHtnFVSNSscWA== +"@ungap/structured-clone@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" + integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== + +"@walletconnect/core@2.11.2": + version "2.11.2" + resolved "https://registry.yarnpkg.com/@walletconnect/core/-/core-2.11.2.tgz#35286be92c645fa461fecc0dfe25de9f076fca8f" + integrity sha512-bB4SiXX8hX3/hyBfVPC5gwZCXCl+OPj+/EDVM71iAO3TDsh78KPbrVAbDnnsbHzZVHlsMohtXX3j5XVsheN3+g== + dependencies: + "@walletconnect/heartbeat" "1.2.1" + "@walletconnect/jsonrpc-provider" "1.0.13" + "@walletconnect/jsonrpc-types" "1.0.3" + "@walletconnect/jsonrpc-utils" "1.0.8" + "@walletconnect/jsonrpc-ws-connection" "1.0.14" + "@walletconnect/keyvaluestorage" "^1.1.1" + "@walletconnect/logger" "^2.0.1" + "@walletconnect/relay-api" "^1.0.9" + "@walletconnect/relay-auth" "^1.0.4" + "@walletconnect/safe-json" "^1.0.2" + "@walletconnect/time" "^1.0.2" + "@walletconnect/types" "2.11.2" + "@walletconnect/utils" "2.11.2" + events "^3.3.0" + isomorphic-unfetch "3.1.0" + lodash.isequal "4.5.0" + uint8arrays "^3.1.0" -"@types/webpack-sources@*": - version "3.2.0" - resolved "https://registry.yarnpkg.com/@types/webpack-sources/-/webpack-sources-3.2.0.tgz#16d759ba096c289034b26553d2df1bf45248d38b" - integrity sha512-Ft7YH3lEVRQ6ls8k4Ff1oB4jN6oy/XmU6tQISKdhfh+1mR+viZFphS6WL0IrtDOzvefmJg5a0s7ZQoRXwqTEFg== +"@walletconnect/environment@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@walletconnect/environment/-/environment-1.0.1.tgz#1d7f82f0009ab821a2ba5ad5e5a7b8ae3b214cd7" + integrity sha512-T426LLZtHj8e8rYnKfzsw1aG6+M0BT1ZxayMdv/p8yM0MU+eJDISqNY3/bccxRr4LrF9csq02Rhqt08Ibl0VRg== dependencies: - "@types/node" "*" - "@types/source-list-map" "*" - source-map "^0.7.3" + tslib "1.14.1" -"@types/webpack@^4": - version "4.41.30" - resolved "https://registry.yarnpkg.com/@types/webpack/-/webpack-4.41.30.tgz#fd3db6d0d41e145a8eeeafcd3c4a7ccde9068ddc" - integrity sha512-GUHyY+pfuQ6haAfzu4S14F+R5iGRwN6b2FRNJY7U0NilmFAqbsOfK6j1HwuLBAqwRIT+pVdNDJGJ6e8rpp0KHA== +"@walletconnect/events@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@walletconnect/events/-/events-1.0.1.tgz#2b5f9c7202019e229d7ccae1369a9e86bda7816c" + integrity sha512-NPTqaoi0oPBVNuLv7qPaJazmGHs5JGyO8eEAk5VGKmJzDR7AHzD4k6ilox5kxk1iwiOnFopBOOMLs86Oa76HpQ== dependencies: - "@types/node" "*" - "@types/tapable" "^1" - "@types/uglify-js" "*" - "@types/webpack-sources" "*" - anymatch "^3.0.0" - source-map "^0.6.0" - -"@types/wrap-ansi@^3.0.0": - version "3.0.0" - resolved "https://registry.yarnpkg.com/@types/wrap-ansi/-/wrap-ansi-3.0.0.tgz#18b97a972f94f60a679fd5c796d96421b9abb9fd" - integrity sha512-ltIpx+kM7g/MLRZfkbL7EsCEjfzCcScLpkg37eXEtx5kmrAKBkTJwd1GIAjDSL8wTpM6Hzn5YO4pSb91BEwu1g== + keyvaluestorage-interface "^1.0.0" + tslib "1.14.1" -"@types/ws@^7.2.0", "@types/ws@^7.4.4": - version "7.4.7" - resolved "https://registry.npmjs.org/@types/ws/-/ws-7.4.7.tgz#f7c390a36f7a0679aa69de2d501319f4f8d9b702" - integrity sha512-JQbbmxZTZehdc2iszGKs5oC3NFnjeay7mtAWrdt7qNtAVK0g19muApzAy4bm9byz79xa2ZnO/BOBC2R8RC5Lww== +"@walletconnect/heartbeat@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@walletconnect/heartbeat/-/heartbeat-1.2.1.tgz#afaa3a53232ae182d7c9cff41c1084472d8f32e9" + integrity sha512-yVzws616xsDLJxuG/28FqtZ5rzrTA4gUjdEMTbWB5Y8V1XHRmqq4efAxCw5ie7WjbXFSUyBHaWlMR+2/CpQC5Q== dependencies: - "@types/node" "*" + "@walletconnect/events" "^1.0.1" + "@walletconnect/time" "^1.0.2" + tslib "1.14.1" -"@types/ws@^8.2.2", "@types/ws@^8.5.5": - version "8.5.10" - resolved "https://registry.yarnpkg.com/@types/ws/-/ws-8.5.10.tgz#4acfb517970853fa6574a3a6886791d04a396787" - integrity sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A== +"@walletconnect/jsonrpc-provider@1.0.13": + version "1.0.13" + resolved "https://registry.yarnpkg.com/@walletconnect/jsonrpc-provider/-/jsonrpc-provider-1.0.13.tgz#9a74da648d015e1fffc745f0c7d629457f53648b" + integrity sha512-K73EpThqHnSR26gOyNEL+acEex3P7VWZe6KE12ZwKzAt2H4e5gldZHbjsu2QR9cLeJ8AXuO7kEMOIcRv1QEc7g== dependencies: - "@types/node" "*" + "@walletconnect/jsonrpc-utils" "^1.0.8" + "@walletconnect/safe-json" "^1.0.2" + tslib "1.14.1" -"@types/yargs-parser@*": - version "20.2.1" - resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-20.2.1.tgz#3b9ce2489919d9e4fea439b76916abc34b2df129" - integrity sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw== +"@walletconnect/jsonrpc-types@1.0.3": + version "1.0.3" + resolved "https://registry.yarnpkg.com/@walletconnect/jsonrpc-types/-/jsonrpc-types-1.0.3.tgz#65e3b77046f1a7fa8347ae02bc1b841abe6f290c" + integrity sha512-iIQ8hboBl3o5ufmJ8cuduGad0CQm3ZlsHtujv9Eu16xq89q+BG7Nh5VLxxUgmtpnrePgFkTwXirCTkwJH1v+Yw== + dependencies: + keyvaluestorage-interface "^1.0.0" + tslib "1.14.1" -"@types/yargs@^16.0.0": - version "16.0.4" - resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-16.0.4.tgz#26aad98dd2c2a38e421086ea9ad42b9e51642977" - integrity sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw== +"@walletconnect/jsonrpc-types@^1.0.2", "@walletconnect/jsonrpc-types@^1.0.3": + version "1.0.4" + resolved "https://registry.yarnpkg.com/@walletconnect/jsonrpc-types/-/jsonrpc-types-1.0.4.tgz#ce1a667d79eadf2a2d9d002c152ceb68739c230c" + integrity sha512-P6679fG/M+wuWg9TY8mh6xFSdYnFyFjwFelxyISxMDrlbXokorEVXYOxiqEbrU3x1BmBoCAJJ+vtEaEoMlpCBQ== dependencies: - "@types/yargs-parser" "*" + events "^3.3.0" + keyvaluestorage-interface "^1.0.0" -"@types/yargs@^17.0.8": - version "17.0.32" - resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-17.0.32.tgz#030774723a2f7faafebf645f4e5a48371dca6229" - integrity sha512-xQ67Yc/laOG5uMfX/093MRlGGCIBzZMarVa+gfNKJxWAIgykYpVGkBdbqEzGDDfCrVUj6Hiff4mTZ5BA6TmAog== +"@walletconnect/jsonrpc-utils@1.0.8", "@walletconnect/jsonrpc-utils@^1.0.6", "@walletconnect/jsonrpc-utils@^1.0.8": + version "1.0.8" + resolved "https://registry.yarnpkg.com/@walletconnect/jsonrpc-utils/-/jsonrpc-utils-1.0.8.tgz#82d0cc6a5d6ff0ecc277cb35f71402c91ad48d72" + integrity sha512-vdeb03bD8VzJUL6ZtzRYsFMq1eZQcM3EAzT0a3st59dyLfJ0wq+tKMpmGH7HlB7waD858UWgfIcudbPFsbzVdw== dependencies: - "@types/yargs-parser" "*" + "@walletconnect/environment" "^1.0.1" + "@walletconnect/jsonrpc-types" "^1.0.3" + tslib "1.14.1" -"@typescript-eslint/eslint-plugin@^5.5.0", "@typescript-eslint/eslint-plugin@^5.60.1": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.62.0.tgz#aeef0328d172b9e37d9bab6dbc13b87ed88977db" - integrity sha512-TiZzBSJja/LbhNPvk6yc0JrX9XqhQ0hdh6M2svYfsHGejaKFIAGd9MQ+ERIMzLGlN/kZoYIgdxFV0PuljTKXag== +"@walletconnect/jsonrpc-ws-connection@1.0.14": + version "1.0.14" + resolved "https://registry.yarnpkg.com/@walletconnect/jsonrpc-ws-connection/-/jsonrpc-ws-connection-1.0.14.tgz#eec700e74766c7887de2bd76c91a0206628732aa" + integrity sha512-Jsl6fC55AYcbkNVkwNM6Jo+ufsuCQRqViOQ8ZBPH9pRREHH9welbBiszuTLqEJiQcO/6XfFDl6bzCJIkrEi8XA== dependencies: - "@eslint-community/regexpp" "^4.4.0" - "@typescript-eslint/scope-manager" "5.62.0" - "@typescript-eslint/type-utils" "5.62.0" - "@typescript-eslint/utils" "5.62.0" - debug "^4.3.4" - graphemer "^1.4.0" - ignore "^5.2.0" - natural-compare-lite "^1.4.0" - semver "^7.3.7" - tsutils "^3.21.0" + "@walletconnect/jsonrpc-utils" "^1.0.6" + "@walletconnect/safe-json" "^1.0.2" + events "^3.3.0" + ws "^7.5.1" -"@typescript-eslint/experimental-utils@^5.0.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-5.62.0.tgz#14559bf73383a308026b427a4a6129bae2146741" - integrity sha512-RTXpeB3eMkpoclG3ZHft6vG/Z30azNHuqY6wKPBHlVMZFuEvrtlEDe8gMqDb+SO+9hjC/pLekeSCryf9vMZlCw== +"@walletconnect/keyvaluestorage@^1.1.1": + version "1.1.1" + resolved "https://registry.yarnpkg.com/@walletconnect/keyvaluestorage/-/keyvaluestorage-1.1.1.tgz#dd2caddabfbaf80f6b8993a0704d8b83115a1842" + integrity sha512-V7ZQq2+mSxAq7MrRqDxanTzu2RcElfK1PfNYiaVnJgJ7Q7G7hTVwF8voIBx92qsRyGHZihrwNPHuZd1aKkd0rA== dependencies: - "@typescript-eslint/utils" "5.62.0" + "@walletconnect/safe-json" "^1.0.1" + idb-keyval "^6.2.1" + unstorage "^1.9.0" -"@typescript-eslint/parser@^5.5.0", "@typescript-eslint/parser@^5.60.1": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.62.0.tgz#1b63d082d849a2fcae8a569248fbe2ee1b8a56c7" - integrity sha512-VlJEV0fOQ7BExOsHYAGrgbEiZoi8D+Bl2+f6V2RrXerRSylnp+ZBHmPvaIa8cz0Ajx7WO7Z5RqfgYg7ED1nRhA== +"@walletconnect/logger@^2.0.1": + version "2.1.2" + resolved "https://registry.yarnpkg.com/@walletconnect/logger/-/logger-2.1.2.tgz#813c9af61b96323a99f16c10089bfeb525e2a272" + integrity sha512-aAb28I3S6pYXZHQm5ESB+V6rDqIYfsnHaQyzFbwUUBFY4H0OXx/YtTl8lvhUNhMMfb9UxbwEBS253TlXUYJWSw== dependencies: - "@typescript-eslint/scope-manager" "5.62.0" - "@typescript-eslint/types" "5.62.0" - "@typescript-eslint/typescript-estree" "5.62.0" - debug "^4.3.4" + "@walletconnect/safe-json" "^1.0.2" + pino "7.11.0" -"@typescript-eslint/scope-manager@5.62.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz#d9457ccc6a0b8d6b37d0eb252a23022478c5460c" - integrity sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w== +"@walletconnect/modal-core@2.6.2": + version "2.6.2" + resolved "https://registry.yarnpkg.com/@walletconnect/modal-core/-/modal-core-2.6.2.tgz#d73e45d96668764e0c8668ea07a45bb8b81119e9" + integrity sha512-cv8ibvdOJQv2B+nyxP9IIFdxvQznMz8OOr/oR/AaUZym4hjXNL/l1a2UlSQBXrVjo3xxbouMxLb3kBsHoYP2CA== dependencies: - "@typescript-eslint/types" "5.62.0" - "@typescript-eslint/visitor-keys" "5.62.0" + valtio "1.11.2" -"@typescript-eslint/type-utils@5.62.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-5.62.0.tgz#286f0389c41681376cdad96b309cedd17d70346a" - integrity sha512-xsSQreu+VnfbqQpW5vnCJdq1Z3Q0U31qiWmRhr98ONQmcp/yhiPJFPq8MXiJVLiksmOKSjIldZzkebzHuCGzew== +"@walletconnect/modal-ui@2.6.2": + version "2.6.2" + resolved "https://registry.yarnpkg.com/@walletconnect/modal-ui/-/modal-ui-2.6.2.tgz#fa57c087c57b7f76aaae93deab0f84bb68b59cf9" + integrity sha512-rbdstM1HPGvr7jprQkyPggX7rP4XiCG85ZA+zWBEX0dVQg8PpAgRUqpeub4xQKDgY7pY/xLRXSiCVdWGqvG2HA== dependencies: - "@typescript-eslint/typescript-estree" "5.62.0" - "@typescript-eslint/utils" "5.62.0" - debug "^4.3.4" - tsutils "^3.21.0" + "@walletconnect/modal-core" "2.6.2" + lit "2.8.0" + motion "10.16.2" + qrcode "1.5.3" -"@typescript-eslint/types@5.62.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.62.0.tgz#258607e60effa309f067608931c3df6fed41fd2f" - integrity sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ== +"@walletconnect/modal@2.6.2": + version "2.6.2" + resolved "https://registry.yarnpkg.com/@walletconnect/modal/-/modal-2.6.2.tgz#4b534a836f5039eeb3268b80be7217a94dd12651" + integrity sha512-eFopgKi8AjKf/0U4SemvcYw9zlLpx9njVN8sf6DAkowC2Md0gPU/UNEbH1Wwj407pEKnEds98pKWib1NN1ACoA== + dependencies: + "@walletconnect/modal-core" "2.6.2" + "@walletconnect/modal-ui" "2.6.2" -"@typescript-eslint/typescript-estree@5.62.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz#7d17794b77fabcac615d6a48fb143330d962eb9b" - integrity sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA== +"@walletconnect/relay-api@^1.0.9": + version "1.0.10" + resolved "https://registry.yarnpkg.com/@walletconnect/relay-api/-/relay-api-1.0.10.tgz#5aef3cd07c21582b968136179aa75849dcc65499" + integrity sha512-tqrdd4zU9VBNqUaXXQASaexklv6A54yEyQQEXYOCr+Jz8Ket0dmPBDyg19LVSNUN2cipAghQc45/KVmfFJ0cYw== dependencies: - "@typescript-eslint/types" "5.62.0" - "@typescript-eslint/visitor-keys" "5.62.0" - debug "^4.3.4" - globby "^11.1.0" - is-glob "^4.0.3" - semver "^7.3.7" - tsutils "^3.21.0" + "@walletconnect/jsonrpc-types" "^1.0.2" -"@typescript-eslint/utils@5.62.0", "@typescript-eslint/utils@^5.58.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.62.0.tgz#141e809c71636e4a75daa39faed2fb5f4b10df86" - integrity sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ== +"@walletconnect/relay-auth@^1.0.4": + version "1.0.4" + resolved "https://registry.yarnpkg.com/@walletconnect/relay-auth/-/relay-auth-1.0.4.tgz#0b5c55c9aa3b0ef61f526ce679f3ff8a5c4c2c7c" + integrity sha512-kKJcS6+WxYq5kshpPaxGHdwf5y98ZwbfuS4EE/NkQzqrDFm5Cj+dP8LofzWvjrrLkZq7Afy7WrQMXdLy8Sx7HQ== dependencies: - "@eslint-community/eslint-utils" "^4.2.0" - "@types/json-schema" "^7.0.9" - "@types/semver" "^7.3.12" - "@typescript-eslint/scope-manager" "5.62.0" - "@typescript-eslint/types" "5.62.0" - "@typescript-eslint/typescript-estree" "5.62.0" - eslint-scope "^5.1.1" - semver "^7.3.7" - -"@typescript-eslint/visitor-keys@5.62.0": - version "5.62.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz#2174011917ce582875954ffe2f6912d5931e353e" - integrity sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw== - dependencies: - "@typescript-eslint/types" "5.62.0" - eslint-visitor-keys "^3.3.0" + "@stablelib/ed25519" "^1.0.2" + "@stablelib/random" "^1.0.1" + "@walletconnect/safe-json" "^1.0.1" + "@walletconnect/time" "^1.0.2" + tslib "1.14.1" + uint8arrays "^3.0.0" -"@ungap/promise-all-settled@1.1.2": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz#aa58042711d6e3275dd37dc597e5d31e8c290a44" - integrity sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q== - -"@webassemblyjs/ast@1.12.1", "@webassemblyjs/ast@^1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.12.1.tgz#bb16a0e8b1914f979f45864c23819cc3e3f0d4bb" - integrity sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg== - dependencies: - "@webassemblyjs/helper-numbers" "1.11.6" - "@webassemblyjs/helper-wasm-bytecode" "1.11.6" - -"@webassemblyjs/floating-point-hex-parser@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz#dacbcb95aff135c8260f77fa3b4c5fea600a6431" - integrity sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw== - -"@webassemblyjs/helper-api-error@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz#6132f68c4acd59dcd141c44b18cbebbd9f2fa768" - integrity sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q== - -"@webassemblyjs/helper-buffer@1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.12.1.tgz#6df20d272ea5439bf20ab3492b7fb70e9bfcb3f6" - integrity sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw== - -"@webassemblyjs/helper-numbers@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz#cbce5e7e0c1bd32cf4905ae444ef64cea919f1b5" - integrity sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g== - dependencies: - "@webassemblyjs/floating-point-hex-parser" "1.11.6" - "@webassemblyjs/helper-api-error" "1.11.6" - "@xtuc/long" "4.2.2" - -"@webassemblyjs/helper-wasm-bytecode@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz#bb2ebdb3b83aa26d9baad4c46d4315283acd51e9" - integrity sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA== - -"@webassemblyjs/helper-wasm-section@1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.12.1.tgz#3da623233ae1a60409b509a52ade9bc22a37f7bf" - integrity sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g== - dependencies: - "@webassemblyjs/ast" "1.12.1" - "@webassemblyjs/helper-buffer" "1.12.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.6" - "@webassemblyjs/wasm-gen" "1.12.1" - -"@webassemblyjs/ieee754@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz#bb665c91d0b14fffceb0e38298c329af043c6e3a" - integrity sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg== - dependencies: - "@xtuc/ieee754" "^1.2.0" - -"@webassemblyjs/leb128@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/leb128/-/leb128-1.11.6.tgz#70e60e5e82f9ac81118bc25381a0b283893240d7" - integrity sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ== - dependencies: - "@xtuc/long" "4.2.2" - -"@webassemblyjs/utf8@1.11.6": - version "1.11.6" - resolved "https://registry.yarnpkg.com/@webassemblyjs/utf8/-/utf8-1.11.6.tgz#90f8bc34c561595fe156603be7253cdbcd0fab5a" - integrity sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA== - -"@webassemblyjs/wasm-edit@^1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.12.1.tgz#9f9f3ff52a14c980939be0ef9d5df9ebc678ae3b" - integrity sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g== - dependencies: - "@webassemblyjs/ast" "1.12.1" - "@webassemblyjs/helper-buffer" "1.12.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.6" - "@webassemblyjs/helper-wasm-section" "1.12.1" - "@webassemblyjs/wasm-gen" "1.12.1" - "@webassemblyjs/wasm-opt" "1.12.1" - "@webassemblyjs/wasm-parser" "1.12.1" - "@webassemblyjs/wast-printer" "1.12.1" - -"@webassemblyjs/wasm-gen@1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.12.1.tgz#a6520601da1b5700448273666a71ad0a45d78547" - integrity sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w== - dependencies: - "@webassemblyjs/ast" "1.12.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.6" - "@webassemblyjs/ieee754" "1.11.6" - "@webassemblyjs/leb128" "1.11.6" - "@webassemblyjs/utf8" "1.11.6" - -"@webassemblyjs/wasm-opt@1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.12.1.tgz#9e6e81475dfcfb62dab574ac2dda38226c232bc5" - integrity sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg== - dependencies: - "@webassemblyjs/ast" "1.12.1" - "@webassemblyjs/helper-buffer" "1.12.1" - "@webassemblyjs/wasm-gen" "1.12.1" - "@webassemblyjs/wasm-parser" "1.12.1" - -"@webassemblyjs/wasm-parser@1.12.1", "@webassemblyjs/wasm-parser@^1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.12.1.tgz#c47acb90e6f083391e3fa61d113650eea1e95937" - integrity sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ== - dependencies: - "@webassemblyjs/ast" "1.12.1" - "@webassemblyjs/helper-api-error" "1.11.6" - "@webassemblyjs/helper-wasm-bytecode" "1.11.6" - "@webassemblyjs/ieee754" "1.11.6" - "@webassemblyjs/leb128" "1.11.6" - "@webassemblyjs/utf8" "1.11.6" - -"@webassemblyjs/wast-printer@1.12.1": - version "1.12.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-printer/-/wast-printer-1.12.1.tgz#bcecf661d7d1abdaf989d8341a4833e33e2b31ac" - integrity sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA== - dependencies: - "@webassemblyjs/ast" "1.12.1" - "@xtuc/long" "4.2.2" - -"@webpack-cli/configtest@^2.1.1": - version "2.1.1" - resolved "https://registry.yarnpkg.com/@webpack-cli/configtest/-/configtest-2.1.1.tgz#3b2f852e91dac6e3b85fb2a314fb8bef46d94646" - integrity sha512-wy0mglZpDSiSS0XHrVR+BAdId2+yxPSoJW8fsna3ZpYSlufjvxnP4YbKTCBZnNIcGN4r6ZPXV55X4mYExOfLmw== +"@walletconnect/safe-json@^1.0.1", "@walletconnect/safe-json@^1.0.2": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@walletconnect/safe-json/-/safe-json-1.0.2.tgz#7237e5ca48046e4476154e503c6d3c914126fa77" + integrity sha512-Ogb7I27kZ3LPC3ibn8ldyUr5544t3/STow9+lzz7Sfo808YD7SBWk7SAsdBFlYgP2zDRy2hS3sKRcuSRM0OTmA== + dependencies: + tslib "1.14.1" + +"@walletconnect/sign-client@2.11.2": + version "2.11.2" + resolved "https://registry.yarnpkg.com/@walletconnect/sign-client/-/sign-client-2.11.2.tgz#855609653855f0d23b0502cdbdcf43402e34c459" + integrity sha512-MfBcuSz2GmMH+P7MrCP46mVE5qhP0ZyWA0FyIH6/WuxQ6G+MgKsGfaITqakpRPsykWOJq8tXMs3XvUPDU413OQ== + dependencies: + "@walletconnect/core" "2.11.2" + "@walletconnect/events" "^1.0.1" + "@walletconnect/heartbeat" "1.2.1" + "@walletconnect/jsonrpc-utils" "1.0.8" + "@walletconnect/logger" "^2.0.1" + "@walletconnect/time" "^1.0.2" + "@walletconnect/types" "2.11.2" + "@walletconnect/utils" "2.11.2" + events "^3.3.0" -"@webpack-cli/info@^2.0.2": - version "2.0.2" - resolved "https://registry.yarnpkg.com/@webpack-cli/info/-/info-2.0.2.tgz#cc3fbf22efeb88ff62310cf885c5b09f44ae0fdd" - integrity sha512-zLHQdI/Qs1UyT5UBdWNqsARasIA+AaF8t+4u2aS2nEpBQh2mWIVb8qAklq0eUENnC5mOItrIB4LiS9xMtph18A== +"@walletconnect/time@^1.0.2": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@walletconnect/time/-/time-1.0.2.tgz#6c5888b835750ecb4299d28eecc5e72c6d336523" + integrity sha512-uzdd9woDcJ1AaBZRhqy5rNC9laqWGErfc4dxA9a87mPdKOgWMD85mcFo9dIYIts/Jwocfwn07EC6EzclKubk/g== + dependencies: + tslib "1.14.1" -"@webpack-cli/serve@^2.0.5": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@webpack-cli/serve/-/serve-2.0.5.tgz#325db42395cd49fe6c14057f9a900e427df8810e" - integrity sha512-lqaoKnRYBdo1UgDX8uF24AfGMifWK19TxPmM5FHc2vAGxrJ/qtyUyFBWoY1tISZdelsQ5fBcOusifo5o5wSJxQ== +"@walletconnect/types@2.11.2": + version "2.11.2" + resolved "https://registry.yarnpkg.com/@walletconnect/types/-/types-2.11.2.tgz#d0359dd4106fcaa1634241a00428d3ea08d0d3c7" + integrity sha512-p632MFB+lJbip2cvtXPBQslpUdiw1sDtQ5y855bOlAGquay+6fZ4h1DcDePeKQDQM3P77ax2a9aNPZxV6y/h1Q== + dependencies: + "@walletconnect/events" "^1.0.1" + "@walletconnect/heartbeat" "1.2.1" + "@walletconnect/jsonrpc-types" "1.0.3" + "@walletconnect/keyvaluestorage" "^1.1.1" + "@walletconnect/logger" "^2.0.1" + events "^3.3.0" -"@xtuc/ieee754@^1.2.0": - version "1.2.0" - resolved "https://registry.yarnpkg.com/@xtuc/ieee754/-/ieee754-1.2.0.tgz#eef014a3145ae477a1cbc00cd1e552336dceb790" - integrity sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA== +"@walletconnect/utils@2.11.2": + version "2.11.2" + resolved "https://registry.yarnpkg.com/@walletconnect/utils/-/utils-2.11.2.tgz#dee0f19adf5e38543612cbe9fa4de7ed28eb7e85" + integrity sha512-LyfdmrnZY6dWqlF4eDrx5jpUwsB2bEPjoqR5Z6rXPiHJKUOdJt7az+mNOn5KTSOlRpd1DmozrBrWr+G9fFLYVw== + dependencies: + "@stablelib/chacha20poly1305" "1.0.1" + "@stablelib/hkdf" "1.0.1" + "@stablelib/random" "^1.0.2" + "@stablelib/sha256" "1.0.1" + "@stablelib/x25519" "^1.0.3" + "@walletconnect/relay-api" "^1.0.9" + "@walletconnect/safe-json" "^1.0.2" + "@walletconnect/time" "^1.0.2" + "@walletconnect/types" "2.11.2" + "@walletconnect/window-getters" "^1.0.1" + "@walletconnect/window-metadata" "^1.0.1" + detect-browser "5.3.0" + query-string "7.1.3" + uint8arrays "^3.1.0" + +"@walletconnect/window-getters@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@walletconnect/window-getters/-/window-getters-1.0.1.tgz#f36d1c72558a7f6b87ecc4451fc8bd44f63cbbdc" + integrity sha512-vHp+HqzGxORPAN8gY03qnbTMnhqIwjeRJNOMOAzePRg4xVEEE2WvYsI9G2NMjOknA8hnuYbU3/hwLcKbjhc8+Q== + dependencies: + tslib "1.14.1" -"@xtuc/long@4.2.2": - version "4.2.2" - resolved "https://registry.yarnpkg.com/@xtuc/long/-/long-4.2.2.tgz#d291c6a4e97989b5c61d9acf396ae4fe133a718d" - integrity sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ== +"@walletconnect/window-metadata@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@walletconnect/window-metadata/-/window-metadata-1.0.1.tgz#2124f75447b7e989e4e4e1581d55d25bc75f7be5" + integrity sha512-9koTqyGrM2cqFRW517BPY/iEtUDx2r1+Pwwu5m7sJ7ka79wi3EyqhqcICk/yDmv6jAS1rjKgTKXlEhanYjijcA== + dependencies: + "@walletconnect/window-getters" "^1.0.1" + tslib "1.14.1" JSONStream@^1.3.5: version "1.3.5" @@ -3856,46 +1733,15 @@ JSONStream@^1.3.5: jsonparse "^1.2.0" through ">=2.2.7 <3" -abbrev@1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" - integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== - -accepts@~1.3.4, accepts@~1.3.5: - version "1.3.7" - resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.7.tgz#531bc726517a3b2b41f850021c6cc15eaab507cd" - integrity sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA== - dependencies: - mime-types "~2.1.24" - negotiator "0.6.2" - -accepts@~1.3.8: - version "1.3.8" - resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" - integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== - dependencies: - mime-types "~2.1.34" - negotiator "0.6.3" - -acorn-import-attributes@^1.9.5: - version "1.9.5" - resolved "https://registry.yarnpkg.com/acorn-import-attributes/-/acorn-import-attributes-1.9.5.tgz#7eb1557b1ba05ef18b5ed0ec67591bfab04688ef" - integrity sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ== - -acorn-jsx@^5.3.1: +acorn-jsx@^5.3.2: version "5.3.2" resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== -acorn@^7.4.0: - version "7.4.1" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" - integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== - -acorn@^8.7.1, acorn@^8.8.2: - version "8.11.2" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.11.2.tgz#ca0d78b51895be5390a5903c5b3bdcdaf78ae40b" - integrity sha512-nc0Axzp/0FILLEVsm4fNwLCwMttvhEI263QtVPQcbpfZZ3ts0hLsZGOpE6czNlid7CJ9MlyH8reXkpsf3YUY4w== +acorn@^8.11.3, acorn@^8.9.0: + version "8.11.3" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.11.3.tgz#71e0b14e13a4ec160724b38fb7b0f233b1b81d7a" + integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== agent-base@6, agent-base@^6.0.2: version "6.0.2" @@ -3904,41 +1750,14 @@ agent-base@6, agent-base@^6.0.2: dependencies: debug "4" -agentkeepalive@^4.1.3, agentkeepalive@^4.2.1, agentkeepalive@^4.5.0: +agentkeepalive@^4.5.0: version "4.5.0" resolved "https://registry.yarnpkg.com/agentkeepalive/-/agentkeepalive-4.5.0.tgz#2673ad1389b3c418c5a20c5d7364f93ca04be923" integrity sha512-5GG/5IbQQpC9FpkRGsSvZI5QYeSCzlJHdpBQntCsuTOxhKD8lqKhrleg2Yi7yvMIf82Ycmmqln9U8V9qwEiJew== dependencies: humanize-ms "^1.2.1" -aggregate-error@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" - integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== - dependencies: - clean-stack "^2.0.0" - indent-string "^4.0.0" - -ajv-formats@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/ajv-formats/-/ajv-formats-2.1.1.tgz#6e669400659eb74973bbf2e33327180a0996b520" - integrity sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA== - dependencies: - ajv "^8.0.0" - -ajv-keywords@^3.5.2: - version "3.5.2" - resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz#31f29da5ab6e00d1c2d329acf7b5929614d5014d" - integrity sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ== - -ajv-keywords@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-5.1.0.tgz#69d4d385a4733cdbeab44964a1170a88f87f0e16" - integrity sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw== - dependencies: - fast-deep-equal "^3.1.3" - -ajv@^6.10.0, ajv@^6.12.4, ajv@^6.12.5: +ajv@^6.12.4: version "6.12.6" resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== @@ -3948,62 +1767,20 @@ ajv@^6.10.0, ajv@^6.12.4, ajv@^6.12.5: json-schema-traverse "^0.4.1" uri-js "^4.2.2" -ajv@^8.0.0, ajv@^8.9.0: - version "8.12.0" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1" - integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA== - dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" - -ajv@^8.0.1: - version "8.6.2" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.6.2.tgz#2fb45e0e5fcbc0813326c1c3da535d1881bb0571" - integrity sha512-9807RlWAgT564wT+DjeyU5OFMPjmzxVobvDFmNAhY+5zD6A2ly3jDp6sgnfyDtlIQ+7H97oc/DGCzzfu9rjw9w== - dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" - -ansi-colors@4.1.1, ansi-colors@^4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.1.tgz#cbb9ae256bf750af1eab344f229aa27fe94ba348" - integrity sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA== - -ansi-escapes@^4.3.2: - version "4.3.2" - resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" - integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== - dependencies: - type-fest "^0.21.3" - -ansi-html-community@^0.0.8: - version "0.0.8" - resolved "https://registry.yarnpkg.com/ansi-html-community/-/ansi-html-community-0.0.8.tgz#69fbc4d6ccbe383f9736934ae34c3f8290f1bf41" - integrity sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw== - -ansi-regex@^2.0.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" - integrity sha1-w7M6te42DYbg5ijwRorn7yfWVN8= - -ansi-regex@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" - integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== +ansi-escapes@^6.2.0: + version "6.2.1" + resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-6.2.1.tgz#76c54ce9b081dad39acec4b5d53377913825fb0f" + integrity sha512-4nJ3yixlEthEJ9Rk4vPcdBRkZvQZlYyu8j4/Mqz5sgIkddmEnH2Yj2ZrnP9S3tQOvSNRUIgVNF/1yPpRAGNRig== ansi-regex@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== -ansi-styles@^2.2.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe" - integrity sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4= +ansi-regex@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-6.0.1.tgz#3183e38fae9a65d7cb5e53945cd5897d0260a06a" + integrity sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA== ansi-styles@^3.2.1: version "3.2.1" @@ -4019,62 +1796,24 @@ ansi-styles@^4.0.0, ansi-styles@^4.1.0: dependencies: color-convert "^2.0.1" -ansi-styles@^5.0.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" - integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== +ansi-styles@^6.0.0, ansi-styles@^6.1.0, ansi-styles@^6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-6.2.1.tgz#0e62320cf99c21afff3b3012192546aacbfb05c5" + integrity sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug== -anymatch@^3.0.0, anymatch@~3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" - integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== +anymatch@^3.1.3, anymatch@~3.1.2: + version "3.1.3" + resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e" + integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw== dependencies: normalize-path "^3.0.0" picomatch "^2.0.4" -"aproba@^1.0.3 || ^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/aproba/-/aproba-2.0.0.tgz#52520b8ae5b569215b354efc0caa3fe1e45a8adc" - integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== - -are-docs-informative@^0.0.2: - version "0.0.2" - resolved "https://registry.yarnpkg.com/are-docs-informative/-/are-docs-informative-0.0.2.tgz#387f0e93f5d45280373d387a59d34c96db321963" - integrity sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig== - -are-we-there-yet@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz#679df222b278c64f2cdba1175cdc00b0d96164bd" - integrity sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg== - dependencies: - delegates "^1.0.0" - readable-stream "^3.6.0" - -argparse@^1.0.7: - version "1.0.10" - resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" - integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== - dependencies: - sprintf-js "~1.0.2" - argparse@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== -aria-query@^4.2.2: - version "4.2.2" - resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-4.2.2.tgz#0d2ca6c9aceb56b8977e9fed6aed7e15bbd2f83b" - integrity sha512-o/HelwhuKpTj/frsOsbNLNgnNGVIFsVP/SW2BSF14gVl7kAfMOJ6/8wUAUvG1R1NHKrfG+2sHZTu0yauT1qBrA== - dependencies: - "@babel/runtime" "^7.10.2" - "@babel/runtime-corejs3" "^7.10.2" - -aria-query@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-5.0.0.tgz#210c21aaf469613ee8c9a62c7f86525e058db52c" - integrity sha512-V+SM7AbUwJ+EBnB8+DXs0hPZHO0W6pqBcc0dW90OwtVG02PswOu/teuARoLQjdDOH+t9pJgGnW5/Qmouf3gPJg== - aria-query@^5.3.0: version "5.3.0" resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-5.3.0.tgz#650c569e41ad90b51b3d7df5e5eed1c7549c103e" @@ -4082,62 +1821,54 @@ aria-query@^5.3.0: dependencies: dequal "^2.0.3" -array-buffer-byte-length@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz#fabe8bc193fea865f317fe7807085ee0dee5aead" - integrity sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A== +array-buffer-byte-length@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz#1e5583ec16763540a27ae52eed99ff899223568f" + integrity sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg== dependencies: - call-bind "^1.0.2" - is-array-buffer "^3.0.1" - -array-flatten@1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" - integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= - -array-flatten@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-2.1.2.tgz#24ef80a28c1a893617e2149b0c6d0d788293b099" - integrity sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ== + call-bind "^1.0.5" + is-array-buffer "^3.0.4" -array-includes@^3.1.6, array-includes@^3.1.7: - version "3.1.7" - resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.7.tgz#8cd2e01b26f7a3086cbc87271593fe921c62abda" - integrity sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ== +array-includes@^3.1.6, array-includes@^3.1.7, array-includes@^3.1.8: + version "3.1.8" + resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.8.tgz#5e370cbe172fdd5dd6530c1d4aadda25281ba97d" + integrity sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - get-intrinsic "^1.2.1" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.2" + es-object-atoms "^1.0.0" + get-intrinsic "^1.2.4" is-string "^1.0.7" -array-union@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/array-union/-/array-union-1.0.2.tgz#9a34410e4f4e3da23dea375be5be70f24778ec39" - integrity sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk= - dependencies: - array-uniq "^1.0.1" - array-union@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== -array-uniq@^1.0.1: - version "1.0.3" - resolved "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6" - integrity sha1-r2rId6Jcx/dOBYiUdThY39sk/bY= +array.prototype.findlast@^1.2.5: + version "1.2.5" + resolved "https://registry.yarnpkg.com/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz#3e4fbcb30a15a7f5bf64cf2faae22d139c2e4904" + integrity sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ== + dependencies: + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.2" + es-errors "^1.3.0" + es-object-atoms "^1.0.0" + es-shim-unscopables "^1.0.2" array.prototype.findlastindex@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.3.tgz#b37598438f97b579166940814e2c0493a4f50207" - integrity sha512-LzLoiOMAxvy+Gd3BAq3B7VeIgPdo+Q8hthvKtXybMvRV0jrXfJM/t8mw7nNlpEcVlVUnCnM2KSX4XU5HmpodOA== + version "1.2.5" + resolved "https://registry.yarnpkg.com/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.5.tgz#8c35a755c72908719453f87145ca011e39334d0d" + integrity sha512-zfETvRFA8o7EiNn++N5f/kaCw221hrpGsDmcpndVupkPzEc1Wuf3VgC0qby1BbHs7f5DVYjgtEU2LLh5bqeGfQ== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - es-shim-unscopables "^1.0.0" - get-intrinsic "^1.2.1" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.2" + es-errors "^1.3.0" + es-object-atoms "^1.0.0" + es-shim-unscopables "^1.0.2" array.prototype.flat@^1.3.1, array.prototype.flat@^1.3.2: version "1.3.2" @@ -4149,7 +1880,7 @@ array.prototype.flat@^1.3.1, array.prototype.flat@^1.3.2: es-abstract "^1.22.1" es-shim-unscopables "^1.0.0" -array.prototype.flatmap@^1.3.1, array.prototype.flatmap@^1.3.2: +array.prototype.flatmap@^1.3.2: version "1.3.2" resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz#c9a7c6831db8e719d6ce639190146c24bbd3e527" integrity sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ== @@ -4159,56 +1890,42 @@ array.prototype.flatmap@^1.3.1, array.prototype.flatmap@^1.3.2: es-abstract "^1.22.1" es-shim-unscopables "^1.0.0" -array.prototype.tosorted@^1.1.1: +array.prototype.toreversed@^1.1.2: version "1.1.2" - resolved "https://registry.yarnpkg.com/array.prototype.tosorted/-/array.prototype.tosorted-1.1.2.tgz#620eff7442503d66c799d95503f82b475745cefd" - integrity sha512-HuQCHOlk1Weat5jzStICBCd83NxiIMwqDg/dHEsoefabn/hJRj5pVdWcPUSpRrwhwxZOsQassMpgN/xRYFBMIg== + resolved "https://registry.yarnpkg.com/array.prototype.toreversed/-/array.prototype.toreversed-1.1.2.tgz#b989a6bf35c4c5051e1dc0325151bf8088954eba" + integrity sha512-wwDCoT4Ck4Cz7sLtgUmzR5UV3YF5mFHUlbChCzZBQZ+0m2cl/DH3tKgvphv1nKgFsJ48oCSg6p91q2Vm0I/ZMA== dependencies: call-bind "^1.0.2" define-properties "^1.2.0" es-abstract "^1.22.1" es-shim-unscopables "^1.0.0" - get-intrinsic "^1.2.1" -arraybuffer.prototype.slice@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz#98bd561953e3e74bb34938e77647179dfe6e9f12" - integrity sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw== +array.prototype.tosorted@^1.1.3: + version "1.1.4" + resolved "https://registry.yarnpkg.com/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz#fe954678ff53034e717ea3352a03f0b0b86f7ffc" + integrity sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA== dependencies: - array-buffer-byte-length "^1.0.0" - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - get-intrinsic "^1.2.1" - is-array-buffer "^3.0.2" - is-shared-array-buffer "^1.0.2" - -arrify@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/arrify/-/arrify-1.0.1.tgz#898508da2226f380df904728456849c1501a4b0d" - integrity sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA== + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.3" + es-errors "^1.3.0" + es-shim-unscopables "^1.0.2" -asn1.js@^5.2.0: - version "5.4.1" - resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-5.4.1.tgz#11a980b84ebb91781ce35b0fdc2ee294e3783f07" - integrity sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA== +arraybuffer.prototype.slice@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz#097972f4255e41bc3425e37dc3f6421cf9aefde6" + integrity sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A== dependencies: - bn.js "^4.0.0" - inherits "^2.0.1" - minimalistic-assert "^1.0.0" - safer-buffer "^2.1.0" + array-buffer-byte-length "^1.0.1" + call-bind "^1.0.5" + define-properties "^1.2.1" + es-abstract "^1.22.3" + es-errors "^1.2.1" + get-intrinsic "^1.2.3" + is-array-buffer "^3.0.4" + is-shared-array-buffer "^1.0.2" assert@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/assert/-/assert-2.0.0.tgz#95fc1c616d48713510680f2eaf2d10dd22e02d32" - integrity sha512-se5Cd+js9dXJnu6Ag2JFc00t+HmHOen+8Q+L7O9zI0PqQXr20uk2J0XQqMxZEeo5U50o8Nvmmx7dZrl+Ufr35A== - dependencies: - es6-object-assign "^1.1.0" - is-nan "^1.2.1" - object-is "^1.0.1" - util "^0.12.0" - -assert@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/assert/-/assert-2.1.0.tgz#6d92a238d05dc02e7427c881fb8be81c8448b2dd" integrity sha512-eLHpSK/Y4nhMJ07gDaAzoX/XAKS8PSaojml3M0DM4JpV1LAi5JOJ/p6H/XWrl8L+DzVEvVCW1z3vWAaB9oTsQw== @@ -4219,59 +1936,27 @@ assert@^2.1.0: object.assign "^4.1.4" util "^0.12.5" -assertion-error@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/assertion-error/-/assertion-error-1.1.0.tgz#e60b6b0e8f301bd97e5375215bda406c85118c0b" - integrity sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw== - ast-types-flow@^0.0.8: version "0.0.8" resolved "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.8.tgz#0a85e1c92695769ac13a428bb653e7538bea27d6" integrity sha512-OH/2E5Fg20h2aPrbe+QL8JZQFko0YZaF+j4mnQ7BGhfavO7OpSLa8a0y9sBwomHdSbkhTS8TQNayBfnW5DwbvQ== -astral-regex@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" - integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ== - -async-each-series@0.1.1: - version "0.1.1" - resolved "https://registry.yarnpkg.com/async-each-series/-/async-each-series-0.1.1.tgz#7617c1917401fd8ca4a28aadce3dbae98afeb432" - integrity sha1-dhfBkXQB/Yykooqtzj266Yr+tDI= - -async-foreach@^0.1.3: - version "0.1.3" - resolved "https://registry.yarnpkg.com/async-foreach/-/async-foreach-0.1.3.tgz#36121f845c0578172de419a97dbeb1d16ec34542" - integrity sha512-VUeSMD8nEGBWaZK4lizI1sf3yEC7pnAQ/mrI7pC2fBz2s/tq5jWWEngTwaf0Gruu/OoXRGLGg1XFqpYBiGTYJA== - -async@^2.6.0: - version "2.6.4" - resolved "https://registry.yarnpkg.com/async/-/async-2.6.4.tgz#706b7ff6084664cd7eae713f6f965433b5504221" - integrity sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA== - dependencies: - lodash "^4.17.14" - -asynciterator.prototype@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/asynciterator.prototype/-/asynciterator.prototype-1.0.0.tgz#8c5df0514936cdd133604dfcc9d3fb93f09b2b62" - integrity sha512-wwHYEIS0Q80f5mosx3L/dfG5t5rjEa9Ft51GTaNt862EnpyGHpgz2RkZvLPp1oF5TnAiTohkEKVEu8pQPJI7Vg== - dependencies: - has-symbols "^1.0.3" - asynckit@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== -atob@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" - integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== +atomic-sleep@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/atomic-sleep/-/atomic-sleep-1.0.0.tgz#eb85b77a601fc932cfe432c5acd364a9e2c9075b" + integrity sha512-kNOjDqAh7px0XWNI+4QbzoiR/nTkHAWNud2uvnJquD1/x5a7EQZMJT0AczqK0Qn67oY/TTQ1LbUKajZpp3I9tQ== -available-typed-arrays@^1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz#92f95616501069d07d10edb2fc37d3e1c65123b7" - integrity sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw== +available-typed-arrays@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz#a5cc375d6a03c2efc87a553f3e0b1522def14846" + integrity sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ== + dependencies: + possible-typed-array-names "^1.0.0" axe-core@=4.7.0: version "4.7.0" @@ -4294,223 +1979,14 @@ axobject-query@^3.2.1: dependencies: dequal "^2.0.3" -babel-code-frame@^6.26.0: - version "6.26.0" - resolved "https://registry.yarnpkg.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz#63fd43f7dc1e3bb7ce35947db8fe369a3f58c74b" - integrity sha512-XqYMR2dfdGMW+hd0IUZ2PwK+fGeFkOxZJ0wY+JaQAHzt1Zx8LcvpiZD2NiGkEG8qx0CfkAOr5xt76d1e8vG90g== - dependencies: - chalk "^1.1.3" - esutils "^2.0.2" - js-tokens "^3.0.2" - -babel-helper-function-name@^6.24.1: - version "6.24.1" - resolved "https://registry.yarnpkg.com/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz#d3475b8c03ed98242a25b48351ab18399d3580a9" - integrity sha512-Oo6+e2iX+o9eVvJ9Y5eKL5iryeRdsIkwRYheCuhYdVHsdEQysbc2z2QkqCLIYnNxkT5Ss3ggrHdXiDI7Dhrn4Q== - dependencies: - babel-helper-get-function-arity "^6.24.1" - babel-runtime "^6.22.0" - babel-template "^6.24.1" - babel-traverse "^6.24.1" - babel-types "^6.24.1" - -babel-helper-get-function-arity@^6.24.1: - version "6.24.1" - resolved "https://registry.yarnpkg.com/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz#8f7782aa93407c41d3aa50908f89b031b1b6853d" - integrity sha512-WfgKFX6swFB1jS2vo+DwivRN4NB8XUdM3ij0Y1gnC21y1tdBoe6xjVnd7NSI6alv+gZXCtJqvrTeMW3fR/c0ng== - dependencies: - babel-runtime "^6.22.0" - babel-types "^6.24.1" - -babel-loader@^9.1.2: - version "9.1.3" - resolved "https://registry.yarnpkg.com/babel-loader/-/babel-loader-9.1.3.tgz#3d0e01b4e69760cc694ee306fe16d358aa1c6f9a" - integrity sha512-xG3ST4DglodGf8qSwv0MdeWLhrDsw/32QMdTO5T1ZIp9gQur0HkCyFs7Awskr10JKXFXwpAhiCuYX5oGXnRGbw== - dependencies: - find-cache-dir "^4.0.0" - schema-utils "^4.0.0" - -babel-messages@^6.23.0: - version "6.23.0" - resolved "https://registry.yarnpkg.com/babel-messages/-/babel-messages-6.23.0.tgz#f3cdf4703858035b2a2951c6ec5edf6c62f2630e" - integrity sha512-Bl3ZiA+LjqaMtNYopA9TYE9HP1tQ+E5dLxE0XrAzcIJeK2UqF0/EaqXwBn9esd4UmTfEab+P+UYQ1GnioFIb/w== - dependencies: - babel-runtime "^6.22.0" - -babel-plugin-macros@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz#9ef6dc74deb934b4db344dc973ee851d148c50c1" - integrity sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg== - dependencies: - "@babel/runtime" "^7.12.5" - cosmiconfig "^7.0.0" - resolve "^1.19.0" - -babel-plugin-polyfill-corejs2@^0.4.10: - version "0.4.11" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.11.tgz#30320dfe3ffe1a336c15afdcdafd6fd615b25e33" - integrity sha512-sMEJ27L0gRHShOh5G54uAAPaiCOygY/5ratXuiyb2G46FmlSpc9eFCzYVyDiPxfNbwzA7mYahmjQc5q+CZQ09Q== - dependencies: - "@babel/compat-data" "^7.22.6" - "@babel/helper-define-polyfill-provider" "^0.6.2" - semver "^6.3.1" - -babel-plugin-polyfill-corejs2@^0.4.6: - version "0.4.7" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.7.tgz#679d1b94bf3360f7682e11f2cb2708828a24fe8c" - integrity sha512-LidDk/tEGDfuHW2DWh/Hgo4rmnw3cduK6ZkOI1NPFceSK3n/yAGeOsNT7FLnSGHkXj3RHGSEVkN3FsCTY6w2CQ== - dependencies: - "@babel/compat-data" "^7.22.6" - "@babel/helper-define-polyfill-provider" "^0.4.4" - semver "^6.3.1" - -babel-plugin-polyfill-corejs3@^0.10.4: - version "0.10.4" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.10.4.tgz#789ac82405ad664c20476d0233b485281deb9c77" - integrity sha512-25J6I8NGfa5YkCDogHRID3fVCadIR8/pGl1/spvCkzb6lVn6SR3ojpx9nOn9iEBcUsjY24AmdKm5khcfKdylcg== - dependencies: - "@babel/helper-define-polyfill-provider" "^0.6.1" - core-js-compat "^3.36.1" - -babel-plugin-polyfill-corejs3@^0.8.5: - version "0.8.7" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.8.7.tgz#941855aa7fdaac06ed24c730a93450d2b2b76d04" - integrity sha512-KyDvZYxAzkC0Aj2dAPyDzi2Ym15e5JKZSK+maI7NAwSqofvuFglbSsxE7wUOvTg9oFVnHMzVzBKcqEb4PJgtOA== - dependencies: - "@babel/helper-define-polyfill-provider" "^0.4.4" - core-js-compat "^3.33.1" - -babel-plugin-polyfill-regenerator@^0.5.3: - version "0.5.4" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.5.4.tgz#c6fc8eab610d3a11eb475391e52584bacfc020f4" - integrity sha512-S/x2iOCvDaCASLYsOOgWOq4bCfKYVqvO/uxjkaYyZ3rVsVE3CeAI/c84NpyuBBymEgNvHgjEot3a9/Z/kXvqsg== - dependencies: - "@babel/helper-define-polyfill-provider" "^0.4.4" - -babel-plugin-polyfill-regenerator@^0.6.1: - version "0.6.2" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.2.tgz#addc47e240edd1da1058ebda03021f382bba785e" - integrity sha512-2R25rQZWP63nGwaAswvDazbPXfrM3HwVoBXK6HcqeKrSrL/JqcC/rDcf95l4r7LXLyxDXc8uQDa064GubtCABg== - dependencies: - "@babel/helper-define-polyfill-provider" "^0.6.2" - -babel-plugin-syntax-class-properties@^6.8.0: - version "6.13.0" - resolved "https://registry.yarnpkg.com/babel-plugin-syntax-class-properties/-/babel-plugin-syntax-class-properties-6.13.0.tgz#d7eb23b79a317f8543962c505b827c7d6cac27de" - integrity sha512-chI3Rt9T1AbrQD1s+vxw3KcwC9yHtF621/MacuItITfZX344uhQoANjpoSJZleAmW2tjlolqB/f+h7jIqXa7pA== - -babel-plugin-transform-class-properties@^6.24.1: - version "6.24.1" - resolved "https://registry.yarnpkg.com/babel-plugin-transform-class-properties/-/babel-plugin-transform-class-properties-6.24.1.tgz#6a79763ea61d33d36f37b611aa9def81a81b46ac" - integrity sha512-n4jtBA3OYBdvG5PRMKsMXJXHfLYw/ZOmtxCLOOwz6Ro5XlrColkStLnz1AS1L2yfPA9BKJ1ZNlmVCLjAL9DSIg== - dependencies: - babel-helper-function-name "^6.24.1" - babel-plugin-syntax-class-properties "^6.8.0" - babel-runtime "^6.22.0" - babel-template "^6.24.1" - -babel-plugin-transform-es2015-modules-commonjs@^6.26.2: - version "6.26.2" - resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.2.tgz#58a793863a9e7ca870bdc5a881117ffac27db6f3" - integrity sha512-CV9ROOHEdrjcwhIaJNBGMBCodN+1cfkwtM1SbUHmvyy35KGT7fohbpOxkE2uLz1o6odKK2Ck/tz47z+VqQfi9Q== - dependencies: - babel-plugin-transform-strict-mode "^6.24.1" - babel-runtime "^6.26.0" - babel-template "^6.26.0" - babel-types "^6.26.0" - -babel-plugin-transform-react-remove-prop-types@^0.4.24: - version "0.4.24" - resolved "https://registry.yarnpkg.com/babel-plugin-transform-react-remove-prop-types/-/babel-plugin-transform-react-remove-prop-types-0.4.24.tgz#f2edaf9b4c6a5fbe5c1d678bfb531078c1555f3a" - integrity sha512-eqj0hVcJUR57/Ug2zE1Yswsw4LhuqqHhD+8v120T1cl3kjg76QwtyBrdIk4WVwK+lAhBJVYCd/v+4nc4y+8JsA== - -babel-plugin-transform-strict-mode@^6.24.1: - version "6.24.1" - resolved "https://registry.yarnpkg.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz#d5faf7aa578a65bbe591cf5edae04a0c67020758" - integrity sha512-j3KtSpjyLSJxNoCDrhwiJad8kw0gJ9REGj8/CqL0HeRyLnvUNYV9zcqluL6QJSXh3nfsLEmSLvwRfGzrgR96Pw== - dependencies: - babel-runtime "^6.22.0" - babel-types "^6.24.1" - -babel-preset-react-app@^10.0.1: - version "10.0.1" - resolved "https://registry.yarnpkg.com/babel-preset-react-app/-/babel-preset-react-app-10.0.1.tgz#ed6005a20a24f2c88521809fa9aea99903751584" - integrity sha512-b0D9IZ1WhhCWkrTXyFuIIgqGzSkRIH5D5AmB0bXbzYAB1OBAwHcUeyWW2LorutLWF5btNo/N7r/cIdmvvKJlYg== - dependencies: - "@babel/core" "^7.16.0" - "@babel/plugin-proposal-class-properties" "^7.16.0" - "@babel/plugin-proposal-decorators" "^7.16.4" - "@babel/plugin-proposal-nullish-coalescing-operator" "^7.16.0" - "@babel/plugin-proposal-numeric-separator" "^7.16.0" - "@babel/plugin-proposal-optional-chaining" "^7.16.0" - "@babel/plugin-proposal-private-methods" "^7.16.0" - "@babel/plugin-transform-flow-strip-types" "^7.16.0" - "@babel/plugin-transform-react-display-name" "^7.16.0" - "@babel/plugin-transform-runtime" "^7.16.4" - "@babel/preset-env" "^7.16.4" - "@babel/preset-react" "^7.16.0" - "@babel/preset-typescript" "^7.16.0" - "@babel/runtime" "^7.16.3" - babel-plugin-macros "^3.1.0" - babel-plugin-transform-react-remove-prop-types "^0.4.24" - -babel-runtime@^6.22.0, babel-runtime@^6.26.0: - version "6.26.0" - resolved "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz#965c7058668e82b55d7bfe04ff2337bc8b5647fe" - integrity sha1-llxwWGaOgrVde/4E/yM3vItWR/4= - dependencies: - core-js "^2.4.0" - regenerator-runtime "^0.11.0" - -babel-template@^6.24.1, babel-template@^6.26.0: - version "6.26.0" - resolved "https://registry.yarnpkg.com/babel-template/-/babel-template-6.26.0.tgz#de03e2d16396b069f46dd9fff8521fb1a0e35e02" - integrity sha512-PCOcLFW7/eazGUKIoqH97sO9A2UYMahsn/yRQ7uOk37iutwjq7ODtcTNF+iFDSHNfkctqsLRjLP7URnOx0T1fg== - dependencies: - babel-runtime "^6.26.0" - babel-traverse "^6.26.0" - babel-types "^6.26.0" - babylon "^6.18.0" - lodash "^4.17.4" - -babel-traverse@^6.24.1, babel-traverse@^6.26.0: - version "6.26.0" - resolved "https://registry.yarnpkg.com/babel-traverse/-/babel-traverse-6.26.0.tgz#46a9cbd7edcc62c8e5c064e2d2d8d0f4035766ee" - integrity sha512-iSxeXx7apsjCHe9c7n8VtRXGzI2Bk1rBSOJgCCjfyXb6v1aCqE1KSEpq/8SXuVN8Ka/Rh1WDTF0MDzkvTA4MIA== - dependencies: - babel-code-frame "^6.26.0" - babel-messages "^6.23.0" - babel-runtime "^6.26.0" - babel-types "^6.26.0" - babylon "^6.18.0" - debug "^2.6.8" - globals "^9.18.0" - invariant "^2.2.2" - lodash "^4.17.4" - -babel-types@^6.24.1, babel-types@^6.26.0: - version "6.26.0" - resolved "https://registry.yarnpkg.com/babel-types/-/babel-types-6.26.0.tgz#a3b073f94ab49eb6fa55cd65227a334380632497" - integrity sha512-zhe3V/26rCWsEZK8kZN+HaQj5yQ1CilTObixFzKW1UWjqG7618Twz6YEsCnjfg5gBcJh02DrpCkS9h98ZqDY+g== - dependencies: - babel-runtime "^6.26.0" - esutils "^2.0.2" - lodash "^4.17.4" - to-fast-properties "^1.0.3" - -babylon@^6.18.0: - version "6.18.0" - resolved "https://registry.yarnpkg.com/babylon/-/babylon-6.18.0.tgz#af2f3b88fa6f5c1e4c634d1a0f8eac4f55b395e3" - integrity sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ== - balanced-match@^1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== -base-x@3.0.9, base-x@^3.0.2: +base-x@^3.0.2, base-x@^3.0.9: version "3.0.9" - resolved "https://registry.npmjs.org/base-x/-/base-x-3.0.9.tgz#6349aaabb58526332de9f60995e548a53fe21320" + resolved "https://registry.yarnpkg.com/base-x/-/base-x-3.0.9.tgz#6349aaabb58526332de9f60995e548a53fe21320" integrity sha512-H7JU6iBHTal1gp56aKoaa//YUxEaAOUiydvrV/pILqIHXTtqxSkATOnDA2u+jZ/61sD+L/412+7kzXRtWukhpQ== dependencies: safe-buffer "^5.0.1" @@ -4523,26 +1999,16 @@ base-x@^4.0.0: base32.js@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/base32.js/-/base32.js-0.1.0.tgz#b582dec693c2f11e893cf064ee6ac5b6131a2202" - integrity sha1-tYLexpPC8R6JPPBk7mrFthMaIgI= + integrity sha512-n3TkB02ixgBOhTvANakDb4xaMXnYUVkNoRFJjQflcqMQhyEKxEHdj3E6N8t8sUQ0mjH/3/JxzlXuz3ul/J90pQ== -base64-js@^1.0.2, base64-js@^1.3.1: +base64-js@^1.3.1: version "1.5.1" resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== -base64id@2.0.0, base64id@~2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/base64id/-/base64id-2.0.0.tgz#2770ac6bc47d312af97a8bf9a634342e0cd25cb6" - integrity sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog== - -batch@0.6.1: - version "0.6.1" - resolved "https://registry.yarnpkg.com/batch/-/batch-0.6.1.tgz#dc34314f4e679318093fc760272525f94bf25c16" - integrity sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY= - bchaddrjs@^0.5.2: version "0.5.2" - resolved "https://registry.npmjs.org/bchaddrjs/-/bchaddrjs-0.5.2.tgz#1f52b5077329774e7c82d4882964628106bb11a0" + resolved "https://registry.yarnpkg.com/bchaddrjs/-/bchaddrjs-0.5.2.tgz#1f52b5077329774e7c82d4882964628106bb11a0" integrity sha512-OO7gIn3m7ea4FVx4cT8gdlWQR2+++EquhdpWQJH9BQjK63tJJ6ngB3QMZDO6DiBoXiIGUsTPHjlrHVxPGcGxLQ== dependencies: bs58check "2.1.2" @@ -4552,23 +2018,18 @@ bchaddrjs@^0.5.2: bech32@^2.0.0: version "2.0.0" - resolved "https://registry.npmjs.org/bech32/-/bech32-2.0.0.tgz#078d3686535075c8c79709f054b1b226a133b355" + resolved "https://registry.yarnpkg.com/bech32/-/bech32-2.0.0.tgz#078d3686535075c8c79709f054b1b226a133b355" integrity sha512-LcknSilhIGatDAsY1ak2I8VtGaHNhgMSYVxFrGLXv+xLHytaKZKcaUJJUE7qmBr7h33o5YQwP55pMI0xmkpJwg== big-integer@1.6.36: version "1.6.36" - resolved "https://registry.npmjs.org/big-integer/-/big-integer-1.6.36.tgz#78631076265d4ae3555c04f85e7d9d2f3a071a36" + resolved "https://registry.yarnpkg.com/big-integer/-/big-integer-1.6.36.tgz#78631076265d4ae3555c04f85e7d9d2f3a071a36" integrity sha512-t70bfa7HYEA1D9idDbmuv7YbsbVkQ+Hp+8KFSul4aE5e/i1bjCNIRYJZlA8Q8p0r9T8cF/RVvwUgRA//FydEyg== big-integer@^1.6.48: - version "1.6.51" - resolved "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz#0df92a5d9880560d3ff2d5fd20245c889d130686" - integrity sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg== - -big.js@^5.2.2: - version "5.2.2" - resolved "https://registry.yarnpkg.com/big.js/-/big.js-5.2.2.tgz#65f0af382f578bcdc742bd9c281e9cb2d7768328" - integrity sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ== + version "1.6.52" + resolved "https://registry.yarnpkg.com/big-integer/-/big-integer-1.6.52.tgz#60a887f3047614a8e1bffe5d7173490a97dc8c85" + integrity sha512-QxD8cf2eVqJOOz63z6JIN9BzvVs/dlySa5HGSBH5xtR8dPteIRQnBxxKqkNTiT6jbDTF6jAfrd4oMcND9RGbQg== bigint-buffer@^1.1.5: version "1.1.5" @@ -4577,20 +2038,15 @@ bigint-buffer@^1.1.5: dependencies: bindings "^1.3.0" -bignumber.js@^9.0.0: - version "9.0.2" - resolved "https://registry.npmjs.org/bignumber.js/-/bignumber.js-9.0.2.tgz#71c6c6bed38de64e24a65ebe16cfcf23ae693673" - integrity sha512-GAcQvbpsM0pUb0zw1EI0KhQEZ+lRwR5fYaAp3vPOYuP7aDvGy6cVN6XHLauvF8SOga2y0dcLcjt3iQDTSEliyw== - -bignumber.js@^9.1.2: +bignumber.js@^9.0.0, bignumber.js@^9.1.2: version "9.1.2" resolved "https://registry.yarnpkg.com/bignumber.js/-/bignumber.js-9.1.2.tgz#b7c4242259c008903b13707983b5f4bbd31eda0c" integrity sha512-2/mKyZH9K85bzOEfhXDBFZTGd1CTs+5IHpeFQo9luiBG7hghdC851Pj2WAhb6E3R6b9tZj/XKhbg4fum+Kepug== binary-extensions@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" - integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== + version "2.3.0" + resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.3.0.tgz#f6e14a97858d327252200242d4ccfe522c445522" + integrity sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw== bindings@^1.3.0: version "1.5.0" @@ -4601,19 +2057,19 @@ bindings@^1.3.0: bip66@^1.1.5: version "1.1.5" - resolved "https://registry.npmjs.org/bip66/-/bip66-1.1.5.tgz#01fa8748785ca70955d5011217d1b3139969ca22" + resolved "https://registry.yarnpkg.com/bip66/-/bip66-1.1.5.tgz#01fa8748785ca70955d5011217d1b3139969ca22" integrity sha512-nemMHz95EmS38a26XbbdxIYj5csHd3RMP3H5bwQknX0WYHF01qhpufP42mLOwVICuH2JmhIhXiWs89MfUGL7Xw== dependencies: safe-buffer "^5.0.1" bitcoin-ops@^1.3.0, bitcoin-ops@^1.4.1: version "1.4.1" - resolved "https://registry.npmjs.org/bitcoin-ops/-/bitcoin-ops-1.4.1.tgz#e45de620398e22fd4ca6023de43974ff42240278" + resolved "https://registry.yarnpkg.com/bitcoin-ops/-/bitcoin-ops-1.4.1.tgz#e45de620398e22fd4ca6023de43974ff42240278" integrity sha512-pef6gxZFztEhaE9RY9HmWVmiIHqCb2OyS4HPKkpc6CIiiOa3Qmuoylxc5P2EkU3w+5eTSifI9SEZC88idAIGow== blake-hash@^2.0.0: version "2.0.0" - resolved "https://registry.npmjs.org/blake-hash/-/blake-hash-2.0.0.tgz#af184dce641951126d05b7d1c3de3224f538d66e" + resolved "https://registry.yarnpkg.com/blake-hash/-/blake-hash-2.0.0.tgz#af184dce641951126d05b7d1c3de3224f538d66e" integrity sha512-Igj8YowDu1PRkRsxZA7NVkdFNxH5rKv5cpLxQ0CVXSIA77pVYwCPRQJ2sMew/oneUpfuYRyjG6r8SmmmnbZb1w== dependencies: node-addon-api "^3.0.0" @@ -4622,57 +2078,19 @@ blake-hash@^2.0.0: blakejs@^1.2.1: version "1.2.1" - resolved "https://registry.npmmirror.com/blakejs/-/blakejs-1.2.1.tgz#5057e4206eadb4a97f7c0b6e197a505042fc3814" + resolved "https://registry.yarnpkg.com/blakejs/-/blakejs-1.2.1.tgz#5057e4206eadb4a97f7c0b6e197a505042fc3814" integrity sha512-QXUSXI3QVc/gJME0dBpXrag1kbzOqCjCX8/b54ntNyW6sjtoqxqRk3LTmXzaJoh71zMsDCjM+47jS7XiwN/+fQ== -bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.11.8, bn.js@^4.11.9: +bn.js@^4.11.8, bn.js@^4.11.9: version "4.12.0" resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== -bn.js@^5.0.0, bn.js@^5.2.0, bn.js@^5.2.1: +bn.js@^5.1.1, bn.js@^5.2.0, bn.js@^5.2.1: version "5.2.1" resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.1.tgz#0bc527a6a0d18d0aa8d5b0538ce4a77dccfa7b70" integrity sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ== -bn.js@^5.1.1: - version "5.2.0" - resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.0.tgz#358860674396c6997771a9d051fcc1b57d4ae002" - integrity sha512-D7iWRBvnZE8ecXiLj/9wbxH7Tk79fAh8IHaTNq1RWRixsS02W+5qS+iE9yq6RYl0asXx5tw0bLhmT5pIfbSquw== - -body-parser@1.20.1: - version "1.20.1" - resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.1.tgz#b1812a8912c195cd371a3ee5e66faa2338a5c668" - integrity sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw== - dependencies: - bytes "3.1.2" - content-type "~1.0.4" - debug "2.6.9" - depd "2.0.0" - destroy "1.2.0" - http-errors "2.0.0" - iconv-lite "0.4.24" - on-finished "2.4.1" - qs "6.11.0" - raw-body "2.5.1" - type-is "~1.6.18" - unpipe "1.0.0" - -bonjour-service@^1.0.11: - version "1.1.1" - resolved "https://registry.yarnpkg.com/bonjour-service/-/bonjour-service-1.1.1.tgz#960948fa0e0153f5d26743ab15baf8e33752c135" - integrity sha512-Z/5lQRMOG9k7W+FkeGTNjh7htqn/2LMnfOvBZ8pynNZCM9MwkQkI3zeI4oz09uWdcgmgHugVvBqxGg4VQJ5PCg== - dependencies: - array-flatten "^2.1.2" - dns-equal "^1.0.0" - fast-deep-equal "^3.1.3" - multicast-dns "^7.2.5" - -boolbase@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" - integrity sha1-aN/1++YMUes3cl6p4+0xDcwed24= - borsh@^0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/borsh/-/borsh-0.7.0.tgz#6e9560d719d86d90dc589bca60ffc8a6c51fec2a" @@ -4697,161 +2115,21 @@ brace-expansion@^2.0.1: dependencies: balanced-match "^1.0.0" -braces@^3.0.1, braces@^3.0.2, braces@~3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" - integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== +braces@^3.0.3, braces@~3.0.2: + version "3.0.3" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.3.tgz#490332f40919452272d55a8480adc0c441358789" + integrity sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA== dependencies: - fill-range "^7.0.1" + fill-range "^7.1.1" -brorand@^1.0.1, brorand@^1.0.5, brorand@^1.1.0: +brorand@^1.0.5, brorand@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" - integrity sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8= - -browser-stdout@1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/browser-stdout/-/browser-stdout-1.3.1.tgz#baa559ee14ced73452229bad7326467c61fabd60" - integrity sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw== - -browser-sync-client@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/browser-sync-client/-/browser-sync-client-3.0.2.tgz#6fbe9a7aada25cf14c824683e089ec9ace91cfe1" - integrity sha512-tBWdfn9L0wd2Pjuz/NWHtNEKthVb1Y67vg8/qyGNtCqetNz5lkDkFnrsx5UhPNPYUO8vci50IWC/BhYaQskDiQ== - dependencies: - etag "1.8.1" - fresh "0.5.2" - mitt "^1.1.3" - -browser-sync-ui@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/browser-sync-ui/-/browser-sync-ui-3.0.2.tgz#8136efcff4ec8cc55084b32b91be02094194f0c4" - integrity sha512-V3FwWAI+abVbFLTyJjXJlCMBwjc3GXf/BPGfwO2fMFACWbIGW9/4SrBOFYEOOtqzCjQE0Di+U3VIb7eES4omNA== - dependencies: - async-each-series "0.1.1" - chalk "4.1.2" - connect-history-api-fallback "^1" - immutable "^3" - server-destroy "1.0.1" - socket.io-client "^4.4.1" - stream-throttle "^0.1.3" - -browser-sync@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/browser-sync/-/browser-sync-3.0.2.tgz#cc763cdbf4180193978fe16ebfc506b910225ae4" - integrity sha512-PC9c7aWJFVR4IFySrJxOqLwB9ENn3/TaXCXtAa0SzLwocLN3qMjN+IatbjvtCX92BjNXsY6YWg9Eb7F3Wy255g== - dependencies: - browser-sync-client "^3.0.2" - browser-sync-ui "^3.0.2" - bs-recipes "1.3.4" - chalk "4.1.2" - chokidar "^3.5.1" - connect "3.6.6" - connect-history-api-fallback "^1" - dev-ip "^1.0.1" - easy-extender "^2.3.4" - eazy-logger "^4.0.1" - etag "^1.8.1" - fresh "^0.5.2" - fs-extra "3.0.1" - http-proxy "^1.18.1" - immutable "^3" - micromatch "^4.0.2" - opn "5.3.0" - portscanner "2.2.0" - raw-body "^2.3.2" - resp-modifier "6.0.2" - rx "4.1.0" - send "0.16.2" - serve-index "1.9.1" - serve-static "1.13.2" - server-destroy "1.0.1" - socket.io "^4.4.1" - ua-parser-js "^1.0.33" - yargs "^17.3.1" - -browserify-aes@^1.0.0, browserify-aes@^1.0.4: - version "1.2.0" - resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.2.0.tgz#326734642f403dabc3003209853bb70ad428ef48" - integrity sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA== - dependencies: - buffer-xor "^1.0.3" - cipher-base "^1.0.0" - create-hash "^1.1.0" - evp_bytestokey "^1.0.3" - inherits "^2.0.1" - safe-buffer "^5.0.1" - -browserify-cipher@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.1.tgz#8d6474c1b870bfdabcd3bcfcc1934a10e94f15f0" - integrity sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w== - dependencies: - browserify-aes "^1.0.4" - browserify-des "^1.0.0" - evp_bytestokey "^1.0.0" - -browserify-des@^1.0.0: - version "1.0.2" - resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.2.tgz#3af4f1f59839403572f1c66204375f7a7f703e9c" - integrity sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A== - dependencies: - cipher-base "^1.0.1" - des.js "^1.0.0" - inherits "^2.0.1" - safe-buffer "^5.1.2" - -browserify-rsa@^4.0.0, browserify-rsa@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.1.0.tgz#b2fd06b5b75ae297f7ce2dc651f918f5be158c8d" - integrity sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog== - dependencies: - bn.js "^5.0.0" - randombytes "^2.0.1" - -browserify-sign@^4.0.0: - version "4.2.2" - resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.2.2.tgz#e78d4b69816d6e3dd1c747e64e9947f9ad79bc7e" - integrity sha512-1rudGyeYY42Dk6texmv7c4VcQ0EsvVbLwZkA+AQB7SxvXxmcD93jcHie8bzecJ+ChDlmAm2Qyu0+Ccg5uhZXCg== - dependencies: - bn.js "^5.2.1" - browserify-rsa "^4.1.0" - create-hash "^1.2.0" - create-hmac "^1.1.7" - elliptic "^6.5.4" - inherits "^2.0.4" - parse-asn1 "^5.1.6" - readable-stream "^3.6.2" - safe-buffer "^5.2.1" - -browserslist@^4.21.10, browserslist@^4.23.0: - version "4.23.1" - resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.23.1.tgz#ce4af0534b3d37db5c1a4ca98b9080f985041e96" - integrity sha512-TUfofFo/KsK/bWZ9TWQ5O26tsWW4Uhmt8IYklbnUa70udB6P2wA7w7o4PY4muaEPBQaAX+CEnmmIA41NVHtPVw== - dependencies: - caniuse-lite "^1.0.30001629" - electron-to-chromium "^1.4.796" - node-releases "^2.0.14" - update-browserslist-db "^1.0.16" - -browserslist@^4.22.2: - version "4.22.2" - resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.22.2.tgz#704c4943072bd81ea18997f3bd2180e89c77874b" - integrity sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A== - dependencies: - caniuse-lite "^1.0.30001565" - electron-to-chromium "^1.4.601" - node-releases "^2.0.14" - update-browserslist-db "^1.0.13" - -bs-recipes@1.3.4: - version "1.3.4" - resolved "https://registry.yarnpkg.com/bs-recipes/-/bs-recipes-1.3.4.tgz#0d2d4d48a718c8c044769fdc4f89592dc8b69585" - integrity sha1-DS1NSKcYyMBEdp/cT4lZLci2lYU= + integrity sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w== bs58@^4.0.0, bs58@^4.0.1: version "4.0.1" - resolved "https://registry.npmjs.org/bs58/-/bs58-4.0.1.tgz#be161e76c354f6f788ae4071f63f34e8c4f0a42a" + resolved "https://registry.yarnpkg.com/bs58/-/bs58-4.0.1.tgz#be161e76c354f6f788ae4071f63f34e8c4f0a42a" integrity sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw== dependencies: base-x "^3.0.2" @@ -4865,7 +2143,7 @@ bs58@^5.0.0: bs58check@2.1.2: version "2.1.2" - resolved "https://registry.npmjs.org/bs58check/-/bs58check-2.1.2.tgz#53b018291228d82a5aa08e7d796fdafda54aebfc" + resolved "https://registry.yarnpkg.com/bs58check/-/bs58check-2.1.2.tgz#53b018291228d82a5aa08e7d796fdafda54aebfc" integrity sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA== dependencies: bs58 "^4.0.0" @@ -4880,130 +2158,29 @@ bs58check@^3.0.1: "@noble/hashes" "^1.2.0" bs58 "^5.0.0" -buffer-from@^1.0.0: - version "1.1.2" - resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" - integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== - -buffer-xor@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" - integrity sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ== - -buffer@5.6.0: - version "5.6.0" - resolved "https://registry.npmjs.org/buffer/-/buffer-5.6.0.tgz#a31749dc7d81d84db08abf937b6b8c4033f62786" - integrity sha512-/gDYp/UtU0eA1ys8bOs9J6a+E/KWIY+DZ+Q2WESNUA0jFRsJOc0SNUO6xJ5SGA1xueg3NL65W6s+NY5l9cunuw== - dependencies: - base64-js "^1.0.2" - ieee754 "^1.1.4" - -buffer@6.0.3, buffer@^6.0.3, buffer@~6.0.3: - version "6.0.3" - resolved "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" - integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== - dependencies: - base64-js "^1.3.1" - ieee754 "^1.2.1" - -bufferutil@^4.0.1: - version "4.0.8" - resolved "https://registry.yarnpkg.com/bufferutil/-/bufferutil-4.0.8.tgz#1de6a71092d65d7766c4d8a522b261a6e787e8ea" - integrity sha512-4T53u4PdgsXqKaIctwF8ifXlRTTmEPJ8iEPWFdGZvcf7sbwYo6FKFEX9eNNAnzFZ7EzJAQ3CJeOtCRA4rDp7Pw== - dependencies: - node-gyp-build "^4.3.0" - -builtin-modules@^3.3.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-3.3.0.tgz#cae62812b89801e9656336e46223e030386be7b6" - integrity sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw== - -builtin-status-codes@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8" - integrity sha512-HpGFw18DgFWlncDfjTa2rcQ4W88O1mC8e8yZ2AvQY5KDaktSTwo+KRf6nHK6FRI5FyRyb/5T6+TSxfP7QyGsmQ== - -bytes@3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048" - integrity sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg= - -bytes@3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6" - integrity sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg== - -bytes@3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" - integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== - -cacache@^15.2.0: - version "15.3.0" - resolved "https://registry.yarnpkg.com/cacache/-/cacache-15.3.0.tgz#dc85380fb2f556fe3dda4c719bfa0ec875a7f1eb" - integrity sha512-VVdYzXEn+cnbXpFgWs5hTT7OScegHVmLhJIR8Ufqk3iFD6A6j5iSX1KuBTfNEv4tdJWE2PzA6IVFtcLC7fN9wQ== - dependencies: - "@npmcli/fs" "^1.0.0" - "@npmcli/move-file" "^1.0.1" - chownr "^2.0.0" - fs-minipass "^2.0.0" - glob "^7.1.4" - infer-owner "^1.0.4" - lru-cache "^6.0.0" - minipass "^3.1.1" - minipass-collect "^1.0.2" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.2" - mkdirp "^1.0.3" - p-map "^4.0.0" - promise-inflight "^1.0.1" - rimraf "^3.0.2" - ssri "^8.0.1" - tar "^6.0.2" - unique-filename "^1.1.1" - -cacache@^16.1.0: - version "16.1.3" - resolved "https://registry.yarnpkg.com/cacache/-/cacache-16.1.3.tgz#a02b9f34ecfaf9a78c9f4bc16fceb94d5d67a38e" - integrity sha512-/+Emcj9DAXxX4cwlLmRI9c166RuL3w30zp4R7Joiv2cQTtTtA+jeuCAjH3ZlGnYS3tKENSrKhAzVVP9GVyzeYQ== - dependencies: - "@npmcli/fs" "^2.1.0" - "@npmcli/move-file" "^2.0.0" - chownr "^2.0.0" - fs-minipass "^2.1.0" - glob "^8.0.1" - infer-owner "^1.0.4" - lru-cache "^7.7.1" - minipass "^3.1.6" - minipass-collect "^1.0.2" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.4" - mkdirp "^1.0.4" - p-map "^4.0.0" - promise-inflight "^1.0.1" - rimraf "^3.0.2" - ssri "^9.0.0" - tar "^6.1.11" - unique-filename "^2.0.0" +buffer@6.0.3, buffer@^6.0.3, buffer@~6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" + integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.2.1" -call-bind@^1.0.0, call-bind@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" - integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== +bufferutil@^4.0.1: + version "4.0.8" + resolved "https://registry.yarnpkg.com/bufferutil/-/bufferutil-4.0.8.tgz#1de6a71092d65d7766c4d8a522b261a6e787e8ea" + integrity sha512-4T53u4PdgsXqKaIctwF8ifXlRTTmEPJ8iEPWFdGZvcf7sbwYo6FKFEX9eNNAnzFZ7EzJAQ3CJeOtCRA4rDp7Pw== dependencies: - function-bind "^1.1.1" - get-intrinsic "^1.0.2" + node-gyp-build "^4.3.0" -call-bind@^1.0.4, call-bind@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.5.tgz#6fa2b7845ce0ea49bf4d8b9ef64727a2c2e2e513" - integrity sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ== +busboy@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/busboy/-/busboy-1.6.0.tgz#966ea36a9502e43cdb9146962523b92f531f6893" + integrity sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA== dependencies: - function-bind "^1.1.2" - get-intrinsic "^1.2.1" - set-function-length "^1.1.1" + streamsearch "^1.1.0" -call-bind@^1.0.7: +call-bind@^1.0.0, call-bind@^1.0.2, call-bind@^1.0.5, call-bind@^1.0.6, call-bind@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.7.tgz#06016599c40c56498c18769d2730be242b6fa3b9" integrity sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w== @@ -5019,83 +2196,24 @@ callsites@^3.0.0: resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== -camel-case@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/camel-case/-/camel-case-4.1.2.tgz#9728072a954f805228225a6deea6b38461e1bd5a" - integrity sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw== - dependencies: - pascal-case "^3.1.2" - tslib "^2.0.3" - -camelcase-keys@^6.2.2: - version "6.2.2" - resolved "https://registry.yarnpkg.com/camelcase-keys/-/camelcase-keys-6.2.2.tgz#5e755d6ba51aa223ec7d3d52f25778210f9dc3c0" - integrity sha512-YrwaA0vEKazPBkn0ipTiMpSajYDSe+KjQfrjhcBMxJt/znbvlHd8Pw/Vamaz5EB4Wfhs3SUR3Z9mwRu/P3s3Yg== - dependencies: - camelcase "^5.3.1" - map-obj "^4.0.0" - quick-lru "^4.0.1" - -camelcase@^5.3.1: +camelcase@^5.0.0: version "5.3.1" resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== -camelcase@^6.0.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.2.0.tgz#924af881c9d525ac9d87f40d964e5cea982a1809" - integrity sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg== - -caniuse-lite@^1.0.30001565: - version "1.0.30001568" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001568.tgz#53fa9297273c9a977a560663f48cbea1767518b7" - integrity sha512-vSUkH84HontZJ88MiNrOau1EBrCqEQYgkC5gIySiDlpsm8sGVrhU7Kx4V6h0tnqaHzIHZv08HlJIwPbL4XL9+A== - -caniuse-lite@^1.0.30001629: - version "1.0.30001633" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001633.tgz#45a4ade9fb9ec80a06537a6271ac1e0afadcb324" - integrity sha512-6sT0yf/z5jqf8tISAgpJDrmwOpLsrpnyCdD/lOZKvKkkJK4Dn0X5i7KF7THEZhOq+30bmhwBlNEaqPUiHiKtZg== +caniuse-lite@^1.0.30001579: + version "1.0.30001632" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001632.tgz#964207b7cba5851701afb4c8afaf1448db3884b6" + integrity sha512-udx3o7yHJfUxMLkGohMlVHCvFvWmirKh9JAH/d7WOLPetlH+LTL5cocMZ0t7oZx/mdlOWXti97xLZWc8uURRHg== cashaddrjs@0.4.4: version "0.4.4" - resolved "https://registry.npmjs.org/cashaddrjs/-/cashaddrjs-0.4.4.tgz#169f1ae620d325db77700273d972282adeeee331" + resolved "https://registry.yarnpkg.com/cashaddrjs/-/cashaddrjs-0.4.4.tgz#169f1ae620d325db77700273d972282adeeee331" integrity sha512-xZkuWdNOh0uq/mxJIng6vYWfTowZLd9F4GMAlp2DwFHlcCqCm91NtuAc47RuV4L7r4PYcY5p6Cr2OKNb4hnkWA== dependencies: big-integer "1.6.36" -chai@^4.3.6: - version "4.3.6" - resolved "https://registry.yarnpkg.com/chai/-/chai-4.3.6.tgz#ffe4ba2d9fa9d6680cc0b370adae709ec9011e9c" - integrity sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q== - dependencies: - assertion-error "^1.1.0" - check-error "^1.0.2" - deep-eql "^3.0.1" - get-func-name "^2.0.0" - loupe "^2.3.1" - pathval "^1.1.1" - type-detect "^4.0.5" - -chalk@4.1.2, chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" - integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== - dependencies: - ansi-styles "^4.1.0" - supports-color "^7.1.0" - -chalk@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz#a8115c55e4a702fe4d150abd3872822a7e09fc98" - integrity sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg= - dependencies: - ansi-styles "^2.2.1" - escape-string-regexp "^1.0.2" - has-ansi "^2.0.0" - strip-ansi "^3.0.0" - supports-color "^2.0.0" - -chalk@^2.0.0, chalk@^2.4.2: +chalk@^2.4.2: version "2.4.2" resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== @@ -5104,38 +2222,23 @@ chalk@^2.0.0, chalk@^2.4.2: escape-string-regexp "^1.0.5" supports-color "^5.3.0" -chalk@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4" - integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg== +chalk@^4.0.0: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== dependencies: ansi-styles "^4.1.0" supports-color "^7.1.0" -check-error@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/check-error/-/check-error-1.0.2.tgz#574d312edd88bb5dd8912e9286dd6c0aed4aac82" - integrity sha1-V00xLt2Iu13YkS6Sht1sCu1KrII= - -chokidar@3.5.3, chokidar@^3.5.3: - version "3.5.3" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" - integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw== - dependencies: - anymatch "~3.1.2" - braces "~3.0.2" - glob-parent "~5.1.2" - is-binary-path "~2.1.0" - is-glob "~4.0.1" - normalize-path "~3.0.0" - readdirp "~3.6.0" - optionalDependencies: - fsevents "~2.3.2" +chalk@~5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-5.3.0.tgz#67c20a7ebef70e7f3970a01f90fa210cb6860385" + integrity sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w== -"chokidar@>=3.0.0 <4.0.0", chokidar@^3.5.1: - version "3.5.2" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.2.tgz#dba3976fcadb016f66fd365021d91600d01c1e75" - integrity sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ== +"chokidar@>=3.0.0 <4.0.0", chokidar@^3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.6.0.tgz#197c6cc669ef2a8dc5e7b4d97ee4e092c3eb0d5b" + integrity sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw== dependencies: anymatch "~3.1.2" braces "~3.0.2" @@ -5147,22 +2250,7 @@ chokidar@3.5.3, chokidar@^3.5.3: optionalDependencies: fsevents "~2.3.2" -chownr@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" - integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== - -chrome-trace-event@^1.0.2: - version "1.0.3" - resolved "https://registry.yarnpkg.com/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz#1015eced4741e15d06664a957dbbf50d041e26ac" - integrity sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg== - -ci-info@^3.2.0: - version "3.9.0" - resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.9.0.tgz#4279a62028a7b1f262f3473fc9605f5e218c59b4" - integrity sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ== - -cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: +cipher-base@^1.0.1, cipher-base@^1.0.3: version "1.0.4" resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" integrity sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q== @@ -5170,66 +2258,50 @@ cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: inherits "^2.0.1" safe-buffer "^5.0.1" -classnames@^2.5.1: - version "2.5.1" - resolved "https://registry.yarnpkg.com/classnames/-/classnames-2.5.1.tgz#ba774c614be0f016da105c858e7159eae8e7687b" - integrity sha512-saHYOzhIQs6wy2sVxTM6bUDsQO4F50V9RQ22qBpEdCW+I+/Wmke2HOl6lS6dTpdxVhb88/I6+Hs+438c3lfUow== - -clean-css@^5.2.2: - version "5.3.3" - resolved "https://registry.yarnpkg.com/clean-css/-/clean-css-5.3.3.tgz#b330653cd3bd6b75009cc25c714cae7b93351ccd" - integrity sha512-D5J+kHaVb/wKSFcyyV75uCn8fiY4sV38XJoe4CUyGQ+mOU/fMVYUdH1hJC+CJQ5uY3EnW27SbJYS4X8BiLrAFg== +citty@^0.1.5, citty@^0.1.6: + version "0.1.6" + resolved "https://registry.yarnpkg.com/citty/-/citty-0.1.6.tgz#0f7904da1ed4625e1a9ea7e0fa780981aab7c5e4" + integrity sha512-tskPPKEs8D2KPafUypv2gxwJP8h/OaJmC82QQGGDQcHvXX43xF2VDACcJVmZ0EuSxkpO9Kc4MlrA3q0+FG58AQ== dependencies: - source-map "~0.6.0" + consola "^3.2.3" -clean-stack@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" - integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== - -clean-webpack-plugin@^4.0.0: +cli-cursor@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/clean-webpack-plugin/-/clean-webpack-plugin-4.0.0.tgz#72947d4403d452f38ed61a9ff0ada8122aacd729" - integrity sha512-WuWE1nyTNAyW5T7oNyys2EN0cfP2fdRxhxnIQWiAp0bMabPdHhoGxM8A6YL2GhqwgrPnnaemVE7nv5XJ2Fhh2w== + resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-4.0.0.tgz#3cecfe3734bf4fe02a8361cbdc0f6fe28c6a57ea" + integrity sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg== dependencies: - del "^4.1.1" + restore-cursor "^4.0.0" -cli-spinners@^2.9.2: - version "2.9.2" - resolved "https://registry.yarnpkg.com/cli-spinners/-/cli-spinners-2.9.2.tgz#1773a8f4b9c4d6ac31563df53b3fc1d79462fe41" - integrity sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg== +cli-truncate@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-4.0.0.tgz#6cc28a2924fee9e25ce91e973db56c7066e6172a" + integrity sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA== + dependencies: + slice-ansi "^5.0.0" + string-width "^7.0.0" -cli-width@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-4.1.0.tgz#42daac41d3c254ef38ad8ac037672130173691c5" - integrity sha512-ouuZd4/dm2Sw5Gmqy6bGyNNNe1qt9RpmxveLSO7KcgsTnU7RXfsw+/bukWGo1abgBiMAic068rclZsO4IWmmxQ== +client-only@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/client-only/-/client-only-0.0.1.tgz#38bba5d403c41ab150bff64a95c85013cf73bca1" + integrity sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA== -cliui@^7.0.2: - version "7.0.4" - resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f" - integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== +clipboardy@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/clipboardy/-/clipboardy-4.0.0.tgz#e73ced93a76d19dd379ebf1f297565426dffdca1" + integrity sha512-5mOlNS0mhX0707P2I0aZ2V/cmHUEO/fL7VFLqszkhUsxt7RwnmrInf/eEQKlf5GzvYeHIjT+Ov1HRfNmymlG0w== dependencies: - string-width "^4.2.0" - strip-ansi "^6.0.0" - wrap-ansi "^7.0.0" + execa "^8.0.1" + is-wsl "^3.1.0" + is64bit "^2.0.0" -cliui@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/cliui/-/cliui-8.0.1.tgz#0c04b075db02cbfe60dc8e6cf2f5486b1a3608aa" - integrity sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ== +cliui@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-6.0.0.tgz#511d702c0c4e41ca156d7d0e96021f23e13225b1" + integrity sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ== dependencies: string-width "^4.2.0" - strip-ansi "^6.0.1" - wrap-ansi "^7.0.0" - -clone-deep@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/clone-deep/-/clone-deep-4.0.1.tgz#c19fd9bdbbf85942b4fd979c84dcf7d5f07c2387" - integrity sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ== - dependencies: - is-plain-object "^2.0.4" - kind-of "^6.0.2" - shallow-clone "^3.0.0" + strip-ansi "^6.0.0" + wrap-ansi "^6.2.0" color-convert@^1.9.0: version "1.9.3" @@ -5248,19 +2320,14 @@ color-convert@^2.0.1: color-name@1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" - integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= + integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== color-name@~1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== -color-support@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/color-support/-/color-support-1.1.3.tgz#93834379a1cc9a0c61f82f52f0d04322251bd5a2" - integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== - -colorette@^2.0.10, colorette@^2.0.14: +colorette@^2.0.20: version "2.0.20" resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.20.tgz#9eb793e6833067f7235902fcd3b09917a000a95a" integrity sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w== @@ -5272,190 +2339,42 @@ combined-stream@^1.0.8: dependencies: delayed-stream "~1.0.0" -commander@^10.0.1: - version "10.0.1" - resolved "https://registry.yarnpkg.com/commander/-/commander-10.0.1.tgz#881ee46b4f77d1c1dccc5823433aa39b022cbe06" - integrity sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug== - -commander@^2.2.0, commander@^2.20.0, commander@^2.20.3: +commander@^2.20.3: version "2.20.3" resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33" integrity sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ== -commander@^8.3.0: - version "8.3.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-8.3.0.tgz#4837ea1b2da67b9c616a67afbb0fafee567bca66" - integrity sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww== - -comment-parser@1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.4.1.tgz#bdafead37961ac079be11eb7ec65c4d021eaf9cc" - integrity sha512-buhp5kePrmda3vhc5B9t7pUQXAb2Tnd0qgpkIhPhkHXxJpiPJ11H0ZEU0oBpJ2QztSbzG/ZxMj/CHsYJqRHmyg== - -common-path-prefix@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/common-path-prefix/-/common-path-prefix-3.0.0.tgz#7d007a7e07c58c4b4d5f433131a19141b29f11e0" - integrity sha512-QE33hToZseCH3jS0qN96O/bSh3kaw/h+Tq7ngyY9eWDUnTlTNUyqfqvCXioLe5Na5jFsL78ra/wuBU4iuEgd4w== - -commondir@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" - integrity sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs= - -compressible@~2.0.16: - version "2.0.18" - resolved "https://registry.yarnpkg.com/compressible/-/compressible-2.0.18.tgz#af53cca6b070d4c3c0750fbd77286a6d7cc46fba" - integrity sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg== - dependencies: - mime-db ">= 1.43.0 < 2" - -compression@^1.7.4: - version "1.7.4" - resolved "https://registry.yarnpkg.com/compression/-/compression-1.7.4.tgz#95523eff170ca57c29a0ca41e6fe131f41e5bb8f" - integrity sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ== - dependencies: - accepts "~1.3.5" - bytes "3.0.0" - compressible "~2.0.16" - debug "2.6.9" - on-headers "~1.0.2" - safe-buffer "5.1.2" - vary "~1.1.2" +commander@~12.1.0: + version "12.1.0" + resolved "https://registry.yarnpkg.com/commander/-/commander-12.1.0.tgz#01423b36f501259fdaac4d0e4d60c96c991585d3" + integrity sha512-Vw8qHK3bZM9y/P10u3Vib8o/DdkvA2OtPtZvD871QKjy74Wj1WSKFILMPRPSdUSx5RFK1arlJzEtA4PkFgnbuA== concat-map@0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" - integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= - -confusing-browser-globals@^1.0.11: - version "1.0.11" - resolved "https://registry.yarnpkg.com/confusing-browser-globals/-/confusing-browser-globals-1.0.11.tgz#ae40e9b57cdd3915408a2805ebd3a5585608dc81" - integrity sha512-JsPKdmh8ZkmnHxDk55FZ1TqVLvEQTvoByJZRN9jzI0UjxK/QgAmsphz7PGtqgPieQZ/CQcHWXCR7ATDNhGe+YA== + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== -connect-history-api-fallback@^1: - version "1.6.0" - resolved "https://registry.yarnpkg.com/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz#8b32089359308d111115d81cad3fceab888f97bc" - integrity sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg== - -connect-history-api-fallback@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz#647264845251a0daf25b97ce87834cace0f5f1c8" - integrity sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA== +confbox@^0.1.7: + version "0.1.7" + resolved "https://registry.yarnpkg.com/confbox/-/confbox-0.1.7.tgz#ccfc0a2bcae36a84838e83a3b7f770fb17d6c579" + integrity sha512-uJcB/FKZtBMCJpK8MQji6bJHgu1tixKPxRLeGkNzBoOZzpnZUJm0jm2/sBDWcuBx1dYgxV4JU+g5hmNxCyAmdA== -connect@3.6.6: - version "3.6.6" - resolved "https://registry.yarnpkg.com/connect/-/connect-3.6.6.tgz#09eff6c55af7236e137135a72574858b6786f524" - integrity sha1-Ce/2xVr3I24TcTWnJXSFi2eG9SQ= - dependencies: - debug "2.6.9" - finalhandler "1.1.0" - parseurl "~1.3.2" - utils-merge "1.0.1" +consola@^3.2.3: + version "3.2.3" + resolved "https://registry.yarnpkg.com/consola/-/consola-3.2.3.tgz#0741857aa88cfa0d6fd53f1cff0375136e98502f" + integrity sha512-I5qxpzLv+sJhTVEoLYNcTW+bThDCPsit0vLNKShZx6rLtpilNpmmeTPaeqJb9ZE9dV3DGaeby6Vuhrw38WjeyQ== -console-control-strings@^1.1.0: +cookie-es@^1.0.0: version "1.1.0" - resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" - integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ== - -content-disposition@0.5.4: - version "0.5.4" - resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" - integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== - dependencies: - safe-buffer "5.2.1" - -content-type@~1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" - integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== - -convert-source-map@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-2.0.0.tgz#4b560f649fc4e918dd0ab75cf4961e8bc882d82a" - integrity sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg== - -cookie-signature@1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" - integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= - -cookie@0.5.0, cookie@^0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.5.0.tgz#d1f5d71adec6558c58f389987c366aa47e994f8b" - integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== - -cookie@~0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.1.tgz#afd713fe26ebd21ba95ceb61f9a8116e50a537d1" - integrity sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA== - -copy-webpack-plugin@^11.0.0: - version "11.0.0" - resolved "https://registry.yarnpkg.com/copy-webpack-plugin/-/copy-webpack-plugin-11.0.0.tgz#96d4dbdb5f73d02dd72d0528d1958721ab72e04a" - integrity sha512-fX2MWpamkW0hZxMEg0+mYnA40LTosOSa5TqZ9GYIBzyJa9C3QUaMPSE2xAi/buNr8u89SfD9wHSQVBzrRa/SOQ== - dependencies: - fast-glob "^3.2.11" - glob-parent "^6.0.1" - globby "^13.1.1" - normalize-path "^3.0.0" - schema-utils "^4.0.0" - serialize-javascript "^6.0.0" - -core-js-compat@^3.31.0, core-js-compat@^3.33.1: - version "3.34.0" - resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.34.0.tgz#61a4931a13c52f8f08d924522bba65f8c94a5f17" - integrity sha512-4ZIyeNbW/Cn1wkMMDy+mvrRUxrwFNjKwbhCfQpDd+eLgYipDqp8oGFGtLmhh18EDPKA0g3VUBYOxQGGwvWLVpA== - dependencies: - browserslist "^4.22.2" - -core-js-compat@^3.36.1: - version "3.37.1" - resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.37.1.tgz#c844310c7852f4bdf49b8d339730b97e17ff09ee" - integrity sha512-9TNiImhKvQqSUkOvk/mMRZzOANTiEVC7WaBNhHcKM7x+/5E1l5NvsysR19zuDQScE8k+kfQXWRN3AtS/eOSHpg== - dependencies: - browserslist "^4.23.0" - -core-js-pure@^3.16.0: - version "3.16.2" - resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.16.2.tgz#0ef4b79cabafb251ea86eb7d139b42bd98c533e8" - integrity sha512-oxKe64UH049mJqrKkynWp6Vu0Rlm/BTXO/bJZuN2mmR3RtOFNepLlSWDd1eo16PzHpQAoNG97rLU1V/YxesJjw== - -core-js@^2.4.0: - version "2.6.12" - resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.6.12.tgz#d9333dfa7b065e347cc5682219d6f690859cc2ec" - integrity sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ== - -core-util-is@~1.0.0: - version "1.0.2" - resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" - integrity sha1-tf1UIgqivFq1eqtxQMlAdUUDwac= - -cors@~2.8.5: - version "2.8.5" - resolved "https://registry.yarnpkg.com/cors/-/cors-2.8.5.tgz#eac11da51592dd86b9f06f6e7ac293b3df875d29" - integrity sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g== - dependencies: - object-assign "^4" - vary "^1" - -cosmiconfig@^7.0.0, cosmiconfig@^7.0.1: - version "7.1.0" - resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-7.1.0.tgz#1443b9afa596b670082ea46cbd8f6a62b84635f6" - integrity sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA== - dependencies: - "@types/parse-json" "^4.0.0" - import-fresh "^3.2.1" - parse-json "^5.0.0" - path-type "^4.0.0" - yaml "^1.10.0" + resolved "https://registry.yarnpkg.com/cookie-es/-/cookie-es-1.1.0.tgz#68f8d9f48aeb5a534f3896f80e792760d3d20def" + integrity sha512-L2rLOcK0wzWSfSDA33YR+PUHDG10a8px7rUHKWbGLP4YfbsMed2KFUw5fczvDPbT98DDe3LEzviswl810apTEw== -create-ecdh@^4.0.0: - version "4.0.4" - resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.4.tgz#d6e7f4bffa66736085a0762fd3a632684dabcc4e" - integrity sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A== +copy-to-clipboard@^3.3.1: + version "3.3.3" + resolved "https://registry.yarnpkg.com/copy-to-clipboard/-/copy-to-clipboard-3.3.3.tgz#55ac43a1db8ae639a4bd99511c148cdd1b83a1b0" + integrity sha512-2KV8NhB5JqC3ky0r9PMCAZKbUHSwtEo4CwCs0KXgruG43gX5PMqDEBbVU4OUzw2MuAWUfsuFmWvEKG5QRfSnJA== dependencies: - bn.js "^4.1.0" - elliptic "^6.5.3" + toggle-selection "^1.0.6" create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: version "1.2.0" @@ -5468,7 +2387,7 @@ create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: ripemd160 "^2.0.1" sha.js "^2.4.0" -create-hmac@^1.1.0, create-hmac@^1.1.4, create-hmac@^1.1.7: +create-hmac@^1.1.7: version "1.1.7" resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.7.tgz#69170c78b3ab957147b2b8b04572e47ead2243ff" integrity sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg== @@ -5480,13 +2399,6 @@ create-hmac@^1.1.0, create-hmac@^1.1.4, create-hmac@^1.1.7: safe-buffer "^5.0.1" sha.js "^2.4.8" -cross-fetch@^3.0.4: - version "3.1.4" - resolved "https://registry.npmmirror.com/cross-fetch/download/cross-fetch-3.1.4.tgz#9723f3a3a247bf8b89039f3a380a9244e8fa2f39" - integrity sha1-lyPzo6JHv4uJA586OAqSROj6Lzk= - dependencies: - node-fetch "2.6.1" - cross-fetch@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/cross-fetch/-/cross-fetch-4.0.0.tgz#f037aef1580bb3a1a35164ea2a848ba81b445983" @@ -5494,7 +2406,7 @@ cross-fetch@^4.0.0: dependencies: node-fetch "^2.6.12" -cross-spawn@^7.0.2, cross-spawn@^7.0.3: +cross-spawn@^7.0.0, cross-spawn@^7.0.2, cross-spawn@^7.0.3: version "7.0.3" resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== @@ -5503,186 +2415,83 @@ cross-spawn@^7.0.2, cross-spawn@^7.0.3: shebang-command "^2.0.0" which "^2.0.1" -crypto-browserify@^3.12.0: - version "3.12.0" - resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec" - integrity sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg== - dependencies: - browserify-cipher "^1.0.0" - browserify-sign "^4.0.0" - create-ecdh "^4.0.0" - create-hash "^1.1.0" - create-hmac "^1.1.0" - diffie-hellman "^5.0.0" - inherits "^2.0.1" - pbkdf2 "^3.0.3" - public-encrypt "^4.0.0" - randombytes "^2.0.0" - randomfill "^1.0.3" - -css-loader@^6.8.1: - version "6.8.1" - resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-6.8.1.tgz#0f8f52699f60f5e679eab4ec0fcd68b8e8a50a88" - integrity sha512-xDAXtEVGlD0gJ07iclwWVkLoZOpEvAWaSyf6W18S2pOC//K8+qUDIx8IIT3D+HjnmkJPQeesOPv5aiUaJsCM2g== - dependencies: - icss-utils "^5.1.0" - postcss "^8.4.21" - postcss-modules-extract-imports "^3.0.0" - postcss-modules-local-by-default "^4.0.3" - postcss-modules-scope "^3.0.0" - postcss-modules-values "^4.0.0" - postcss-value-parser "^4.2.0" - semver "^7.3.8" - -css-select@^4.1.3: - version "4.1.3" - resolved "https://registry.yarnpkg.com/css-select/-/css-select-4.1.3.tgz#a70440f70317f2669118ad74ff105e65849c7067" - integrity sha512-gT3wBNd9Nj49rAbmtFHj1cljIAOLYSX1nZ8CB7TBO3INYckygm5B7LISU/szY//YmdiSLbJvDLOx9VnMVpMBxA== - dependencies: - boolbase "^1.0.0" - css-what "^5.0.0" - domhandler "^4.2.0" - domutils "^2.6.0" - nth-check "^2.0.0" - -css-what@^5.0.0: - version "5.0.1" - resolved "https://registry.yarnpkg.com/css-what/-/css-what-5.0.1.tgz#3efa820131f4669a8ac2408f9c32e7c7de9f4cad" - integrity sha512-FYDTSHb/7KXsWICVsxdmiExPjCfRC4qRFBdVwv7Ax9hMnvMmEjP9RfxTEZ3qPZGmADDn2vAKSo9UcN1jKVYscg== - -css.escape@^1.5.1: - version "1.5.1" - resolved "https://registry.yarnpkg.com/css.escape/-/css.escape-1.5.1.tgz#42e27d4fa04ae32f931a4b4d4191fa9cddee97cb" - integrity sha1-QuJ9T6BK4y+TGktNQZH6nN3ul8s= - -css@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/css/-/css-3.0.0.tgz#4447a4d58fdd03367c516ca9f64ae365cee4aa5d" - integrity sha512-DG9pFfwOrzc+hawpmqX/dHYHJG+Bsdb0klhyi1sDneOgGOXy9wQIC8hzyVp1e4NRYDBdxcylvywPkkXCHAzTyQ== - dependencies: - inherits "^2.0.4" - source-map "^0.6.1" - source-map-resolve "^0.6.0" - -cssesc@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee" - integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg== +crossws@^0.2.0, crossws@^0.2.2: + version "0.2.4" + resolved "https://registry.yarnpkg.com/crossws/-/crossws-0.2.4.tgz#82a8b518bff1018ab1d21ced9e35ffbe1681ad03" + integrity sha512-DAxroI2uSOgUKLz00NX6A8U/8EE3SZHmIND+10jkVSaypvyt57J5JEOxAQOL6lQxyzi/wZbTIwssU1uy69h5Vg== csstype@^3.0.2: - version "3.0.8" - resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.0.8.tgz#d2266a792729fb227cd216fb572f43728e1ad340" - integrity sha512-jXKhWqXPmlUeoQnF/EhTtTl4C9SnrxSH/jZUih3jmO6lBKr99rP3/+FmrMj4EFpOXzMtXHAZkd3x0E6h6Fgflw== + version "3.1.3" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.1.3.tgz#d80ff294d114fb0e6ac500fbf85b60137d7eff81" + integrity sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw== damerau-levenshtein@^1.0.8: version "1.0.8" resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz#b43d286ccbd36bc5b2f7ed41caf2d0aba1f8a6e7" integrity sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA== -debug@2.6.9, debug@^2.2.0, debug@^2.6.8: - version "2.6.9" - resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== - dependencies: - ms "2.0.0" - -debug@4, debug@^4.0.1, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1: - version "4.3.2" - resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.2.tgz#f0a49c18ac8779e31d4a0c6029dfb76873c7428b" - integrity sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw== - dependencies: - ms "2.1.2" - -debug@4.3.3: - version "4.3.3" - resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" - integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q== +data-view-buffer@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/data-view-buffer/-/data-view-buffer-1.0.1.tgz#8ea6326efec17a2e42620696e671d7d5a8bc66b2" + integrity sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA== dependencies: - ms "2.1.2" + call-bind "^1.0.6" + es-errors "^1.3.0" + is-data-view "^1.0.1" -debug@^3.2.7: - version "3.2.7" - resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" - integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== +data-view-byte-length@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz#90721ca95ff280677eb793749fce1011347669e2" + integrity sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ== dependencies: - ms "^2.1.1" + call-bind "^1.0.7" + es-errors "^1.3.0" + is-data-view "^1.0.1" -debug@^4.3.3, debug@^4.3.4: - version "4.3.4" - resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" - integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== +data-view-byte-offset@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz#5e0bbfb4828ed2d1b9b400cd8a7d119bca0ff18a" + integrity sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA== dependencies: - ms "2.1.2" + call-bind "^1.0.6" + es-errors "^1.3.0" + is-data-view "^1.0.1" -debug@~4.3.1, debug@~4.3.2, debug@~4.3.4: +debug@4, debug@^4.3.1, debug@^4.3.2, debug@^4.3.4, debug@~4.3.4: version "4.3.5" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.5.tgz#e83444eceb9fedd4a1da56d671ae2446a01a6e1e" integrity sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg== dependencies: ms "2.1.2" -decamelize-keys@^1.1.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/decamelize-keys/-/decamelize-keys-1.1.1.tgz#04a2d523b2f18d80d0158a43b895d56dff8d19d8" - integrity sha512-WiPxgEirIV0/eIOMcnFBA3/IJZAZqKnwAwWyvvdi4lsr1WCN22nhdf/3db3DoZcUjTV2SqfzIwNyp6y2xs3nmg== +debug@^3.2.7: + version "3.2.7" + resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" + integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== dependencies: - decamelize "^1.1.0" - map-obj "^1.0.0" + ms "^2.1.1" -decamelize@^1.1.0, decamelize@^1.2.0: +decamelize@^1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" - integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA= - -decamelize@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" - integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== + integrity sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA== decimal.js@^10.2.0: - version "10.3.1" - resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.3.1.tgz#d8c3a444a9c6774ba60ca6ad7261c3a94fd5e783" - integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== - -decode-uri-component@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" - integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= + version "10.4.3" + resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.4.3.tgz#1044092884d245d1b7f65725fa4ad4c6f781cc23" + integrity sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA== -deep-eql@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-3.0.1.tgz#dfc9404400ad1c8fe023e7da1df1c147c4b444df" - integrity sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw== - dependencies: - type-detect "^4.0.0" +decode-uri-component@^0.2.2: + version "0.2.2" + resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz#e69dbe25d37941171dd540e024c444cd5188e1e9" + integrity sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ== deep-is@^0.1.3: - version "0.1.3" - resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" - integrity sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ= - -deepmerge@^4.2.2: - version "4.2.2" - resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.2.2.tgz#44d2ea3679b8f4d4ffba33f03d865fc1e7bf4955" - integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== - -default-gateway@^6.0.3: - version "6.0.3" - resolved "https://registry.yarnpkg.com/default-gateway/-/default-gateway-6.0.3.tgz#819494c888053bdb743edbf343d6cdf7f2943a71" - integrity sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg== - dependencies: - execa "^5.0.0" - -define-data-property@^1.0.1, define-data-property@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.1.tgz#c35f7cd0ab09883480d12ac5cb213715587800b3" - integrity sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ== - dependencies: - get-intrinsic "^1.2.1" - gopd "^1.0.1" - has-property-descriptors "^1.0.0" + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== -define-data-property@^1.1.4: +define-data-property@^1.0.1, define-data-property@^1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.4.tgz#894dc141bb7d3060ae4366f6a0107e68fbe48c5e" integrity sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A== @@ -5691,27 +2500,7 @@ define-data-property@^1.1.4: es-errors "^1.3.0" gopd "^1.0.1" -define-lazy-prop@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz#3f7ae421129bcaaac9bc74905c98a0009ec9ee7f" - integrity sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og== - -define-properties@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.3.tgz#cf88da6cbee26fe6db7094f61d870cbd84cee9f1" - integrity sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ== - dependencies: - object-keys "^1.0.12" - -define-properties@^1.1.4: - version "1.1.4" - resolved "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz#0b14d7bd7fbeb2f3572c3a7eda80ea5d57fb05b1" - integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== - dependencies: - has-property-descriptors "^1.0.0" - object-keys "^1.1.1" - -define-properties@^1.2.0, define-properties@^1.2.1: +define-properties@^1.1.3, define-properties@^1.2.0, define-properties@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.1.tgz#10781cc616eb951a80a034bafcaa7377f6af2b6c" integrity sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg== @@ -5720,18 +2509,10 @@ define-properties@^1.2.0, define-properties@^1.2.1: has-property-descriptors "^1.0.0" object-keys "^1.1.1" -del@^4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/del/-/del-4.1.1.tgz#9e8f117222ea44a31ff3a156c049b99052a9f0b4" - integrity sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ== - dependencies: - "@types/glob" "^7.1.1" - globby "^6.1.0" - is-path-cwd "^2.0.0" - is-path-in-cwd "^2.0.0" - p-map "^2.0.0" - pify "^4.0.1" - rimraf "^2.6.3" +defu@^6.1.3, defu@^6.1.4: + version "6.1.4" + resolved "https://registry.yarnpkg.com/defu/-/defu-6.1.4.tgz#4e0c9cf9ff68fe5f3d7f2765cc1a012dfdcb0479" + integrity sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg== delay@^5.0.0: version "5.0.0" @@ -5743,72 +2524,30 @@ delayed-stream@~1.0.0: resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== -delegates@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" - integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ== - -depd@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" - integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== - -depd@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" - integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= - dequal@^2.0.3: version "2.0.3" resolved "https://registry.yarnpkg.com/dequal/-/dequal-2.0.3.tgz#2644214f1997d39ed0ee0ece72335490a7ac67be" integrity sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA== -des.js@^1.0.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.1.0.tgz#1d37f5766f3bbff4ee9638e871a8768c173b81da" - integrity sha512-r17GxjhUCjSRy8aiJpr8/UadFIzMzJGexI3Nmz4ADi9LYSFx4gTBp80+NaX/YsXWWLhpZ7v/v/ubEc/bCNfKwg== - dependencies: - inherits "^2.0.1" - minimalistic-assert "^1.0.0" - -destroy@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" - integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== - -destroy@~1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" - integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= - -detect-node@^2.0.4: - version "2.1.0" - resolved "https://registry.yarnpkg.com/detect-node/-/detect-node-2.1.0.tgz#c9c70775a49c3d03bc2c06d9a73be550f978f8b1" - integrity sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g== - -dev-ip@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/dev-ip/-/dev-ip-1.0.1.tgz#a76a3ed1855be7a012bb8ac16cb80f3c00dc28f0" - integrity sha1-p2o+0YVb56ASu4rBbLgPPADcKPA= +destr@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/destr/-/destr-2.0.3.tgz#7f9e97cb3d16dbdca7be52aca1644ce402cfe449" + integrity sha512-2N3BOUU4gYMpTP24s5rF5iP7BDr7uNTCs4ozw3kf/eKfvWSIu93GEBi5m427YoyJoeOzQ5smuu4nNAPGb8idSQ== -diff-sequences@^27.0.6: - version "27.0.6" - resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-27.0.6.tgz#3305cb2e55a033924054695cc66019fd7f8e5723" - integrity sha512-ag6wfpBFyNXZ0p8pcuIDS//D8H062ZQJ3fzYxjpmeKjnz8W4pekL3AI8VohmyZmsWW2PWaHgjsmqR6L13101VQ== +detect-browser@5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/detect-browser/-/detect-browser-5.3.0.tgz#9705ef2bddf46072d0f7265a1fe300e36fe7ceca" + integrity sha512-53rsFbGdwMwlF7qvCt0ypLM5V5/Mbl0szB7GPN8y9NCcbknYOeVVXdrXEq+90IwAfrrzt6Hd+u2E2ntakICU8w== -diff@5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/diff/-/diff-5.0.0.tgz#7ed6ad76d859d030787ec35855f5b1daf31d852b" - integrity sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w== +detect-libc@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" + integrity sha512-pGjwhsmsp4kL2RTz08wcOlGN83otlqHeD/Z5T8GXZB+/YcpQ/dgo+lbU8ZsGxV0HIvqqxo9l7mqYwyYMD9bKDg== -diffie-hellman@^5.0.0: - version "5.0.3" - resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.3.tgz#40e8ee98f55a2149607146921c63e1ae5f3d2875" - integrity sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg== - dependencies: - bn.js "^4.1.0" - miller-rabin "^4.0.0" - randombytes "^2.0.0" +dijkstrajs@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/dijkstrajs/-/dijkstrajs-1.0.3.tgz#4c8dbdea1f0f6478bff94d9c49c784d623e4fc23" + integrity sha512-qiSlmBq9+BCdCA/L46dw8Uy93mloxsPSbwnm5yrKn2vMPiy8KyAskTF6zuV/j5BMsmOGZDPs7KjU+mjb670kfA== dir-glob@^3.0.1: version "3.0.1" @@ -5817,141 +2556,74 @@ dir-glob@^3.0.1: dependencies: path-type "^4.0.0" -dns-equal@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/dns-equal/-/dns-equal-1.0.0.tgz#b39e7f1da6eb0a75ba9c17324b34753c47e0654d" - integrity sha1-s55/HabrCnW6nBcySzR1PEfgZU0= - -dns-packet@^5.2.2: - version "5.6.1" - resolved "https://registry.yarnpkg.com/dns-packet/-/dns-packet-5.6.1.tgz#ae888ad425a9d1478a0674256ab866de1012cf2f" - integrity sha512-l4gcSouhcgIKRvyy99RNVOgxXiicE+2jZoNmaNmZ6JXiGajBOJAesk1OBlJuM5k2c+eudGdLxDqXuPCKIj6kpw== - dependencies: - "@leichtgewicht/ip-codec" "^2.0.1" - doctrine@^2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz#5cd01fc101621b42c4cd7f5d1a66243716d3f39d" - integrity sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw== - dependencies: - esutils "^2.0.2" - -doctrine@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" - integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== - dependencies: - esutils "^2.0.2" - -dom-accessibility-api@^0.5.6: - version "0.5.7" - resolved "https://registry.yarnpkg.com/dom-accessibility-api/-/dom-accessibility-api-0.5.7.tgz#8c2aa6325968f2933160a0b7dbb380893ddf3e7d" - integrity sha512-ml3lJIq9YjUfM9TUnEPvEYWFSwivwIGBPKpewX7tii7fwCazA8yCioGdqQcNsItPpfFvSJ3VIdMQPj60LJhcQA== - -dom-converter@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/dom-converter/-/dom-converter-0.2.0.tgz#6721a9daee2e293682955b6afe416771627bb768" - integrity sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA== - dependencies: - utila "~0.4" - -dom-serializer@^1.0.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-1.3.2.tgz#6206437d32ceefaec7161803230c7a20bc1b4d91" - integrity sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.2.0" - entities "^2.0.0" - -dom-walk@^0.1.0: - version "0.1.2" - resolved "https://registry.yarnpkg.com/dom-walk/-/dom-walk-0.1.2.tgz#0c548bef048f4d1f2a97249002236060daa3fd84" - integrity sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w== - -domelementtype@^2.0.1, domelementtype@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.2.0.tgz#9a0b6c2782ed6a1c7323d42267183df9bd8b1d57" - integrity sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A== - -domhandler@4.3.0, domhandler@^4.2.2: - version "4.3.0" - resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.3.0.tgz#16c658c626cf966967e306f966b431f77d4a5626" - integrity sha512-fC0aXNQXqKSFTr2wDNZDhsEYjCiYsDWl3D01kwt25hm1YIPyDGHvvi3rw+PLqHAl/m71MaiF7d5zvBr0p5UB2g== + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz#5cd01fc101621b42c4cd7f5d1a66243716d3f39d" + integrity sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw== dependencies: - domelementtype "^2.2.0" + esutils "^2.0.2" -domhandler@^4.0.0, domhandler@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.2.0.tgz#f9768a5f034be60a89a27c2e4d0f74eba0d8b059" - integrity sha512-zk7sgt970kzPks2Bf+dwT/PLzghLnsivb9CcxkvR8Mzr66Olr0Ofd8neSbglHJHaHa2MadfoSdNlKYAaafmWfA== +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== dependencies: - domelementtype "^2.2.0" - -dompurify@^2.3.5: - version "2.3.5" - resolved "https://registry.yarnpkg.com/dompurify/-/dompurify-2.3.5.tgz#c83ed5a3ae5ce23e52efe654ea052ffb358dd7e3" - integrity sha512-kD+f8qEaa42+mjdOpKeztu9Mfx5bv9gVLO6K9jRx4uGvh6Wv06Srn4jr1wPNY2OOUGGSKHNFN+A8MA3v0E0QAQ== + esutils "^2.0.2" -domutils@^2.5.2, domutils@^2.6.0: - version "2.7.0" - resolved "https://registry.yarnpkg.com/domutils/-/domutils-2.7.0.tgz#8ebaf0c41ebafcf55b0b72ec31c56323712c5442" - integrity sha512-8eaHa17IwJUPAiB+SoTYBo5mCdeMgdcAoXJ59m6DT1vw+5iLS3gNoqYaRowaBKtGVrOF1Jz4yDTgYKLK2kvfJg== +dom-serializer@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-2.0.0.tgz#e41b802e1eedf9f6cae183ce5e622d789d7d8e53" + integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg== dependencies: - dom-serializer "^1.0.1" - domelementtype "^2.2.0" - domhandler "^4.2.0" + domelementtype "^2.3.0" + domhandler "^5.0.2" + entities "^4.2.0" -domutils@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/domutils/-/domutils-2.8.0.tgz#4437def5db6e2d1f5d6ee859bd95ca7d02048135" - integrity sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A== - dependencies: - dom-serializer "^1.0.1" - domelementtype "^2.2.0" - domhandler "^4.2.0" +domelementtype@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d" + integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== -dot-case@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-3.0.4.tgz#9b2b670d00a431667a8a75ba29cd1b98809ce751" - integrity sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w== +domhandler@5.0.3, domhandler@^5.0.2, domhandler@^5.0.3: + version "5.0.3" + resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-5.0.3.tgz#cc385f7f751f1d1fc650c21374804254538c7d31" + integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w== dependencies: - no-case "^3.0.4" - tslib "^2.0.3" + domelementtype "^2.3.0" -easy-extender@^2.3.4: - version "2.3.4" - resolved "https://registry.yarnpkg.com/easy-extender/-/easy-extender-2.3.4.tgz#298789b64f9aaba62169c77a2b3b64b4c9589b8f" - integrity sha512-8cAwm6md1YTiPpOvDULYJL4ZS6WfM5/cTeVVh4JsvyYZAoqlRVUpHL9Gr5Fy7HA6xcSZicUia3DeAgO3Us8E+Q== - dependencies: - lodash "^4.17.10" +dompurify@^3.1.2: + version "3.1.5" + resolved "https://registry.yarnpkg.com/dompurify/-/dompurify-3.1.5.tgz#2c6a113fc728682a0f55684b1388c58ddb79dc38" + integrity sha512-lwG+n5h8QNpxtyrJW/gJWckL+1/DQiYMX8f7t8Z2AZTPw1esVrqjI63i7Zc2Gz0aKzLVMYC1V1PL/ky+aY/NgA== -eazy-logger@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/eazy-logger/-/eazy-logger-4.0.1.tgz#2e9fe487fb14ed6ac20d5f01d90dff377d403041" - integrity sha512-2GSFtnnC6U4IEKhEI7+PvdxrmjJ04mdsj3wHZTFiw0tUtG4HCWzTr13ZYTk8XOGnA1xQMaDljoBOYlk3D/MMSw== +domutils@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/domutils/-/domutils-3.1.0.tgz#c47f551278d3dc4b0b1ab8cbb42d751a6f0d824e" + integrity sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA== dependencies: - chalk "4.1.2" + dom-serializer "^2.0.0" + domelementtype "^2.3.0" + domhandler "^5.0.3" -ee-first@1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" - integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= - -electron-to-chromium@^1.4.601: - version "1.4.609" - resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.609.tgz#5790a70aaa96de232501b56e14b64d17aff93988" - integrity sha512-ihiCP7PJmjoGNuLpl7TjNA8pCQWu09vGyjlPYw1Rqww4gvNuCcmvl+44G+2QyJ6S2K4o+wbTS++Xz0YN8Q9ERw== +duplexify@^4.1.2: + version "4.1.3" + resolved "https://registry.yarnpkg.com/duplexify/-/duplexify-4.1.3.tgz#a07e1c0d0a2c001158563d32592ba58bddb0236f" + integrity sha512-M3BmBhwJRZsSx38lZyhE53Csddgzl5R7xGJNk7CVddZD6CcmwMCH8J+7AprIrQKH7TonKxaCjcv27Qmf+sQ+oA== + dependencies: + end-of-stream "^1.4.1" + inherits "^2.0.3" + readable-stream "^3.1.1" + stream-shift "^1.0.2" -electron-to-chromium@^1.4.796: - version "1.4.802" - resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.802.tgz#49b397eadc95a49b1ac33eebee146b8e5a93773f" - integrity sha512-TnTMUATbgNdPXVSHsxvNVSG0uEd6cSZsANjm8c9HbvflZVVn1yTRcmVXYT1Ma95/ssB/Dcd30AHweH2TE+dNpA== +eastasianwidth@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.2.0.tgz#696ce2ec0aa0e6ea93a397ffcf24aa7840c827cb" + integrity sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA== -elliptic@^6.4.0, elliptic@^6.5.3, elliptic@^6.5.4: - version "6.5.4" - resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.4.tgz#da37cebd31e79a1367e941b592ed1fbebd58abbb" - integrity sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ== +elliptic@^6.4.0, elliptic@^6.5.4: + version "6.5.5" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.5.tgz#c715e09f78b6923977610d4c2346d6ce22e6dded" + integrity sha512-7EjbcmUm17NQFu4Pmgmq2olYMj8nwMnpcddByChSUjArp8F5DQWcIcpriwO4ZToLNAJig0yiyjswfyGNje/ixw== dependencies: bn.js "^4.11.9" brorand "^1.1.0" @@ -5961,6 +2633,11 @@ elliptic@^6.4.0, elliptic@^6.5.3, elliptic@^6.5.4: minimalistic-assert "^1.0.1" minimalistic-crypto-utils "^1.0.1" +emoji-regex@^10.3.0: + version "10.3.0" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-10.3.0.tgz#76998b9268409eb3dae3de989254d456e70cfe23" + integrity sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw== + emoji-regex@^8.0.0: version "8.0.0" resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" @@ -5971,64 +2648,19 @@ emoji-regex@^9.2.2: resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-9.2.2.tgz#840c8803b0d8047f4ff0cf963176b32d4ef3ed72" integrity sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg== -emojis-list@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" - integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== +encode-utf8@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/encode-utf8/-/encode-utf8-1.0.3.tgz#f30fdd31da07fb596f281beb2f6b027851994cda" + integrity sha512-ucAnuBEhUK4boH2HjVYG5Q2mQyPorvv0u/ocS+zhdw0S8AlHYY+GOFhP1Gio5z4icpP2ivFSvhtFjQi8+T9ppw== -encodeurl@~1.0.1, encodeurl@~1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" - integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= - -encoding@^0.1.12, encoding@^0.1.13: - version "0.1.13" - resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" - integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== - dependencies: - iconv-lite "^0.6.2" - -engine.io-client@~6.5.2: - version "6.5.3" - resolved "https://registry.yarnpkg.com/engine.io-client/-/engine.io-client-6.5.3.tgz#4cf6fa24845029b238f83c628916d9149c399bc5" - integrity sha512-9Z0qLB0NIisTRt1DZ/8U2k12RJn8yls/nXMZLn+/N8hANT3TcYjKFKcwbw5zFQiN4NTde3TSY9zb79e1ij6j9Q== - dependencies: - "@socket.io/component-emitter" "~3.1.0" - debug "~4.3.1" - engine.io-parser "~5.2.1" - ws "~8.11.0" - xmlhttprequest-ssl "~2.0.0" - -engine.io-parser@~5.2.1: - version "5.2.2" - resolved "https://registry.yarnpkg.com/engine.io-parser/-/engine.io-parser-5.2.2.tgz#37b48e2d23116919a3453738c5720455e64e1c49" - integrity sha512-RcyUFKA93/CXH20l4SoVvzZfrSDMOTUS3bWVpTt2FuFP+XYrL8i8oonHP7WInRyVHXh0n/ORtoeiE1os+8qkSw== - -engine.io@~6.5.2: - version "6.5.4" - resolved "https://registry.yarnpkg.com/engine.io/-/engine.io-6.5.4.tgz#6822debf324e781add2254e912f8568508850cdc" - integrity sha512-KdVSDKhVKyOi+r5uEabrDLZw2qXStVvCsEB/LN3mw4WFi6Gx50jTyuxYVCwAAC0U46FdnzP/ScKRBTXb/NiEOg== - dependencies: - "@types/cookie" "^0.4.1" - "@types/cors" "^2.8.12" - "@types/node" ">=10.0.0" - accepts "~1.3.4" - base64id "2.0.0" - cookie "~0.4.1" - cors "~2.8.5" - debug "~4.3.1" - engine.io-parser "~5.2.1" - ws "~8.11.0" - -enhanced-resolve@^5.0.0, enhanced-resolve@^5.7.0: - version "5.15.0" - resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz#1af946c7d93603eb88e9896cee4904dc012e9c35" - integrity sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg== +end-of-stream@^1.4.1: + version "1.4.4" + resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" + integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== dependencies: - graceful-fs "^4.2.4" - tapable "^2.2.0" + once "^1.4.0" -enhanced-resolve@^5.17.0: +enhanced-resolve@^5.12.0: version "5.17.0" resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.17.0.tgz#d037603789dd9555b89aaec7eb78845c49089bc5" integrity sha512-dwDPwZL0dmye8Txp2gzFmA6sxALaSvdRDjPH0viLcKrtlOL3tw62nWWweVD1SdILDTJrbrL6tdWVN58Wo6U3eA== @@ -6036,118 +2668,62 @@ enhanced-resolve@^5.17.0: graceful-fs "^4.2.4" tapable "^2.2.0" -enquirer@^2.3.5: - version "2.3.6" - resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.3.6.tgz#2a7fe5dd634a1e4125a975ec994ff5456dc3734d" - integrity sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg== - dependencies: - ansi-colors "^4.1.1" - -entities@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" - integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== - -entities@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/entities/-/entities-3.0.1.tgz#2b887ca62585e96db3903482d336c1006c3001d4" - integrity sha512-WiyBqoomrwMdFG1e0kqvASYfnlb0lp8M5o5Fw2OFq1hNZxxcNk8Ik0Xm7LxzBhuidnZB/UtBqVCgUz3kBOP51Q== - -env-paths@^2.2.0: - version "2.2.1" - resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" - integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== - -envinfo@^7.7.3: - version "7.11.0" - resolved "https://registry.yarnpkg.com/envinfo/-/envinfo-7.11.0.tgz#c3793f44284a55ff8c82faf1ffd91bc6478ea01f" - integrity sha512-G9/6xF1FPbIw0TtalAMaVPpiq2aDEuKLXM314jPVAO9r2fo2a4BLqMNkmRS7O/xPPZ+COAhGIz3ETvHEV3eUcg== - -err-code@^2.0.2: - version "2.0.3" - resolved "https://registry.yarnpkg.com/err-code/-/err-code-2.0.3.tgz#23c2f3b756ffdfc608d30e27c9a941024807e7f9" - integrity sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA== - -error-ex@^1.3.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" - integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== - dependencies: - is-arrayish "^0.2.1" - -es-abstract@^1.19.0, es-abstract@^1.19.5, es-abstract@^1.20.0: - version "1.20.1" - resolved "https://registry.npmjs.org/es-abstract/-/es-abstract-1.20.1.tgz#027292cd6ef44bd12b1913b828116f54787d1814" - integrity sha512-WEm2oBhfoI2sImeM4OF2zE2V3BYdSF+KnSi9Sidz51fQHd7+JuF8Xgcj9/0o+OWeIeIS/MiuNnlruQrJf16GQA== - dependencies: - call-bind "^1.0.2" - es-to-primitive "^1.2.1" - function-bind "^1.1.1" - function.prototype.name "^1.1.5" - get-intrinsic "^1.1.1" - get-symbol-description "^1.0.0" - has "^1.0.3" - has-property-descriptors "^1.0.0" - has-symbols "^1.0.3" - internal-slot "^1.0.3" - is-callable "^1.2.4" - is-negative-zero "^2.0.2" - is-regex "^1.1.4" - is-shared-array-buffer "^1.0.2" - is-string "^1.0.7" - is-weakref "^1.0.2" - object-inspect "^1.12.0" - object-keys "^1.1.1" - object.assign "^4.1.2" - regexp.prototype.flags "^1.4.3" - string.prototype.trimend "^1.0.5" - string.prototype.trimstart "^1.0.5" - unbox-primitive "^1.0.2" +entities@^4.2.0, entities@^4.5.0: + version "4.5.0" + resolved "https://registry.yarnpkg.com/entities/-/entities-4.5.0.tgz#5d268ea5e7113ec74c4d033b79ea5a35a488fb48" + integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw== -es-abstract@^1.22.1: - version "1.22.3" - resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.22.3.tgz#48e79f5573198de6dee3589195727f4f74bc4f32" - integrity sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA== +es-abstract@^1.22.1, es-abstract@^1.22.3, es-abstract@^1.23.0, es-abstract@^1.23.1, es-abstract@^1.23.2, es-abstract@^1.23.3: + version "1.23.3" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.23.3.tgz#8f0c5a35cd215312573c5a27c87dfd6c881a0aa0" + integrity sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A== dependencies: - array-buffer-byte-length "^1.0.0" - arraybuffer.prototype.slice "^1.0.2" - available-typed-arrays "^1.0.5" - call-bind "^1.0.5" - es-set-tostringtag "^2.0.1" + array-buffer-byte-length "^1.0.1" + arraybuffer.prototype.slice "^1.0.3" + available-typed-arrays "^1.0.7" + call-bind "^1.0.7" + data-view-buffer "^1.0.1" + data-view-byte-length "^1.0.1" + data-view-byte-offset "^1.0.0" + es-define-property "^1.0.0" + es-errors "^1.3.0" + es-object-atoms "^1.0.0" + es-set-tostringtag "^2.0.3" es-to-primitive "^1.2.1" function.prototype.name "^1.1.6" - get-intrinsic "^1.2.2" - get-symbol-description "^1.0.0" + get-intrinsic "^1.2.4" + get-symbol-description "^1.0.2" globalthis "^1.0.3" gopd "^1.0.1" - has-property-descriptors "^1.0.0" - has-proto "^1.0.1" + has-property-descriptors "^1.0.2" + has-proto "^1.0.3" has-symbols "^1.0.3" - hasown "^2.0.0" - internal-slot "^1.0.5" - is-array-buffer "^3.0.2" + hasown "^2.0.2" + internal-slot "^1.0.7" + is-array-buffer "^3.0.4" is-callable "^1.2.7" - is-negative-zero "^2.0.2" + is-data-view "^1.0.1" + is-negative-zero "^2.0.3" is-regex "^1.1.4" - is-shared-array-buffer "^1.0.2" + is-shared-array-buffer "^1.0.3" is-string "^1.0.7" - is-typed-array "^1.1.12" + is-typed-array "^1.1.13" is-weakref "^1.0.2" object-inspect "^1.13.1" object-keys "^1.1.1" - object.assign "^4.1.4" - regexp.prototype.flags "^1.5.1" - safe-array-concat "^1.0.1" - safe-regex-test "^1.0.0" - string.prototype.trim "^1.2.8" - string.prototype.trimend "^1.0.7" - string.prototype.trimstart "^1.0.7" - typed-array-buffer "^1.0.0" - typed-array-byte-length "^1.0.0" - typed-array-byte-offset "^1.0.0" - typed-array-length "^1.0.4" + object.assign "^4.1.5" + regexp.prototype.flags "^1.5.2" + safe-array-concat "^1.1.2" + safe-regex-test "^1.0.3" + string.prototype.trim "^1.2.9" + string.prototype.trimend "^1.0.8" + string.prototype.trimstart "^1.0.8" + typed-array-buffer "^1.0.2" + typed-array-byte-length "^1.0.1" + typed-array-byte-offset "^1.0.2" + typed-array-length "^1.0.6" unbox-primitive "^1.0.2" - which-typed-array "^1.1.13" + which-typed-array "^1.1.15" es-define-property@^1.0.0: version "1.0.0" @@ -6156,46 +2732,48 @@ es-define-property@^1.0.0: dependencies: get-intrinsic "^1.2.4" -es-errors@^1.3.0: +es-errors@^1.2.1, es-errors@^1.3.0: version "1.3.0" resolved "https://registry.yarnpkg.com/es-errors/-/es-errors-1.3.0.tgz#05f75a25dab98e4fb1dcd5e1472c0546d5057c8f" integrity sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw== -es-iterator-helpers@^1.0.12, es-iterator-helpers@^1.0.15: - version "1.0.15" - resolved "https://registry.yarnpkg.com/es-iterator-helpers/-/es-iterator-helpers-1.0.15.tgz#bd81d275ac766431d19305923707c3efd9f1ae40" - integrity sha512-GhoY8uYqd6iwUl2kgjTm4CZAf6oo5mHK7BPqx3rKgx893YSsy0LGHV6gfqqQvZt/8xM8xeOnfXBCfqclMKkJ5g== +es-iterator-helpers@^1.0.15, es-iterator-helpers@^1.0.19: + version "1.0.19" + resolved "https://registry.yarnpkg.com/es-iterator-helpers/-/es-iterator-helpers-1.0.19.tgz#117003d0e5fec237b4b5c08aded722e0c6d50ca8" + integrity sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw== dependencies: - asynciterator.prototype "^1.0.0" - call-bind "^1.0.2" + call-bind "^1.0.7" define-properties "^1.2.1" - es-abstract "^1.22.1" - es-set-tostringtag "^2.0.1" - function-bind "^1.1.1" - get-intrinsic "^1.2.1" + es-abstract "^1.23.3" + es-errors "^1.3.0" + es-set-tostringtag "^2.0.3" + function-bind "^1.1.2" + get-intrinsic "^1.2.4" globalthis "^1.0.3" - has-property-descriptors "^1.0.0" - has-proto "^1.0.1" + has-property-descriptors "^1.0.2" + has-proto "^1.0.3" has-symbols "^1.0.3" - internal-slot "^1.0.5" + internal-slot "^1.0.7" iterator.prototype "^1.1.2" - safe-array-concat "^1.0.1" + safe-array-concat "^1.1.2" -es-module-lexer@^1.2.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/es-module-lexer/-/es-module-lexer-1.4.1.tgz#41ea21b43908fe6a287ffcbe4300f790555331f5" - integrity sha512-cXLGjP0c4T3flZJKQSuziYoq7MlT+rnvfZjfp7h+I7K9BNX54kP9nyWvdbwjQ4u1iWbOL4u96fgeZLToQlZC7w== +es-object-atoms@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/es-object-atoms/-/es-object-atoms-1.0.0.tgz#ddb55cd47ac2e240701260bc2a8e31ecb643d941" + integrity sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw== + dependencies: + es-errors "^1.3.0" -es-set-tostringtag@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz#11f7cc9f63376930a5f20be4915834f4bc74f9c9" - integrity sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q== +es-set-tostringtag@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz#8bb60f0a440c2e4281962428438d58545af39777" + integrity sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ== dependencies: - get-intrinsic "^1.2.2" - has-tostringtag "^1.0.0" - hasown "^2.0.0" + get-intrinsic "^1.2.4" + has-tostringtag "^1.0.2" + hasown "^2.0.1" -es-shim-unscopables@^1.0.0: +es-shim-unscopables@^1.0.0, es-shim-unscopables@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz#1f6942e71ecc7835ed1c8a83006d8771a63a3763" integrity sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw== @@ -6211,11 +2789,6 @@ es-to-primitive@^1.2.1: is-date-object "^1.0.1" is-symbol "^1.0.2" -es6-object-assign@^1.1.0: - version "1.1.0" - resolved "https://registry.npmjs.org/es6-object-assign/-/es6-object-assign-1.1.0.tgz#c2c3582656247c39ea107cb1e6652b6f9f24523c" - integrity sha512-MEl9uirslVwqQU369iHNWZXsI8yaZYGg/D65aOgZkeyFJwHYSxilf7rQzXKI7DdDuBPrBXbfk3sl9hJhmd5AUw== - es6-promise@^4.0.3: version "4.2.8" resolved "https://registry.yarnpkg.com/es6-promise/-/es6-promise-4.2.8.tgz#4eb21594c972bc40553d276e510539143db53e0a" @@ -6228,62 +2801,37 @@ es6-promisify@^5.0.0: dependencies: es6-promise "^4.0.3" -escalade@^3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" - integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== - -escalade@^3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.2.tgz#54076e9ab29ea5bf3d8f1ed62acffbb88272df27" - integrity sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA== - -escape-html@~1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" - integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= +escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== -escape-string-regexp@4.0.0, escape-string-regexp@^4.0.0: +escape-string-regexp@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== -escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" - integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ= - -eslint-config-prettier@^8.3.0: - version "8.3.0" - resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.3.0.tgz#f7471b20b6fe8a9a9254cc684454202886a2dd7a" - integrity sha512-BgZuLUSeKzvlL/VUjx/Yb787VQ26RU3gGjA3iiFvdsp/2bMfVIWUVP7tjxtjS0e+HP409cPlPvNkQloz8C91ew== - -eslint-config-react-app@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/eslint-config-react-app/-/eslint-config-react-app-7.0.1.tgz#73ba3929978001c5c86274c017ea57eb5fa644b4" - integrity sha512-K6rNzvkIeHaTd8m/QEh1Zko0KI7BACWkkneSs6s9cKZC/J27X3eZR6Upt1jkmZ/4FK+XUOPPxMEN7+lbUXfSlA== - dependencies: - "@babel/core" "^7.16.0" - "@babel/eslint-parser" "^7.16.3" - "@rushstack/eslint-patch" "^1.1.0" - "@typescript-eslint/eslint-plugin" "^5.5.0" - "@typescript-eslint/parser" "^5.5.0" - babel-preset-react-app "^10.0.1" - confusing-browser-globals "^1.0.11" - eslint-plugin-flowtype "^8.0.3" - eslint-plugin-import "^2.25.3" - eslint-plugin-jest "^25.3.0" - eslint-plugin-jsx-a11y "^6.5.1" - eslint-plugin-react "^7.27.1" - eslint-plugin-react-hooks "^4.3.0" - eslint-plugin-testing-library "^5.0.1" - -eslint-config-react@^1.1.7: - version "1.1.7" - resolved "https://registry.yarnpkg.com/eslint-config-react/-/eslint-config-react-1.1.7.tgz#a0918d0fc47d0e9bd161a47308021da85d2585b3" - integrity sha1-oJGND8R9DpvRYaRzCAIdqF0lhbM= +eslint-config-next@14.2.4: + version "14.2.4" + resolved "https://registry.yarnpkg.com/eslint-config-next/-/eslint-config-next-14.2.4.tgz#eb0bedfe4a894bc2aea918214bb5243ee4fa7d4b" + integrity sha512-Qr0wMgG9m6m4uYy2jrYJmyuNlYZzPRQq5Kvb9IDlYwn+7yq6W6sfMNFgb+9guM1KYwuIo6TIaiFhZJ6SnQ/Efw== + dependencies: + "@next/eslint-plugin-next" "14.2.4" + "@rushstack/eslint-patch" "^1.3.3" + "@typescript-eslint/parser" "^5.4.2 || ^6.0.0 || 7.0.0 - 7.2.0" + eslint-import-resolver-node "^0.3.6" + eslint-import-resolver-typescript "^3.5.2" + eslint-plugin-import "^2.28.1" + eslint-plugin-jsx-a11y "^6.7.1" + eslint-plugin-react "^7.33.2" + eslint-plugin-react-hooks "^4.5.0 || 5.0.0-canary-7118f5dd7-20230705" + +eslint-config-prettier@^9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz#31af3d94578645966c082fcb71a5846d3c94867f" + integrity sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw== -eslint-import-resolver-node@^0.3.9: +eslint-import-resolver-node@^0.3.6, eslint-import-resolver-node@^0.3.9: version "0.3.9" resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz#d4eaac52b8a2e7c3cd1903eb00f7e053356118ac" integrity sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g== @@ -6292,25 +2840,30 @@ eslint-import-resolver-node@^0.3.9: is-core-module "^2.13.0" resolve "^1.22.4" -eslint-module-utils@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz#e439fee65fc33f6bba630ff621efc38ec0375c49" - integrity sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw== +eslint-import-resolver-typescript@^3.5.2: + version "3.6.1" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-3.6.1.tgz#7b983680edd3f1c5bce1a5829ae0bc2d57fe9efa" + integrity sha512-xgdptdoi5W3niYeuQxKmzVDTATvLYqhpwmykwsh7f6HIOStGWEIL9iqZgQDF9u9OEzrRwR8no5q2VT+bjAujTg== dependencies: - debug "^3.2.7" + debug "^4.3.4" + enhanced-resolve "^5.12.0" + eslint-module-utils "^2.7.4" + fast-glob "^3.3.1" + get-tsconfig "^4.5.0" + is-core-module "^2.11.0" + is-glob "^4.0.3" -eslint-plugin-flowtype@^8.0.3: - version "8.0.3" - resolved "https://registry.yarnpkg.com/eslint-plugin-flowtype/-/eslint-plugin-flowtype-8.0.3.tgz#e1557e37118f24734aa3122e7536a038d34a4912" - integrity sha512-dX8l6qUL6O+fYPtpNRideCFSpmWOUVx5QcaGLVqe/vlDiBSe4vYljDWDETwnyFzpl7By/WVIu6rcrniCgH9BqQ== +eslint-module-utils@^2.7.4, eslint-module-utils@^2.8.0: + version "2.8.1" + resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.8.1.tgz#52f2404300c3bd33deece9d7372fb337cc1d7c34" + integrity sha512-rXDXR3h7cs7dy9RNpUlQf80nX31XWJEyGq1tRMo+6GsO5VmTe4UTwtmonAD4ZkAsrfMVDA2wlGJ3790Ys+D49Q== dependencies: - lodash "^4.17.21" - string-natural-compare "^3.0.1" + debug "^3.2.7" -eslint-plugin-import@^2.25.3: - version "2.29.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.29.0.tgz#8133232e4329ee344f2f612885ac3073b0b7e155" - integrity sha512-QPOO5NO6Odv5lpoTkddtutccQjysJuFxoPS7fAHO+9m9udNHvTCPSAMW9zGAYj8lAIdr40I8yPCdUYrncXtrwg== +eslint-plugin-import@^2.28.1: + version "2.29.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.29.1.tgz#d45b37b5ef5901d639c15270d74d46d161150643" + integrity sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw== dependencies: array-includes "^3.1.7" array.prototype.findlastindex "^1.2.3" @@ -6328,31 +2881,9 @@ eslint-plugin-import@^2.25.3: object.groupby "^1.0.1" object.values "^1.1.7" semver "^6.3.1" - tsconfig-paths "^3.14.2" - -eslint-plugin-jest@^25.3.0: - version "25.7.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-jest/-/eslint-plugin-jest-25.7.0.tgz#ff4ac97520b53a96187bad9c9814e7d00de09a6a" - integrity sha512-PWLUEXeeF7C9QGKqvdSbzLOiLTx+bno7/HC9eefePfEb257QFHg7ye3dh80AZVkaa/RQsBB1Q/ORQvg2X7F0NQ== - dependencies: - "@typescript-eslint/experimental-utils" "^5.0.0" - -eslint-plugin-jsdoc@^46.9.0: - version "46.9.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-46.9.0.tgz#9887569dbeef0a008a2770bfc5d0f7fc39f21f2b" - integrity sha512-UQuEtbqLNkPf5Nr/6PPRCtr9xypXY+g8y/Q7gPa0YK7eDhh0y2lWprXRnaYbW7ACgIUvpDKy9X2bZqxtGzBG9Q== - dependencies: - "@es-joy/jsdoccomment" "~0.41.0" - are-docs-informative "^0.0.2" - comment-parser "1.4.1" - debug "^4.3.4" - escape-string-regexp "^4.0.0" - esquery "^1.5.0" - is-builtin-module "^3.2.1" - semver "^7.5.4" - spdx-expression-parse "^3.0.1" + tsconfig-paths "^3.15.0" -eslint-plugin-jsx-a11y@^6.5.1: +eslint-plugin-jsx-a11y@^6.7.1: version "6.8.0" resolved "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.8.0.tgz#2fa9c701d44fcd722b7c771ec322432857fcbad2" integrity sha512-Hdh937BS3KdwwbBaKd5+PLCOmYY6U4f2h9Z2ktwtNKvIdIEu137rjYbcb9ApSbVJfWxANNuiKTD/9tOKjK9qOA== @@ -6374,154 +2905,102 @@ eslint-plugin-jsx-a11y@^6.5.1: object.entries "^1.1.7" object.fromentries "^2.0.7" -eslint-plugin-prefer-arrow@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/eslint-plugin-prefer-arrow/-/eslint-plugin-prefer-arrow-1.2.3.tgz#e7fbb3fa4cd84ff1015b9c51ad86550e55041041" - integrity sha512-J9I5PKCOJretVuiZRGvPQxCbllxGAV/viI20JO3LYblAodofBxyMnZAJ+WGeClHgANnSJberTNoFWWjrWKBuXQ== - -eslint-plugin-react-hooks@^4.3.0: - version "4.6.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz#4c3e697ad95b77e93f8646aaa1630c1ba607edd3" - integrity sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g== +"eslint-plugin-react-hooks@^4.5.0 || 5.0.0-canary-7118f5dd7-20230705", eslint-plugin-react-hooks@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.2.tgz#c829eb06c0e6f484b3fbb85a97e57784f328c596" + integrity sha512-QzliNJq4GinDBcD8gPB5v0wh6g8q3SUi6EFF0x8N/BL9PoVs0atuGc47ozMRyOWAKdwaZ5OnbOEa3WR+dSGKuQ== -eslint-plugin-react@^7.27.1: - version "7.33.2" - resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.33.2.tgz#69ee09443ffc583927eafe86ffebb470ee737608" - integrity sha512-73QQMKALArI8/7xGLNI/3LylrEYrlKZSb5C9+q3OtOewTnMQi5cT+aE9E41sLCmli3I9PGGmD1yiZydyo4FEPw== +eslint-plugin-react@^7.33.2: + version "7.34.2" + resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.34.2.tgz#2780a1a35a51aca379d86d29b9a72adc6bfe6b66" + integrity sha512-2HCmrU+/JNigDN6tg55cRDKCQWicYAPB38JGSFDQt95jDm8rrvSUo7YPkOIm5l6ts1j1zCvysNcasvfTMQzUOw== dependencies: - array-includes "^3.1.6" - array.prototype.flatmap "^1.3.1" - array.prototype.tosorted "^1.1.1" + array-includes "^3.1.8" + array.prototype.findlast "^1.2.5" + array.prototype.flatmap "^1.3.2" + array.prototype.toreversed "^1.1.2" + array.prototype.tosorted "^1.1.3" doctrine "^2.1.0" - es-iterator-helpers "^1.0.12" + es-iterator-helpers "^1.0.19" estraverse "^5.3.0" jsx-ast-utils "^2.4.1 || ^3.0.0" minimatch "^3.1.2" - object.entries "^1.1.6" - object.fromentries "^2.0.6" - object.hasown "^1.1.2" - object.values "^1.1.6" + object.entries "^1.1.8" + object.fromentries "^2.0.8" + object.hasown "^1.1.4" + object.values "^1.2.0" prop-types "^15.8.1" - resolve "^2.0.0-next.4" + resolve "^2.0.0-next.5" semver "^6.3.1" - string.prototype.matchall "^4.0.8" - -eslint-plugin-testing-library@^5.0.1: - version "5.11.1" - resolved "https://registry.yarnpkg.com/eslint-plugin-testing-library/-/eslint-plugin-testing-library-5.11.1.tgz#5b46cdae96d4a78918711c0b4792f90088e62d20" - integrity sha512-5eX9e1Kc2PqVRed3taaLnAAqPZGEX75C+M/rXzUAI3wIg/ZxzUm1OVAwfe/O+vE+6YXOLetSe9g5GKD2ecXipw== - dependencies: - "@typescript-eslint/utils" "^5.58.0" + string.prototype.matchall "^4.0.11" -eslint-scope@5.1.1, eslint-scope@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" - integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== +eslint-scope@^7.2.2: + version "7.2.2" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.2.2.tgz#deb4f92563390f32006894af62a22dba1c46423f" + integrity sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg== dependencies: esrecurse "^4.3.0" - estraverse "^4.1.1" - -eslint-utils@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-2.1.0.tgz#d2de5e03424e707dc10c74068ddedae708741b27" - integrity sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg== - dependencies: - eslint-visitor-keys "^1.1.0" - -eslint-visitor-keys@^1.1.0, eslint-visitor-keys@^1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz#30ebd1ef7c2fdff01c3a4f151044af25fab0523e" - integrity sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ== - -eslint-visitor-keys@^2.0.0, eslint-visitor-keys@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz#f65328259305927392c938ed44eb0a5c9b2bd303" - integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw== + estraverse "^5.2.0" -eslint-visitor-keys@^3.3.0: +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1, eslint-visitor-keys@^3.4.3: version "3.4.3" resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800" integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== -eslint-webpack-plugin@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/eslint-webpack-plugin/-/eslint-webpack-plugin-4.2.0.tgz#41f54b25379908eb9eca8645bc997c90cfdbd34e" - integrity sha512-rsfpFQ01AWQbqtjgPRr2usVRxhWDuG0YDYcG8DJOteD3EFnpeuYuOwk0PQiN7PRBTqS6ElNdtPZPggj8If9WnA== - dependencies: - "@types/eslint" "^8.56.10" - jest-worker "^29.7.0" - micromatch "^4.0.5" - normalize-path "^3.0.0" - schema-utils "^4.2.0" - -eslint@^7.31.0: - version "7.32.0" - resolved "https://registry.yarnpkg.com/eslint/-/eslint-7.32.0.tgz#c6d328a14be3fb08c8d1d21e12c02fdb7a2a812d" - integrity sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA== +eslint@^8.57.0: + version "8.57.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.57.0.tgz#c786a6fd0e0b68941aaf624596fb987089195668" + integrity sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ== dependencies: - "@babel/code-frame" "7.12.11" - "@eslint/eslintrc" "^0.4.3" - "@humanwhocodes/config-array" "^0.5.0" - ajv "^6.10.0" + "@eslint-community/eslint-utils" "^4.2.0" + "@eslint-community/regexpp" "^4.6.1" + "@eslint/eslintrc" "^2.1.4" + "@eslint/js" "8.57.0" + "@humanwhocodes/config-array" "^0.11.14" + "@humanwhocodes/module-importer" "^1.0.1" + "@nodelib/fs.walk" "^1.2.8" + "@ungap/structured-clone" "^1.2.0" + ajv "^6.12.4" chalk "^4.0.0" cross-spawn "^7.0.2" - debug "^4.0.1" + debug "^4.3.2" doctrine "^3.0.0" - enquirer "^2.3.5" escape-string-regexp "^4.0.0" - eslint-scope "^5.1.1" - eslint-utils "^2.1.0" - eslint-visitor-keys "^2.0.0" - espree "^7.3.1" - esquery "^1.4.0" + eslint-scope "^7.2.2" + eslint-visitor-keys "^3.4.3" + espree "^9.6.1" + esquery "^1.4.2" esutils "^2.0.2" fast-deep-equal "^3.1.3" file-entry-cache "^6.0.1" - functional-red-black-tree "^1.0.1" - glob-parent "^5.1.2" - globals "^13.6.0" - ignore "^4.0.6" - import-fresh "^3.0.0" + find-up "^5.0.0" + glob-parent "^6.0.2" + globals "^13.19.0" + graphemer "^1.4.0" + ignore "^5.2.0" imurmurhash "^0.1.4" is-glob "^4.0.0" - js-yaml "^3.13.1" + is-path-inside "^3.0.3" + js-yaml "^4.1.0" json-stable-stringify-without-jsonify "^1.0.1" levn "^0.4.1" lodash.merge "^4.6.2" - minimatch "^3.0.4" + minimatch "^3.1.2" natural-compare "^1.4.0" - optionator "^0.9.1" - progress "^2.0.0" - regexpp "^3.1.0" - semver "^7.2.1" - strip-ansi "^6.0.0" - strip-json-comments "^3.1.0" - table "^6.0.9" + optionator "^0.9.3" + strip-ansi "^6.0.1" text-table "^0.2.0" - v8-compile-cache "^2.0.3" - -espree@^7.3.0, espree@^7.3.1: - version "7.3.1" - resolved "https://registry.yarnpkg.com/espree/-/espree-7.3.1.tgz#f2df330b752c6f55019f8bd89b7660039c1bbbb6" - integrity sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g== - dependencies: - acorn "^7.4.0" - acorn-jsx "^5.3.1" - eslint-visitor-keys "^1.3.0" - -esprima@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" - integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== -esquery@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.4.0.tgz#2148ffc38b82e8c7057dfed48425b3e61f0f24a5" - integrity sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w== +espree@^9.6.0, espree@^9.6.1: + version "9.6.1" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.6.1.tgz#a2a17b8e434690a5432f2f8018ce71d331a48c6f" + integrity sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ== dependencies: - estraverse "^5.1.0" + acorn "^8.9.0" + acorn-jsx "^5.3.2" + eslint-visitor-keys "^3.4.1" -esquery@^1.5.0: +esquery@^1.4.2: version "1.5.0" resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== @@ -6535,17 +3014,7 @@ esrecurse@^4.3.0: dependencies: estraverse "^5.2.0" -estraverse@^4.1.1: - version "4.3.0" - resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" - integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== - -estraverse@^5.1.0, estraverse@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.2.0.tgz#307df42547e6cc7324d3cf03c155d5cdb8c53880" - integrity sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ== - -estraverse@^5.3.0: +estraverse@^5.1.0, estraverse@^5.2.0, estraverse@^5.3.0: version "5.3.0" resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== @@ -6555,22 +3024,17 @@ esutils@^2.0.2: resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== -etag@1.8.1, etag@^1.8.1, etag@~1.8.1: - version "1.8.1" - resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" - integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= - ethereum-cryptography@^2.1.3: - version "2.1.3" - resolved "https://registry.yarnpkg.com/ethereum-cryptography/-/ethereum-cryptography-2.1.3.tgz#1352270ed3b339fe25af5ceeadcf1b9c8e30768a" - integrity sha512-BlwbIL7/P45W8FGW2r7LGuvoEZ+7PWsniMvQ4p5s2xCyw9tmaDlpfsN9HjAucbF+t/qpVHwZUisgfK24TCW8aA== + version "2.2.0" + resolved "https://registry.yarnpkg.com/ethereum-cryptography/-/ethereum-cryptography-2.2.0.tgz#06e2d9c0d89f98ffc6a83818f55bf85afecd50dc" + integrity sha512-hsm9JhfytIf8QME/3B7j4bc8V+VdTU+Vas1aJlvIS96ffoNAosudXvGoEvWmc7QZYdkC8mrMJz9r0fcbw7GyCA== dependencies: - "@noble/curves" "1.3.0" - "@noble/hashes" "1.3.3" - "@scure/bip32" "1.3.3" - "@scure/bip39" "1.2.2" + "@noble/curves" "1.4.0" + "@noble/hashes" "1.4.0" + "@scure/bip32" "1.4.0" + "@scure/bip39" "1.3.0" -eventemitter3@^4.0.0: +eventemitter3@^4.0.7: version "4.0.7" resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-4.0.7.tgz#2de9b68f6528d5644ef5c59526a1b4a07306169f" integrity sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw== @@ -6580,7 +3044,7 @@ eventemitter3@^5.0.1: resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-5.0.1.tgz#53f5ffd0a492ac800721bb42c66b841de96423c4" integrity sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA== -events@^3.2.0, events@^3.3.0: +events@^3.3.0: version "3.3.0" resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== @@ -6590,65 +3054,20 @@ eventsource@^2.0.2: resolved "https://registry.yarnpkg.com/eventsource/-/eventsource-2.0.2.tgz#76dfcc02930fb2ff339520b6d290da573a9e8508" integrity sha512-IzUmBGPR3+oUG9dUeXynyNmf91/3zUSJg1lCktzKw47OXuhco54U3r9B7O4XX+Rb1Itm9OZ2b0RkTs10bICOxA== -evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" - integrity sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA== - dependencies: - md5.js "^1.3.4" - safe-buffer "^5.1.1" - -execa@^5.0.0: - version "5.1.1" - resolved "https://registry.yarnpkg.com/execa/-/execa-5.1.1.tgz#f80ad9cbf4298f7bd1d4c9555c21e93741c411dd" - integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== +execa@^8.0.1, execa@~8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/execa/-/execa-8.0.1.tgz#51f6a5943b580f963c3ca9c6321796db8cc39b8c" + integrity sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg== dependencies: cross-spawn "^7.0.3" - get-stream "^6.0.0" - human-signals "^2.1.0" - is-stream "^2.0.0" + get-stream "^8.0.1" + human-signals "^5.0.0" + is-stream "^3.0.0" merge-stream "^2.0.0" - npm-run-path "^4.0.1" - onetime "^5.1.2" - signal-exit "^3.0.3" - strip-final-newline "^2.0.0" - -express@^4.17.3: - version "4.18.2" - resolved "https://registry.yarnpkg.com/express/-/express-4.18.2.tgz#3fabe08296e930c796c19e3c516979386ba9fd59" - integrity sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ== - dependencies: - accepts "~1.3.8" - array-flatten "1.1.1" - body-parser "1.20.1" - content-disposition "0.5.4" - content-type "~1.0.4" - cookie "0.5.0" - cookie-signature "1.0.6" - debug "2.6.9" - depd "2.0.0" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - finalhandler "1.2.0" - fresh "0.5.2" - http-errors "2.0.0" - merge-descriptors "1.0.1" - methods "~1.1.2" - on-finished "2.4.1" - parseurl "~1.3.3" - path-to-regexp "0.1.7" - proxy-addr "~2.0.7" - qs "6.11.0" - range-parser "~1.2.1" - safe-buffer "5.2.1" - send "0.18.0" - serve-static "1.15.0" - setprototypeof "1.2.0" - statuses "2.0.1" - type-is "~1.6.18" - utils-merge "1.0.1" - vary "~1.1.2" + npm-run-path "^5.1.0" + onetime "^6.0.0" + signal-exit "^4.1.0" + strip-final-newline "^3.0.0" eyes@^0.1.8: version "0.1.8" @@ -6660,7 +3079,7 @@ fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-glob@^3.2.11, fast-glob@^3.2.9, fast-glob@^3.3.0: +fast-glob@^3.2.9, fast-glob@^3.3.1: version "3.3.2" resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.2.tgz#a904501e57cfdd2ffcded45e99a54fef55e46129" integrity sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow== @@ -6679,32 +3098,25 @@ fast-json-stable-stringify@^2.0.0: fast-levenshtein@^2.0.6: version "2.0.6" resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" - integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + +fast-redact@^3.0.0: + version "3.5.0" + resolved "https://registry.yarnpkg.com/fast-redact/-/fast-redact-3.5.0.tgz#e9ea02f7e57d0cd8438180083e93077e496285e4" + integrity sha512-dwsoQlS7h9hMeYUq1W++23NDcBLV4KqONnITDV9DjfS3q1SgDGVrBdvvTLUotWtPSD7asWDV9/CmsZPy8Hf70A== fast-stable-stringify@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fast-stable-stringify/-/fast-stable-stringify-1.0.0.tgz#5c5543462b22aeeefd36d05b34e51c78cb86d313" integrity sha512-wpYMUmFu5f00Sm0cj2pfivpmawLZ0NKdviQ4w9zJeR8JVtOpOxHmLaJuj0vxvGqMJQWyP/COUkF75/57OKyRag== -fastest-levenshtein@^1.0.12: - version "1.0.16" - resolved "https://registry.yarnpkg.com/fastest-levenshtein/-/fastest-levenshtein-1.0.16.tgz#210e61b6ff181de91ea9b3d1b84fdedd47e034e5" - integrity sha512-eRnCtTTtGZFpQCwhJiUOuxPQWRXVKYDn0b2PeHfXL6/Zi53SLAzAHfVhVWK2AryC/WH05kGfxhFIPvTF0SXQzg== - fastq@^1.6.0: - version "1.11.1" - resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.11.1.tgz#5d8175aae17db61947f8b162cfc7f63264d22807" - integrity sha512-HOnr8Mc60eNYl1gzwp6r5RoUyAn5/glBolUzP/Ez6IFVPMPirxn/9phgL6zhOtaTy7ISwPvQ+wT+hfcRZh/bzw== + version "1.17.1" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.17.1.tgz#2a523f07a4e7b1e81a42b91b8bf2254107753b47" + integrity sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w== dependencies: reusify "^1.0.4" -faye-websocket@^0.11.3: - version "0.11.4" - resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.4.tgz#7f0d9275cfdd86a1c963dc8b65fcc451edcbb1da" - integrity sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g== - dependencies: - websocket-driver ">=0.5.1" - file-entry-cache@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" @@ -6717,72 +3129,19 @@ file-uri-to-path@1.0.0: resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" integrity sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw== -fill-range@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" - integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== +fill-range@^7.1.1: + version "7.1.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.1.1.tgz#44265d3cac07e3ea7dc247516380643754a05292" + integrity sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg== dependencies: to-regex-range "^5.0.1" -finalhandler@1.1.0: +filter-obj@^1.1.0: version "1.1.0" - resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.0.tgz#ce0b6855b45853e791b2fcc680046d88253dd7f5" - integrity sha1-zgtoVbRYU+eRsvzGgARtiCU91/U= - dependencies: - debug "2.6.9" - encodeurl "~1.0.1" - escape-html "~1.0.3" - on-finished "~2.3.0" - parseurl "~1.3.2" - statuses "~1.3.1" - unpipe "~1.0.0" - -finalhandler@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.2.0.tgz#7d23fe5731b207b4640e4fcd00aec1f9207a7b32" - integrity sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg== - dependencies: - debug "2.6.9" - encodeurl "~1.0.2" - escape-html "~1.0.3" - on-finished "2.4.1" - parseurl "~1.3.3" - statuses "2.0.1" - unpipe "~1.0.0" - -find-cache-dir@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-2.1.0.tgz#8d0f94cd13fe43c6c7c261a0d86115ca918c05f7" - integrity sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ== - dependencies: - commondir "^1.0.1" - make-dir "^2.0.0" - pkg-dir "^3.0.0" - -find-cache-dir@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-4.0.0.tgz#a30ee0448f81a3990708f6453633c733e2f6eec2" - integrity sha512-9ZonPT4ZAK4a+1pUPVPZJapbi7O5qbbJPdYw/NOQWZZbVLdDTYM3A4R9z/DpAM08IDaFGsvPgiGZ82WEwUDWjg== - dependencies: - common-path-prefix "^3.0.0" - pkg-dir "^7.0.0" - -find-up@5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" - integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== - dependencies: - locate-path "^6.0.0" - path-exists "^4.0.0" - -find-up@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" - integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== - dependencies: - locate-path "^3.0.0" + resolved "https://registry.yarnpkg.com/filter-obj/-/filter-obj-1.1.0.tgz#9b311112bc6c6127a16e016c6c5d7f19e0805c5b" + integrity sha512-8rXg1ZnX7xzy2NGDVkBVaAy+lSlPNwad13BtgSlLuxfIslyt5Vg64U7tFcCt4WS1R0hvtnQybT/IyCkGZ3DpXQ== -find-up@^4.0.0, find-up@^4.1.0: +find-up@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== @@ -6790,36 +3149,27 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" -find-up@^6.3.0: - version "6.3.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-6.3.0.tgz#2abab3d3280b2dc7ac10199ef324c4e002c8c790" - integrity sha512-v2ZsoEuVHYy8ZIlYqwPe/39Cy+cFDzp4dXPaxNvkEuouymu+2Jbz0PxpKarJHYJTmv2HWT3O382qY8l4jMWthw== +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== dependencies: - locate-path "^7.1.0" - path-exists "^5.0.0" + locate-path "^6.0.0" + path-exists "^4.0.0" flat-cache@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" - integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + version "3.2.0" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.2.0.tgz#2c0c2d5040c99b1632771a9d105725c0115363ee" + integrity sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw== dependencies: - flatted "^3.1.0" + flatted "^3.2.9" + keyv "^4.5.3" rimraf "^3.0.2" -flat@^5.0.2: - version "5.0.2" - resolved "https://registry.yarnpkg.com/flat/-/flat-5.0.2.tgz#8ca6fe332069ffa9d324c327198c598259ceb241" - integrity sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ== - -flatted@^3.1.0: - version "3.2.2" - resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.2.tgz#64bfed5cb68fe3ca78b3eb214ad97b63bedce561" - integrity sha512-JaTY/wtrcSyvXJl4IMFHPKyFur1sE9AUqc0QnhOaJ0CxHtAoIV8pYDzeEfAaNEtGkOfq4gr3LBFmdXW5mOQFnA== - -follow-redirects@^1.0.0: - version "1.14.2" - resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.2.tgz#cecb825047c00f5e66b142f90fed4f515dec789b" - integrity sha512-yLR6WaE2lbF0x4K2qE2p9PEXKLDjUjnR/xmjS3wHAYxtlsI9MLLBJUZirAHKzUZDGLxje7w/cXR49WOUo4rbsA== +flatted@^3.2.9: + version "3.3.1" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.3.1.tgz#21db470729a6734d4997002f439cb308987f567a" + integrity sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw== follow-redirects@^1.15.6: version "1.15.6" @@ -6828,28 +3178,18 @@ follow-redirects@^1.15.6: for-each@^0.3.3: version "0.3.3" - resolved "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" + resolved "https://registry.yarnpkg.com/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" integrity sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw== dependencies: is-callable "^1.1.3" -fork-ts-checker-webpack-plugin@^8.0.0: - version "8.0.0" - resolved "https://registry.yarnpkg.com/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-8.0.0.tgz#dae45dfe7298aa5d553e2580096ced79b6179504" - integrity sha512-mX3qW3idpueT2klaQXBzrIM/pHw+T0B/V9KHEvNrqijTq9NFnMZU6oreVxDYcf33P8a5cW+67PjodNHthGnNVg== - dependencies: - "@babel/code-frame" "^7.16.7" - chalk "^4.1.2" - chokidar "^3.5.3" - cosmiconfig "^7.0.1" - deepmerge "^4.2.2" - fs-extra "^10.0.0" - memfs "^3.4.1" - minimatch "^3.0.4" - node-abort-controller "^3.0.1" - schema-utils "^3.1.1" - semver "^7.3.5" - tapable "^2.2.1" +foreground-child@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/foreground-child/-/foreground-child-3.1.1.tgz#1d173e776d75d2772fed08efe4a0de1ea1b12d0d" + integrity sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg== + dependencies: + cross-spawn "^7.0.0" + signal-exit "^4.0.1" form-data@^4.0.0: version "4.0.0" @@ -6860,77 +3200,27 @@ form-data@^4.0.0: combined-stream "^1.0.8" mime-types "^2.1.12" -forwarded@0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" - integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== - -fresh@0.5.2, fresh@^0.5.2: - version "0.5.2" - resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" - integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= - -fs-extra@3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-3.0.1.tgz#3794f378c58b342ea7dbbb23095109c4b3b62291" - integrity sha1-N5TzeMWLNC6n27sjCVEJxLO2IpE= - dependencies: - graceful-fs "^4.1.2" - jsonfile "^3.0.0" - universalify "^0.1.0" - -fs-extra@^10.0.0: - version "10.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-10.1.0.tgz#02873cfbc4084dde127eaa5f9905eef2325d1abf" - integrity sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ== - dependencies: - graceful-fs "^4.2.0" - jsonfile "^6.0.1" - universalify "^2.0.0" - -fs-minipass@^2.0.0, fs-minipass@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" - integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== - dependencies: - minipass "^3.0.0" - -fs-monkey@^1.0.4: - version "1.0.5" - resolved "https://registry.yarnpkg.com/fs-monkey/-/fs-monkey-1.0.5.tgz#fe450175f0db0d7ea758102e1d84096acb925788" - integrity sha512-8uMbBjrhzW76TYgEV27Y5E//W2f/lTFmx78P2w19FZSxarhI/798APGQyuGCwmkNxgwGRhrLfvWyLBvNtuOmew== - fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" - integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== -fsevents@~2.3.2: +fsevents@2.3.2: version "2.3.2" resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== -function-bind@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" - integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== +fsevents@~2.3.2: + version "2.3.3" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6" + integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== function-bind@^1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== -function.prototype.name@^1.1.5: - version "1.1.5" - resolved "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz#cce0505fe1ffb80503e6f9e46cc64e46a12a9621" - integrity sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.3" - es-abstract "^1.19.0" - functions-have-names "^1.2.2" - -function.prototype.name@^1.1.6: +function.prototype.name@^1.1.5, function.prototype.name@^1.1.6: version "1.1.6" resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.6.tgz#cdf315b7d90ee77a4c6ee216c3c3362da07533fd" integrity sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg== @@ -6940,72 +3230,22 @@ function.prototype.name@^1.1.6: es-abstract "^1.22.1" functions-have-names "^1.2.3" -functional-red-black-tree@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" - integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= - -functions-have-names@^1.2.2, functions-have-names@^1.2.3: +functions-have-names@^1.2.3: version "1.2.3" - resolved "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" + resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== -gauge@^4.0.3: - version "4.0.4" - resolved "https://registry.yarnpkg.com/gauge/-/gauge-4.0.4.tgz#52ff0652f2bbf607a989793d53b751bef2328dce" - integrity sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg== - dependencies: - aproba "^1.0.3 || ^2.0.0" - color-support "^1.1.3" - console-control-strings "^1.1.0" - has-unicode "^2.0.1" - signal-exit "^3.0.7" - string-width "^4.2.3" - strip-ansi "^6.0.1" - wide-align "^1.1.5" - -gaze@^1.0.0: - version "1.1.3" - resolved "https://registry.yarnpkg.com/gaze/-/gaze-1.1.3.tgz#c441733e13b927ac8c0ff0b4c3b033f28812924a" - integrity sha512-BRdNm8hbWzFzWHERTrejLqwHDfS4GibPoq5wjTPIoJHoBtKGPg3xAFfxmM+9ztbXelxcf2hwQcaz1PtmFeue8g== - dependencies: - globule "^1.0.0" - -gensync@^1.0.0-beta.2: - version "1.0.0-beta.2" - resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" - integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== - -get-caller-file@^2.0.5: +get-caller-file@^2.0.1: version "2.0.5" resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== -get-func-name@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.0.tgz#ead774abee72e20409433a066366023dd6887a41" - integrity sha1-6td0q+5y4gQJQzoGY2YCPdaIekE= - -get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.1.tgz#15f59f376f855c446963948f0d24cd3637b4abc6" - integrity sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q== - dependencies: - function-bind "^1.1.1" - has "^1.0.3" - has-symbols "^1.0.1" - -get-intrinsic@^1.1.3, get-intrinsic@^1.2.0, get-intrinsic@^1.2.1, get-intrinsic@^1.2.2: - version "1.2.2" - resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.2.tgz#281b7622971123e1ef4b3c90fd7539306da93f3b" - integrity sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA== - dependencies: - function-bind "^1.1.2" - has-proto "^1.0.1" - has-symbols "^1.0.3" - hasown "^2.0.0" +get-east-asian-width@^1.0.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/get-east-asian-width/-/get-east-asian-width-1.2.0.tgz#5e6ebd9baee6fb8b7b6bd505221065f0cd91f64e" + integrity sha512-2nk+7SIVb14QrgXFHcm84tD4bKQz0RxPuMT8Ag5KPOq7J5fEmAg0UbXdTOSHqNuHSU28k55qnceesxXRZGzKWA== -get-intrinsic@^1.2.4: +get-intrinsic@^1.1.3, get-intrinsic@^1.2.1, get-intrinsic@^1.2.3, get-intrinsic@^1.2.4: version "1.2.4" resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.4.tgz#e385f5a4b5227d449c3eabbad05494ef0abbeadd" integrity sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ== @@ -7016,23 +3256,31 @@ get-intrinsic@^1.2.4: has-symbols "^1.0.3" hasown "^2.0.0" -get-stdin@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/get-stdin/-/get-stdin-4.0.1.tgz#b968c6b0a04384324902e8bf1a5df32579a450fe" - integrity sha512-F5aQMywwJ2n85s4hJPTT9RPxGmubonuB10MNYo17/xph174n2MIR33HRguhzVag10O/npM7SPk73LMZNP+FaWw== +get-port-please@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/get-port-please/-/get-port-please-3.1.2.tgz#502795e56217128e4183025c89a48c71652f4e49" + integrity sha512-Gxc29eLs1fbn6LQ4jSU4vXjlwyZhF5HsGuMAa7gqBP4Rw4yxxltyDUuF5MBclFzDTXO+ACchGQoeela4DSfzdQ== + +get-stream@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-8.0.1.tgz#def9dfd71742cd7754a7761ed43749a27d02eca2" + integrity sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA== -get-stream@^6.0.0: - version "6.0.1" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" - integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== +get-symbol-description@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.2.tgz#533744d5aa20aca4e079c8e5daf7fd44202821f5" + integrity sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg== + dependencies: + call-bind "^1.0.5" + es-errors "^1.3.0" + get-intrinsic "^1.2.4" -get-symbol-description@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" - integrity sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw== +get-tsconfig@^4.5.0: + version "4.7.5" + resolved "https://registry.yarnpkg.com/get-tsconfig/-/get-tsconfig-4.7.5.tgz#5e012498579e9a6947511ed0cd403272c7acbbaf" + integrity sha512-ZCuZCnlqNzjb4QprAzXKdpp/gh6KTxSJuw3IBsPnV/7fV4NxC9ckB+vPTt8w7fJA0TaSD7c55BR47JD6MEDyDw== dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.1.1" + resolve-pkg-maps "^1.0.0" glob-parent@^5.1.2, glob-parent@~5.1.2: version "5.1.2" @@ -7041,31 +3289,25 @@ glob-parent@^5.1.2, glob-parent@~5.1.2: dependencies: is-glob "^4.0.1" -glob-parent@^6.0.1: +glob-parent@^6.0.2: version "6.0.2" resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== dependencies: is-glob "^4.0.3" -glob-to-regexp@^0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz#c75297087c851b9a578bd217dd59a92f59fe546e" - integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw== - -glob@7.2.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023" - integrity sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q== +glob@10.3.10: + version "10.3.10" + resolved "https://registry.yarnpkg.com/glob/-/glob-10.3.10.tgz#0351ebb809fd187fe421ab96af83d3a70715df4b" + integrity sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g== dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^3.0.4" - once "^1.3.0" - path-is-absolute "^1.0.0" + foreground-child "^3.1.0" + jackspeak "^2.3.5" + minimatch "^9.0.1" + minipass "^5.0.0 || ^6.0.2 || ^7.0.0" + path-scurry "^1.10.1" -glob@^7.0.0: +glob@^7.1.3: version "7.2.3" resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== @@ -7077,60 +3319,25 @@ glob@^7.0.0: once "^1.3.0" path-is-absolute "^1.0.0" -glob@^7.0.3, glob@^7.1.3, glob@^7.1.4, glob@~7.1.1: - version "7.1.7" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90" - integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^3.0.4" - once "^1.3.0" - path-is-absolute "^1.0.0" - -glob@^8.0.1: - version "8.1.0" - resolved "https://registry.yarnpkg.com/glob/-/glob-8.1.0.tgz#d388f656593ef708ee3e34640fdfb99a9fd1c33e" - integrity sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^5.0.1" - once "^1.3.0" - -global@^4.3.0: - version "4.4.0" - resolved "https://registry.yarnpkg.com/global/-/global-4.4.0.tgz#3e7b105179006a323ed71aafca3e9c57a5cc6406" - integrity sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w== - dependencies: - min-document "^2.19.0" - process "^0.11.10" - globals@^11.1.0: version "11.12.0" resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== -globals@^13.6.0, globals@^13.9.0: - version "13.11.0" - resolved "https://registry.yarnpkg.com/globals/-/globals-13.11.0.tgz#40ef678da117fe7bd2e28f1fab24951bd0255be7" - integrity sha512-08/xrJ7wQjK9kkkRoI3OFUBbLx4f+6x3SGwcPvQ0QH6goFDrOU2oyAWrmh3dJezu65buo+HBMzAMQy6rovVC3g== +globals@^13.19.0: + version "13.24.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.24.0.tgz#8432a19d78ce0c1e833949c36adb345400bb1171" + integrity sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ== dependencies: type-fest "^0.20.2" -globals@^9.18.0: - version "9.18.0" - resolved "https://registry.yarnpkg.com/globals/-/globals-9.18.0.tgz#aa3896b3e69b487f17e31ed2143d69a8e30c2d8a" - integrity sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ== - globalthis@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/globalthis/-/globalthis-1.0.3.tgz#5852882a52b80dc301b0660273e1ed082f0b6ccf" - integrity sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA== + version "1.0.4" + resolved "https://registry.yarnpkg.com/globalthis/-/globalthis-1.0.4.tgz#7430ed3a975d97bfb59bcce41f5cabbafa651236" + integrity sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ== dependencies: - define-properties "^1.1.3" + define-properties "^1.2.1" + gopd "^1.0.1" globby@^11.1.0: version "11.1.0" @@ -7144,37 +3351,6 @@ globby@^11.1.0: merge2 "^1.4.1" slash "^3.0.0" -globby@^13.1.1: - version "13.2.2" - resolved "https://registry.yarnpkg.com/globby/-/globby-13.2.2.tgz#63b90b1bf68619c2135475cbd4e71e66aa090592" - integrity sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w== - dependencies: - dir-glob "^3.0.1" - fast-glob "^3.3.0" - ignore "^5.2.4" - merge2 "^1.4.1" - slash "^4.0.0" - -globby@^6.1.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/globby/-/globby-6.1.0.tgz#f5a6d70e8395e21c858fb0489d64df02424d506c" - integrity sha1-9abXDoOV4hyFj7BInWTfAkJNUGw= - dependencies: - array-union "^1.0.1" - glob "^7.0.3" - object-assign "^4.0.1" - pify "^2.0.0" - pinkie-promise "^2.0.0" - -globule@^1.0.0: - version "1.3.4" - resolved "https://registry.yarnpkg.com/globule/-/globule-1.3.4.tgz#7c11c43056055a75a6e68294453c17f2796170fb" - integrity sha512-OPTIfhMBh7JbBYDpa5b+Q5ptmMWKwcNcFSR/0c6t8V4f3ZAVBEsKNY37QdVqmLRYSMhOUGYrY0QhSoEpzGr/Eg== - dependencies: - glob "~7.1.1" - lodash "^4.17.21" - minimatch "~3.0.2" - gopd@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" @@ -7182,12 +3358,7 @@ gopd@^1.0.1: dependencies: get-intrinsic "^1.1.3" -graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4: - version "4.2.8" - resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.8.tgz#e412b8d33f5e006593cbd3cee6df9f2cebbe802a" - integrity sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg== - -graceful-fs@^4.2.11, graceful-fs@^4.2.6, graceful-fs@^4.2.9: +graceful-fs@^4.2.11, graceful-fs@^4.2.4: version "4.2.11" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== @@ -7197,100 +3368,60 @@ graphemer@^1.4.0: resolved "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6" integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== -graphql@^16.8.1: - version "16.8.2" - resolved "https://registry.yarnpkg.com/graphql/-/graphql-16.8.2.tgz#54771c7ff195da913f5e70af8044a026d32eca2a" - integrity sha512-cvVIBILwuoSyD54U4cF/UXDh5yAobhNV/tPygI4lZhgOIJQE/WLWC4waBRb4I6bDVYb3OVx3lfHbaQOEoUD5sg== - -growl@1.10.5: - version "1.10.5" - resolved "https://registry.yarnpkg.com/growl/-/growl-1.10.5.tgz#f2735dc2283674fa67478b10181059355c369e5e" - integrity sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA== - -handle-thing@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/handle-thing/-/handle-thing-2.0.1.tgz#857f79ce359580c340d43081cc648970d0bb234e" - integrity sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg== - -hard-rejection@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/hard-rejection/-/hard-rejection-2.1.0.tgz#1c6eda5c1685c63942766d79bb40ae773cecd883" - integrity sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA== - -has-ansi@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz#34f5049ce1ecdf2b0649af3ef24e45ed35416d91" - integrity sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE= - dependencies: - ansi-regex "^2.0.0" - -has-bigints@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.1.tgz#64fe6acb020673e3b78db035a5af69aa9d07b113" - integrity sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA== - -has-bigints@^1.0.2: +h3@^1.10.2, h3@^1.11.1: + version "1.11.1" + resolved "https://registry.yarnpkg.com/h3/-/h3-1.11.1.tgz#e9414ae6f2a076a345ea07256b320edb29bab9f7" + integrity sha512-AbaH6IDnZN6nmbnJOH72y3c5Wwh9P97soSVdGSBbcDACRdkC0FEWf25pzx4f/NuOCK6quHmW18yF2Wx+G4Zi1A== + dependencies: + cookie-es "^1.0.0" + crossws "^0.2.2" + defu "^6.1.4" + destr "^2.0.3" + iron-webcrypto "^1.0.0" + ohash "^1.1.3" + radix3 "^1.1.0" + ufo "^1.4.0" + uncrypto "^0.1.3" + unenv "^1.9.0" + +has-bigints@^1.0.1, has-bigints@^1.0.2: version "1.0.2" - resolved "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz#0871bd3e3d51626f6ca0966668ba35d5602d6eaa" + resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.2.tgz#0871bd3e3d51626f6ca0966668ba35d5602d6eaa" integrity sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ== has-flag@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" - integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= + integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== has-flag@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== -has-property-descriptors@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" - integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== - dependencies: - get-intrinsic "^1.1.1" - -has-property-descriptors@^1.0.2: +has-property-descriptors@^1.0.0, has-property-descriptors@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz#963ed7d071dc7bf5f084c5bfbe0d1b6222586854" integrity sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg== dependencies: es-define-property "^1.0.0" -has-proto@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.1.tgz#1885c1305538958aff469fef37937c22795408e0" - integrity sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg== - -has-symbols@^1.0.1, has-symbols@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" - integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== +has-proto@^1.0.1, has-proto@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.3.tgz#b31ddfe9b0e6e9914536a6ab286426d0214f77fd" + integrity sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q== -has-symbols@^1.0.3: +has-symbols@^1.0.2, has-symbols@^1.0.3: version "1.0.3" - resolved "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== -has-tostringtag@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz#7e133818a7d394734f941e73c3d3f9291e658b25" - integrity sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ== - dependencies: - has-symbols "^1.0.2" - -has-unicode@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" - integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ== - -has@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" - integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== +has-tostringtag@^1.0.0, has-tostringtag@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.2.tgz#2cdc42d40bef2e5b4eeab7c01a73c54ce7ab5abc" + integrity sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw== dependencies: - function-bind "^1.1.1" + has-symbols "^1.0.3" hash-base@^3.0.0: version "3.1.0" @@ -7309,230 +3440,72 @@ hash.js@^1.0.0, hash.js@^1.0.3: inherits "^2.0.3" minimalistic-assert "^1.0.1" -hasown@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.0.tgz#f4c513d454a57b7c7e1650778de226b11700546c" - integrity sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA== +hasown@^2.0.0, hasown@^2.0.1, hasown@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.2.tgz#003eaf91be7adc372e84ec59dc37252cedb80003" + integrity sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ== dependencies: function-bind "^1.1.2" -he@1.2.0, he@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" - integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== - -headers-polyfill@^4.0.2: - version "4.0.3" - resolved "https://registry.yarnpkg.com/headers-polyfill/-/headers-polyfill-4.0.3.tgz#922a0155de30ecc1f785bcf04be77844ca95ad07" - integrity sha512-IScLbePpkvO846sIwOtOTDjutRMWdXdJmXdMvk6gCBHxFO8d+QKOQedyZSxFTTFYRSmlgSTDtXqqq4pcenBXLQ== +hey-listen@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/hey-listen/-/hey-listen-1.0.8.tgz#8e59561ff724908de1aa924ed6ecc84a56a9aa68" + integrity sha512-COpmrF2NOg4TBWUJ5UVyaCU2A88wEMkUPK4hNqyCkqHbxT92BbvfjoSozkAIIm6XhicGlJHhFdullInrdhwU8Q== hmac-drbg@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" - integrity sha1-0nRXAQJabHdabFRXk+1QL8DGSaE= + integrity sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg== dependencies: hash.js "^1.0.3" minimalistic-assert "^1.0.0" minimalistic-crypto-utils "^1.0.1" -hoist-non-react-statics@^3.3.0, hoist-non-react-statics@^3.3.2: - version "3.3.2" - resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" - integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== - dependencies: - react-is "^16.7.0" - -hosted-git-info@^2.1.4: - version "2.8.9" - resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz#dffc0bf9a21c02209090f2aa69429e1414daf3f9" - integrity sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw== - -hosted-git-info@^4.0.1: - version "4.1.0" - resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-4.1.0.tgz#827b82867e9ff1c8d0c4d9d53880397d2c86d224" - integrity sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA== - dependencies: - lru-cache "^6.0.0" - -hpack.js@^2.1.6: - version "2.1.6" - resolved "https://registry.yarnpkg.com/hpack.js/-/hpack.js-2.1.6.tgz#87774c0949e513f42e84575b3c45681fade2a0b2" - integrity sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI= - dependencies: - inherits "^2.0.1" - obuf "^1.0.0" - readable-stream "^2.0.1" - wbuf "^1.1.0" - -html-dom-parser@1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/html-dom-parser/-/html-dom-parser-1.1.0.tgz#daf0ff559bb0c4ffe7543d507baeaf1e2ca14e2c" - integrity sha512-x3MOz8S8BkihGgggtp2N0U+JAWlD9iGERbjuBJH+gIGF9B1kGQh5x489IQ0YPqi8HyMIWCRLdJY1q3IaQlqG/Q== - dependencies: - domhandler "4.3.0" - htmlparser2 "7.2.0" - -html-entities@^2.3.2: - version "2.4.0" - resolved "https://registry.yarnpkg.com/html-entities/-/html-entities-2.4.0.tgz#edd0cee70402584c8c76cc2c0556db09d1f45061" - integrity sha512-igBTJcNNNhvZFRtm8uA6xMY6xYleeDwn3PeBCkDz7tHttv4F2hsDI2aPgNERWzvRcNYHNT3ymRaQzllmXj4YsQ== - -html-minifier-terser@^6.0.2: - version "6.1.0" - resolved "https://registry.yarnpkg.com/html-minifier-terser/-/html-minifier-terser-6.1.0.tgz#bfc818934cc07918f6b3669f5774ecdfd48f32ab" - integrity sha512-YXxSlJBZTP7RS3tWnQw74ooKa6L9b9i9QYXY21eUEvhZ3u9XLfv6OnFsQq6RxkhHygsaUMvYsZRV5rU/OVNZxw== - dependencies: - camel-case "^4.1.2" - clean-css "^5.2.2" - commander "^8.3.0" - he "^1.2.0" - param-case "^3.0.4" - relateurl "^0.2.7" - terser "^5.10.0" - -html-react-parser@^1.4.8: - version "1.4.8" - resolved "https://registry.yarnpkg.com/html-react-parser/-/html-react-parser-1.4.8.tgz#27bc0f9dc294c875daeca8a21a48d5b845a1364e" - integrity sha512-5XsBdFVhJLxdtRp7tWwZ6DwqOt6fJ+2lJc0lctwjX1yaxWNB41S5uzqii7vJcSCaabM+CK28U75e5f4wIMqdSg== - dependencies: - domhandler "4.3.0" - html-dom-parser "1.1.0" - react-property "2.0.0" - style-to-js "1.1.0" - -html-webpack-plugin@^5.6.0: - version "5.6.0" - resolved "https://registry.yarnpkg.com/html-webpack-plugin/-/html-webpack-plugin-5.6.0.tgz#50a8fa6709245608cb00e811eacecb8e0d7b7ea0" - integrity sha512-iwaY4wzbe48AfKLZ/Cc8k0L+FKG6oSNRaZ8x5A/T/IVDGyXcbHncM9TdDa93wn0FsSm82FhTKW7f3vS61thXAw== - dependencies: - "@types/html-minifier-terser" "^6.0.0" - html-minifier-terser "^6.0.2" - lodash "^4.17.21" - pretty-error "^4.0.0" - tapable "^2.0.0" - -htmlparser2@7.2.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-7.2.0.tgz#8817cdea38bbc324392a90b1990908e81a65f5a5" - integrity sha512-H7MImA4MS6cw7nbyURtLPO1Tms7C5H602LRETv95z1MxO/7CP7rDVROehUYeYBUYEON94NXXDEPmZuq+hX4sog== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.2.2" - domutils "^2.8.0" - entities "^3.0.1" - -htmlparser2@^6.1.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-6.1.0.tgz#c4d762b6c3371a05dbe65e94ae43a9f845fb8fb7" - integrity sha512-gyyPk6rgonLFEDGoeRgQNaEUvdJ4ktTmmUh/h2t7s+M8oPpIPxgNACWa+6ESR57kXstwqPiCut0V8NRpcwgU7A== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.0.0" - domutils "^2.5.2" - entities "^2.0.0" - -http-cache-semantics@^4.1.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz#abe02fcb2985460bf0323be664436ec3476a6d5a" - integrity sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ== - -http-deceiver@^1.2.7: - version "1.2.7" - resolved "https://registry.yarnpkg.com/http-deceiver/-/http-deceiver-1.2.7.tgz#fa7168944ab9a519d337cb0bec7284dc3e723d87" - integrity sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc= - -http-errors@1.7.3: - version "1.7.3" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" - integrity sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw== - dependencies: - depd "~1.1.2" - inherits "2.0.4" - setprototypeof "1.1.1" - statuses ">= 1.5.0 < 2" - toidentifier "1.0.0" - -http-errors@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" - integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== - dependencies: - depd "2.0.0" - inherits "2.0.4" - setprototypeof "1.2.0" - statuses "2.0.1" - toidentifier "1.0.1" - -http-errors@~1.6.2: - version "1.6.3" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.3.tgz#8b55680bb4be283a0b5bf4ea2e38580be1d9320d" - integrity sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0= - dependencies: - depd "~1.1.2" - inherits "2.0.3" - setprototypeof "1.1.0" - statuses ">= 1.4.0 < 2" - -http-parser-js@>=0.5.1: - version "0.5.3" - resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.3.tgz#01d2709c79d41698bb01d4decc5e9da4e4a033d9" - integrity sha512-t7hjvef/5HEK7RWTdUzVUhl8zkEu+LlaE0IYzdMuvbSDipxBRpOn4Uhw8ZyECEa808iVT8XCjzo6xmYt4CiLZg== - -http-proxy-agent@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz#8a8c8ef7f5932ccf953c296ca8291b95aa74aa3a" - integrity sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg== - dependencies: - "@tootallnate/once" "1" - agent-base "6" - debug "4" - -http-proxy-agent@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz#5129800203520d434f142bc78ff3c170800f2b43" - integrity sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w== +html-dom-parser@5.0.8: + version "5.0.8" + resolved "https://registry.yarnpkg.com/html-dom-parser/-/html-dom-parser-5.0.8.tgz#540057d8eb7ff28c9fd45fa9eead374c34dae20c" + integrity sha512-vuWiX9EXgu8CJ5m9EP5c7bvBmNSuQVnrY8tl0z0ZX96Uth1IPlYH/8W8VZ/hBajFf18EN+j2pukbCNd01HEd1w== dependencies: - "@tootallnate/once" "2" - agent-base "6" - debug "4" + domhandler "5.0.3" + htmlparser2 "9.1.0" -http-proxy-middleware@^2.0.3: - version "2.0.6" - resolved "https://registry.yarnpkg.com/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz#e1a4dd6979572c7ab5a4e4b55095d1f32a74963f" - integrity sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw== +html-react-parser@^5.1.10: + version "5.1.10" + resolved "https://registry.yarnpkg.com/html-react-parser/-/html-react-parser-5.1.10.tgz#e65bf68df9b505756680d2cae842f7add3da5305" + integrity sha512-gV22PvLij4wdEdtrZbGVC7Zy2OVWnQ0bYhX63S196ZRSx4+K0TuutCreHSXr+saUia8KeKB+2TYziVfijpH4Tw== dependencies: - "@types/http-proxy" "^1.17.8" - http-proxy "^1.18.1" - is-glob "^4.0.1" - is-plain-obj "^3.0.0" - micromatch "^4.0.2" + domhandler "5.0.3" + html-dom-parser "5.0.8" + react-property "2.0.2" + style-to-js "1.1.12" -http-proxy@^1.18.1: - version "1.18.1" - resolved "https://registry.yarnpkg.com/http-proxy/-/http-proxy-1.18.1.tgz#401541f0534884bbf95260334e72f88ee3976549" - integrity sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ== +htmlparser2@9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-9.1.0.tgz#cdb498d8a75a51f739b61d3f718136c369bc8c23" + integrity sha512-5zfg6mHUoaer/97TxnGpxmbR7zJtPwIYFMZ/H5ucTlPZhKvtum05yiPK3Mgai3a0DyVxv7qYqoweaEd2nrYQzQ== dependencies: - eventemitter3 "^4.0.0" - follow-redirects "^1.0.0" - requires-port "^1.0.0" + domelementtype "^2.3.0" + domhandler "^5.0.3" + domutils "^3.1.0" + entities "^4.5.0" -https-browserify@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73" - integrity sha512-J+FkSdyD+0mA0N+81tMotaRMfSL9SGi+xpD3T6YApKsc3bGSXJlfXri3VyFOeYkfLRQisDk1W+jIFFKBeUBbBg== +http-shutdown@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/http-shutdown/-/http-shutdown-1.2.2.tgz#41bc78fc767637c4c95179bc492f312c0ae64c5f" + integrity sha512-S9wWkJ/VSY9/k4qcjG318bqJNruzE4HySUhFYknwmu6LBP97KLLfwNf+n4V1BHurvFNkSKLFnK/RsuUnRTf9Vw== https-proxy-agent@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz#e2a90542abb68a762e0a0850f6c9edadfd8506b2" - integrity sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA== + version "5.0.1" + resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" + integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== dependencies: agent-base "6" debug "4" -human-signals@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" - integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== +human-signals@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-5.0.0.tgz#42665a284f9ae0dade3ba41ebc37eb4b852f3a28" + integrity sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ== humanize-ms@^1.2.1: version "1.2.1" @@ -7541,56 +3514,37 @@ humanize-ms@^1.2.1: dependencies: ms "^2.0.0" -iconv-lite@0.4.24: - version "0.4.24" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" - integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== - dependencies: - safer-buffer ">= 2.1.2 < 3" - -iconv-lite@^0.6.2: - version "0.6.3" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" - integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== - dependencies: - safer-buffer ">= 2.1.2 < 3.0.0" +husky@^9.0.11: + version "9.0.11" + resolved "https://registry.yarnpkg.com/husky/-/husky-9.0.11.tgz#fc91df4c756050de41b3e478b2158b87c1e79af9" + integrity sha512-AB6lFlbwwyIqMdHYhwPe+kjOC3Oc5P3nThEoW/AaO2BX3vJDjWPFxYLxokUZOo6RNX20He3AaT8sESs9NJcmEw== -icss-utils@^5.0.0, icss-utils@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/icss-utils/-/icss-utils-5.1.0.tgz#c6be6858abd013d768e98366ae47e25d5887b1ae" - integrity sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA== +idb-keyval@^6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/idb-keyval/-/idb-keyval-6.2.1.tgz#94516d625346d16f56f3b33855da11bfded2db33" + integrity sha512-8Sb3veuYCyrZL+VBt9LJfZjLUPWVvqn8tG28VqYNFCo43KHcKuq+b4EiXGeuaLAQWL2YmyDgMp2aSpH9JHsEQg== -ieee754@^1.1.4, ieee754@^1.2.1: +ieee754@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== -ignore@^4.0.6: - version "4.0.6" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" - integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== - -ignore@^5.2.0, ignore@^5.2.4: - version "5.3.0" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.3.0.tgz#67418ae40d34d6999c95ff56016759c718c82f78" - integrity sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg== - -immer@^9.0.7: - version "9.0.12" - resolved "https://registry.yarnpkg.com/immer/-/immer-9.0.12.tgz#2d33ddf3ee1d247deab9d707ca472c8c942a0f20" - integrity sha512-lk7UNmSbAukB5B6dh9fnh5D0bJTOFKxVg2cyJWTYrWRfhLrLMBquONcUs3aFq507hNoIZEDDh8lb8UtOizSMhA== +ignore@^5.2.0, ignore@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.3.1.tgz#5073e554cd42c5b33b394375f538b8593e34d4ef" + integrity sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw== -immutable@^3: - version "3.8.2" - resolved "https://registry.yarnpkg.com/immutable/-/immutable-3.8.2.tgz#c2439951455bb39913daf281376f1530e104adf3" - integrity sha1-wkOZUUVbs5kT2vKBN28VMOEErfM= +immer@^10.1.1: + version "10.1.1" + resolved "https://registry.yarnpkg.com/immer/-/immer-10.1.1.tgz#206f344ea372d8ea176891545ee53ccc062db7bc" + integrity sha512-s2MPrmjovJcoMaHtx6K11Ra7oD05NT97w1IC5zpMkT6Atjr7H8LjaDd81iIxUYpMKSRRNMJE703M1Fhr/TctHw== immutable@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/immutable/-/immutable-4.0.0.tgz#b86f78de6adef3608395efb269a91462797e2c23" - integrity sha512-zIE9hX70qew5qTUjSS7wi1iwj/l7+m54KWU247nhM3v806UdGj1yDndXj+IOYxxtW9zyLI+xqFNZjTuDaLUqFw== + version "4.3.6" + resolved "https://registry.yarnpkg.com/immutable/-/immutable-4.3.6.tgz#6a05f7858213238e587fb83586ffa3b4b27f0447" + integrity sha512-Ju0+lEMyzMVZarkTn/gqRpdqd5dOPaz1mCZ0SH3JV6iFw81PldE/PEB1hWVEA288HPt4WXW8O7AWxB10M+03QQ== -import-fresh@^3.0.0, import-fresh@^3.2.1: +import-fresh@^3.2.1: version "3.3.0" resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== @@ -7598,106 +3552,55 @@ import-fresh@^3.0.0, import-fresh@^3.2.1: parent-module "^1.0.0" resolve-from "^4.0.0" -import-local@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/import-local/-/import-local-3.0.2.tgz#a8cfd0431d1de4a2199703d003e3e62364fa6db6" - integrity sha512-vjL3+w0oulAVZ0hBHnxa/Nm5TAurf9YLQJDhqRZyqb+VKGOB6LU8t9H1Nr5CIo16vh9XfJTOoHwU0B71S557gA== - dependencies: - pkg-dir "^4.2.0" - resolve-cwd "^3.0.0" - imurmurhash@^0.1.4: version "0.1.4" resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" - integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= - -indent-string@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" - integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== - -infer-owner@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" - integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== inflight@^1.0.4: version "1.0.6" resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" - integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== dependencies: once "^1.3.0" wrappy "1" -inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.3, inherits@~2.0.4: +inherits@2, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.4: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== -inherits@2.0.3: - version "2.0.3" - resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" - integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= - -inline-style-parser@0.1.1: - version "0.1.1" - resolved "https://registry.yarnpkg.com/inline-style-parser/-/inline-style-parser-0.1.1.tgz#ec8a3b429274e9c0a1f1c4ffa9453a7fef72cea1" - integrity sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q== +inline-style-parser@0.2.3: + version "0.2.3" + resolved "https://registry.yarnpkg.com/inline-style-parser/-/inline-style-parser-0.2.3.tgz#e35c5fb45f3a83ed7849fe487336eb7efa25971c" + integrity sha512-qlD8YNDqyTKTyuITrDOffsl6Tdhv+UC4hcdAVuQsK4IMQ99nSgd1MIA/Q+jQYoh9r3hVUXhYh7urSRmXPkW04g== int64-buffer@^1.0.1: version "1.0.1" - resolved "https://registry.npmjs.org/int64-buffer/-/int64-buffer-1.0.1.tgz#c78d841b444cadf036cd04f8683696c740f15dca" + resolved "https://registry.yarnpkg.com/int64-buffer/-/int64-buffer-1.0.1.tgz#c78d841b444cadf036cd04f8683696c740f15dca" integrity sha512-+3azY4pXrjAupJHU1V9uGERWlhoqNswJNji6aD/02xac7oxol508AsMC5lxKhEqyZeDFy3enq5OGWXF4u75hiw== -internal-slot@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.3.tgz#7347e307deeea2faac2ac6205d4bc7d34967f59c" - integrity sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA== - dependencies: - get-intrinsic "^1.1.0" - has "^1.0.3" - side-channel "^1.0.4" - -internal-slot@^1.0.5: - version "1.0.6" - resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.6.tgz#37e756098c4911c5e912b8edbf71ed3aa116f930" - integrity sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg== +internal-slot@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.7.tgz#c06dcca3ed874249881007b0a5523b172a190802" + integrity sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g== dependencies: - get-intrinsic "^1.2.2" + es-errors "^1.3.0" hasown "^2.0.0" side-channel "^1.0.4" -interpret@^3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/interpret/-/interpret-3.1.1.tgz#5be0ceed67ca79c6c4bc5cf0d7ee843dcea110c4" - integrity sha512-6xwYfHbajpoF0xLW+iwLkhwgvLoZDfjYfoFNu8ftMoXINzwuymNLd9u/KmwtdT2GbR+/Cz66otEGEVVUHX9QLQ== - -invariant@^2.2.2: - version "2.2.4" - resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6" - integrity sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA== +ip-address@^9.0.5: + version "9.0.5" + resolved "https://registry.yarnpkg.com/ip-address/-/ip-address-9.0.5.tgz#117a960819b08780c3bd1f14ef3c1cc1d3f3ea5a" + integrity sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g== dependencies: - loose-envify "^1.0.0" - -ip@^1.1.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/ip/-/ip-1.1.5.tgz#bdded70114290828c0a039e72ef25f5aaec4354a" - integrity sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo= - -ip@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ip/-/ip-2.0.0.tgz#4cf4ab182fee2314c75ede1276f8c80b479936da" - integrity sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ== - -ipaddr.js@1.9.1: - version "1.9.1" - resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" - integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + jsbn "1.1.0" + sprintf-js "^1.1.3" -ipaddr.js@^2.0.1: - version "2.1.0" - resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-2.1.0.tgz#2119bc447ff8c257753b196fc5f1ce08a4cdf39f" - integrity sha512-LlbxQ7xKzfBusov6UMi4MFpEg0m+mAm9xyNGEduwXMEDuf4WfzB/RZwMVYEd7IKGvh4IUkEXYxtAVu9T3OelJQ== +iron-webcrypto@^1.0.0: + version "1.2.1" + resolved "https://registry.yarnpkg.com/iron-webcrypto/-/iron-webcrypto-1.2.1.tgz#aa60ff2aa10550630f4c0b11fd2442becdb35a6f" + integrity sha512-feOM6FaSr6rEABp/eDfVseKyTMDt+KGpeB35SkVn9Tyn0CqvVsY3EwI0v5i8nMHyJnzCIQf7nsy3p41TPkJZhg== is-arguments@^1.0.4: version "1.1.1" @@ -7707,19 +3610,13 @@ is-arguments@^1.0.4: call-bind "^1.0.2" has-tostringtag "^1.0.0" -is-array-buffer@^3.0.1, is-array-buffer@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/is-array-buffer/-/is-array-buffer-3.0.2.tgz#f2653ced8412081638ecb0ebbd0c41c6e0aecbbe" - integrity sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w== +is-array-buffer@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/is-array-buffer/-/is-array-buffer-3.0.4.tgz#7a1f92b3d61edd2bc65d24f130530ea93d7fae98" + integrity sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw== dependencies: call-bind "^1.0.2" - get-intrinsic "^1.2.0" - is-typed-array "^1.1.10" - -is-arrayish@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" - integrity sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0= + get-intrinsic "^1.2.1" is-async-function@^2.0.0: version "2.0.0" @@ -7750,36 +3647,24 @@ is-boolean-object@^1.1.0: call-bind "^1.0.2" has-tostringtag "^1.0.0" -is-builtin-module@^3.2.1: - version "3.2.1" - resolved "https://registry.yarnpkg.com/is-builtin-module/-/is-builtin-module-3.2.1.tgz#f03271717d8654cfcaf07ab0463faa3571581169" - integrity sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A== - dependencies: - builtin-modules "^3.3.0" - -is-callable@^1.1.3, is-callable@^1.1.4, is-callable@^1.2.4: - version "1.2.4" - resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.4.tgz#47301d58dd0259407865547853df6d61fe471945" - integrity sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w== - -is-callable@^1.2.7: +is-callable@^1.1.3, is-callable@^1.1.4, is-callable@^1.2.7: version "1.2.7" resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.7.tgz#3bc2a85ea742d9e36205dcacdd72ca1fdc51b055" integrity sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA== -is-core-module@^2.13.0, is-core-module@^2.13.1, is-core-module@^2.5.0: +is-core-module@^2.11.0, is-core-module@^2.13.0, is-core-module@^2.13.1: version "2.13.1" resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.13.1.tgz#ad0d7532c6fea9da1ebdc82742d74525c6273384" integrity sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw== dependencies: hasown "^2.0.0" -is-core-module@^2.2.0: - version "2.6.0" - resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.6.0.tgz#d7553b2526fe59b92ba3e40c8df757ec8a709e19" - integrity sha512-wShG8vs60jKfPWpF2KZRaAtvt3a20OAn7+IJ6hLPECpSABLcKtFKTTI4ZtH5QcBruBHlq+WsdHWyz0BCZW7svQ== +is-data-view@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-data-view/-/is-data-view-1.0.1.tgz#4b4d3a511b70f3dc26d42c03ca9ca515d847759f" + integrity sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w== dependencies: - has "^1.0.3" + is-typed-array "^1.1.13" is-date-object@^1.0.1, is-date-object@^1.0.5: version "1.0.5" @@ -7788,15 +3673,15 @@ is-date-object@^1.0.1, is-date-object@^1.0.5: dependencies: has-tostringtag "^1.0.0" -is-docker@^2.0.0, is-docker@^2.1.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.2.1.tgz#33eeabe23cfe86f14bde4408a02c0cfb853acdaa" - integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== +is-docker@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-3.0.0.tgz#90093aa3106277d8a77a5910dbae71747e15a200" + integrity sha512-eljcgEDlEns/7AXFosB5K/2nCM4P7FQPkGc/DWLy5rmFEWvZayGrik1d9/QIY5nJ4f9YsVvBkA6kJpHn9rISdQ== is-extglob@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" - integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== is-finalizationregistry@^1.0.2: version "1.0.2" @@ -7810,66 +3695,61 @@ is-fullwidth-code-point@^3.0.0: resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== +is-fullwidth-code-point@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz#fae3167c729e7463f8461ce512b080a49268aa88" + integrity sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ== + +is-fullwidth-code-point@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz#9609efced7c2f97da7b60145ef481c787c7ba704" + integrity sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA== + dependencies: + get-east-asian-width "^1.0.0" + is-generator-function@^1.0.10, is-generator-function@^1.0.7: version "1.0.10" - resolved "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz#f1558baf1ac17e0deea7c0415c438351ff2b3c72" + resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.10.tgz#f1558baf1ac17e0deea7c0415c438351ff2b3c72" integrity sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A== dependencies: has-tostringtag "^1.0.0" -is-glob@^4.0.0, is-glob@^4.0.1, is-glob@~4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" - integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== - dependencies: - is-extglob "^2.1.1" - -is-glob@^4.0.3: +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: version "4.0.3" resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== dependencies: is-extglob "^2.1.1" -is-lambda@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-lambda/-/is-lambda-1.0.1.tgz#3d9877899e6a53efc0160504cde15f82e6f061d5" - integrity sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ== +is-inside-container@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-inside-container/-/is-inside-container-1.0.0.tgz#e81fba699662eb31dbdaf26766a61d4814717ea4" + integrity sha512-KIYLCCJghfHZxqjYBE7rEy0OBuTd5xCHS7tHVgvCLkx7StIoaxwNW3hCALgEUjFfeRk+MG/Qxmp/vtETEF3tRA== + dependencies: + is-docker "^3.0.0" -is-map@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/is-map/-/is-map-2.0.2.tgz#00922db8c9bf73e81b7a335827bc2a43f2b91127" - integrity sha512-cOZFQQozTha1f4MxLFzlgKYPTyj26picdZTx82hbc/Xf4K/tZOOXSCkMvU4pKioRXGDLJRn0GM7Upe7kR721yg== +is-map@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/is-map/-/is-map-2.0.3.tgz#ede96b7fe1e270b3c4465e3a465658764926d62e" + integrity sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw== -is-nan@^1.2.1, is-nan@^1.3.2: +is-nan@^1.3.2: version "1.3.2" - resolved "https://registry.npmjs.org/is-nan/-/is-nan-1.3.2.tgz#043a54adea31748b55b6cd4e09aadafa69bd9e1d" + resolved "https://registry.yarnpkg.com/is-nan/-/is-nan-1.3.2.tgz#043a54adea31748b55b6cd4e09aadafa69bd9e1d" integrity sha512-E+zBKpQ2t6MEo1VsonYmluk9NxGrbzpeeLC2xIViuO2EjU2xsXsBPwTr3Ykv9l08UYEVEdWeRZNouaZqF6RN0w== dependencies: call-bind "^1.0.0" define-properties "^1.1.3" -is-negative-zero@^2.0.2: - version "2.0.2" - resolved "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" - integrity sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA== - -is-node-process@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/is-node-process/-/is-node-process-1.2.0.tgz#ea02a1b90ddb3934a19aea414e88edef7e11d134" - integrity sha512-Vg4o6/fqPxIjtxgUH5QLJhwZ7gW5diGCVlXpuUfELC62CuxM1iHcRe51f2W1FDy04Ai4KJkagKjx3XaqyfRKXw== - -is-number-like@^1.0.3: - version "1.0.8" - resolved "https://registry.yarnpkg.com/is-number-like/-/is-number-like-1.0.8.tgz#2e129620b50891042e44e9bbbb30593e75cfbbe3" - integrity sha512-6rZi3ezCyFcn5L71ywzz2bS5b2Igl1En3eTlZlvKjpz1n3IZLAYMbKYAIQgFmEu0GENg92ziU/faEOA/aixjbA== - dependencies: - lodash.isfinite "^3.3.2" +is-negative-zero@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.3.tgz#ced903a027aca6381b777a5743069d7376a49747" + integrity sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw== is-number-object@^1.0.4: - version "1.0.6" - resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.6.tgz#6a7aaf838c7f0686a50b4553f7e54a96494e89f0" - integrity sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g== + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.7.tgz#59d50ada4c45251784e9904f5246c742f07a42fc" + integrity sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ== dependencies: has-tostringtag "^1.0.0" @@ -7878,46 +3758,10 @@ is-number@^7.0.0: resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== -is-path-cwd@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/is-path-cwd/-/is-path-cwd-2.2.0.tgz#67d43b82664a7b5191fd9119127eb300048a9fdb" - integrity sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ== - -is-path-in-cwd@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz#bfe2dca26c69f397265a4009963602935a053acb" - integrity sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ== - dependencies: - is-path-inside "^2.1.0" - -is-path-inside@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-2.1.0.tgz#7c9810587d659a40d27bcdb4d5616eab059494b2" - integrity sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg== - dependencies: - path-is-inside "^1.0.2" - -is-plain-obj@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e" - integrity sha1-caUMhCnfync8kqOQpKA7OfzVHT4= - -is-plain-obj@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-2.1.0.tgz#45e42e37fccf1f40da8e5f76ee21515840c09287" - integrity sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA== - -is-plain-obj@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-3.0.0.tgz#af6f2ea14ac5a646183a5bbdb5baabbc156ad9d7" - integrity sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA== - -is-plain-object@^2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" - integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== - dependencies: - isobject "^3.0.1" +is-path-inside@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" + integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== is-regex@^1.1.4: version "1.1.4" @@ -7927,22 +3771,22 @@ is-regex@^1.1.4: call-bind "^1.0.2" has-tostringtag "^1.0.0" -is-set@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/is-set/-/is-set-2.0.2.tgz#90755fa4c2562dc1c5d4024760d6119b94ca18ec" - integrity sha512-+2cnTEZeY5z/iXGbLhPrOAaK/Mau5k5eXq9j14CpRTftq0pAJu2MwVRSZhyZWBzx3o6X795Lz6Bpb6R0GKf37g== +is-set@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/is-set/-/is-set-2.0.3.tgz#8ab209ea424608141372ded6e0cb200ef1d9d01d" + integrity sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg== -is-shared-array-buffer@^1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz#8f259c573b60b6a32d4058a1a07430c0a7344c79" - integrity sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA== +is-shared-array-buffer@^1.0.2, is-shared-array-buffer@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz#1237f1cba059cdb62431d378dcc37d9680181688" + integrity sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg== dependencies: - call-bind "^1.0.2" + call-bind "^1.0.7" -is-stream@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" - integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== +is-stream@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-3.0.0.tgz#e6bfd7aa6bef69f4f472ce9bb681e3e57b4319ac" + integrity sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA== is-string@^1.0.5, is-string@^1.0.7: version "1.0.7" @@ -7958,80 +3802,64 @@ is-symbol@^1.0.2, is-symbol@^1.0.3: dependencies: has-symbols "^1.0.2" -is-typed-array@^1.1.10, is-typed-array@^1.1.12: - version "1.1.12" - resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.12.tgz#d0bab5686ef4a76f7a73097b95470ab199c57d4a" - integrity sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg== - dependencies: - which-typed-array "^1.1.11" - -is-typed-array@^1.1.3, is-typed-array@^1.1.9: - version "1.1.9" - resolved "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.9.tgz#246d77d2871e7d9f5aeb1d54b9f52c71329ece67" - integrity sha512-kfrlnTTn8pZkfpJMUgYD7YZ3qzeJgWUn8XfVYBARc4wnmNOmLbmuuaAs3q5fvB0UJOn6yHAKaGTPM7d6ezoD/A== +is-typed-array@^1.1.13, is-typed-array@^1.1.3: + version "1.1.13" + resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.13.tgz#d6c5ca56df62334959322d7d7dd1cca50debe229" + integrity sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw== dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" - es-abstract "^1.20.0" - for-each "^0.3.3" - has-tostringtag "^1.0.0" - -is-unicode-supported@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" - integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== + which-typed-array "^1.1.14" -is-weakmap@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/is-weakmap/-/is-weakmap-2.0.1.tgz#5008b59bdc43b698201d18f62b37b2ca243e8cf2" - integrity sha512-NSBR4kH5oVj1Uwvv970ruUkCV7O1mzgVFO4/rev2cLRda9Tm9HrL70ZPut4rOHgY0FNrUu9BCbXA2sdQ+x0chA== +is-weakmap@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/is-weakmap/-/is-weakmap-2.0.2.tgz#bf72615d649dfe5f699079c54b83e47d1ae19cfd" + integrity sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w== is-weakref@^1.0.2: version "1.0.2" - resolved "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" + resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" integrity sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ== dependencies: call-bind "^1.0.2" -is-weakset@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/is-weakset/-/is-weakset-2.0.2.tgz#4569d67a747a1ce5a994dfd4ef6dcea76e7c0a1d" - integrity sha512-t2yVvttHkQktwnNNmBQ98AhENLdPUTDTE21uPqAQ0ARwQfGeQKRVS0NNurH7bTf7RrvcVn1OOge45CnBeHCSmg== +is-weakset@^2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/is-weakset/-/is-weakset-2.0.3.tgz#e801519df8c0c43e12ff2834eead84ec9e624007" + integrity sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ== dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.1.1" + call-bind "^1.0.7" + get-intrinsic "^1.2.4" -is-wsl@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-1.1.0.tgz#1f16e4aa22b04d1336b66188a66af3c600c3a66d" - integrity sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0= +is-wsl@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-3.1.0.tgz#e1c657e39c10090afcbedec61720f6b924c3cbd2" + integrity sha512-UcVfVfaK4Sc4m7X3dUSoHoozQGBEFeDC+zVo06t98xe8CzHSZZBekNXH+tu0NalHolcJ/QAGqS46Hef7QXBIMw== + dependencies: + is-inside-container "^1.0.0" -is-wsl@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-2.2.0.tgz#74a4c76e77ca9fd3f932f290c17ea326cd157271" - integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== +is64bit@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is64bit/-/is64bit-2.0.0.tgz#198c627cbcb198bbec402251f88e5e1a51236c07" + integrity sha512-jv+8jaWCl0g2lSBkNSVXdzfBA0npK1HGC2KtWM9FumFRoGS94g3NbCCLVnCYHLjp4GrW2KZeeSTMo5ddtznmGw== dependencies: - is-docker "^2.0.0" + system-architecture "^0.1.0" isarray@^2.0.5: version "2.0.5" resolved "https://registry.yarnpkg.com/isarray/-/isarray-2.0.5.tgz#8af1e4c1221244cc62459faf38940d4e644a5723" integrity sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw== -isarray@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" - integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= - isexe@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" - integrity sha1-6PvzdNxVb/iUehDcsFctYz8s+hA= + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== -isobject@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" - integrity sha1-TkMekrEalzFjaqH5yNHMvP2reN8= +isomorphic-unfetch@3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/isomorphic-unfetch/-/isomorphic-unfetch-3.1.0.tgz#87341d5f4f7b63843d468438128cb087b7c3e98f" + integrity sha512-geDJjpoZ8N0kWexiwkX8F9NkTsXhetLPVbZFQ+JTW239QNOwvB0gniuR1Wc6f0AMTn7/mFGyXvHTifrCp/GH8Q== + dependencies: + node-fetch "^2.6.1" + unfetch "^4.2.0" isomorphic-ws@^4.0.1: version "4.0.1" @@ -8049,6 +3877,15 @@ iterator.prototype@^1.1.2: reflect.getprototypeof "^1.0.4" set-function-name "^2.0.1" +jackspeak@^2.3.5: + version "2.3.6" + resolved "https://registry.yarnpkg.com/jackspeak/-/jackspeak-2.3.6.tgz#647ecc472238aee4b06ac0e461acc21a8c505ca8" + integrity sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ== + dependencies: + "@isaacs/cliui" "^8.0.2" + optionalDependencies: + "@pkgjs/parseargs" "^0.11.0" + jayson@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/jayson/-/jayson-4.1.0.tgz#60dc946a85197317f2b1439d672a8b0a99cea2f9" @@ -8067,129 +3904,47 @@ jayson@^4.1.0: uuid "^8.3.2" ws "^7.4.5" -jest-diff@^27.0.0: - version "27.0.6" - resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-27.0.6.tgz#4a7a19ee6f04ad70e0e3388f35829394a44c7b5e" - integrity sha512-Z1mqgkTCSYaFgwTlP/NUiRzdqgxmmhzHY1Tq17zL94morOHfHu3K4bgSgl+CR4GLhpV8VxkuOYuIWnQ9LnFqmg== - dependencies: - chalk "^4.0.0" - diff-sequences "^27.0.6" - jest-get-type "^27.0.6" - pretty-format "^27.0.6" - -jest-fetch-mock@^3.0.3: - version "3.0.3" - resolved "https://registry.yarnpkg.com/jest-fetch-mock/-/jest-fetch-mock-3.0.3.tgz#31749c456ae27b8919d69824f1c2bd85fe0a1f3b" - integrity sha512-Ux1nWprtLrdrH4XwE7O7InRY6psIi3GOsqNESJgMJ+M5cv4A8Lh7SN9d2V2kKRZ8ebAfcd1LNyZguAOb6JiDqw== - dependencies: - cross-fetch "^3.0.4" - promise-polyfill "^8.1.3" - -jest-get-type@^27.0.6: - version "27.0.6" - resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-27.0.6.tgz#0eb5c7f755854279ce9b68a9f1a4122f69047cfe" - integrity sha512-XTkK5exIeUbbveehcSR8w0bhH+c0yloW/Wpl+9vZrjzztCPWrxhHwkIFpZzCt71oRBsgxmuUfxEqOYoZI2macg== - -jest-util@^29.7.0: - version "29.7.0" - resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-29.7.0.tgz#23c2b62bfb22be82b44de98055802ff3710fc0bc" - integrity sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA== - dependencies: - "@jest/types" "^29.6.3" - "@types/node" "*" - chalk "^4.0.0" - ci-info "^3.2.0" - graceful-fs "^4.2.9" - picomatch "^2.2.3" - -jest-worker@^27.4.5: - version "27.5.1" - resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.5.1.tgz#8d146f0900e8973b106b6f73cc1e9a8cb86f8db0" - integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg== - dependencies: - "@types/node" "*" - merge-stream "^2.0.0" - supports-color "^8.0.0" - -jest-worker@^29.7.0: - version "29.7.0" - resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-29.7.0.tgz#acad073acbbaeb7262bd5389e1bcf43e10058d4a" - integrity sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw== - dependencies: - "@types/node" "*" - jest-util "^29.7.0" - merge-stream "^2.0.0" - supports-color "^8.0.0" - -js-base64@^2.4.9: - version "2.6.4" - resolved "https://registry.yarnpkg.com/js-base64/-/js-base64-2.6.4.tgz#f4e686c5de1ea1f867dbcad3d46d969428df98c4" - integrity sha512-pZe//GGmwJndub7ZghVHz7vjb2LgC1m8B07Au3eYqeqv9emhESByMXxaEgkUkEqJe87oBbSniGYoQNIBklc7IQ== +jiti@^1.21.0: + version "1.21.6" + resolved "https://registry.yarnpkg.com/jiti/-/jiti-1.21.6.tgz#6c7f7398dd4b3142767f9a168af2f317a428d268" + integrity sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w== "js-tokens@^3.0.0 || ^4.0.0", js-tokens@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== -js-tokens@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz#9866df395102130e38f7f996bceb65443209c25b" - integrity sha512-RjTcuD4xjtthQkaWH7dFlH85L+QaVtSoOyGdZ3g6HFhS9dFNDfLyqgm2NFe2X6cQpeFmt0452FJjFG5UameExg== - -js-yaml@4.1.0: +js-yaml@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== dependencies: argparse "^2.0.1" -js-yaml@^3.13.1: - version "3.14.1" - resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.1.tgz#dae812fdb3825fa306609a8717383c50c36a0537" - integrity sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g== - dependencies: - argparse "^1.0.7" - esprima "^4.0.0" - -jsdoc-type-pratt-parser@~4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.0.0.tgz#136f0571a99c184d84ec84662c45c29ceff71114" - integrity sha512-YtOli5Cmzy3q4dP26GraSOeAhqecewG04hoO8DY56CH4KJ9Fvv5qKWUCCo3HZob7esJQHCv6/+bnTy72xZZaVQ== +jsbn@1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-1.1.0.tgz#b01307cb29b618a1ed26ec79e911f803c4da0040" + integrity sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A== jsesc@^2.5.1: version "2.5.2" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== -jsesc@~0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" - integrity sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0= - -json-loader@^0.5.7: - version "0.5.7" - resolved "https://registry.yarnpkg.com/json-loader/-/json-loader-0.5.7.tgz#dca14a70235ff82f0ac9a3abeb60d337a365185d" - integrity sha512-QLPs8Dj7lnf3e3QYS1zkCo+4ZwqOiF9d/nZnYozTISxXWCfNs9yuky5rJw4/W34s7POaNlbZmQGaB5NiXCbP4w== - -json-parse-even-better-errors@^2.3.0, json-parse-even-better-errors@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" - integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== +json-buffer@3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" + integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ== json-schema-traverse@^0.4.1: version "0.4.1" resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== -json-schema-traverse@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" - integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== - json-stable-stringify-without-jsonify@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" - integrity sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE= + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== json-stable-stringify@^1.1.1: version "1.1.1" @@ -8213,34 +3968,6 @@ json5@^1.0.2: dependencies: minimist "^1.2.0" -json5@^2.1.2: - version "2.2.0" - resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.0.tgz#2dfefe720c6ba525d9ebd909950f0515316c89a3" - integrity sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA== - dependencies: - minimist "^1.2.5" - -json5@^2.2.2, json5@^2.2.3: - version "2.2.3" - resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" - integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== - -jsonfile@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-3.0.1.tgz#a5ecc6f65f53f662c4415c7675a0331d0992ec66" - integrity sha1-pezG9l9T9mLEQVx2daAzHQmS7GY= - optionalDependencies: - graceful-fs "^4.1.6" - -jsonfile@^6.0.1: - version "6.1.0" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" - integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ== - dependencies: - universalify "^2.0.0" - optionalDependencies: - graceful-fs "^4.1.6" - jsonify@^0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.1.tgz#2aa3111dae3d34a0f151c63f3a45d995d9420978" @@ -8253,7 +3980,7 @@ jsonparse@^1.2.0: jsonschema@1.2.2: version "1.2.2" - resolved "https://registry.npmjs.org/jsonschema/-/jsonschema-1.2.2.tgz#83ab9c63d65bf4d596f91d81195e78772f6452bc" + resolved "https://registry.yarnpkg.com/jsonschema/-/jsonschema-1.2.2.tgz#83ab9c63d65bf4d596f91d81195e78772f6452bc" integrity sha512-iX5OFQ6yx9NgbHCwse51ohhKgLuLL7Z5cNOeZOPIlDUtAMrxlruHLzVZxbltdHE5mEDXN+75oFOwq6Gn0MZwsA== "jsx-ast-utils@^2.4.1 || ^3.0.0", jsx-ast-utils@^3.3.5: @@ -8266,15 +3993,22 @@ jsonschema@1.2.2: object.assign "^4.1.4" object.values "^1.1.6" -kind-of@^6.0.2, kind-of@^6.0.3: - version "6.0.3" - resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" - integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== +keyv@^4.5.3: + version "4.5.4" + resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93" + integrity sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw== + dependencies: + json-buffer "3.0.1" + +keyvaluestorage-interface@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/keyvaluestorage-interface/-/keyvaluestorage-interface-1.0.0.tgz#13ebdf71f5284ad54be94bd1ad9ed79adad515ff" + integrity sha512-8t6Q3TclQ4uZynJY9IGr2+SsIGwK9JHcO6ootkHCGA0CrQCRy+VkouYNO2xicET6b9al7QKzpebNow+gkpCL8g== language-subtag-registry@^0.3.20: - version "0.3.22" - resolved "https://registry.yarnpkg.com/language-subtag-registry/-/language-subtag-registry-0.3.22.tgz#2e1500861b2e457eba7e7ae86877cbd08fa1fd1d" - integrity sha512-tN0MCzyWnoz/4nHS6uxdlFWoUZT7ABptwKPQ52Ea7URk6vll88bWBVhodtnlfEuCcKWNGoc+uGbw1cwa9IKh/w== + version "0.3.23" + resolved "https://registry.yarnpkg.com/language-subtag-registry/-/language-subtag-registry-0.3.23.tgz#23529e04d9e3b74679d70142df3fd2eb6ec572e7" + integrity sha512-0K65Lea881pHotoGEa5gDlMxt3pctLi2RplBb7Ezh4rRdLEOtgi7n4EwK9lamnUCkKBqaeKRVebTq6BAxSkpXQ== language-tags@^1.0.9: version "1.0.9" @@ -8283,14 +4017,6 @@ language-tags@^1.0.9: dependencies: language-subtag-registry "^0.3.20" -launch-editor@^2.6.0: - version "2.6.1" - resolved "https://registry.yarnpkg.com/launch-editor/-/launch-editor-2.6.1.tgz#f259c9ef95cbc9425620bbbd14b468fcdb4ffe3c" - integrity sha512-eB/uXmFVpY4zezmGp5XtU21kwo7GBbKB+EQ+UZeWtGb9yAM5xt/Evk+lYH3eRNAtId+ej4u7TYPFZ07w4s7rRw== - dependencies: - picocolors "^1.0.0" - shell-quote "^1.8.1" - levn@^0.4.1: version "0.4.1" resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" @@ -8299,37 +4025,87 @@ levn@^0.4.1: prelude-ls "^1.2.1" type-check "~0.4.0" -limiter@^1.0.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/limiter/-/limiter-1.1.5.tgz#8f92a25b3b16c6131293a0cc834b4a838a2aa7c2" - integrity sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA== +lilconfig@~3.1.1: + version "3.1.2" + resolved "https://registry.yarnpkg.com/lilconfig/-/lilconfig-3.1.2.tgz#e4a7c3cb549e3a606c8dcc32e5ae1005e62c05cb" + integrity sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow== -lines-and-columns@^1.1.6: - version "1.1.6" - resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.1.6.tgz#1c00c743b433cd0a4e80758f7b64a57440d9ff00" - integrity sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA= +lint-staged@^15.2.7: + version "15.2.7" + resolved "https://registry.yarnpkg.com/lint-staged/-/lint-staged-15.2.7.tgz#97867e29ed632820c0fb90be06cd9ed384025649" + integrity sha512-+FdVbbCZ+yoh7E/RosSdqKJyUM2OEjTciH0TFNkawKgvFp1zbGlEC39RADg+xKBG1R4mhoH2j85myBQZ5wR+lw== + dependencies: + chalk "~5.3.0" + commander "~12.1.0" + debug "~4.3.4" + execa "~8.0.1" + lilconfig "~3.1.1" + listr2 "~8.2.1" + micromatch "~4.0.7" + pidtree "~0.6.0" + string-argv "~0.3.2" + yaml "~2.4.2" + +listhen@^1.7.2: + version "1.7.2" + resolved "https://registry.yarnpkg.com/listhen/-/listhen-1.7.2.tgz#66b81740692269d5d8cafdc475020f2fc51afbae" + integrity sha512-7/HamOm5YD9Wb7CFgAZkKgVPA96WwhcTQoqtm2VTZGVbVVn3IWKRBTgrU7cchA3Q8k9iCsG8Osoi9GX4JsGM9g== + dependencies: + "@parcel/watcher" "^2.4.1" + "@parcel/watcher-wasm" "^2.4.1" + citty "^0.1.6" + clipboardy "^4.0.0" + consola "^3.2.3" + crossws "^0.2.0" + defu "^6.1.4" + get-port-please "^3.1.2" + h3 "^1.10.2" + http-shutdown "^1.2.2" + jiti "^1.21.0" + mlly "^1.6.1" + node-forge "^1.3.1" + pathe "^1.1.2" + std-env "^3.7.0" + ufo "^1.4.0" + untun "^0.1.3" + uqr "^0.1.2" + +listr2@~8.2.1: + version "8.2.1" + resolved "https://registry.yarnpkg.com/listr2/-/listr2-8.2.1.tgz#06a1a6efe85f23c5324180d7c1ddbd96b5eefd6d" + integrity sha512-irTfvpib/rNiD637xeevjO2l3Z5loZmuaRi0L0YE5LfijwVY96oyVn0DFD3o/teAok7nfobMG1THvvcHh/BP6g== + dependencies: + cli-truncate "^4.0.0" + colorette "^2.0.20" + eventemitter3 "^5.0.1" + log-update "^6.0.0" + rfdc "^1.3.1" + wrap-ansi "^9.0.0" -loader-runner@^4.2.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-4.3.0.tgz#c1b4a163b99f614830353b16755e7149ac2314e1" - integrity sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg== +lit-element@^3.3.0: + version "3.3.3" + resolved "https://registry.yarnpkg.com/lit-element/-/lit-element-3.3.3.tgz#10bc19702b96ef5416cf7a70177255bfb17b3209" + integrity sha512-XbeRxmTHubXENkV4h8RIPyr8lXc+Ff28rkcQzw3G6up2xg5E8Zu1IgOWIwBLEQsu3cOVFqdYwiVi0hv0SlpqUA== + dependencies: + "@lit-labs/ssr-dom-shim" "^1.1.0" + "@lit/reactive-element" "^1.3.0" + lit-html "^2.8.0" -loader-utils@^2.0.3: - version "2.0.4" - resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.4.tgz#8b5cb38b5c34a9a018ee1fc0e6a066d1dfcc528c" - integrity sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw== +lit-html@^2.8.0: + version "2.8.0" + resolved "https://registry.yarnpkg.com/lit-html/-/lit-html-2.8.0.tgz#96456a4bb4ee717b9a7d2f94562a16509d39bffa" + integrity sha512-o9t+MQM3P4y7M7yNzqAyjp7z+mQGa4NS4CxiyLqFPyFWyc4O+nodLrkrxSaCTrla6M5YOLaT3RpbbqjszB5g3Q== dependencies: - big.js "^5.2.2" - emojis-list "^3.0.0" - json5 "^2.1.2" + "@types/trusted-types" "^2.0.2" -locate-path@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" - integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== +lit@2.8.0, lit@^2.2.4: + version "2.8.0" + resolved "https://registry.yarnpkg.com/lit/-/lit-2.8.0.tgz#4d838ae03059bf9cafa06e5c61d8acc0081e974e" + integrity sha512-4Sc3OFX9QHOJaHbmTMk28SYgVxLN3ePDjg7hofEft2zWlehFL3LiAuapWc4U/kYwMYJSh2hTCPZ6/LIC7ii0MA== dependencies: - p-locate "^3.0.0" - path-exists "^3.0.0" + "@lit/reactive-element" "^1.6.0" + lit-element "^3.3.0" + lit-html "^2.8.0" locate-path@^5.0.0: version "5.0.0" @@ -8345,54 +4121,40 @@ locate-path@^6.0.0: dependencies: p-locate "^5.0.0" -locate-path@^7.1.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-7.2.0.tgz#69cb1779bd90b35ab1e771e1f2f89a202c2a8a8a" - integrity sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA== - dependencies: - p-locate "^6.0.0" +lodash-es@^4.17.21: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash-es/-/lodash-es-4.17.21.tgz#43e626c46e6591b7750beb2b50117390c609e3ee" + integrity sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw== -lodash.clonedeep@^4.5.0: +lodash.isequal@4.5.0: version "4.5.0" - resolved "https://registry.yarnpkg.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz#e23f3f9c4f8fbdde872529c1071857a086e5ccef" - integrity sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8= - -lodash.debounce@^4.0.8: - version "4.0.8" - resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" - integrity sha1-gteb/zCmfEAF/9XiUVMArZyk168= - -lodash.isfinite@^3.3.2: - version "3.3.2" - resolved "https://registry.yarnpkg.com/lodash.isfinite/-/lodash.isfinite-3.3.2.tgz#fb89b65a9a80281833f0b7478b3a5104f898ebb3" - integrity sha1-+4m2WpqAKBgz8LdHizpRBPiY67M= + resolved "https://registry.yarnpkg.com/lodash.isequal/-/lodash.isequal-4.5.0.tgz#415c4478f2bcc30120c22ce10ed3226f7d3e18e0" + integrity sha512-pDo3lu8Jhfjqls6GkMgpahsF9kCyayhgykjyLMNFTKWrpVdAQtYyB4muAMWozBB4ig/dtWAmsMxLEI8wuz+DYQ== lodash.merge@^4.6.2: version "4.6.2" resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== -lodash.truncate@^4.4.2: - version "4.4.2" - resolved "https://registry.yarnpkg.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz#5a350da0b1113b837ecfffd5812cbe58d6eae193" - integrity sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM= - -lodash@^4.17.10, lodash@^4.17.11, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.20, lodash@^4.17.21, lodash@^4.17.4, lodash@^4.17.5: +lodash@^4.17.15, lodash@^4.17.21, lodash@^4.17.4: version "4.17.21" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== -log-symbols@4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-4.1.0.tgz#3fbdbb95b4683ac9fc785111e792e558d4abd503" - integrity sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg== +log-update@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/log-update/-/log-update-6.0.0.tgz#0ddeb7ac6ad658c944c1de902993fce7c33f5e59" + integrity sha512-niTvB4gqvtof056rRIrTZvjNYE4rCUzO6X/X+kYjd7WFxXeJ0NwEFnRxX6ehkvv3jTwrXnNdtAak5XYZuIyPFw== dependencies: - chalk "^4.1.0" - is-unicode-supported "^0.1.0" + ansi-escapes "^6.2.0" + cli-cursor "^4.0.0" + slice-ansi "^7.0.0" + strip-ansi "^7.1.0" + wrap-ansi "^9.0.0" long@^4.0.0: version "4.0.0" - resolved "https://registry.npmjs.org/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28" + resolved "https://registry.yarnpkg.com/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28" integrity sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA== long@^5.0.0: @@ -8400,112 +4162,22 @@ long@^5.0.0: resolved "https://registry.yarnpkg.com/long/-/long-5.2.3.tgz#a3ba97f3877cf1d778eccbcb048525ebb77499e1" integrity sha512-lcHwpNoggQTObv5apGNCTdJrO69eHOZMi4BNC+rTLER8iHAqGrUVeLh/irVIM7zTw2bOXA8T6uNPeujwOLg/2Q== -loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.4.0: +loose-envify@^1.1.0, loose-envify@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== dependencies: js-tokens "^3.0.0 || ^4.0.0" -loupe@^2.3.1: - version "2.3.3" - resolved "https://registry.yarnpkg.com/loupe/-/loupe-2.3.3.tgz#5a92027d54cfb6de4c327d3c3b705561d394d3c6" - integrity sha512-krIV4Cf1BIGIx2t1e6tucThhrBemUnIUjMtD2vN4mrMxnxpBvrcosBSpooqunBqP/hOEEV1w/Cr1YskGtqw5Jg== - dependencies: - get-func-name "^2.0.0" - -lower-case@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-2.0.2.tgz#6fa237c63dbdc4a82ca0fd882e4722dc5e634e28" - integrity sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg== - dependencies: - tslib "^2.0.3" - -lru-cache@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" - integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== - dependencies: - yallist "^3.0.2" - -lru-cache@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" - integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== - dependencies: - yallist "^4.0.0" - -lru-cache@^7.7.1: - version "7.18.3" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-7.18.3.tgz#f793896e0fd0e954a59dfdd82f0773808df6aa89" - integrity sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA== - -lz-string@^1.4.4: - version "1.4.4" - resolved "https://registry.yarnpkg.com/lz-string/-/lz-string-1.4.4.tgz#c0d8eaf36059f705796e1e344811cf4c498d3a26" - integrity sha1-wNjq82BZ9wV5bh40SBHPTEmNOiY= - -make-dir@^2.0.0, make-dir@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" - integrity sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA== - dependencies: - pify "^4.0.1" - semver "^5.6.0" - -make-fetch-happen@^10.0.4: - version "10.2.1" - resolved "https://registry.yarnpkg.com/make-fetch-happen/-/make-fetch-happen-10.2.1.tgz#f5e3835c5e9817b617f2770870d9492d28678164" - integrity sha512-NgOPbRiaQM10DYXvN3/hhGVI2M5MtITFryzBGxHM5p4wnFxsVCbxkrBrDsk+EZ5OB4jEOT7AjDxtdF+KVEFT7w== - dependencies: - agentkeepalive "^4.2.1" - cacache "^16.1.0" - http-cache-semantics "^4.1.0" - http-proxy-agent "^5.0.0" - https-proxy-agent "^5.0.0" - is-lambda "^1.0.1" - lru-cache "^7.7.1" - minipass "^3.1.6" - minipass-collect "^1.0.2" - minipass-fetch "^2.0.3" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.4" - negotiator "^0.6.3" - promise-retry "^2.0.1" - socks-proxy-agent "^7.0.0" - ssri "^9.0.0" - -make-fetch-happen@^9.1.0: - version "9.1.0" - resolved "https://registry.yarnpkg.com/make-fetch-happen/-/make-fetch-happen-9.1.0.tgz#53085a09e7971433e6765f7971bf63f4e05cb968" - integrity sha512-+zopwDy7DNknmwPQplem5lAZX/eCOzSvSNNcSKm5eVwTkOBzoktEfXsa9L23J/GIRhxRsaxzkPEhrJEpE2F4Gg== - dependencies: - agentkeepalive "^4.1.3" - cacache "^15.2.0" - http-cache-semantics "^4.1.0" - http-proxy-agent "^4.0.1" - https-proxy-agent "^5.0.0" - is-lambda "^1.0.1" - lru-cache "^6.0.0" - minipass "^3.1.3" - minipass-collect "^1.0.2" - minipass-fetch "^1.3.2" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.4" - negotiator "^0.6.2" - promise-retry "^2.0.1" - socks-proxy-agent "^6.0.0" - ssri "^8.0.0" - -map-obj@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/map-obj/-/map-obj-1.0.1.tgz#d933ceb9205d82bdcf4886f6742bdc2b4dea146d" - integrity sha512-7N/q3lyZ+LVCp7PzuxrJr4KMbBE2hW7BT7YNia330OFxIf4d3r5zVpicP2650l7CPN6RM9zOJRl3NGpqSiw3Eg== +lossless-json@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/lossless-json/-/lossless-json-4.0.1.tgz#d45229e3abb213a0235812780ca894ea8c5b2c6b" + integrity sha512-l0L+ppmgPDnb+JGxNLndPtJZGNf6+ZmVaQzoxQm3u6TXmhdnsA+YtdVR8DjzZd/em58686CQhOFDPewfJ4l7MA== -map-obj@^4.0.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/map-obj/-/map-obj-4.3.0.tgz#9304f906e93faae70880da102a9f1df0ea8bb05a" - integrity sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ== +lru-cache@^10.2.0: + version "10.2.2" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-10.2.2.tgz#48206bc114c1252940c41b25b41af5b545aca878" + integrity sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ== md5.js@^1.3.4: version "1.3.5" @@ -8516,41 +4188,6 @@ md5.js@^1.3.4: inherits "^2.0.1" safe-buffer "^5.1.2" -media-typer@0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" - integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= - -memfs@^3.4.1, memfs@^3.4.3: - version "3.6.0" - resolved "https://registry.yarnpkg.com/memfs/-/memfs-3.6.0.tgz#d7a2110f86f79dd950a8b6df6d57bc984aa185f6" - integrity sha512-EGowvkkgbMcIChjMTMkESFDbZeSh8xZ7kNSF0hAiAN4Jh6jgHCRS0Ga/+C8y6Au+oqpezRHCfPsmJ2+DwAgiwQ== - dependencies: - fs-monkey "^1.0.4" - -meow@^9.0.0: - version "9.0.0" - resolved "https://registry.yarnpkg.com/meow/-/meow-9.0.0.tgz#cd9510bc5cac9dee7d03c73ee1f9ad959f4ea364" - integrity sha512-+obSblOQmRhcyBt62furQqRAQpNyWXo8BuQ5bN7dG8wmwQ+vwHKp/rCFD4CrTP8CsDQD1sjoZ94K417XEUk8IQ== - dependencies: - "@types/minimist" "^1.2.0" - camelcase-keys "^6.2.2" - decamelize "^1.2.0" - decamelize-keys "^1.1.0" - hard-rejection "^2.1.0" - minimist-options "4.1.0" - normalize-package-data "^3.0.0" - read-pkg-up "^7.0.1" - redent "^3.0.0" - trim-newlines "^3.0.0" - type-fest "^0.18.0" - yargs-parser "^20.2.3" - -merge-descriptors@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" - integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= - merge-stream@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" @@ -8561,93 +4198,40 @@ merge2@^1.3.0, merge2@^1.4.1: resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== -methods@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" - integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= - -micromatch@^4.0.0, micromatch@^4.0.5: - version "4.0.5" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" - integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== +micromatch@^4.0.4, micromatch@^4.0.5, micromatch@~4.0.7: + version "4.0.7" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.7.tgz#33e8190d9fe474a9895525f5618eee136d46c2e5" + integrity sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q== dependencies: - braces "^3.0.2" + braces "^3.0.3" picomatch "^2.3.1" -micromatch@^4.0.2, micromatch@^4.0.4: - version "4.0.4" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.4.tgz#896d519dfe9db25fce94ceb7a500919bf881ebf9" - integrity sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg== - dependencies: - braces "^3.0.1" - picomatch "^2.2.3" - -miller-rabin@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" - integrity sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA== - dependencies: - bn.js "^4.0.0" - brorand "^1.0.1" - -mime-db@1.49.0, "mime-db@>= 1.43.0 < 2": - version "1.49.0" - resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.49.0.tgz#f3dfde60c99e9cf3bc9701d687778f537001cbed" - integrity sha512-CIc8j9URtOVApSFCQIF+VBkX1RwXp/oMMOrqdyXSBXq5RWNEsRfyj1kiRnQgmNXmHxPoFIxOroKA3zcU9P+nAA== - mime-db@1.52.0: version "1.52.0" resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== -mime-types@^2.1.12, mime-types@^2.1.31, mime-types@~2.1.34: +mime-types@^2.1.12: version "2.1.35" resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== dependencies: mime-db "1.52.0" -mime-types@^2.1.27, mime-types@~2.1.17, mime-types@~2.1.24: - version "2.1.32" - resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.32.tgz#1d00e89e7de7fe02008db61001d9e02852670fd5" - integrity sha512-hJGaVS4G4c9TSMYh2n6SQAGrC4RnfU+daP8G7cSCmaqNjiOoUY0VHCMS42pxnQmVF1GWwFhbHWn3RIxCqTmZ9A== - dependencies: - mime-db "1.49.0" - -mime@1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/mime/-/mime-1.4.1.tgz#121f9ebc49e3766f311a76e1fa1c8003c4b03aa6" - integrity sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ== - -mime@1.6.0: - version "1.6.0" - resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" - integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== +mime@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-3.0.0.tgz#b374550dca3a0c18443b0c950a6a58f1931cf7a7" + integrity sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A== mimic-fn@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== -min-document@^2.19.0: - version "2.19.0" - resolved "https://registry.yarnpkg.com/min-document/-/min-document-2.19.0.tgz#7bd282e3f5842ed295bb748cdd9f1ffa2c824685" - integrity sha512-9Wy1B3m3f66bPPmU5hdA4DR4PB2OfDU/+GS3yAB7IQozE3tqXaVv2zOjgla7MEGSRv95+ILmOuvhLkOK6wJtCQ== - dependencies: - dom-walk "^0.1.0" - -min-indent@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/min-indent/-/min-indent-1.0.1.tgz#a63f681673b30571fbe8bc25686ae746eefa9869" - integrity sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg== - -mini-css-extract-plugin@^2.9.0: - version "2.9.0" - resolved "https://registry.yarnpkg.com/mini-css-extract-plugin/-/mini-css-extract-plugin-2.9.0.tgz#c73a1327ccf466f69026ac22a8e8fd707b78a235" - integrity sha512-Zs1YsZVfemekSZG+44vBsYTLQORkPMwnlv+aehcxK/NLKC+EGhDB39/YePYYqx/sTk6NnYpuqikhSn7+JIevTA== - dependencies: - schema-utils "^4.0.0" - tapable "^2.2.1" +mimic-fn@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-4.0.0.tgz#60a90550d5cb0b239cca65d893b1a53b29871ecc" + integrity sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw== minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: version "1.0.1" @@ -8657,448 +4241,183 @@ minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: minimalistic-crypto-utils@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" - integrity sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo= + integrity sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg== -minimatch@3.0.4, minimatch@^3.0.2, minimatch@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" - integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== +minimatch@9.0.3: + version "9.0.3" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.3.tgz#a6e00c3de44c3a542bfaae70abfc22420a6da825" + integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== dependencies: - brace-expansion "^1.1.7" + brace-expansion "^2.0.1" -minimatch@^3.1.1, minimatch@^3.1.2: +minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== dependencies: brace-expansion "^1.1.7" -minimatch@^5.0.1: - version "5.1.6" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" - integrity sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g== +minimatch@^9.0.1, minimatch@^9.0.4: + version "9.0.4" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.4.tgz#8e49c731d1749cbec05050ee5145147b32496a51" + integrity sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw== dependencies: brace-expansion "^2.0.1" -minimatch@~3.0.2: - version "3.0.8" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.8.tgz#5e6a59bd11e2ab0de1cfb843eb2d82e546c321c1" - integrity sha512-6FsRAQsxQ61mw+qP1ZzbL9Bc78x2p5OqNgNpnoAFLTrX8n5Kxph0CsnhmKKNXTWjXqU5L0pGPR7hYk+XWZr60Q== - dependencies: - brace-expansion "^1.1.7" - -minimist-options@4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/minimist-options/-/minimist-options-4.1.0.tgz#c0655713c53a8a2ebd77ffa247d342c40f010619" - integrity sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A== - dependencies: - arrify "^1.0.1" - is-plain-obj "^1.1.0" - kind-of "^6.0.3" - minimist@^1.2.0, minimist@^1.2.6: version "1.2.8" resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== -minimist@^1.2.5: - version "1.2.5" - resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" - integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== - -minipass-collect@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" - integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== - dependencies: - minipass "^3.0.0" - -minipass-fetch@^1.3.2: - version "1.4.1" - resolved "https://registry.yarnpkg.com/minipass-fetch/-/minipass-fetch-1.4.1.tgz#d75e0091daac1b0ffd7e9d41629faff7d0c1f1b6" - integrity sha512-CGH1eblLq26Y15+Azk7ey4xh0J/XfJfrCox5LDJiKqI2Q2iwOLOKrlmIaODiSQS8d18jalF6y2K2ePUm0CmShw== - dependencies: - minipass "^3.1.0" - minipass-sized "^1.0.3" - minizlib "^2.0.0" - optionalDependencies: - encoding "^0.1.12" - -minipass-fetch@^2.0.3: - version "2.1.2" - resolved "https://registry.yarnpkg.com/minipass-fetch/-/minipass-fetch-2.1.2.tgz#95560b50c472d81a3bc76f20ede80eaed76d8add" - integrity sha512-LT49Zi2/WMROHYoqGgdlQIZh8mLPZmOrN2NdJjMXxYe4nkN6FUyuPuOAOedNJDrx0IRGg9+4guZewtp8hE6TxA== - dependencies: - minipass "^3.1.6" - minipass-sized "^1.0.3" - minizlib "^2.1.2" - optionalDependencies: - encoding "^0.1.13" - -minipass-flush@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" - integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== - dependencies: - minipass "^3.0.0" - -minipass-pipeline@^1.2.2, minipass-pipeline@^1.2.4: - version "1.2.4" - resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" - integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== - dependencies: - minipass "^3.0.0" - -minipass-sized@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/minipass-sized/-/minipass-sized-1.0.3.tgz#70ee5a7c5052070afacfbc22977ea79def353b70" - integrity sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g== - dependencies: - minipass "^3.0.0" - -minipass@^3.0.0, minipass@^3.1.1: - version "3.1.3" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.1.3.tgz#7d42ff1f39635482e15f9cdb53184deebd5815fd" - integrity sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg== - dependencies: - yallist "^4.0.0" - -minipass@^3.1.0, minipass@^3.1.3, minipass@^3.1.6: - version "3.3.6" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.3.6.tgz#7bba384db3a1520d18c9c0e5251c3444e95dd94a" - integrity sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw== - dependencies: - yallist "^4.0.0" - -minipass@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-5.0.0.tgz#3e9788ffb90b694a5d0ec94479a45b5d8738133d" - integrity sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ== - -minizlib@^2.0.0, minizlib@^2.1.1, minizlib@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" - integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== - dependencies: - minipass "^3.0.0" - yallist "^4.0.0" - -mitt@^1.1.3: +"minipass@^5.0.0 || ^6.0.2 || ^7.0.0": + version "7.1.2" + resolved "https://registry.yarnpkg.com/minipass/-/minipass-7.1.2.tgz#93a9626ce5e5e66bd4db86849e7515e92340a707" + integrity sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw== + +mlly@^1.6.1, mlly@^1.7.0: + version "1.7.1" + resolved "https://registry.yarnpkg.com/mlly/-/mlly-1.7.1.tgz#e0336429bb0731b6a8e887b438cbdae522c8f32f" + integrity sha512-rrVRZRELyQzrIUAVMHxP97kv+G786pHmOKzuFII8zDYahFBS7qnHh2AlYSl1GAHhaMPCz6/oHjVMcfFYgFYHgA== + dependencies: + acorn "^8.11.3" + pathe "^1.1.2" + pkg-types "^1.1.1" + ufo "^1.5.3" + +motion@10.16.2: + version "10.16.2" + resolved "https://registry.yarnpkg.com/motion/-/motion-10.16.2.tgz#7dc173c6ad62210a7e9916caeeaf22c51e598d21" + integrity sha512-p+PurYqfUdcJZvtnmAqu5fJgV2kR0uLFQuBKtLeFVTrYEVllI99tiOTSefVNYuip9ELTEkepIIDftNdze76NAQ== + dependencies: + "@motionone/animation" "^10.15.1" + "@motionone/dom" "^10.16.2" + "@motionone/svelte" "^10.16.2" + "@motionone/types" "^10.15.1" + "@motionone/utils" "^10.15.1" + "@motionone/vue" "^10.16.2" + +mri@^1.2.0: version "1.2.0" - resolved "https://registry.yarnpkg.com/mitt/-/mitt-1.2.0.tgz#cb24e6569c806e31bd4e3995787fe38a04fdf90d" - integrity sha512-r6lj77KlwqLhIUku9UWYes7KJtsczvolZkzp8hbaDPPaE24OmWl5s539Mytlj22siEQKosZ26qCBgda2PKwoJw== - -mkdirp@^1.0.3, mkdirp@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" - integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== - -mocha@^9.2.0: - version "9.2.0" - resolved "https://registry.yarnpkg.com/mocha/-/mocha-9.2.0.tgz#2bfba73d46e392901f877ab9a47b7c9c5d0275cc" - integrity sha512-kNn7E8g2SzVcq0a77dkphPsDSN7P+iYkqE0ZsGCYWRsoiKjOt+NvXfaagik8vuDa6W5Zw3qxe8Jfpt5qKf+6/Q== - dependencies: - "@ungap/promise-all-settled" "1.1.2" - ansi-colors "4.1.1" - browser-stdout "1.3.1" - chokidar "3.5.3" - debug "4.3.3" - diff "5.0.0" - escape-string-regexp "4.0.0" - find-up "5.0.0" - glob "7.2.0" - growl "1.10.5" - he "1.2.0" - js-yaml "4.1.0" - log-symbols "4.1.0" - minimatch "3.0.4" - ms "2.1.3" - nanoid "3.2.0" - serialize-javascript "6.0.0" - strip-json-comments "3.1.1" - supports-color "8.1.1" - which "2.0.2" - workerpool "6.2.0" - yargs "16.2.0" - yargs-parser "20.2.4" - yargs-unparser "2.0.0" - -ms@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" - integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= + resolved "https://registry.yarnpkg.com/mri/-/mri-1.2.0.tgz#6721480fec2a11a4889861115a48b6cbe7cc8f0b" + integrity sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA== ms@2.1.2: version "2.1.2" resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== -ms@2.1.3, ms@^2.0.0, ms@^2.1.1: +ms@^2.0.0, ms@^2.1.1: version "2.1.3" resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== -msw@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/msw/-/msw-2.3.1.tgz#bfc73e256ffc2c74ec4381b604abb258df35f32b" - integrity sha512-ocgvBCLn/5l3jpl1lssIb3cniuACJLoOfZu01e3n5dbJrpA5PeeWn28jCLgQDNt6d7QT8tF2fYRzm9JoEHtiig== - dependencies: - "@bundled-es-modules/cookie" "^2.0.0" - "@bundled-es-modules/statuses" "^1.0.1" - "@inquirer/confirm" "^3.0.0" - "@mswjs/cookies" "^1.1.0" - "@mswjs/interceptors" "^0.29.0" - "@open-draft/until" "^2.1.0" - "@types/cookie" "^0.6.0" - "@types/statuses" "^2.0.4" - chalk "^4.1.2" - graphql "^16.8.1" - headers-polyfill "^4.0.2" - is-node-process "^1.2.0" - outvariant "^1.4.2" - path-to-regexp "^6.2.0" - strict-event-emitter "^0.5.1" - type-fest "^4.9.0" - yargs "^17.7.2" - -multicast-dns@^7.2.5: - version "7.2.5" - resolved "https://registry.yarnpkg.com/multicast-dns/-/multicast-dns-7.2.5.tgz#77eb46057f4d7adbd16d9290fa7299f6fa64cced" - integrity sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg== - dependencies: - dns-packet "^5.2.2" - thunky "^1.0.2" - -mute-stream@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-1.0.0.tgz#e31bd9fe62f0aed23520aa4324ea6671531e013e" - integrity sha512-avsJQhyd+680gKXyG/sQc0nXaC6rBkPOfyHYcFb9+hdkqQkR9bdnkJ0AMZhke0oesPqIO+mFFJ+IdBc7mst4IA== +multiformats@^9.4.2: + version "9.9.0" + resolved "https://registry.yarnpkg.com/multiformats/-/multiformats-9.9.0.tgz#c68354e7d21037a8f1f8833c8ccd68618e8f1d37" + integrity sha512-HoMUjhH9T8DDBNT+6xzkrd9ga/XiBI4xLr58LJACwK6G3HTOPeMz4nB4KJs33L2BelrIJa7P0VuNaVF3hMYfjg== nan@^2.13.2: - version "2.16.0" - resolved "https://registry.npmjs.org/nan/-/nan-2.16.0.tgz#664f43e45460fb98faf00edca0bb0d7b8dce7916" - integrity sha512-UdAqHyFngu7TfQKsCBgAA6pWDkT8MAO7d0jyOecVhN5354xbLqdn8mV9Tat9gepAupm0bt2DbeaSC8vS52MuFA== - -nan@^2.17.0: - version "2.18.0" - resolved "https://registry.yarnpkg.com/nan/-/nan-2.18.0.tgz#26a6faae7ffbeb293a39660e88a76b82e30b7554" - integrity sha512-W7tfG7vMOGtD30sHoZSSc/JVYiyDPEyQVso/Zz+/uQd0B0L46gtC+pHha5FFMRpil6fm/AoEcRWyOVi4+E/f8w== - -nanoid@3.2.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.2.0.tgz#62667522da6673971cca916a6d3eff3f415ff80c" - integrity sha512-fmsZYa9lpn69Ad5eDn7FMcnnSR+8R34W9qJEijxYhTbfOWzr22n1QxCMzXLK+ODyW2973V3Fux959iQoUxzUIA== + version "2.19.0" + resolved "https://registry.yarnpkg.com/nan/-/nan-2.19.0.tgz#bb58122ad55a6c5bc973303908d5b16cfdd5a8c0" + integrity sha512-nO1xXxfh/RWNxfd/XPfbIfFk5vgLsAxUR9y5O0cHMJu/AW9U95JLXqthYHjEp+8gQ5p96K9jUp8nbVOxCdRbtw== -nanoid@^3.3.7: +nanoid@^3.3.6: version "3.3.7" resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.7.tgz#d0c301a691bc8d54efa0a2226ccf3fe2fd656bd8" integrity sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g== -natural-compare-lite@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz#17b09581988979fddafe0201e931ba933c96cbb4" - integrity sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g== +napi-wasm@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/napi-wasm/-/napi-wasm-1.1.0.tgz#bbe617823765ae9c1bc12ff5942370eae7b2ba4e" + integrity sha512-lHwIAJbmLSjF9VDRm9GoVOy9AGp3aIvkjv+Kvz9h16QR3uSVYH78PNQUnT2U4X53mhlnV2M7wrhibQ3GHicDmg== natural-compare@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" - integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc= - -negotiator@0.6.2: - version "0.6.2" - resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" - integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== - -negotiator@0.6.3, negotiator@^0.6.2, negotiator@^0.6.3: - version "0.6.3" - resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" - integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== -neo-async@^2.6.2: - version "2.6.2" - resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" - integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== - -no-case@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" - integrity sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg== +next@14.2.4: + version "14.2.4" + resolved "https://registry.yarnpkg.com/next/-/next-14.2.4.tgz#ef66c39c71e2d8ad0a3caa0383c8933f4663e4d1" + integrity sha512-R8/V7vugY+822rsQGQCjoLhMuC9oFj9SOi4Cl4b2wjDrseD0LRZ10W7R6Czo4w9ZznVSshKjuIomsRjvm9EKJQ== dependencies: - lower-case "^2.0.2" - tslib "^2.0.3" - -node-abort-controller@^3.0.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/node-abort-controller/-/node-abort-controller-3.1.1.tgz#a94377e964a9a37ac3976d848cb5c765833b8548" - integrity sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ== + "@next/env" "14.2.4" + "@swc/helpers" "0.5.5" + busboy "1.6.0" + caniuse-lite "^1.0.30001579" + graceful-fs "^4.2.11" + postcss "8.4.31" + styled-jsx "5.1.1" + optionalDependencies: + "@next/swc-darwin-arm64" "14.2.4" + "@next/swc-darwin-x64" "14.2.4" + "@next/swc-linux-arm64-gnu" "14.2.4" + "@next/swc-linux-arm64-musl" "14.2.4" + "@next/swc-linux-x64-gnu" "14.2.4" + "@next/swc-linux-x64-musl" "14.2.4" + "@next/swc-win32-arm64-msvc" "14.2.4" + "@next/swc-win32-ia32-msvc" "14.2.4" + "@next/swc-win32-x64-msvc" "14.2.4" node-addon-api@^3.0.0: version "3.2.1" - resolved "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz#81325e0a2117789c0128dab65e7e38f07ceba161" + resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-3.2.1.tgz#81325e0a2117789c0128dab65e7e38f07ceba161" integrity sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A== node-addon-api@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-7.0.0.tgz#8136add2f510997b3b94814f4af1cce0b0e3962e" - integrity sha512-vgbBJTS4m5/KkE16t5Ly0WW9hz46swAstv0hYYwMtbG7AznRhNyfLRe8HZAiWIpcHzoO7HxhLuBQj9rJ/Ho0ZA== + version "7.1.0" + resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-7.1.0.tgz#71f609369379c08e251c558527a107107b5e0fdb" + integrity sha512-mNcltoe1R8o7STTegSOHdnJNN7s5EUvhoS7ShnTHDyOSd+8H+UdWODq6qSv67PjC8Zc5JRT8+oLAMCr0SIXw7g== + +node-addon-api@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-8.0.0.tgz#5453b7ad59dd040d12e0f1a97a6fa1c765c5c9d2" + integrity sha512-ipO7rsHEBqa9STO5C5T10fj732ml+5kLN1cAG8/jdHd56ldQeGj3Q7+scUS+VHK/qy1zLEwC4wMK5+yM0btPvw== -node-fetch@2.6.1: - version "2.6.1" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.1.tgz#045bd323631f76ed2e2b55573394416b639a0052" - integrity sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw== +node-fetch-native@^1.6.1, node-fetch-native@^1.6.2, node-fetch-native@^1.6.3: + version "1.6.4" + resolved "https://registry.yarnpkg.com/node-fetch-native/-/node-fetch-native-1.6.4.tgz#679fc8fd8111266d47d7e72c379f1bed9acff06e" + integrity sha512-IhOigYzAKHd244OC0JIMIUrjzctirCmPkaIfhDeGcEETWof5zKYUW7e7MYvChGWh/4CJeXEgsRyGzuF334rOOQ== -node-fetch@^2.6.12, node-fetch@^2.7.0: +node-fetch@^2.6.1, node-fetch@^2.6.12, node-fetch@^2.7.0: version "2.7.0" resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.7.0.tgz#d0f0fa6e3e2dc1d27efcd8ad99d550bda94d187d" integrity sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A== dependencies: whatwg-url "^5.0.0" -node-forge@^1: +node-forge@^1.3.1: version "1.3.1" resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-1.3.1.tgz#be8da2af243b2417d5f646a770663a92b7e9ded3" integrity sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA== -node-gyp-build@^4.2.2: - version "4.4.0" - resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.4.0.tgz#42e99687ce87ddeaf3a10b99dc06abc11021f3f4" - integrity sha512-amJnQCcgtRVw9SvoebO3BKGESClrfXGCUTX9hSn1OuGQTQBOZmVd0Z0OlecpuRksKvbsUqALE8jls/ErClAPuQ== - -node-gyp-build@^4.3.0, node-gyp-build@^4.8.0: +node-gyp-build@^4.2.2, node-gyp-build@^4.3.0, node-gyp-build@^4.5.0, node-gyp-build@^4.8.0: version "4.8.1" resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.8.1.tgz#976d3ad905e71b76086f4f0b0d3637fe79b6cda5" integrity sha512-OSs33Z9yWr148JZcbZd5WiAXhh/n9z8TxQcdMhIOlpN9AhWpLfvVFO73+m77bBABQMaY9XSvIa+qk0jlI7Gcaw== -node-gyp-build@^4.5.0: - version "4.7.1" - resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.7.1.tgz#cd7d2eb48e594874053150a9418ac85af83ca8f7" - integrity sha512-wTSrZ+8lsRRa3I3H8Xr65dLWSgCvY2l4AOnaeKdPA9TB/WYMPaTcrzf3rXvFoVvjKNVnu0CcWSx54qq9GKRUYg== - -node-gyp@^8.4.1: - version "8.4.1" - resolved "https://registry.yarnpkg.com/node-gyp/-/node-gyp-8.4.1.tgz#3d49308fc31f768180957d6b5746845fbd429937" - integrity sha512-olTJRgUtAb/hOXG0E93wZDs5YiJlgbXxTwQAFHyNlRsXQnYzUaF2aGgujZbw+hR8aF4ZG/rST57bWMWD16jr9w== - dependencies: - env-paths "^2.2.0" - glob "^7.1.4" - graceful-fs "^4.2.6" - make-fetch-happen "^9.1.0" - nopt "^5.0.0" - npmlog "^6.0.0" - rimraf "^3.0.2" - semver "^7.3.5" - tar "^6.1.2" - which "^2.0.2" - -node-releases@^2.0.14: - version "2.0.14" - resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.14.tgz#2ffb053bceb8b2be8495ece1ab6ce600c4461b0b" - integrity sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw== - -node-sass@^9.0.0: - version "9.0.0" - resolved "https://registry.yarnpkg.com/node-sass/-/node-sass-9.0.0.tgz#c21cd17bd9379c2d09362b3baf2cbf089bce08ed" - integrity sha512-yltEuuLrfH6M7Pq2gAj5B6Zm7m+gdZoG66wTqG6mIZV/zijq3M2OO2HswtT6oBspPyFhHDcaxWpsBm0fRNDHPg== - dependencies: - async-foreach "^0.1.3" - chalk "^4.1.2" - cross-spawn "^7.0.3" - gaze "^1.0.0" - get-stdin "^4.0.1" - glob "^7.0.3" - lodash "^4.17.15" - make-fetch-happen "^10.0.4" - meow "^9.0.0" - nan "^2.17.0" - node-gyp "^8.4.1" - sass-graph "^4.0.1" - stdout-stream "^1.4.0" - "true-case-path" "^2.2.1" - -nopt@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/nopt/-/nopt-5.0.0.tgz#530942bb58a512fccafe53fe210f13a25355dc88" - integrity sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ== - dependencies: - abbrev "1" - -normalize-package-data@^2.5.0: - version "2.5.0" - resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" - integrity sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA== - dependencies: - hosted-git-info "^2.1.4" - resolve "^1.10.0" - semver "2 || 3 || 4 || 5" - validate-npm-package-license "^3.0.1" - -normalize-package-data@^3.0.0: - version "3.0.3" - resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-3.0.3.tgz#dbcc3e2da59509a0983422884cd172eefdfa525e" - integrity sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA== - dependencies: - hosted-git-info "^4.0.1" - is-core-module "^2.5.0" - semver "^7.3.4" - validate-npm-package-license "^3.0.1" - normalize-path@^3.0.0, normalize-path@~3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== -npm-run-path@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" - integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== - dependencies: - path-key "^3.0.0" - -npmlog@^6.0.0: - version "6.0.2" - resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-6.0.2.tgz#c8166017a42f2dea92d6453168dd865186a70830" - integrity sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg== - dependencies: - are-we-there-yet "^3.0.0" - console-control-strings "^1.1.0" - gauge "^4.0.3" - set-blocking "^2.0.0" - -nth-check@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.0.0.tgz#1bb4f6dac70072fc313e8c9cd1417b5074c0a125" - integrity sha512-i4sc/Kj8htBrAiH1viZ0TgU8Y5XqCaV/FziYK6TBczxmeKm3AEFWqqF3195yKudrarqy7Zu80Ra5dobFjn9X/Q== +npm-run-path@^5.1.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-5.3.0.tgz#e23353d0ebb9317f174e93417e4a4d82d0249e9f" + integrity sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ== dependencies: - boolbase "^1.0.0" + path-key "^4.0.0" -object-assign@^4, object-assign@^4.0.1, object-assign@^4.1.1: +object-assign@^4.1.1: version "4.1.1" resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" - integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= - -object-inspect@^1.12.0: - version "1.12.2" - resolved "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz#c0641f26394532f28ab8d796ab954e43c009a8ea" - integrity sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ== + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== object-inspect@^1.13.1: version "1.13.1" resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.1.tgz#b96c6109324ccfef6b12216a956ca4dc2ff94bc2" integrity sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ== -object-inspect@^1.9.0: - version "1.11.0" - resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.11.0.tgz#9dceb146cedd4148a0d9e51ab88d34cf509922b1" - integrity sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg== - -object-is@^1.0.1: - version "1.1.5" - resolved "https://registry.yarnpkg.com/object-is/-/object-is-1.1.5.tgz#b9deeaa5fc7f1846a0faecdceec138e5778f53ac" - integrity sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.3" - object-is@^1.1.5: version "1.1.6" resolved "https://registry.yarnpkg.com/object-is/-/object-is-1.1.6.tgz#1a6a53aed2dd8f7e6775ff870bea58545956ab07" @@ -9107,22 +4426,12 @@ object-is@^1.1.5: call-bind "^1.0.7" define-properties "^1.2.1" -object-keys@^1.0.12, object-keys@^1.1.1: +object-keys@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== -object.assign@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.2.tgz#0ed54a342eceb37b38ff76eb831a0e788cb63940" - integrity sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ== - dependencies: - call-bind "^1.0.0" - define-properties "^1.1.3" - has-symbols "^1.0.1" - object-keys "^1.1.1" - -object.assign@^4.1.4: +object.assign@^4.1.4, object.assign@^4.1.5: version "4.1.5" resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.5.tgz#3a833f9ab7fdb80fc9e8d2300c803d216d8fdbb0" integrity sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ== @@ -9132,128 +4441,105 @@ object.assign@^4.1.4: has-symbols "^1.0.3" object-keys "^1.1.1" -object.entries@^1.1.6, object.entries@^1.1.7: - version "1.1.7" - resolved "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.7.tgz#2b47760e2a2e3a752f39dd874655c61a7f03c131" - integrity sha512-jCBs/0plmPsOnrKAfFQXRG2NFjlhZgjjcBLSmTnEhU8U6vVTsVe8ANeQJCHTl3gSsI4J+0emOoCgoKlmQPMgmA== +object.entries@^1.1.7, object.entries@^1.1.8: + version "1.1.8" + resolved "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.8.tgz#bffe6f282e01f4d17807204a24f8edd823599c41" + integrity sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-object-atoms "^1.0.0" -object.fromentries@^2.0.6, object.fromentries@^2.0.7: - version "2.0.7" - resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.7.tgz#71e95f441e9a0ea6baf682ecaaf37fa2a8d7e616" - integrity sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA== - dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" +object.fromentries@^2.0.7, object.fromentries@^2.0.8: + version "2.0.8" + resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.8.tgz#f7195d8a9b97bd95cbc1999ea939ecd1a2b00c65" + integrity sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ== + dependencies: + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.2" + es-object-atoms "^1.0.0" object.groupby@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/object.groupby/-/object.groupby-1.0.1.tgz#d41d9f3c8d6c778d9cbac86b4ee9f5af103152ee" - integrity sha512-HqaQtqLnp/8Bn4GL16cj+CUYbnpe1bh0TtEaWvybszDG4tgxCJuRpV8VGuvNaI1fAnI4lUJzDG55MXcOH4JZcQ== + version "1.0.3" + resolved "https://registry.yarnpkg.com/object.groupby/-/object.groupby-1.0.3.tgz#9b125c36238129f6f7b61954a1e7176148d5002e" + integrity sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - get-intrinsic "^1.2.1" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.2" -object.hasown@^1.1.2: - version "1.1.3" - resolved "https://registry.yarnpkg.com/object.hasown/-/object.hasown-1.1.3.tgz#6a5f2897bb4d3668b8e79364f98ccf971bda55ae" - integrity sha512-fFI4VcYpRHvSLXxP7yiZOMAd331cPfd2p7PFDVbgUsYOfCT3tICVqXWngbjr4m49OvsBwUBQ6O2uQoJvy3RexA== +object.hasown@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/object.hasown/-/object.hasown-1.1.4.tgz#e270ae377e4c120cdcb7656ce66884a6218283dc" + integrity sha512-FZ9LZt9/RHzGySlBARE3VF+gE26TxR38SdmqOqliuTnl9wrKulaQs+4dee1V+Io8VfxqzAfHu6YuRgUy8OHoTg== dependencies: - define-properties "^1.2.0" - es-abstract "^1.22.1" + define-properties "^1.2.1" + es-abstract "^1.23.2" + es-object-atoms "^1.0.0" -object.values@^1.1.6, object.values@^1.1.7: - version "1.1.7" - resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.7.tgz#617ed13272e7e1071b43973aa1655d9291b8442a" - integrity sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng== +object.values@^1.1.6, object.values@^1.1.7, object.values@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.2.0.tgz#65405a9d92cee68ac2d303002e0b8470a4d9ab1b" + integrity sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - -obuf@^1.0.0, obuf@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/obuf/-/obuf-1.1.2.tgz#09bea3343d41859ebd446292d11c9d4db619084e" - integrity sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg== + call-bind "^1.0.7" + define-properties "^1.2.1" + es-object-atoms "^1.0.0" -on-finished@2.4.1: - version "2.4.1" - resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" - integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== +ofetch@^1.3.3: + version "1.3.4" + resolved "https://registry.yarnpkg.com/ofetch/-/ofetch-1.3.4.tgz#7ea65ced3c592ec2b9906975ae3fe1d26a56f635" + integrity sha512-KLIET85ik3vhEfS+3fDlc/BAZiAp+43QEC/yCo5zkNoY2YaKvNkOaFr/6wCFgFH1kuYQM5pMNi0Tg8koiIemtw== dependencies: - ee-first "1.1.1" + destr "^2.0.3" + node-fetch-native "^1.6.3" + ufo "^1.5.3" -on-finished@~2.3.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" - integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= - dependencies: - ee-first "1.1.1" +ohash@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/ohash/-/ohash-1.1.3.tgz#f12c3c50bfe7271ce3fd1097d42568122ccdcf07" + integrity sha512-zuHHiGTYTA1sYJ/wZN+t5HKZaH23i4yI1HMwbuXm24Nid7Dv0KcuRlKoNKS9UNfAVSBlnGLcuQrnOKWOZoEGaw== -on-headers@~1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" - integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== +on-exit-leak-free@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/on-exit-leak-free/-/on-exit-leak-free-0.2.0.tgz#b39c9e3bf7690d890f4861558b0d7b90a442d209" + integrity sha512-dqaz3u44QbRXQooZLTUKU41ZrzYrcvLISVgbrzbyCMxpmSLJvZ3ZamIJIZ29P6OhZIkNIQKosdeM6t1LYbA9hg== -once@^1.3.0: +once@^1.3.0, once@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" - integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== dependencies: wrappy "1" -onetime@^5.1.2: +onetime@^5.1.0: version "5.1.2" resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== dependencies: mimic-fn "^2.1.0" -open@^8.0.9: - version "8.4.2" - resolved "https://registry.yarnpkg.com/open/-/open-8.4.2.tgz#5b5ffe2a8f793dcd2aad73e550cb87b59cb084f9" - integrity sha512-7x81NCL719oNbsq/3mh+hVrAWmFuEYUqrq/Iw3kUzH8ReypT9QQ0BLoJS7/G9k6N81XjW4qHWtjWwe/9eLy1EQ== - dependencies: - define-lazy-prop "^2.0.0" - is-docker "^2.1.1" - is-wsl "^2.2.0" - -opn@5.3.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/opn/-/opn-5.3.0.tgz#64871565c863875f052cfdf53d3e3cb5adb53b1c" - integrity sha512-bYJHo/LOmoTd+pfiYhfZDnf9zekVJrY+cnS2a5F2x+w5ppvTqObojTP7WiFG+kVZs9Inw+qQ/lw7TroWwhdd2g== +onetime@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-6.0.0.tgz#7c24c18ed1fd2e9bca4bd26806a33613c77d34b4" + integrity sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ== dependencies: - is-wsl "^1.1.0" + mimic-fn "^4.0.0" -optionator@^0.9.1: - version "0.9.1" - resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" - integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== +optionator@^0.9.3: + version "0.9.4" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.4.tgz#7ea1c1a5d91d764fb282139c88fe11e182a3a734" + integrity sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g== dependencies: deep-is "^0.1.3" fast-levenshtein "^2.0.6" levn "^0.4.1" prelude-ls "^1.2.1" type-check "^0.4.0" - word-wrap "^1.2.3" + word-wrap "^1.2.5" -os-browserify@^0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.3.0.tgz#854373c7f5c2315914fc9bfc6bd8238fdda1ec27" - integrity sha512-gjcpUc3clBf9+210TRaDWbf+rZZZEshZ+DlXMRCeAjp0xhTrnQsKHypIy1J3d5hKdUzj69t708EHtU8P6bUn0A== - -outvariant@^1.2.1, outvariant@^1.4.0, outvariant@^1.4.2: - version "1.4.2" - resolved "https://registry.yarnpkg.com/outvariant/-/outvariant-1.4.2.tgz#f54f19240eeb7f15b28263d5147405752d8e2066" - integrity sha512-Ou3dJ6bA/UJ5GVHxah4LnqDwZRwAmWxrG3wtrHrbGnP4RnLCtA64A4F+ae7Y8ww660JaddSoArUR5HjipWSHAQ== - -p-limit@^2.0.0, p-limit@^2.2.0: +p-limit@^2.2.0: version "2.3.0" resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== @@ -9267,20 +4553,6 @@ p-limit@^3.0.2: dependencies: yocto-queue "^0.1.0" -p-limit@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-4.0.0.tgz#914af6544ed32bfa54670b061cafcbd04984b644" - integrity sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ== - dependencies: - yocto-queue "^1.0.0" - -p-locate@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" - integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== - dependencies: - p-limit "^2.0.0" - p-locate@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" @@ -9295,46 +4567,11 @@ p-locate@^5.0.0: dependencies: p-limit "^3.0.2" -p-locate@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-6.0.0.tgz#3da9a49d4934b901089dca3302fa65dc5a05c04f" - integrity sha512-wPrq66Llhl7/4AGC6I+cqxT07LhXvWL08LNXz1fENOw0Ap4sRZZ/gZpTTJ5jpurzzzfS2W/Ge9BY3LgLjCShcw== - dependencies: - p-limit "^4.0.0" - -p-map@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/p-map/-/p-map-2.1.0.tgz#310928feef9c9ecc65b68b17693018a665cea175" - integrity sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw== - -p-map@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" - integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== - dependencies: - aggregate-error "^3.0.0" - -p-retry@^4.5.0: - version "4.6.2" - resolved "https://registry.yarnpkg.com/p-retry/-/p-retry-4.6.2.tgz#9baae7184057edd4e17231cee04264106e092a16" - integrity sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ== - dependencies: - "@types/retry" "0.12.0" - retry "^0.13.1" - p-try@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== -param-case@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/param-case/-/param-case-3.0.4.tgz#7d17fe4aa12bde34d4a77d91acfb6219caad01c5" - integrity sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A== - dependencies: - dot-case "^3.0.4" - tslib "^2.0.3" - parent-module@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" @@ -9342,242 +4579,133 @@ parent-module@^1.0.0: dependencies: callsites "^3.0.0" -parse-asn1@^5.0.0, parse-asn1@^5.1.6: - version "5.1.6" - resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.6.tgz#385080a3ec13cb62a62d39409cb3e88844cdaed4" - integrity sha512-RnZRo1EPU6JBnra2vGHj0yhp6ebyjBZpmUCLHWiFhxlzvBCCpAuZ7elsBp1PVAbQN0/04VD/19rfzlBSwLstMw== - dependencies: - asn1.js "^5.2.0" - browserify-aes "^1.0.0" - evp_bytestokey "^1.0.0" - pbkdf2 "^3.0.3" - safe-buffer "^5.1.1" - -parse-json@^5.0.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" - integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== - dependencies: - "@babel/code-frame" "^7.0.0" - error-ex "^1.3.1" - json-parse-even-better-errors "^2.3.0" - lines-and-columns "^1.1.6" - -parseurl@~1.3.2, parseurl@~1.3.3: - version "1.3.3" - resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" - integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== - -pascal-case@^3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-3.1.2.tgz#b48e0ef2b98e205e7c1dae747d0b1508237660eb" - integrity sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g== - dependencies: - no-case "^3.0.4" - tslib "^2.0.3" - -path-exists@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" - integrity sha1-zg6+ql94yxiSXqfYENe1mwEP1RU= - path-exists@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== -path-exists@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-5.0.0.tgz#a6aad9489200b21fab31e49cf09277e5116fb9e7" - integrity sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ== - path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" - integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= - -path-is-inside@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz#365417dede44430d1c11af61027facf074bdfc53" - integrity sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM= + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== -path-key@^3.0.0, path-key@^3.1.0: +path-key@^3.1.0: version "3.1.1" resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== -path-parse@^1.0.6, path-parse@^1.0.7: +path-key@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-4.0.0.tgz#295588dc3aee64154f877adb9d780b81c554bf18" + integrity sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ== + +path-parse@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== -path-to-regexp@0.1.7: - version "0.1.7" - resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" - integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= - -path-to-regexp@^6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-6.2.0.tgz#f7b3803336104c346889adece614669230645f38" - integrity sha512-f66KywYG6+43afgE/8j/GoiNyygk/bnoCbps++3ErRKsIYkGGupyv07R2Ok5m9i67Iqc+T2g1eAUGUPzWhYTyg== +path-scurry@^1.10.1: + version "1.11.1" + resolved "https://registry.yarnpkg.com/path-scurry/-/path-scurry-1.11.1.tgz#7960a668888594a0720b12a911d1a742ab9f11d2" + integrity sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA== + dependencies: + lru-cache "^10.2.0" + minipass "^5.0.0 || ^6.0.2 || ^7.0.0" path-type@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== -pathval@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/pathval/-/pathval-1.1.1.tgz#8534e77a77ce7ac5a2512ea21e0fdb8fcf6c3d8d" - integrity sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ== - -pbkdf2@^3.0.3: - version "3.1.2" - resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.2.tgz#dd822aa0887580e52f1a039dc3eda108efae3075" - integrity sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA== - dependencies: - create-hash "^1.1.2" - create-hmac "^1.1.4" - ripemd160 "^2.0.1" - safe-buffer "^5.0.1" - sha.js "^2.4.8" +pathe@^1.1.1, pathe@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/pathe/-/pathe-1.1.2.tgz#6c4cb47a945692e48a1ddd6e4094d170516437ec" + integrity sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ== picocolors@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" - integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== - -picocolors@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.1.tgz#a8ad579b571952f0e5d25892de5445bcfe25aaa1" integrity sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew== -picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.3: - version "2.3.0" - resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.0.tgz#f1f061de8f6a4bf022892e2d128234fb98302972" - integrity sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw== - -picomatch@^2.3.1: +picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: version "2.3.1" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== -pify@^2.0.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" - integrity sha1-7RQaasBDqEnqWISY59yosVMw6Qw= - -pify@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/pify/-/pify-4.0.1.tgz#4b2cd25c50d598735c50292224fd8c6df41e3231" - integrity sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g== - -pinkie-promise@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa" - integrity sha1-ITXW36ejWMBprJsXh3YogihFD/o= - dependencies: - pinkie "^2.0.0" - -pinkie@^2.0.0: - version "2.0.4" - resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" - integrity sha1-clVrgM+g1IqXToDnckjoDtT3+HA= - -pirates@^4.0.6: - version "4.0.6" - resolved "https://registry.yarnpkg.com/pirates/-/pirates-4.0.6.tgz#3018ae32ecfcff6c29ba2267cbf21166ac1f36b9" - integrity sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg== - -pkg-dir@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-3.0.0.tgz#2749020f239ed990881b1f71210d51eb6523bea3" - integrity sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw== - dependencies: - find-up "^3.0.0" - -pkg-dir@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" - integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== - dependencies: - find-up "^4.0.0" - -pkg-dir@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-7.0.0.tgz#8f0c08d6df4476756c5ff29b3282d0bab7517d11" - integrity sha512-Ie9z/WINcxxLp27BKOCHGde4ITq9UklYKDzVo1nhk5sqGEXU3FpkwP5GM2voTGJkGd9B3Otl+Q4uwSOeSUtOBA== - dependencies: - find-up "^6.3.0" - -portscanner@2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/portscanner/-/portscanner-2.2.0.tgz#6059189b3efa0965c9d96a56b958eb9508411cf1" - integrity sha512-IFroCz/59Lqa2uBvzK3bKDbDDIEaAY8XJ1jFxcLWTqosrsc32//P4VuSB2vZXoHiHqOmx8B5L5hnKOxL/7FlPw== - dependencies: - async "^2.6.0" - is-number-like "^1.0.3" - -postcss-modules-extract-imports@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz#cda1f047c0ae80c97dbe28c3e76a43b88025741d" - integrity sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw== - -postcss-modules-local-by-default@^4.0.3: - version "4.0.3" - resolved "https://registry.yarnpkg.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.3.tgz#b08eb4f083050708998ba2c6061b50c2870ca524" - integrity sha512-2/u2zraspoACtrbFRnTijMiQtb4GW4BvatjaG/bCjYQo8kLTdevCUlwuBHx2sCnSyrI3x3qj4ZK1j5LQBgzmwA== - dependencies: - icss-utils "^5.0.0" - postcss-selector-parser "^6.0.2" - postcss-value-parser "^4.1.0" +pidtree@~0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/pidtree/-/pidtree-0.6.0.tgz#90ad7b6d42d5841e69e0a2419ef38f8883aa057c" + integrity sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g== -postcss-modules-scope@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz#9ef3151456d3bbfa120ca44898dfca6f2fa01f06" - integrity sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg== +pino-abstract-transport@v0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/pino-abstract-transport/-/pino-abstract-transport-0.5.0.tgz#4b54348d8f73713bfd14e3dc44228739aa13d9c0" + integrity sha512-+KAgmVeqXYbTtU2FScx1XS3kNyfZ5TrXY07V96QnUSFqo2gAqlvmaxH67Lj7SWazqsMabf+58ctdTcBgnOLUOQ== dependencies: - postcss-selector-parser "^6.0.4" + duplexify "^4.1.2" + split2 "^4.0.0" -postcss-modules-values@^4.0.0: +pino-std-serializers@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz#d7c5e7e68c3bb3c9b27cbf48ca0bb3ffb4602c9c" - integrity sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ== - dependencies: - icss-utils "^5.0.0" + resolved "https://registry.yarnpkg.com/pino-std-serializers/-/pino-std-serializers-4.0.0.tgz#1791ccd2539c091ae49ce9993205e2cd5dbba1e2" + integrity sha512-cK0pekc1Kjy5w9V2/n+8MkZwusa6EyyxfeQCB799CQRhRt/CqYKiWs5adeu8Shve2ZNffvfC/7J64A2PJo1W/Q== -postcss-selector-parser@^6.0.2: - version "6.0.6" - resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-6.0.6.tgz#2c5bba8174ac2f6981ab631a42ab0ee54af332ea" - integrity sha512-9LXrvaaX3+mcv5xkg5kFwqSzSH1JIObIx51PrndZwlmznwXRfxMddDvo9gve3gVR8ZTKgoFDdWkbRFmEhT4PMg== +pino@7.11.0: + version "7.11.0" + resolved "https://registry.yarnpkg.com/pino/-/pino-7.11.0.tgz#0f0ea5c4683dc91388081d44bff10c83125066f6" + integrity sha512-dMACeu63HtRLmCG8VKdy4cShCPKaYDR4youZqoSWLxl5Gu99HUw8bw75thbPv9Nip+H+QYX8o3ZJbTdVZZ2TVg== + dependencies: + atomic-sleep "^1.0.0" + fast-redact "^3.0.0" + on-exit-leak-free "^0.2.0" + pino-abstract-transport v0.5.0 + pino-std-serializers "^4.0.0" + process-warning "^1.0.0" + quick-format-unescaped "^4.0.3" + real-require "^0.1.0" + safe-stable-stringify "^2.1.0" + sonic-boom "^2.2.1" + thread-stream "^0.15.1" + +pkg-types@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/pkg-types/-/pkg-types-1.1.1.tgz#07b626880749beb607b0c817af63aac1845a73f2" + integrity sha512-ko14TjmDuQJ14zsotODv7dBlwxKhUKQEhuhmbqo1uCi9BB0Z2alo/wAXg6q1dTR5TyuqYyWhjtfe/Tsh+X28jQ== dependencies: - cssesc "^3.0.0" - util-deprecate "^1.0.2" + confbox "^0.1.7" + mlly "^1.7.0" + pathe "^1.1.2" + +playwright-core@1.44.1: + version "1.44.1" + resolved "https://registry.yarnpkg.com/playwright-core/-/playwright-core-1.44.1.tgz#53ec975503b763af6fc1a7aa995f34bc09ff447c" + integrity sha512-wh0JWtYTrhv1+OSsLPgFzGzt67Y7BE/ZS3jEqgGBlp2ppp1ZDj8c+9IARNW4dwf1poq5MgHreEM2KV/GuR4cFA== -postcss-selector-parser@^6.0.4: - version "6.0.13" - resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-6.0.13.tgz#d05d8d76b1e8e173257ef9d60b706a8e5e99bf1b" - integrity sha512-EaV1Gl4mUEV4ddhDnv/xtj7sxwrwxdetHdWUGnT4VJQf+4d05v6lHYZr8N573k5Z0BViss7BDhfWtKS3+sfAqQ== +playwright@1.44.1: + version "1.44.1" + resolved "https://registry.yarnpkg.com/playwright/-/playwright-1.44.1.tgz#5634369d777111c1eea9180430b7a184028e7892" + integrity sha512-qr/0UJ5CFAtloI3avF95Y0L1xQo6r3LQArLIg/z/PoGJ6xa+EwzrwO5lpNr/09STxdHuUoP2mvuELJS+hLdtgg== dependencies: - cssesc "^3.0.0" - util-deprecate "^1.0.2" + playwright-core "1.44.1" + optionalDependencies: + fsevents "2.3.2" -postcss-value-parser@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.1.0.tgz#443f6a20ced6481a2bda4fa8532a6e55d789a2cb" - integrity sha512-97DXOFbQJhk71ne5/Mt6cOu6yxsSfM0QGQyl0L25Gca4yGWEGJaig7l7gbCX623VqTBNGLRLaVUCnNkcedlRSQ== +pngjs@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/pngjs/-/pngjs-5.0.0.tgz#e79dd2b215767fd9c04561c01236df960bce7fbb" + integrity sha512-40QW5YalBNfQo5yRYmiw7Yz6TKKVr3h6970B2YE+3fQpsWcrbj1PzJgxeJ19DRQjhMbKPIuMY8rFaXc8moolVw== -postcss-value-parser@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514" - integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ== +possible-typed-array-names@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz#89bb63c6fada2c3e90adc4a647beeeb39cc7bf8f" + integrity sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q== -postcss@^8.4.21: - version "8.4.32" - resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.32.tgz#1dac6ac51ab19adb21b8b34fd2d93a86440ef6c9" - integrity sha512-D/kj5JNu6oo2EIy+XL/26JEDTlIbB8hw85G8StOE6L74RQAVVP5rej6wxCNqyMbR4RkPfqvezVbPw81Ngd6Kcw== +postcss@8.4.31: + version "8.4.31" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.31.tgz#92b451050a9f914da6755af352bdc0192508656d" + integrity sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ== dependencies: - nanoid "^3.3.7" + nanoid "^3.3.6" picocolors "^1.0.0" source-map-js "^1.0.2" @@ -9586,72 +4714,17 @@ prelude-ls@^1.2.1: resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== -prettier@^2.5.1: - version "2.5.1" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.5.1.tgz#fff75fa9d519c54cf0fce328c1017d94546bc56a" - integrity sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg== - -pretty-error@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-4.0.0.tgz#90a703f46dd7234adb46d0f84823e9d1cb8f10d6" - integrity sha512-AoJ5YMAcXKYxKhuJGdcvse+Voc6v1RgnsR3nWcYU7q4t6z0Q6T86sv5Zq8VIRbOWWFpvdGE83LtdSMNd+6Y0xw== - dependencies: - lodash "^4.17.20" - renderkid "^3.0.0" - -pretty-format@^27.0.0, pretty-format@^27.0.2, pretty-format@^27.0.6: - version "27.0.6" - resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-27.0.6.tgz#ab770c47b2c6f893a21aefc57b75da63ef49a11f" - integrity sha512-8tGD7gBIENgzqA+UBzObyWqQ5B778VIFZA/S66cclyd5YkFLYs2Js7gxDKf0MXtTc9zcS7t1xhdfcElJ3YIvkQ== - dependencies: - "@jest/types" "^27.0.6" - ansi-regex "^5.0.0" - ansi-styles "^5.0.0" - react-is "^17.0.1" - -process-nextick-args@~2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" - integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== - -process@^0.11.10: - version "0.11.10" - resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" - integrity sha1-czIwDoQBYb2j5podHZGn1LwW8YI= - -progress@^2.0.0: - version "2.0.3" - resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" - integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA== - -promise-inflight@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" - integrity sha1-mEcocL8igTL8vdhoEputEsPAKeM= - -promise-polyfill@^8.1.3: - version "8.2.0" - resolved "https://registry.yarnpkg.com/promise-polyfill/-/promise-polyfill-8.2.0.tgz#367394726da7561457aba2133c9ceefbd6267da0" - integrity sha512-k/TC0mIcPVF6yHhUvwAp7cvL6I2fFV7TzF1DuGPI8mBh4QQazf36xCKEHKTZKRysEoTQoQdKyP25J8MPJp7j5g== - -promise-retry@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/promise-retry/-/promise-retry-2.0.1.tgz#ff747a13620ab57ba688f5fc67855410c370da22" - integrity sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g== - dependencies: - err-code "^2.0.2" - retry "^0.12.0" +prettier@^3.3.2: + version "3.3.2" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.3.2.tgz#03ff86dc7c835f2d2559ee76876a3914cec4a90a" + integrity sha512-rAVeHYMcv8ATV5d508CFdn+8/pHPpXeIid1DdrPwXnaAdH7cqjVbpJaT5eq4yRAFU/lsbwYwSF/n5iNrdJHPQA== -prop-types@^15.5.0, prop-types@^15.7.2: - version "15.7.2" - resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.7.2.tgz#52c41e75b8c87e72b9d9360e0206b99dcbffa6c5" - integrity sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ== - dependencies: - loose-envify "^1.4.0" - object-assign "^4.1.1" - react-is "^16.8.1" +process-warning@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/process-warning/-/process-warning-1.0.0.tgz#980a0b25dc38cd6034181be4b7726d89066b4616" + integrity sha512-du4wfLyj4yCZq1VupnVSZmRsPJsNuxoDQFdCFHLaYiEbFBD7QE0a+I4D7hOxrVnh78QE/YipFAj9lXHiXocV+Q== -prop-types@^15.6.1, prop-types@^15.8.1: +prop-types@^15.8.1: version "15.8.1" resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.8.1.tgz#67d87bf1a694f48435cf332c24af10214a3140b5" integrity sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg== @@ -9678,428 +4751,173 @@ protobufjs@7.2.6: "@types/node" ">=13.7.0" long "^5.0.0" -proxy-addr@~2.0.7: - version "2.0.7" - resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" - integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== - dependencies: - forwarded "0.2.0" - ipaddr.js "1.9.1" +proxy-compare@2.5.1: + version "2.5.1" + resolved "https://registry.yarnpkg.com/proxy-compare/-/proxy-compare-2.5.1.tgz#17818e33d1653fbac8c2ec31406bce8a2966f600" + integrity sha512-oyfc0Tx87Cpwva5ZXezSp5V9vht1c7dZBhvuV/y3ctkgMVUmiAGDVeeB0dKhGSyT0v1ZTEQYpe/RXlBVBNuCLA== proxy-from-env@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2" integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== -public-encrypt@^4.0.0: - version "4.0.3" - resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.3.tgz#4fcc9d77a07e48ba7527e7cbe0de33d0701331e0" - integrity sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q== - dependencies: - bn.js "^4.1.0" - browserify-rsa "^4.0.0" - create-hash "^1.1.0" - parse-asn1 "^5.0.0" - randombytes "^2.0.1" - safe-buffer "^5.1.2" - -punycode@^1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" - integrity sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ== - punycode@^2.1.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" - integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== + version "2.3.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.1.tgz#027422e2faec0b25e1549c3e1bd8309b9133b6e5" + integrity sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg== pushdata-bitcoin@^1.0.1: version "1.0.1" - resolved "https://registry.npmjs.org/pushdata-bitcoin/-/pushdata-bitcoin-1.0.1.tgz#15931d3cd967ade52206f523aa7331aef7d43af7" + resolved "https://registry.yarnpkg.com/pushdata-bitcoin/-/pushdata-bitcoin-1.0.1.tgz#15931d3cd967ade52206f523aa7331aef7d43af7" integrity sha512-hw7rcYTJRAl4olM8Owe8x0fBuJJ+WGbMhQuLWOXEMN3PxPCKQHRkhfL+XG0+iXUmSHjkMmb3Ba55Mt21cZc9kQ== dependencies: bitcoin-ops "^1.3.0" -qs@6.11.0: - version "6.11.0" - resolved "https://registry.yarnpkg.com/qs/-/qs-6.11.0.tgz#fd0d963446f7a65e1367e01abd85429453f0c37a" - integrity sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q== +qrcode@1.5.3: + version "1.5.3" + resolved "https://registry.yarnpkg.com/qrcode/-/qrcode-1.5.3.tgz#03afa80912c0dccf12bc93f615a535aad1066170" + integrity sha512-puyri6ApkEHYiVl4CFzo1tDkAZ+ATcnbJrJ6RiBM1Fhctdn/ix9MTE3hRph33omisEbC/2fcfemsseiKgBPKZg== dependencies: - side-channel "^1.0.4" + dijkstrajs "^1.0.1" + encode-utf8 "^1.0.3" + pngjs "^5.0.0" + yargs "^15.3.1" -qs@^6.11.2: - version "6.11.2" - resolved "https://registry.yarnpkg.com/qs/-/qs-6.11.2.tgz#64bea51f12c1f5da1bc01496f48ffcff7c69d7d9" - integrity sha512-tDNIz22aBzCDxLtVH++VnTfzxlfeK5CbqohpSqpJgj1Wg/cQbStNAz3NuqCs5vV+pjBsK4x4pN9HlVh7rcYRiA== +query-string@7.1.3: + version "7.1.3" + resolved "https://registry.yarnpkg.com/query-string/-/query-string-7.1.3.tgz#a1cf90e994abb113a325804a972d98276fe02328" + integrity sha512-hh2WYhq4fi8+b+/2Kg9CEge4fDPvHS534aOOvOZeQ3+Vf2mCFsaFBYj0i+iXcAq6I9Vzp5fjMFBlONvayDC1qg== dependencies: - side-channel "^1.0.4" - -querystring-es3@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73" - integrity sha512-773xhDQnZBMFobEiztv8LIl70ch5MSF/jUQVlhwFyBILqq96anmoctVIYz+ZRp0qbCKATTn6ev02M3r7Ga5vqA== + decode-uri-component "^0.2.2" + filter-obj "^1.1.0" + split-on-first "^1.0.0" + strict-uri-encode "^2.0.0" queue-microtask@^1.2.2: version "1.2.3" resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== -quick-lru@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-4.0.1.tgz#5b8878f113a58217848c6482026c73e1ba57727f" - integrity sha512-ARhCpm70fzdcvNQfPoy49IaanKkTlRWF2JMzqhcJbhSFRZv7nPTvZJdcY7301IPmvW+/p0RgIWnQDLJxifsQ7g== +quick-format-unescaped@^4.0.3: + version "4.0.4" + resolved "https://registry.yarnpkg.com/quick-format-unescaped/-/quick-format-unescaped-4.0.4.tgz#93ef6dd8d3453cbc7970dd614fad4c5954d6b5a7" + integrity sha512-tYC1Q1hgyRuHgloV/YXs2w15unPVh8qfu/qCTfhTYamaw7fyhumKa2yGpdSo87vY32rIclj+4fWYQXUMs9EHvg== + +radix3@^1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/radix3/-/radix3-1.1.2.tgz#fd27d2af3896c6bf4bcdfab6427c69c2afc69ec0" + integrity sha512-b484I/7b8rDEdSDKckSSBA8knMpcdsXudlE/LNL639wFoHKwLbEkQFZHWEYwDC0wa0FKUcCY+GAF73Z7wxNVFA== -randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5, randombytes@^2.1.0: +randombytes@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== dependencies: safe-buffer "^5.1.0" -randomfill@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458" - integrity sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw== - dependencies: - randombytes "^2.0.5" - safe-buffer "^5.1.0" - -range-parser@^1.2.1, range-parser@~1.2.0, range-parser@~1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" - integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== - -raw-body@2.5.1: - version "2.5.1" - resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.1.tgz#fe1b1628b181b700215e5fd42389f98b71392857" - integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== - dependencies: - bytes "3.1.2" - http-errors "2.0.0" - iconv-lite "0.4.24" - unpipe "1.0.0" - -raw-body@^2.3.2: - version "2.4.1" - resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.1.tgz#30ac82f98bb5ae8c152e67149dac8d55153b168c" - integrity sha512-9WmIKF6mkvA0SLmA2Knm9+qj89e+j1zqgyn8aXGd7+nAduPoqgI9lO57SAZNn/Byzo5P7JhXTyg9PzaJbH73bA== +react-copy-to-clipboard@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/react-copy-to-clipboard/-/react-copy-to-clipboard-5.1.0.tgz#09aae5ec4c62750ccb2e6421a58725eabc41255c" + integrity sha512-k61RsNgAayIJNoy9yDsYzDe/yAZAzEbEgcz3DZMhF686LEyukcE1hzurxe85JandPUG+yTfGVFzuEw3xt8WP/A== dependencies: - bytes "3.1.0" - http-errors "1.7.3" - iconv-lite "0.4.24" - unpipe "1.0.0" + copy-to-clipboard "^3.3.1" + prop-types "^15.8.1" -react-dom@^17.0.2: - version "17.0.2" - resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-17.0.2.tgz#ecffb6845e3ad8dbfcdc498f0d0a939736502c23" - integrity sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA== +react-dom@^18.3.1: + version "18.3.1" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.3.1.tgz#c2265d79511b57d479b3dd3fdfa51536494c5cb4" + integrity sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" - scheduler "^0.20.2" + scheduler "^0.23.2" -react-hot-loader@^4.13.1: - version "4.13.1" - resolved "https://registry.yarnpkg.com/react-hot-loader/-/react-hot-loader-4.13.1.tgz#979fd7598e27338b3faffae6ed01c65374dace5e" - integrity sha512-ZlqCfVRqDJmMXTulUGic4lN7Ic1SXgHAFw7y/Jb7t25GBgTR0fYAJ8uY4mrpxjRyWGWmqw77qJQGnYbzCvBU7g== - dependencies: - fast-levenshtein "^2.0.6" - global "^4.3.0" - hoist-non-react-statics "^3.3.0" - loader-utils "^2.0.3" - prop-types "^15.6.1" - react-lifecycles-compat "^3.0.4" - shallowequal "^1.1.0" - source-map "^0.7.3" - -react-is@^16.13.1, react-is@^16.7.0, react-is@^16.8.1: +react-is@^16.13.1: version "16.13.1" resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" - integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== - -react-is@^17.0.1, react-is@^17.0.2: - version "17.0.2" - resolved "https://registry.yarnpkg.com/react-is/-/react-is-17.0.2.tgz#e691d4a8e9c789365655539ab372762b0efb54f0" - integrity sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w== - -react-lifecycles-compat@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz#4f1a273afdfc8f3488a8c516bfda78f872352362" - integrity sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA== - -react-loadable@^5.5.0: - version "5.5.0" - resolved "https://registry.yarnpkg.com/react-loadable/-/react-loadable-5.5.0.tgz#582251679d3da86c32aae2c8e689c59f1196d8c4" - integrity sha512-C8Aui0ZpMd4KokxRdVAm2bQtI03k2RMRNzOB+IipV3yxFTSVICv7WoUr5L9ALB5BmKO1iHgZtWM8EvYG83otdg== - dependencies: - prop-types "^15.5.0" - -react-property@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/react-property/-/react-property-2.0.0.tgz#2156ba9d85fa4741faf1918b38efc1eae3c6a136" - integrity sha512-kzmNjIgU32mO4mmH5+iUyrqlpFQhF8K2k7eZ4fdLSOPFrD1XgEuSBv9LDEgxRXTMBqMd8ppT0x6TIzqE5pdGdw== - -react-redux@^7.2.6: - version "7.2.6" - resolved "https://registry.yarnpkg.com/react-redux/-/react-redux-7.2.6.tgz#49633a24fe552b5f9caf58feb8a138936ddfe9aa" - integrity sha512-10RPdsz0UUrRL1NZE0ejTkucnclYSgXp5q+tB5SWx2qeG2ZJQJyymgAhwKy73yiL/13btfB6fPr+rgbMAaZIAQ== - dependencies: - "@babel/runtime" "^7.15.4" - "@types/react-redux" "^7.1.20" - hoist-non-react-statics "^3.3.2" - loose-envify "^1.4.0" - prop-types "^15.7.2" - react-is "^17.0.2" - -react@^17.0.2: - version "17.0.2" - resolved "https://registry.yarnpkg.com/react/-/react-17.0.2.tgz#d0b5cc516d29eb3eee383f75b62864cfb6800037" - integrity sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA== - dependencies: - loose-envify "^1.1.0" - object-assign "^4.1.1" - -read-pkg-up@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-7.0.1.tgz#f3a6135758459733ae2b95638056e1854e7ef507" - integrity sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg== - dependencies: - find-up "^4.1.0" - read-pkg "^5.2.0" - type-fest "^0.8.1" - -read-pkg@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-5.2.0.tgz#7bf295438ca5a33e56cd30e053b34ee7250c93cc" - integrity sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg== - dependencies: - "@types/normalize-package-data" "^2.4.0" - normalize-package-data "^2.5.0" - parse-json "^5.0.0" - type-fest "^0.6.0" - -readable-stream@^2.0.1: - version "2.3.7" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" - integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== - dependencies: - core-util-is "~1.0.0" - inherits "~2.0.3" - isarray "~1.0.0" - process-nextick-args "~2.0.0" - safe-buffer "~5.1.1" - string_decoder "~1.1.1" - util-deprecate "~1.0.1" - -readable-stream@^3.0.6, readable-stream@^3.5.0, readable-stream@^3.6.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - -readable-stream@^3.6.2: - version "3.6.2" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" - integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - -readdirp@~3.6.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" - integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== - dependencies: - picomatch "^2.2.1" - -rechoir@^0.8.0: - version "0.8.0" - resolved "https://registry.yarnpkg.com/rechoir/-/rechoir-0.8.0.tgz#49f866e0d32146142da3ad8f0eff352b3215ff22" - integrity sha512-/vxpCXddiX8NGfGO/mTafwjq4aFa/71pvamip0++IQk3zG8cbCj0fifNPrjjF1XMXUne91jL9OoxmdykoEtifQ== - dependencies: - resolve "^1.20.0" - -redent@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/redent/-/redent-3.0.0.tgz#e557b7998316bb53c9f1f56fa626352c6963059f" - integrity sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg== - dependencies: - indent-string "^4.0.0" - strip-indent "^3.0.0" - -redux-thunk@^2.4.1: - version "2.4.1" - resolved "https://registry.yarnpkg.com/redux-thunk/-/redux-thunk-2.4.1.tgz#0dd8042cf47868f4b29699941de03c9301a75714" - integrity sha512-OOYGNY5Jy2TWvTL1KgAlVy6dcx3siPJ1wTq741EPyUKfn6W6nChdICjZwCd0p8AZBs5kWpZlbkXW2nE/zjUa+Q== - -redux@^4.0.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/redux/-/redux-4.1.1.tgz#76f1c439bb42043f985fbd9bf21990e60bd67f47" - integrity sha512-hZQZdDEM25UY2P493kPYuKqviVwZ58lEmGQNeQ+gXa+U0gYPUBf7NKYazbe3m+bs/DzM/ahN12DbF+NG8i0CWw== - dependencies: - "@babel/runtime" "^7.9.2" - -redux@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/redux/-/redux-4.1.2.tgz#140f35426d99bb4729af760afcf79eaaac407104" - integrity sha512-SH8PglcebESbd/shgf6mii6EIoRM0zrQyjcuQ+ojmfxjTtE0z9Y8pa62iA/OJ58qjP6j27uyW4kUF4jl/jd6sw== - dependencies: - "@babel/runtime" "^7.9.2" - -reflect.getprototypeof@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/reflect.getprototypeof/-/reflect.getprototypeof-1.0.4.tgz#aaccbf41aca3821b87bb71d9dcbc7ad0ba50a3f3" - integrity sha512-ECkTw8TmJwW60lOTR+ZkODISW6RQ8+2CL3COqtiJKLd6MmB45hN51HprHFziKLGkAuTGQhBb91V8cy+KHlaCjw== - dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - get-intrinsic "^1.2.1" - globalthis "^1.0.3" - which-builtin-type "^1.1.3" - -regenerate-unicode-properties@^10.1.0: - version "10.1.1" - resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.1.tgz#6b0e05489d9076b04c436f318d9b067bba459480" - integrity sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q== - dependencies: - regenerate "^1.4.2" - -regenerate@^1.4.2: - version "1.4.2" - resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.2.tgz#b9346d8827e8f5a32f7ba29637d398b69014848a" - integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== - -regenerator-runtime@^0.11.0: - version "0.11.1" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz#be05ad7f9bf7d22e056f9726cee5017fbf19e2e9" - integrity sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg== - -regenerator-runtime@^0.13.4, regenerator-runtime@^0.13.9: - version "0.13.9" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz#8925742a98ffd90814988d7566ad30ca3b263b52" - integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== + integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== -regenerator-runtime@^0.14.0: - version "0.14.0" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.0.tgz#5e19d68eb12d486f797e15a3c6a918f7cec5eb45" - integrity sha512-srw17NI0TUWHuGa5CFGGmhfNIeja30WMBfbslPNhf6JrqQlLN5gcrvig1oqPxiVaXb0oW0XRKtH6Nngs5lKCIA== +react-property@2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/react-property/-/react-property-2.0.2.tgz#d5ac9e244cef564880a610bc8d868bd6f60fdda6" + integrity sha512-+PbtI3VuDV0l6CleQMsx2gtK0JZbZKbpdu5ynr+lbsuvtmgbNcS3VM0tuY2QjFNOcWxvXeHjDpy42RO+4U2rug== -regenerator-transform@^0.15.2: - version "0.15.2" - resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.15.2.tgz#5bbae58b522098ebdf09bca2f83838929001c7a4" - integrity sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg== +react@^18.3.1: + version "18.3.1" + resolved "https://registry.yarnpkg.com/react/-/react-18.3.1.tgz#49ab892009c53933625bd16b2533fc754cab2891" + integrity sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ== dependencies: - "@babel/runtime" "^7.8.4" + loose-envify "^1.1.0" -regexp.prototype.flags@^1.4.3: - version "1.4.3" - resolved "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz#87cab30f80f66660181a3bb7bf5981a872b367ac" - integrity sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA== +readable-stream@^3.1.1, readable-stream@^3.5.0, readable-stream@^3.6.0: + version "3.6.2" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" + integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== dependencies: - call-bind "^1.0.2" - define-properties "^1.1.3" - functions-have-names "^1.2.2" + inherits "^2.0.3" + string_decoder "^1.1.1" + util-deprecate "^1.0.1" -regexp.prototype.flags@^1.5.0, regexp.prototype.flags@^1.5.1: - version "1.5.1" - resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz#90ce989138db209f81492edd734183ce99f9677e" - integrity sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg== +readdirp@~3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" + integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - set-function-name "^2.0.0" - -regexpp@^3.1.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.2.0.tgz#0425a2768d8f23bad70ca4b90461fa2f1213e1b2" - integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== + picomatch "^2.2.1" -regexpu-core@^5.3.1: - version "5.3.2" - resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.3.2.tgz#11a2b06884f3527aec3e93dbbf4a3b958a95546b" - integrity sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ== - dependencies: - "@babel/regjsgen" "^0.8.0" - regenerate "^1.4.2" - regenerate-unicode-properties "^10.1.0" - regjsparser "^0.9.1" - unicode-match-property-ecmascript "^2.0.0" - unicode-match-property-value-ecmascript "^2.1.0" +real-require@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/real-require/-/real-require-0.1.0.tgz#736ac214caa20632847b7ca8c1056a0767df9381" + integrity sha512-r/H9MzAWtrv8aSVjPCMFpDMl5q66GqtmmRkRjpHTsp4zBAa+snZyiQNlMONiUmEJcsnaw0wCauJ2GWODr/aFkg== -regjsparser@^0.9.1: - version "0.9.1" - resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.9.1.tgz#272d05aa10c7c1f67095b1ff0addae8442fc5709" - integrity sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ== +reflect.getprototypeof@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz#3ab04c32a8390b770712b7a8633972702d278859" + integrity sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg== dependencies: - jsesc "~0.5.0" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.1" + es-errors "^1.3.0" + get-intrinsic "^1.2.4" + globalthis "^1.0.3" + which-builtin-type "^1.1.3" -relateurl@^0.2.7: - version "0.2.7" - resolved "https://registry.yarnpkg.com/relateurl/-/relateurl-0.2.7.tgz#54dbf377e51440aca90a4cd274600d3ff2d888a9" - integrity sha1-VNvzd+UUQKypCkzSdGANP/LYiKk= +regenerator-runtime@^0.14.0: + version "0.14.1" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz#356ade10263f685dda125100cd862c1db895327f" + integrity sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw== -renderkid@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/renderkid/-/renderkid-3.0.0.tgz#5fd823e4d6951d37358ecc9a58b1f06836b6268a" - integrity sha512-q/7VIQA8lmM1hF+jn+sFSPWGlMkSAeNYcPLmDQx2zzuiDfaLrOmumR8iaUKlenFgh0XRPIUeSPlH3A+AW3Z5pg== +regexp.prototype.flags@^1.5.2: + version "1.5.2" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz#138f644a3350f981a858c44f6bb1a61ff59be334" + integrity sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw== dependencies: - css-select "^4.1.3" - dom-converter "^0.2.0" - htmlparser2 "^6.1.0" - lodash "^4.17.21" - strip-ansi "^6.0.1" + call-bind "^1.0.6" + define-properties "^1.2.1" + es-errors "^1.3.0" + set-function-name "^2.0.1" require-directory@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" - integrity sha1-jGStX9MNqxyXbiNE/+f3kqam30I= - -require-from-string@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" - integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== - -requires-port@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" - integrity sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8= - -reselect@^4.1.5: - version "4.1.5" - resolved "https://registry.yarnpkg.com/reselect/-/reselect-4.1.5.tgz#852c361247198da6756d07d9296c2b51eddb79f6" - integrity sha512-uVdlz8J7OO+ASpBYoz1Zypgx0KasCY20H+N8JD13oUMtPvSHQuscrHop4KbXrbsBcdB9Ds7lVK7eRkBIfO43vQ== + integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q== -resolve-cwd@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/resolve-cwd/-/resolve-cwd-3.0.0.tgz#0f0075f1bb2544766cf73ba6a6e2adfebcb13f2d" - integrity sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg== - dependencies: - resolve-from "^5.0.0" +require-main-filename@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-2.0.0.tgz#d0b329ecc7cc0f61649f62215be69af54aa8989b" + integrity sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg== resolve-from@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== -resolve-from@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-5.0.0.tgz#c35225843df8f776df21c57557bc087e9dfdfc69" - integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw== - -resolve@^1.10.0, resolve@^1.14.2, resolve@^1.20.0: - version "1.20.0" - resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975" - integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A== - dependencies: - is-core-module "^2.2.0" - path-parse "^1.0.6" +resolve-pkg-maps@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz#616b3dc2c57056b5588c31cdf4b3d64db133720f" + integrity sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw== -resolve@^1.19.0, resolve@^1.22.4: +resolve@^1.22.4: version "1.22.8" resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.8.tgz#b6c87a9f2aa06dfab52e3d70ac8cde321fa5a48d" integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== @@ -10108,7 +4926,7 @@ resolve@^1.19.0, resolve@^1.22.4: path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" -resolve@^2.0.0-next.4: +resolve@^2.0.0-next.5: version "2.0.0-next.5" resolved "https://registry.yarnpkg.com/resolve/-/resolve-2.0.0-next.5.tgz#6b0ec3107e671e52b68cd068ef327173b90dc03c" integrity sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA== @@ -10117,35 +4935,23 @@ resolve@^2.0.0-next.4: path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" -resp-modifier@6.0.2: - version "6.0.2" - resolved "https://registry.yarnpkg.com/resp-modifier/-/resp-modifier-6.0.2.tgz#b124de5c4fbafcba541f48ffa73970f4aa456b4f" - integrity sha1-sSTeXE+6/LpUH0j/pzlw9KpFa08= +restore-cursor@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-4.0.0.tgz#519560a4318975096def6e609d44100edaa4ccb9" + integrity sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg== dependencies: - debug "^2.2.0" - minimatch "^3.0.2" - -retry@^0.12.0: - version "0.12.0" - resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" - integrity sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs= - -retry@^0.13.1: - version "0.13.1" - resolved "https://registry.yarnpkg.com/retry/-/retry-0.13.1.tgz#185b1587acf67919d63b357349e03537b2484658" - integrity sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg== + onetime "^5.1.0" + signal-exit "^3.0.2" reusify@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== -rimraf@^2.6.3: - version "2.7.1" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" - integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== - dependencies: - glob "^7.1.3" +rfdc@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/rfdc/-/rfdc-1.3.1.tgz#2b6d4df52dffe8bb346992a10ea9451f24373a8f" + integrity sha512-r5a3l5HzYlIC68TpmYKlxWjmOP6wiPJ1vWv2HeLhNsRZMrCkxeqxiHlQ21oXmQ4F3SiryXBHhAD7JZqvOJjFmg== rimraf@^3.0.2: version "3.0.2" @@ -10162,40 +4968,40 @@ ripemd160@^2.0.0, ripemd160@^2.0.1: hash-base "^3.0.0" inherits "^2.0.1" -ripple-address-codec@^4.1.1, ripple-address-codec@^4.2.4: - version "4.2.4" - resolved "https://registry.npmjs.org/ripple-address-codec/-/ripple-address-codec-4.2.4.tgz#a56c2168c8bb81269ea4d15ed96d6824c5a866f8" - integrity sha512-roAOjKz94+FboTItey1XRh5qynwt4xvfBLvbbcx+FiR94Yw2x3LrKLF2GVCMCSAh5I6PkcpADg6AbYsUbGN3nA== +ripple-address-codec@^4.1.1, ripple-address-codec@^4.3.1: + version "4.3.1" + resolved "https://registry.yarnpkg.com/ripple-address-codec/-/ripple-address-codec-4.3.1.tgz#68fbaf646bb8567f70743af7f1ce4479f73efbf6" + integrity sha512-Qa3+9wKVvpL/xYtT6+wANsn0A1QcC5CT6IMZbRJZ/1lGt7gmwIfsrCuz1X0+LCEO7zgb+3UT1I1dc0k/5dwKQQ== dependencies: - base-x "3.0.9" + base-x "^3.0.9" create-hash "^1.1.2" ripple-binary-codec@^1.1.3: - version "1.4.1" - resolved "https://registry.npmjs.org/ripple-binary-codec/-/ripple-binary-codec-1.4.1.tgz#ff0ff83e3b8abd1a9a30daa4f38b5fd1a86eed9b" - integrity sha512-sheaXn0pOnuRDty07wQmeo651OwxE2xMxFbw4jxLA+xS3RXOnjQuei8t+3FZhs49JcYGVgxNev72R2DHTfFnaQ== + version "1.11.0" + resolved "https://registry.yarnpkg.com/ripple-binary-codec/-/ripple-binary-codec-1.11.0.tgz#d99c848c51a19746b738785001fb7208704bfe30" + integrity sha512-g7+gs3T+NfoeW6vIq5dcN0CkIT4t/zwRzFxz8X2RzfbrWRnewPUKqQbmBgs05tXLX5NuWPaneiaAVpFpYBcdfw== dependencies: assert "^2.0.0" big-integer "^1.6.48" - buffer "5.6.0" + buffer "6.0.3" create-hash "^1.2.0" decimal.js "^10.2.0" - ripple-address-codec "^4.2.4" + ripple-address-codec "^4.3.1" ripple-keypairs@^1.0.3: - version "1.1.4" - resolved "https://registry.npmjs.org/ripple-keypairs/-/ripple-keypairs-1.1.4.tgz#4486fca703b8a2fc4f30cfd568478f3d12c1a911" - integrity sha512-PMMjTOxZmCSBOvHPj6bA+V/HGx7oFgDtGGI8VcZYuaFO2H87UX0X0jhfHy+LA2Xy31WYlD7GaDIDDt2QO+AMtw== + version "1.3.1" + resolved "https://registry.yarnpkg.com/ripple-keypairs/-/ripple-keypairs-1.3.1.tgz#7fa531df36b138134afb53555a87d7f5eb465b2e" + integrity sha512-dmPlraWKJciFJxHcoubDahGnoIalG5e/BtV6HNDUs7wLXmtnLMHt6w4ed9R8MTL2zNrVPiIdI/HCtMMo0Tm7JQ== dependencies: bn.js "^5.1.1" brorand "^1.0.5" elliptic "^6.5.4" hash.js "^1.0.3" - ripple-address-codec "^4.2.4" + ripple-address-codec "^4.3.1" ripple-lib-transactionparser@0.8.2: version "0.8.2" - resolved "https://registry.npmjs.org/ripple-lib-transactionparser/-/ripple-lib-transactionparser-0.8.2.tgz#7aaad3ba1e1aeee1d5bcff32334a7a838f834dce" + resolved "https://registry.yarnpkg.com/ripple-lib-transactionparser/-/ripple-lib-transactionparser-0.8.2.tgz#7aaad3ba1e1aeee1d5bcff32334a7a838f834dce" integrity sha512-1teosQLjYHLyOQrKUQfYyMjDR3MAq/Ga+MJuLUfpBMypl4LZB4bEoMcmG99/+WVTEiZOezJmH9iCSvm/MyxD+g== dependencies: bignumber.js "^9.0.0" @@ -10218,21 +5024,12 @@ ripple-lib@^1.10.1: ripple-lib-transactionparser "0.8.2" ws "^7.2.0" -route-recognizer@^0.3.4: - version "0.3.4" - resolved "https://registry.yarnpkg.com/route-recognizer/-/route-recognizer-0.3.4.tgz#39ab1ffbce1c59e6d2bdca416f0932611e4f3ca3" - integrity sha512-2+MhsfPhvauN1O8KaXpXAOfR/fwe8dnUXVM+xw7yt40lJRfPVQxV6yryZm0cgRvAj5fMF/mdRZbL2ptwbs5i2g== - -rpc-websockets@^9.0.0: - version "9.0.1" - resolved "https://registry.yarnpkg.com/rpc-websockets/-/rpc-websockets-9.0.1.tgz#a69c83ffd5e26bdd6117f5b434ae68133c4805b6" - integrity sha512-JCkdc/TfJBGRfmjIFK7cmqX79nwPWUd9xCM0DAydRbdLShsW3j/GV2gmPlaFa8V1+2u4V/O47fm4ZR5+F6HyDw== +rpc-websockets@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/rpc-websockets/-/rpc-websockets-8.0.1.tgz#fa76db08badc0b2f5cd66b5496debd2c404c94b1" + integrity sha512-PptrPRK40uQvifq5sCcObmqInVcZXhy+RRrirzdE5KUPvDI47y1wPvfckD2QzqngOU9xaPW/dT+G+b+wj6M1MQ== dependencies: - "@swc/helpers" "^0.5.11" - "@types/uuid" "^8.3.4" - "@types/ws" "^8.2.2" - buffer "^6.0.3" - eventemitter3 "^5.0.1" + eventemitter3 "^4.0.7" uuid "^8.3.2" ws "^8.5.0" optionalDependencies: @@ -10246,68 +5043,41 @@ run-parallel@^1.1.9: dependencies: queue-microtask "^1.2.2" -rx@4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/rx/-/rx-4.1.0.tgz#a5f13ff79ef3b740fe30aa803fb09f98805d4782" - integrity sha1-pfE/957zt0D+MKqAP7CfmIBdR4I= - -rxjs@^7.8.1: +rxjs@^7.5.5, rxjs@^7.8.1: version "7.8.1" resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-7.8.1.tgz#6f6f3d99ea8044291efd92e7c7fcf562c4057543" integrity sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg== dependencies: tslib "^2.1.0" -safe-array-concat@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/safe-array-concat/-/safe-array-concat-1.0.1.tgz#91686a63ce3adbea14d61b14c99572a8ff84754c" - integrity sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q== +safe-array-concat@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/safe-array-concat/-/safe-array-concat-1.1.2.tgz#81d77ee0c4e8b863635227c721278dd524c20edb" + integrity sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q== dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.2.1" + call-bind "^1.0.7" + get-intrinsic "^1.2.4" has-symbols "^1.0.3" isarray "^2.0.5" -safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: - version "5.1.2" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" - integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== - -safe-buffer@5.2.1, safe-buffer@>=5.1.0, safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@^5.2.1, safe-buffer@~5.2.0: +safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@~5.2.0: version "5.2.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== -safe-regex-test@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/safe-regex-test/-/safe-regex-test-1.0.0.tgz#793b874d524eb3640d1873aad03596db2d4f2295" - integrity sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA== +safe-regex-test@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/safe-regex-test/-/safe-regex-test-1.0.3.tgz#a5b4c0f06e0ab50ea2c395c14d8371232924c377" + integrity sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw== dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.1.3" + call-bind "^1.0.6" + es-errors "^1.3.0" is-regex "^1.1.4" -"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.1.0: - version "2.1.2" - resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" - integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== - -sass-graph@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/sass-graph/-/sass-graph-4.0.1.tgz#2ff8ca477224d694055bf4093f414cf6cfad1d2e" - integrity sha512-5YCfmGBmxoIRYHnKK2AKzrAkCoQ8ozO+iumT8K4tXJXRVCPf+7s1/9KxTSW3Rbvf+7Y7b4FR3mWyLnQr3PHocA== - dependencies: - glob "^7.0.0" - lodash "^4.17.11" - scss-tokenizer "^0.4.3" - yargs "^17.2.1" - -sass-loader@^13.3.2: - version "13.3.2" - resolved "https://registry.yarnpkg.com/sass-loader/-/sass-loader-13.3.2.tgz#460022de27aec772480f03de17f5ba88fa7e18c6" - integrity sha512-CQbKl57kdEv+KDLquhC+gE3pXt74LEAzm+tzywcA0/aHZuub8wTErbjAoNI57rPUWRYRNC5WUnNl8eGJNbDdwg== - dependencies: - neo-async "^2.6.2" +safe-stable-stringify@^2.1.0: + version "2.4.3" + resolved "https://registry.yarnpkg.com/safe-stable-stringify/-/safe-stable-stringify-2.4.3.tgz#138c84b6f6edb3db5f8ef3ef7115b8f55ccbf886" + integrity sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g== sass@^1.77.5: version "1.77.5" @@ -10318,182 +5088,27 @@ sass@^1.77.5: immutable "^4.0.0" source-map-js ">=0.6.2 <2.0.0" -scheduler@^0.20.2: - version "0.20.2" - resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.20.2.tgz#4baee39436e34aa93b4874bddcbf0fe8b8b50e91" - integrity sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ== +scheduler@^0.23.2: + version "0.23.2" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.2.tgz#414ba64a3b282892e944cf2108ecc078d115cdc3" + integrity sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" - -schema-utils@^3.1.1, schema-utils@^3.2.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.3.0.tgz#f50a88877c3c01652a15b622ae9e9795df7a60fe" - integrity sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg== - dependencies: - "@types/json-schema" "^7.0.8" - ajv "^6.12.5" - ajv-keywords "^3.5.2" - -schema-utils@^4.0.0, schema-utils@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-4.2.0.tgz#70d7c93e153a273a805801882ebd3bff20d89c8b" - integrity sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw== - dependencies: - "@types/json-schema" "^7.0.9" - ajv "^8.9.0" - ajv-formats "^2.1.1" - ajv-keywords "^5.1.0" - -scss-tokenizer@^0.4.3: - version "0.4.3" - resolved "https://registry.yarnpkg.com/scss-tokenizer/-/scss-tokenizer-0.4.3.tgz#1058400ee7d814d71049c29923d2b25e61dc026c" - integrity sha512-raKLgf1LI5QMQnG+RxHz6oK0sL3x3I4FN2UDLqgLOGO8hodECNnNh5BXn7fAyBxrA8zVzdQizQ6XjNJQ+uBwMw== - dependencies: - js-base64 "^2.4.9" - source-map "^0.7.3" - -select-hose@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/select-hose/-/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca" - integrity sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo= - -selfsigned@^2.1.1: - version "2.4.1" - resolved "https://registry.yarnpkg.com/selfsigned/-/selfsigned-2.4.1.tgz#560d90565442a3ed35b674034cec4e95dceb4ae0" - integrity sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q== - dependencies: - "@types/node-forge" "^1.3.0" - node-forge "^1" - -"semver@2 || 3 || 4 || 5", semver@^5.6.0: - version "5.7.1" - resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" - integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== semver@^6.3.1: version "6.3.1" resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== -semver@^7.2.1, semver@^7.3.5: - version "7.3.5" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.5.tgz#0b621c879348d8998e4b0e4be94b3f12e6018ef7" - integrity sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ== - dependencies: - lru-cache "^6.0.0" - -semver@^7.3.4, semver@^7.3.7, semver@^7.3.8, semver@^7.5.4: - version "7.5.4" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.4.tgz#483986ec4ed38e1c6c48c34894a9182dbff68a6e" - integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== - dependencies: - lru-cache "^6.0.0" - -send@0.16.2: - version "0.16.2" - resolved "https://registry.yarnpkg.com/send/-/send-0.16.2.tgz#6ecca1e0f8c156d141597559848df64730a6bbc1" - integrity sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw== - dependencies: - debug "2.6.9" - depd "~1.1.2" - destroy "~1.0.4" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - fresh "0.5.2" - http-errors "~1.6.2" - mime "1.4.1" - ms "2.0.0" - on-finished "~2.3.0" - range-parser "~1.2.0" - statuses "~1.4.0" - -send@0.18.0: - version "0.18.0" - resolved "https://registry.yarnpkg.com/send/-/send-0.18.0.tgz#670167cc654b05f5aa4a767f9113bb371bc706be" - integrity sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg== - dependencies: - debug "2.6.9" - depd "2.0.0" - destroy "1.2.0" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - fresh "0.5.2" - http-errors "2.0.0" - mime "1.6.0" - ms "2.1.3" - on-finished "2.4.1" - range-parser "~1.2.1" - statuses "2.0.1" - -serialize-javascript@6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.0.tgz#efae5d88f45d7924141da8b5c3a7a7e663fefeb8" - integrity sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag== - dependencies: - randombytes "^2.1.0" - -serialize-javascript@^6.0.0, serialize-javascript@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.1.tgz#b206efb27c3da0b0ab6b52f48d170b7996458e5c" - integrity sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w== - dependencies: - randombytes "^2.1.0" - -serve-index@1.9.1, serve-index@^1.9.1: - version "1.9.1" - resolved "https://registry.yarnpkg.com/serve-index/-/serve-index-1.9.1.tgz#d3768d69b1e7d82e5ce050fff5b453bea12a9239" - integrity sha1-03aNabHn2C5c4FD/9bRTvqEqkjk= - dependencies: - accepts "~1.3.4" - batch "0.6.1" - debug "2.6.9" - escape-html "~1.0.3" - http-errors "~1.6.2" - mime-types "~2.1.17" - parseurl "~1.3.2" - -serve-static@1.13.2: - version "1.13.2" - resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.13.2.tgz#095e8472fd5b46237db50ce486a43f4b86c6cec1" - integrity sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw== - dependencies: - encodeurl "~1.0.2" - escape-html "~1.0.3" - parseurl "~1.3.2" - send "0.16.2" - -serve-static@1.15.0: - version "1.15.0" - resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.15.0.tgz#faaef08cffe0a1a62f60cad0c4e513cff0ac9540" - integrity sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g== - dependencies: - encodeurl "~1.0.2" - escape-html "~1.0.3" - parseurl "~1.3.3" - send "0.18.0" - -server-destroy@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/server-destroy/-/server-destroy-1.0.1.tgz#f13bf928e42b9c3e79383e61cc3998b5d14e6cdd" - integrity sha1-8Tv5KOQrnD55OD5hzDmYtdFObN0= +semver@^7.3.5, semver@^7.5.4, semver@^7.6.0: + version "7.6.2" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.6.2.tgz#1e3b34759f896e8f14d6134732ce798aeb0c6e13" + integrity sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w== set-blocking@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" - integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc= - -set-function-length@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/set-function-length/-/set-function-length-1.1.1.tgz#4bc39fafb0307224a33e106a7d35ca1218d659ed" - integrity sha512-VoaqjbBJKiWtg4yRcKBQ7g7wnGnLV3M8oLvVWwOk2PdYY6PEFegR1vezXR0tw6fZGF9csVakIRjrJiy2veSBFQ== - dependencies: - define-data-property "^1.1.1" - get-intrinsic "^1.2.1" - gopd "^1.0.1" - has-property-descriptors "^1.0.0" + integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== set-function-length@^1.2.1: version "1.2.2" @@ -10507,29 +5122,15 @@ set-function-length@^1.2.1: gopd "^1.0.1" has-property-descriptors "^1.0.2" -set-function-name@^2.0.0, set-function-name@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/set-function-name/-/set-function-name-2.0.1.tgz#12ce38b7954310b9f61faa12701620a0c882793a" - integrity sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA== +set-function-name@^2.0.1, set-function-name@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/set-function-name/-/set-function-name-2.0.2.tgz#16a705c5a0dc2f5e638ca96d8a8cd4e1c2b90985" + integrity sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ== dependencies: - define-data-property "^1.0.1" + define-data-property "^1.1.4" + es-errors "^1.3.0" functions-have-names "^1.2.3" - has-property-descriptors "^1.0.0" - -setprototypeof@1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656" - integrity sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ== - -setprototypeof@1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683" - integrity sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw== - -setprototypeof@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" - integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== + has-property-descriptors "^1.0.2" sha.js@^2.3.6, sha.js@^2.4.0, sha.js@^2.4.8: version "2.4.11" @@ -10539,18 +5140,6 @@ sha.js@^2.3.6, sha.js@^2.4.0, sha.js@^2.4.8: inherits "^2.0.1" safe-buffer "^5.0.1" -shallow-clone@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/shallow-clone/-/shallow-clone-3.0.1.tgz#8f2981ad92531f55035b01fb230769a40e02efa3" - integrity sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA== - dependencies: - kind-of "^6.0.2" - -shallowequal@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/shallowequal/-/shallowequal-1.1.0.tgz#188d521de95b9087404fd4dcb68b13df0ae4e7f8" - integrity sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ== - shebang-command@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" @@ -10563,26 +5152,22 @@ shebang-regex@^3.0.0: resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== -shell-quote@^1.8.1: - version "1.8.1" - resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-1.8.1.tgz#6dbf4db75515ad5bac63b4f1894c3a154c766680" - integrity sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA== - -side-channel@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" - integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== +side-channel@^1.0.4, side-channel@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.6.tgz#abd25fb7cd24baf45466406b1096b7831c9215f2" + integrity sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA== dependencies: - call-bind "^1.0.0" - get-intrinsic "^1.0.2" - object-inspect "^1.9.0" + call-bind "^1.0.7" + es-errors "^1.3.0" + get-intrinsic "^1.2.4" + object-inspect "^1.13.1" -signal-exit@^3.0.3, signal-exit@^3.0.7: +signal-exit@^3.0.2: version "3.0.7" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== -signal-exit@^4.1.0: +signal-exit@^4.0.1, signal-exit@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-4.1.0.tgz#952188c1cbd546070e2dd20d0f41c0ae0530cb04" integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== @@ -10592,114 +5177,42 @@ slash@^3.0.0: resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== -slash@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/slash/-/slash-4.0.0.tgz#2422372176c4c6c5addb5e2ada885af984b396a7" - integrity sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew== +slice-ansi@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-5.0.0.tgz#b73063c57aa96f9cd881654b15294d95d285c42a" + integrity sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ== + dependencies: + ansi-styles "^6.0.0" + is-fullwidth-code-point "^4.0.0" -slice-ansi@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-4.0.0.tgz#500e8dd0fd55b05815086255b3195adf2a45fe6b" - integrity sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ== +slice-ansi@^7.0.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-7.1.0.tgz#cd6b4655e298a8d1bdeb04250a433094b347b9a9" + integrity sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg== dependencies: - ansi-styles "^4.0.0" - astral-regex "^2.0.0" - is-fullwidth-code-point "^3.0.0" + ansi-styles "^6.2.1" + is-fullwidth-code-point "^5.0.0" smart-buffer@^4.2.0: version "4.2.0" - resolved "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae" + resolved "https://registry.yarnpkg.com/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae" integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg== -socket.io-adapter@~2.5.2: - version "2.5.4" - resolved "https://registry.yarnpkg.com/socket.io-adapter/-/socket.io-adapter-2.5.4.tgz#4fdb1358667f6d68f25343353bd99bd11ee41006" - integrity sha512-wDNHGXGewWAjQPt3pyeYBtpWSq9cLE5UW1ZUPL/2eGK9jtse/FpXib7epSTsz0Q0m+6sg6Y4KtcFTlah1bdOVg== - dependencies: - debug "~4.3.4" - ws "~8.11.0" - -socket.io-client@^4.4.1: - version "4.7.5" - resolved "https://registry.yarnpkg.com/socket.io-client/-/socket.io-client-4.7.5.tgz#919be76916989758bdc20eec63f7ee0ae45c05b7" - integrity sha512-sJ/tqHOCe7Z50JCBCXrsY3I2k03iOiUe+tj1OmKeD2lXPiGH/RUCdTZFoqVyN7l1MnpIzPrGtLcijffmeouNlQ== - dependencies: - "@socket.io/component-emitter" "~3.1.0" - debug "~4.3.2" - engine.io-client "~6.5.2" - socket.io-parser "~4.2.4" - -socket.io-parser@~4.2.4: - version "4.2.4" - resolved "https://registry.yarnpkg.com/socket.io-parser/-/socket.io-parser-4.2.4.tgz#c806966cf7270601e47469ddeec30fbdfda44c83" - integrity sha512-/GbIKmo8ioc+NIWIhwdecY0ge+qVBSMdgxGygevmdHj24bsfgtCmcUUcQ5ZzcylGFHsN3k4HB4Cgkl96KVnuew== - dependencies: - "@socket.io/component-emitter" "~3.1.0" - debug "~4.3.1" - -socket.io@^4.4.1: - version "4.7.5" - resolved "https://registry.yarnpkg.com/socket.io/-/socket.io-4.7.5.tgz#56eb2d976aef9d1445f373a62d781a41c7add8f8" - integrity sha512-DmeAkF6cwM9jSfmp6Dr/5/mfMwb5Z5qRrSXLpo3Fq5SqyU8CMF15jIN4ZhfSwu35ksM1qmHZDQ/DK5XTccSTvA== - dependencies: - accepts "~1.3.4" - base64id "~2.0.0" - cors "~2.8.5" - debug "~4.3.2" - engine.io "~6.5.2" - socket.io-adapter "~2.5.2" - socket.io-parser "~4.2.4" - -sockjs@^0.3.24: - version "0.3.24" - resolved "https://registry.yarnpkg.com/sockjs/-/sockjs-0.3.24.tgz#c9bc8995f33a111bea0395ec30aa3206bdb5ccce" - integrity sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ== - dependencies: - faye-websocket "^0.11.3" - uuid "^8.3.2" - websocket-driver "^0.7.4" - socks-proxy-agent@6.1.1: version "6.1.1" - resolved "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-6.1.1.tgz#e664e8f1aaf4e1fb3df945f09e3d94f911137f87" + resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-6.1.1.tgz#e664e8f1aaf4e1fb3df945f09e3d94f911137f87" integrity sha512-t8J0kG3csjA4g6FTbsMOWws+7R7vuRC8aQ/wy3/1OWmsgwA68zs/+cExQ0koSitUDXqhufF/YJr9wtNMZHw5Ew== dependencies: agent-base "^6.0.2" debug "^4.3.1" socks "^2.6.1" -socks-proxy-agent@^6.0.0: - version "6.2.1" - resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-6.2.1.tgz#2687a31f9d7185e38d530bef1944fe1f1496d6ce" - integrity sha512-a6KW9G+6B3nWZ1yB8G7pJwL3ggLy1uTzKAgCb7ttblwqdz9fMGJUuTy3uFzEP48FAs9FLILlmzDlE2JJhVQaXQ== - dependencies: - agent-base "^6.0.2" - debug "^4.3.3" - socks "^2.6.2" - -socks-proxy-agent@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-7.0.0.tgz#dc069ecf34436621acb41e3efa66ca1b5fed15b6" - integrity sha512-Fgl0YPZ902wEsAyiQ+idGd1A7rSFx/ayC1CQVMw5P+EQx2V0SgpGtf6OKFhVjPflPUl9YMmEOnmfjCdMUsygww== - dependencies: - agent-base "^6.0.2" - debug "^4.3.3" - socks "^2.6.2" - socks@^2.6.1: - version "2.6.2" - resolved "https://registry.npmjs.org/socks/-/socks-2.6.2.tgz#ec042d7960073d40d94268ff3bb727dc685f111a" - integrity sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA== + version "2.8.3" + resolved "https://registry.yarnpkg.com/socks/-/socks-2.8.3.tgz#1ebd0f09c52ba95a09750afe3f3f9f724a800cb5" + integrity sha512-l5x7VUUWbjVFbafGLxPWkYsHIhEvmF85tbIeFZWc8ZPtoMyybuEhL7Jye/ooC4/d48FgOjSJXgsF/AJPYCW8Zw== dependencies: - ip "^1.1.5" - smart-buffer "^4.2.0" - -socks@^2.6.2: - version "2.7.1" - resolved "https://registry.yarnpkg.com/socks/-/socks-2.7.1.tgz#d8e651247178fde79c0663043e07240196857d55" - integrity sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ== - dependencies: - ip "^2.0.0" + ip-address "^9.0.5" smart-buffer "^4.2.0" sodium-native@^4.1.1: @@ -10709,186 +5222,67 @@ sodium-native@^4.1.1: dependencies: node-gyp-build "^4.8.0" -"solar-stellarorg@git+https://github.com/stellar/solar-stellarorg#master": - version "0.2.0" - resolved "git+https://github.com/stellar/solar-stellarorg#78ce86e856d21e77fab77b3767c1a224bfb7e9fe" - -"source-map-js@>=0.6.2 <2.0.0", source-map-js@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" - integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw== - -source-map-resolve@^0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.6.0.tgz#3d9df87e236b53f16d01e58150fc7711138e5ed2" - integrity sha512-KXBr9d/fO/bWo97NXsPIAW1bFSBOuCnjbNTBMO7N59hsv5i9yzRDfcYwwt0l04+VqnKC+EwzvJZIP/qkuMgR/w== - dependencies: - atob "^2.1.2" - decode-uri-component "^0.2.0" - -source-map-support@^0.5.16: - version "0.5.19" - resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61" - integrity sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw== - dependencies: - buffer-from "^1.0.0" - source-map "^0.6.0" - -source-map-support@~0.5.20: - version "0.5.21" - resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" - integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== - dependencies: - buffer-from "^1.0.0" - source-map "^0.6.0" - -source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.0: - version "0.6.1" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" - integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== - -source-map@^0.7.3: - version "0.7.3" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.3.tgz#5302f8169031735226544092e64981f751750383" - integrity sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ== - -source-map@^0.7.4: - version "0.7.4" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.4.tgz#a9bbe705c9d8846f4e08ff6765acf0f1b0898656" - integrity sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA== - -spdx-correct@^3.0.0: - version "3.1.1" - resolved "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-3.1.1.tgz#dece81ac9c1e6713e5f7d1b6f17d468fa53d89a9" - integrity sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w== - dependencies: - spdx-expression-parse "^3.0.0" - spdx-license-ids "^3.0.0" - -spdx-exceptions@^2.1.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz#3f28ce1a77a00372683eade4a433183527a2163d" - integrity sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A== - -spdx-expression-parse@^3.0.0, spdx-expression-parse@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz#cf70f50482eefdc98e3ce0a6833e4a53ceeba679" - integrity sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q== - dependencies: - spdx-exceptions "^2.1.0" - spdx-license-ids "^3.0.0" - -spdx-license-ids@^3.0.0: - version "3.0.10" - resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.10.tgz#0d9becccde7003d6c658d487dd48a32f0bf3014b" - integrity sha512-oie3/+gKf7QtpitB0LYLETe+k8SifzsX4KixvpOsbI6S0kRiRQ5MKOio8eMSAKQ17N06+wdEOXRiId+zOxo0hA== - -spdy-transport@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/spdy-transport/-/spdy-transport-3.0.0.tgz#00d4863a6400ad75df93361a1608605e5dcdcf31" - integrity sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw== - dependencies: - debug "^4.1.0" - detect-node "^2.0.4" - hpack.js "^2.1.6" - obuf "^1.1.2" - readable-stream "^3.0.6" - wbuf "^1.7.3" - -spdy@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/spdy/-/spdy-4.0.2.tgz#b74f466203a3eda452c02492b91fb9e84a27677b" - integrity sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA== - dependencies: - debug "^4.1.0" - handle-thing "^2.0.0" - http-deceiver "^1.2.7" - select-hose "^2.0.0" - spdy-transport "^3.0.0" - -sprintf-js@~1.0.2: - version "1.0.3" - resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" - integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw= - -ssri@^8.0.0, ssri@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/ssri/-/ssri-8.0.1.tgz#638e4e439e2ffbd2cd289776d5ca457c4f51a2af" - integrity sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ== - dependencies: - minipass "^3.1.1" - -ssri@^9.0.0: - version "9.0.1" - resolved "https://registry.yarnpkg.com/ssri/-/ssri-9.0.1.tgz#544d4c357a8d7b71a19700074b6883fcb4eae057" - integrity sha512-o57Wcn66jMQvfHG1FlYbWeZWW/dHZhJXjpIcTfXldXEk5nz5lStPo3mK0OJQfGR3RbZUlbISexbljkJzuEj/8Q== +sonic-boom@^2.2.1: + version "2.8.0" + resolved "https://registry.yarnpkg.com/sonic-boom/-/sonic-boom-2.8.0.tgz#c1def62a77425090e6ad7516aad8eb402e047611" + integrity sha512-kuonw1YOYYNOve5iHdSahXPOK49GqwA+LZhI6Wz/l0rP57iKyXXIHaRagOBHAPmGwJC6od2Z9zgvZ5loSgMlVg== dependencies: - minipass "^3.1.1" + atomic-sleep "^1.0.0" -statuses@2.0.1, statuses@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" - integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== +"source-map-js@>=0.6.2 <2.0.0", source-map-js@^1.0.2: + version "1.2.0" + resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.2.0.tgz#16b809c162517b5b8c3e7dcd315a2a5c2612b2af" + integrity sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg== -"statuses@>= 1.4.0 < 2", "statuses@>= 1.5.0 < 2": - version "1.5.0" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" - integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= +split-on-first@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/split-on-first/-/split-on-first-1.1.0.tgz#f610afeee3b12bce1d0c30425e76398b78249a5f" + integrity sha512-43ZssAJaMusuKWL8sKUBQXHWOpq8d6CfN/u1p4gUzfJkM05C8rxTmYrkIPTXapZpORA6LkkzcUulJ8FqA7Uudw== -statuses@~1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.3.1.tgz#faf51b9eb74aaef3b3acf4ad5f61abf24cb7b93e" - integrity sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4= +split2@^4.0.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/split2/-/split2-4.2.0.tgz#c9c5920904d148bab0b9f67145f245a86aadbfa4" + integrity sha512-UcjcJOWknrNkF6PLX83qcHM6KHgVKNkV62Y8a5uYDVv9ydGQVwAHMKqHdJje1VTWpljG0WYpCDhrCdAOYH4TWg== -statuses@~1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.4.0.tgz#bb73d446da2796106efcc1b601a253d6c46bd087" - integrity sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew== +sprintf-js@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.1.3.tgz#4914b903a2f8b685d17fdf78a70e917e872e444a" + integrity sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA== -stdout-stream@^1.4.0: - version "1.4.1" - resolved "https://registry.yarnpkg.com/stdout-stream/-/stdout-stream-1.4.1.tgz#5ac174cdd5cd726104aa0c0b2bd83815d8d535de" - integrity sha512-j4emi03KXqJWcIeF8eIXkjMFN1Cmb8gUlDYGeBALLPo5qdyTfA9bOtl8m33lRoC+vFMkP3gl0WsDr6+gzxbbTA== - dependencies: - readable-stream "^2.0.1" +std-env@^3.7.0: + version "3.7.0" + resolved "https://registry.yarnpkg.com/std-env/-/std-env-3.7.0.tgz#c9f7386ced6ecf13360b6c6c55b8aaa4ef7481d2" + integrity sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg== stream-browserify@^3.0.0: version "3.0.0" - resolved "https://registry.npmjs.org/stream-browserify/-/stream-browserify-3.0.0.tgz#22b0a2850cdf6503e73085da1fc7b7d0c2122f2f" + resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-3.0.0.tgz#22b0a2850cdf6503e73085da1fc7b7d0c2122f2f" integrity sha512-H73RAHsVBapbim0tU2JwwOiXUj+fikfiaoYAKHF3VJfA0pe2BCzkhAHBlLG6REzE+2WNZcxOXjK7lkso+9euLA== dependencies: inherits "~2.0.4" readable-stream "^3.5.0" -stream-http@^3.2.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-3.2.0.tgz#1872dfcf24cb15752677e40e5c3f9cc1926028b5" - integrity sha512-Oq1bLqisTyK3TSCXpPbT4sdeYNdmyZJv1LxpEm2vu1ZhK89kSE5YXwZc3cWk0MagGaKriBh9mCFbVGtO+vY29A== - dependencies: - builtin-status-codes "^3.0.0" - inherits "^2.0.4" - readable-stream "^3.6.0" - xtend "^4.0.2" +stream-shift@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/stream-shift/-/stream-shift-1.0.3.tgz#85b8fab4d71010fc3ba8772e8046cc49b8a3864b" + integrity sha512-76ORR0DO1o1hlKwTbi/DM3EXWGf3ZJYO8cXX5RJwnul2DEg2oyoZyjLNoQM8WsvZiFKCRfC1O0J7iCvie3RZmQ== -stream-throttle@^0.1.3: - version "0.1.3" - resolved "https://registry.yarnpkg.com/stream-throttle/-/stream-throttle-0.1.3.tgz#add57c8d7cc73a81630d31cd55d3961cfafba9c3" - integrity sha1-rdV8jXzHOoFjDTHNVdOWHPr7qcM= - dependencies: - commander "^2.2.0" - limiter "^1.0.5" +streamsearch@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/streamsearch/-/streamsearch-1.1.0.tgz#404dd1e2247ca94af554e841a8ef0eaa238da764" + integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg== -strict-event-emitter@^0.5.1: - version "0.5.1" - resolved "https://registry.yarnpkg.com/strict-event-emitter/-/strict-event-emitter-0.5.1.tgz#1602ece81c51574ca39c6815e09f1a3e8550bd93" - integrity sha512-vMgjE/GGEPEFnhFub6pa4FmJBRBVOLpIII2hvCZ8Kzb7K0hlHo7mQv6xYrBvCL2LtAIBwFUK8wvuJgTVSQ5MFQ== +strict-uri-encode@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/strict-uri-encode/-/strict-uri-encode-2.0.0.tgz#b9c7330c7042862f6b142dc274bbcc5866ce3546" + integrity sha512-QwiXZgpRcKkhTj2Scnn++4PKtWsH0kpzZ62L2R6c/LUVYv7hVnZqcg2+sMuT6R7Jusu1vviK/MFsu6kNJfWlEQ== -string-natural-compare@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/string-natural-compare/-/string-natural-compare-3.0.1.tgz#7a42d58474454963759e8e8b7ae63d71c1e7fdf4" - integrity sha512-n3sPwynL1nwKi3WJ6AIsClwBMa0zTi54fn2oLU6ndfTSIO05xaznjSf15PcBZU6FNWbmN5Q6cxT4V5hGvB4taw== +string-argv@~0.3.2: + version "0.3.2" + resolved "https://registry.yarnpkg.com/string-argv/-/string-argv-0.3.2.tgz#2b6d0ef24b656274d957d54e0a4bbf6153dc02b6" + integrity sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q== -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.2.3: +"string-width-cjs@npm:string-width@^4.2.0": version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -10898,73 +5292,77 @@ string-natural-compare@^3.0.1: strip-ansi "^6.0.1" string-width@^4.1.0, string-width@^4.2.0: - version "4.2.2" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.2.tgz#dafd4f9559a7585cfba529c6a0a4f73488ebd4c5" - integrity sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA== + version "4.2.3" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" + integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== dependencies: emoji-regex "^8.0.0" is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.0" + strip-ansi "^6.0.1" -string.prototype.matchall@^4.0.8: - version "4.0.10" - resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.10.tgz#a1553eb532221d4180c51581d6072cd65d1ee100" - integrity sha512-rGXbGmOEosIQi6Qva94HUjgPs9vKW+dkG7Y8Q5O2OYkWL6wFaTRZO8zM4mhP94uX55wgyrXzfS2aGtGzUL7EJQ== +string-width@^5.0.1, string-width@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-5.1.2.tgz#14f8daec6d81e7221d2a357e668cab73bdbca794" + integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" - get-intrinsic "^1.2.1" - has-symbols "^1.0.3" - internal-slot "^1.0.5" - regexp.prototype.flags "^1.5.0" - set-function-name "^2.0.0" - side-channel "^1.0.4" + eastasianwidth "^0.2.0" + emoji-regex "^9.2.2" + strip-ansi "^7.0.1" -string.prototype.trim@^1.2.8: - version "1.2.8" - resolved "https://registry.yarnpkg.com/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz#f9ac6f8af4bd55ddfa8895e6aea92a96395393bd" - integrity sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ== +string-width@^7.0.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-7.1.0.tgz#d994252935224729ea3719c49f7206dc9c46550a" + integrity sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" + emoji-regex "^10.3.0" + get-east-asian-width "^1.0.0" + strip-ansi "^7.1.0" -string.prototype.trimend@^1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.5.tgz#914a65baaab25fbdd4ee291ca7dde57e869cb8d0" - integrity sha512-I7RGvmjV4pJ7O3kdf+LXFpVfdNOxtCW/2C8f6jNiW4+PQchwxkCDzlk1/7p+Wl4bqFIZeF47qAHXLuHHWKAxog== +string.prototype.matchall@^4.0.11: + version "4.0.11" + resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz#1092a72c59268d2abaad76582dccc687c0297e0a" + integrity sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg== dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.19.5" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.2" + es-errors "^1.3.0" + es-object-atoms "^1.0.0" + get-intrinsic "^1.2.4" + gopd "^1.0.1" + has-symbols "^1.0.3" + internal-slot "^1.0.7" + regexp.prototype.flags "^1.5.2" + set-function-name "^2.0.2" + side-channel "^1.0.6" -string.prototype.trimend@^1.0.7: - version "1.0.7" - resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz#1bb3afc5008661d73e2dc015cd4853732d6c471e" - integrity sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA== +string.prototype.trim@^1.2.9: + version "1.2.9" + resolved "https://registry.yarnpkg.com/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz#b6fa326d72d2c78b6df02f7759c73f8f6274faa4" + integrity sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.23.0" + es-object-atoms "^1.0.0" -string.prototype.trimstart@^1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.5.tgz#5466d93ba58cfa2134839f81d7f42437e8c01fef" - integrity sha512-THx16TJCGlsN0o6dl2o6ncWUsdgnLRSA23rRE5pyGBw/mLr3Ej/R2LaqCtgP8VNMGZsvMWnf9ooZPyY2bHvUFg== +string.prototype.trimend@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz#3651b8513719e8a9f48de7f2f77640b26652b229" + integrity sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ== dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.19.5" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-object-atoms "^1.0.0" -string.prototype.trimstart@^1.0.7: - version "1.0.7" - resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz#d4cdb44b83a4737ffbac2d406e405d43d0184298" - integrity sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg== +string.prototype.trimstart@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz#7ee834dda8c7c17eff3118472bb35bfedaa34dde" + integrity sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg== dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.22.1" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-object-atoms "^1.0.0" string_decoder@^1.1.1: version "1.3.0" @@ -10973,92 +5371,68 @@ string_decoder@^1.1.1: dependencies: safe-buffer "~5.2.0" -string_decoder@~1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" - integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== - dependencies: - safe-buffer "~5.1.0" - -strip-ansi@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" - integrity sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8= - dependencies: - ansi-regex "^2.0.0" - -strip-ansi@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" - integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== +"strip-ansi-cjs@npm:strip-ansi@^6.0.1": + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== dependencies: - ansi-regex "^5.0.0" + ansi-regex "^5.0.1" -strip-ansi@^6.0.1: +strip-ansi@^6.0.0, strip-ansi@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== dependencies: ansi-regex "^5.0.1" +strip-ansi@^7.0.1, strip-ansi@^7.1.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.1.0.tgz#d5b6568ca689d8561370b0707685d22434faff45" + integrity sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ== + dependencies: + ansi-regex "^6.0.1" + strip-bom@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" - integrity sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM= - -strip-final-newline@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" - integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== + integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== -strip-indent@^3.0.0: +strip-final-newline@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/strip-indent/-/strip-indent-3.0.0.tgz#c32e1cee940b6b3432c771bc2c54bcce73cd3001" - integrity sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ== - dependencies: - min-indent "^1.0.0" + resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-3.0.0.tgz#52894c313fbff318835280aed60ff71ebf12b8fd" + integrity sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw== -strip-json-comments@3.1.1, strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: +strip-json-comments@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== -style-loader@^3.3.3: - version "3.3.3" - resolved "https://registry.yarnpkg.com/style-loader/-/style-loader-3.3.3.tgz#bba8daac19930169c0c9c96706749a597ae3acff" - integrity sha512-53BiGLXAcll9maCYtZi2RCQZKa8NQQai5C4horqKyRmHj9H7QmcUyucrH+4KW/gBQbXM2AsB0axoEcFZPlfPcw== +style-to-js@1.1.12: + version "1.1.12" + resolved "https://registry.yarnpkg.com/style-to-js/-/style-to-js-1.1.12.tgz#112dd054231e71643514013a4475d4649bb2b581" + integrity sha512-tv+/FkgNYHI2fvCoBMsqPHh5xovwiw+C3X0Gfnss/Syau0Nr3IqGOJ9XiOYXoPnToHVbllKFf5qCNFJGwFg5mg== + dependencies: + style-to-object "1.0.6" -style-to-js@1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/style-to-js/-/style-to-js-1.1.0.tgz#631cbb20fce204019b3aa1fcb5b69d951ceac4ac" - integrity sha512-1OqefPDxGrlMwcbfpsTVRyzwdhr4W0uxYQzeA2F1CBc8WG04udg2+ybRnvh3XYL4TdHQrCahLtax2jc8xaE6rA== +style-to-object@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/style-to-object/-/style-to-object-1.0.6.tgz#0c28aed8be1813d166c60d962719b2907c26547b" + integrity sha512-khxq+Qm3xEyZfKd/y9L3oIWQimxuc4STrQKtQn8aSDRHb8mFgpukgX1hdzfrMEW6JCjyJ8p89x+IUMVnCBI1PA== dependencies: - style-to-object "0.3.0" + inline-style-parser "0.2.3" -style-to-object@0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/style-to-object/-/style-to-object-0.3.0.tgz#b1b790d205991cc783801967214979ee19a76e46" - integrity sha512-CzFnRRXhzWIdItT3OmF8SQfWyahHhjq3HwcMNCNLn+N7klOOqPjMeG/4JSu77D7ypZdGvSzvkrbyeTMizz2VrA== +styled-jsx@5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/styled-jsx/-/styled-jsx-5.1.1.tgz#839a1c3aaacc4e735fed0781b8619ea5d0009d1f" + integrity sha512-pW7uC1l4mBZ8ugbiZrcIsiIvVx1UmTfw7UkC3Um2tmfUq9Bhk8IiyEIPl6F8agHgjzku6j0xQEZbfA5uSgSaCw== dependencies: - inline-style-parser "0.1.1" + client-only "0.0.1" superstruct@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/superstruct/-/superstruct-1.0.4.tgz#0adb99a7578bd2f1c526220da6571b2d485d91ca" integrity sha512-7JpaAoX2NGyoFlI9NBh66BQXGONc+uE+MRS5i2iOBKuS4e+ccgMDjATgZldkah+33DakBxDHiss9kvUcGAO8UQ== -supports-color@8.1.1, supports-color@^8.0.0: - version "8.1.1" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" - integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== - dependencies: - has-flag "^4.0.0" - -supports-color@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7" - integrity sha1-U10EXOa2Nj+kARcIRimZXp3zJMc= - supports-color@^5.3.0: version "5.5.0" resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" @@ -11078,78 +5452,16 @@ supports-preserve-symlinks-flag@^1.0.0: resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== -table@^6.0.9: - version "6.7.1" - resolved "https://registry.yarnpkg.com/table/-/table-6.7.1.tgz#ee05592b7143831a8c94f3cee6aae4c1ccef33e2" - integrity sha512-ZGum47Yi6KOOFDE8m223td53ath2enHcYLgOCjGr5ngu8bdIARQk6mN/wRMv4yMRcHnCSnHbCEha4sobQx5yWg== - dependencies: - ajv "^8.0.1" - lodash.clonedeep "^4.5.0" - lodash.truncate "^4.4.2" - slice-ansi "^4.0.0" - string-width "^4.2.0" - strip-ansi "^6.0.0" +system-architecture@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/system-architecture/-/system-architecture-0.1.0.tgz#71012b3ac141427d97c67c56bc7921af6bff122d" + integrity sha512-ulAk51I9UVUyJgxlv9M6lFot2WP3e7t8Kz9+IS6D4rVba1tR9kON+Ey69f+1R4Q8cd45Lod6a4IcJIxnzGc/zA== -tapable@^2.0.0, tapable@^2.1.1, tapable@^2.2.0, tapable@^2.2.1: +tapable@^2.2.0: version "2.2.1" resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.2.1.tgz#1967a73ef4060a82f12ab96af86d52fdb76eeca0" integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== -tar@^6.0.2: - version "6.1.8" - resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.8.tgz#4fc50cfe56511c538ce15b71e05eebe66530cbd4" - integrity sha512-sb9b0cp855NbkMJcskdSYA7b11Q8JsX4qe4pyUAfHp+Y6jBjJeek2ZVlwEfWayshEIwlIzXx0Fain3QG9JPm2A== - dependencies: - chownr "^2.0.0" - fs-minipass "^2.0.0" - minipass "^3.0.0" - minizlib "^2.1.1" - mkdirp "^1.0.3" - yallist "^4.0.0" - -tar@^6.1.11, tar@^6.1.2: - version "6.2.0" - resolved "https://registry.yarnpkg.com/tar/-/tar-6.2.0.tgz#b14ce49a79cb1cd23bc9b016302dea5474493f73" - integrity sha512-/Wo7DcT0u5HUV486xg675HtjNd3BXZ6xDbzsCUZPt5iw8bTQ63bP0Raut3mvro9u+CUyq7YQd8Cx55fsZXxqLQ== - dependencies: - chownr "^2.0.0" - fs-minipass "^2.0.0" - minipass "^5.0.0" - minizlib "^2.1.1" - mkdirp "^1.0.3" - yallist "^4.0.0" - -terser-webpack-plugin@^5.3.10: - version "5.3.10" - resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz#904f4c9193c6fd2a03f693a2150c62a92f40d199" - integrity sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w== - dependencies: - "@jridgewell/trace-mapping" "^0.3.20" - jest-worker "^27.4.5" - schema-utils "^3.1.1" - serialize-javascript "^6.0.1" - terser "^5.26.0" - -terser@^5.10.0: - version "5.26.0" - resolved "https://registry.yarnpkg.com/terser/-/terser-5.26.0.tgz#ee9f05d929f4189a9c28a0feb889d96d50126fe1" - integrity sha512-dytTGoE2oHgbNV9nTzgBEPaqAWvcJNl66VZ0BkJqlvp71IjO8CxdBx/ykCNb47cLnCmCvRZ6ZR0tLkqvZCdVBQ== - dependencies: - "@jridgewell/source-map" "^0.3.3" - acorn "^8.8.2" - commander "^2.20.0" - source-map-support "~0.5.20" - -terser@^5.26.0: - version "5.31.1" - resolved "https://registry.yarnpkg.com/terser/-/terser-5.31.1.tgz#735de3c987dd671e95190e6b98cfe2f07f3cf0d4" - integrity sha512-37upzU1+viGvuFtBo9NPufCb9dwM0+l9hMxYyWfBA+fbwrPqNJAhbZ6W47bBFnZHKHTUBnMvi87434qq+qnxOg== - dependencies: - "@jridgewell/source-map" "^0.3.3" - acorn "^8.8.2" - commander "^2.20.0" - source-map-support "~0.5.20" - text-encoding-utf-8@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/text-encoding-utf-8/-/text-encoding-utf-8-1.0.2.tgz#585b62197b0ae437e3c7b5d0af27ac1021e10d13" @@ -11158,21 +5470,23 @@ text-encoding-utf-8@^1.0.2: text-table@^0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" - integrity sha1-f17oI66AUgfACvLfSoTsP8+lcLQ= + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + +thread-stream@^0.15.1: + version "0.15.2" + resolved "https://registry.yarnpkg.com/thread-stream/-/thread-stream-0.15.2.tgz#fb95ad87d2f1e28f07116eb23d85aba3bc0425f4" + integrity sha512-UkEhKIg2pD+fjkHQKyJO3yoIvAP3N6RlNFt2dUhcS1FGvCD1cQa1M/PGknCLFIyZdtJOWQjejp7bdNqmN7zwdA== + dependencies: + real-require "^0.1.0" "through@>=2.2.7 <3": version "2.3.8" resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" - integrity sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU= - -thunky@^1.0.2: - version "1.1.0" - resolved "https://registry.yarnpkg.com/thunky/-/thunky-1.1.0.tgz#5abaf714a9405db0504732bbccd2cedd9ef9537d" - integrity sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA== + integrity sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg== tiny-secp256k1@^1.1.6: version "1.1.6" - resolved "https://registry.npmjs.org/tiny-secp256k1/-/tiny-secp256k1-1.1.6.tgz#7e224d2bee8ab8283f284e40e6b4acb74ffe047c" + resolved "https://registry.yarnpkg.com/tiny-secp256k1/-/tiny-secp256k1-1.1.6.tgz#7e224d2bee8ab8283f284e40e6b4acb74ffe047c" integrity sha512-FmqJZGduTyvsr2cF3375fqGHUovSwDi/QytexX1Se4BPuPZpTE5Ftp5fg+EFSuEf3lhZqgCRjEG3ydUQ/aNiwA== dependencies: bindings "^1.3.0" @@ -11181,15 +5495,10 @@ tiny-secp256k1@^1.1.6: elliptic "^6.4.0" nan "^2.13.2" -to-fast-properties@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-1.0.3.tgz#b83571fa4d8c25b82e231b06e3a3055de4ca1a47" - integrity sha512-lxrWP8ejsq+7E3nNjwYmUBMAgjMTZoTI+sdBOpvNyijeDLa29LUn9QaoXAHv4+Z578hbmHHJKZknzxVtvo77og== - to-fast-properties@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" - integrity sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4= + integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== to-regex-range@^5.0.1: version "5.0.1" @@ -11198,15 +5507,10 @@ to-regex-range@^5.0.1: dependencies: is-number "^7.0.0" -toidentifier@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" - integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== - -toidentifier@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" - integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== +toggle-selection@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/toggle-selection/-/toggle-selection-1.0.6.tgz#6e45b1263f2017fa0acc7d89d78b15b8bf77da32" + integrity sha512-BiZS+C1OS8g/q2RRbJmy59xpyghNBqrr6k5L/uKBGRsTfxmu3ffiRnd8mlGPUVayg8pvfi5urfnu8TU7DVOkLQ== toml@^3.0.0: version "3.0.0" @@ -11216,83 +5520,42 @@ toml@^3.0.0: tr46@~0.0.3: version "0.0.3" resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" - integrity sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o= - -trim-newlines@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/trim-newlines/-/trim-newlines-3.0.1.tgz#260a5d962d8b752425b32f3a7db0dcacd176c144" - integrity sha512-c1PTsA3tYrIsLGkJkzHF+w9F2EyxfXGo4UyJc4pFL++FMjnq0HJS69T3M7d//gKrFKwy429bouPescbjecU+Zw== + integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== -"true-case-path@^2.2.1": - version "2.2.1" - resolved "https://registry.yarnpkg.com/true-case-path/-/true-case-path-2.2.1.tgz#c5bf04a5bbec3fd118be4084461b3a27c4d796bf" - integrity sha512-0z3j8R7MCjy10kc/g+qg7Ln3alJTodw9aDuVWZa3uiWqfuBMKeAeP2ocWcxoyM3D73yz3Jt/Pu4qPr4wHSdB/Q== - -ts-loader@^9.4.3: - version "9.5.1" - resolved "https://registry.yarnpkg.com/ts-loader/-/ts-loader-9.5.1.tgz#63d5912a86312f1fbe32cef0859fb8b2193d9b89" - integrity sha512-rNH3sK9kGZcH9dYzC7CewQm4NtxJTjSEVRJ2DyBZR7f8/wcta+iV44UPCXc5+nzDzivKtlzV6c9P4e+oFhDLYg== - dependencies: - chalk "^4.1.0" - enhanced-resolve "^5.0.0" - micromatch "^4.0.0" - semver "^7.3.4" - source-map "^0.7.4" +ts-api-utils@^1.0.1, ts-api-utils@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-1.3.0.tgz#4b490e27129f1e8e686b45cc4ab63714dc60eea1" + integrity sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ== ts-mixer@^6.0.3: version "6.0.4" resolved "https://registry.yarnpkg.com/ts-mixer/-/ts-mixer-6.0.4.tgz#1da39ceabc09d947a82140d9f09db0f84919ca28" integrity sha512-ufKpbmrugz5Aou4wcr5Wc1UUFWOLhq+Fm6qa6P0w0K5Qw2yhaUoiWszhCVuNQyNwrlGiscHOmqYoAox1PtvgjA== -tsconfig-paths-webpack-plugin@^4.0.1: - version "4.1.0" - resolved "https://registry.yarnpkg.com/tsconfig-paths-webpack-plugin/-/tsconfig-paths-webpack-plugin-4.1.0.tgz#3c6892c5e7319c146eee1e7302ed9e6f2be4f763" - integrity sha512-xWFISjviPydmtmgeUAuXp4N1fky+VCtfhOkDUFIv5ea7p4wuTomI4QTrXvFBX2S4jZsmyTSrStQl+E+4w+RzxA== - dependencies: - chalk "^4.1.0" - enhanced-resolve "^5.7.0" - tsconfig-paths "^4.1.2" - -tsconfig-paths@^3.14.2: - version "3.14.2" - resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.14.2.tgz#6e32f1f79412decd261f92d633a9dc1cfa99f088" - integrity sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g== +tsconfig-paths@^3.15.0: + version "3.15.0" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz#5299ec605e55b1abb23ec939ef15edaf483070d4" + integrity sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg== dependencies: "@types/json5" "^0.0.29" json5 "^1.0.2" minimist "^1.2.6" strip-bom "^3.0.0" -tsconfig-paths@^4.1.2: - version "4.2.0" - resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz#ef78e19039133446d244beac0fd6a1632e2d107c" - integrity sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg== - dependencies: - json5 "^2.2.2" - minimist "^1.2.6" - strip-bom "^3.0.0" - -tslib@^1.8.1: +tslib@1.14.1: version "1.14.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== -tslib@^2.0.3: - version "2.3.1" - resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.3.1.tgz#e8a335add5ceae51aa261d32a490158ef042ef01" - integrity sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw== - -tslib@^2.1.0, tslib@^2.4.0: +tslib@^2.1.0, tslib@^2.3.1, tslib@^2.4.0, tslib@^2.6.2: version "2.6.3" resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.3.tgz#0438f810ad7a9edcde7a241c3d80db693c8cbfe0" integrity sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ== -tsutils@^3.21.0: - version "3.21.0" - resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" - integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== - dependencies: - tslib "^1.8.1" +tweetnacl-util@^0.15.1: + version "0.15.1" + resolved "https://registry.yarnpkg.com/tweetnacl-util/-/tweetnacl-util-0.15.1.tgz#b80fcdb5c97bcc508be18c44a4be50f022eea00b" + integrity sha512-RKJBIj8lySrShN4w6i/BonWp2Z/uxwC3h4y7xsRrpP59ZboCd0GpEVsOnMDYLMmKBpYhb5TgHzZXy7wTfYFBRw== tweetnacl@^1.0.3: version "1.0.3" @@ -11306,111 +5569,85 @@ type-check@^0.4.0, type-check@~0.4.0: dependencies: prelude-ls "^1.2.1" -type-detect@^4.0.0, type-detect@^4.0.5: - version "4.0.8" - resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" - integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== - -type-fest@^0.18.0: - version "0.18.1" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.18.1.tgz#db4bc151a4a2cf4eebf9add5db75508db6cc841f" - integrity sha512-OIAYXk8+ISY+qTOwkHtKqzAuxchoMiD9Udx+FSGQDuiRR+PJKJHc2NJAXlbhkGwTt/4/nKZxELY1w3ReWOL8mw== - type-fest@^0.20.2: version "0.20.2" resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== -type-fest@^0.21.3: - version "0.21.3" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37" - integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== - -type-fest@^0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.6.0.tgz#8d2a2370d3df886eb5c90ada1c5bf6188acf838b" - integrity sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg== - -type-fest@^0.8.1: - version "0.8.1" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" - integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== - -type-fest@^4.9.0: - version "4.20.0" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-4.20.0.tgz#019becf5a97cd58eee93f592f0961859a74482a7" - integrity sha512-MBh+PHUHHisjXf4tlx0CFWoMdjx8zCMLJHOjnV1prABYZFHqtFOyauCIK2/7w4oIfwkF8iNhLtnJEfVY2vn3iw== - -type-is@~1.6.18: - version "1.6.18" - resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" - integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== - dependencies: - media-typer "0.3.0" - mime-types "~2.1.24" - -typed-array-buffer@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz#18de3e7ed7974b0a729d3feecb94338d1472cd60" - integrity sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw== +typed-array-buffer@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz#1867c5d83b20fcb5ccf32649e5e2fc7424474ff3" + integrity sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ== dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.2.1" - is-typed-array "^1.1.10" + call-bind "^1.0.7" + es-errors "^1.3.0" + is-typed-array "^1.1.13" -typed-array-byte-length@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz#d787a24a995711611fb2b87a4052799517b230d0" - integrity sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA== +typed-array-byte-length@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz#d92972d3cff99a3fa2e765a28fcdc0f1d89dec67" + integrity sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw== dependencies: - call-bind "^1.0.2" + call-bind "^1.0.7" for-each "^0.3.3" - has-proto "^1.0.1" - is-typed-array "^1.1.10" + gopd "^1.0.1" + has-proto "^1.0.3" + is-typed-array "^1.1.13" -typed-array-byte-offset@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz#cbbe89b51fdef9cd6aaf07ad4707340abbc4ea0b" - integrity sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg== +typed-array-byte-offset@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz#f9ec1acb9259f395093e4567eb3c28a580d02063" + integrity sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA== dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" + available-typed-arrays "^1.0.7" + call-bind "^1.0.7" for-each "^0.3.3" - has-proto "^1.0.1" - is-typed-array "^1.1.10" + gopd "^1.0.1" + has-proto "^1.0.3" + is-typed-array "^1.1.13" -typed-array-length@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/typed-array-length/-/typed-array-length-1.0.4.tgz#89d83785e5c4098bec72e08b319651f0eac9c1bb" - integrity sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng== +typed-array-length@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/typed-array-length/-/typed-array-length-1.0.6.tgz#57155207c76e64a3457482dfdc1c9d1d3c4c73a3" + integrity sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g== dependencies: - call-bind "^1.0.2" + call-bind "^1.0.7" for-each "^0.3.3" - is-typed-array "^1.1.9" + gopd "^1.0.1" + has-proto "^1.0.3" + is-typed-array "^1.1.13" + possible-typed-array-names "^1.0.0" typeforce@^1.18.0: version "1.18.0" - resolved "https://registry.npmjs.org/typeforce/-/typeforce-1.18.0.tgz#d7416a2c5845e085034d70fcc5b6cc4a90edbfdc" + resolved "https://registry.yarnpkg.com/typeforce/-/typeforce-1.18.0.tgz#d7416a2c5845e085034d70fcc5b6cc4a90edbfdc" integrity sha512-7uc1O8h1M1g0rArakJdf0uLRSSgFcYexrVoKo+bzJd32gd4gDy2L/Z+8/FjPnU9ydY3pEnVPtr9FyscYY60K1g== -typescript@^5.3.3: - version "5.3.3" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.3.3.tgz#b3ce6ba258e72e6305ba66f5c9b452aaee3ffe37" - integrity sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw== +typescript@^5.4.5: + version "5.4.5" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.4.5.tgz#42ccef2c571fdbd0f6718b1d1f5e6e5ef006f611" + integrity sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ== -ua-parser-js@^1.0.33: +ua-parser-js@^1.0.37: version "1.0.38" resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-1.0.38.tgz#66bb0c4c0e322fe48edfe6d446df6042e62f25e2" integrity sha512-Aq5ppTOfvrCMgAPneW1HfWj66Xi7XL+/mIy996R1/CLS/rcyJQm6QZdsKrUeivDFQ+Oc9Wyuwor8Ze8peEoUoQ== -ua-parser-js@^1.0.37: - version "1.0.37" - resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-1.0.37.tgz#b5dc7b163a5c1f0c510b08446aed4da92c46373f" - integrity sha512-bhTyI94tZofjo+Dn8SN6Zv8nBDvyXTymAdM3LDI/0IboIUwTu1rEhW7v2TfiVsoYWgkQ4kOVqnI8APUFbIQIFQ== +ufo@^1.4.0, ufo@^1.5.3: + version "1.5.3" + resolved "https://registry.yarnpkg.com/ufo/-/ufo-1.5.3.tgz#3325bd3c977b6c6cd3160bf4ff52989adc9d3344" + integrity sha512-Y7HYmWaFwPUmkoQCUIAYpKqkOf+SbVj/2fJJZ4RJMCfZp0rTGwRbzQD+HghfnhKOjL9E01okqz+ncJskGYfBNw== + +uint8arrays@^3.0.0, uint8arrays@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/uint8arrays/-/uint8arrays-3.1.1.tgz#2d8762acce159ccd9936057572dade9459f65ae0" + integrity sha512-+QJa8QRnbdXVpHYjLoTpJIdCTiw9Ir62nocClWuXIq2JIh4Uta0cQsTSpFL678p2CN8B+XSApwcU+pQEqVpKWg== + dependencies: + multiformats "^9.4.2" unbox-primitive@^1.0.2: version "1.0.2" - resolved "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" + resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" integrity sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw== dependencies: call-bind "^1.0.2" @@ -11418,92 +5655,61 @@ unbox-primitive@^1.0.2: has-symbols "^1.0.3" which-boxed-primitive "^1.0.2" +uncrypto@^0.1.3: + version "0.1.3" + resolved "https://registry.yarnpkg.com/uncrypto/-/uncrypto-0.1.3.tgz#e1288d609226f2d02d8d69ee861fa20d8348ef2b" + integrity sha512-Ql87qFHB3s/De2ClA9e0gsnS6zXG27SkTiSJwjCc9MebbfapQfuPzumMIUMi38ezPZVNFcHI9sUIepeQfw8J8Q== + undici-types@~5.26.4: version "5.26.5" resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-5.26.5.tgz#bcd539893d00b56e964fd2657a4866b221a65617" integrity sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA== -unicode-canonical-property-names-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz#301acdc525631670d39f6146e0e77ff6bbdebddc" - integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== - -unicode-match-property-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz#54fd16e0ecb167cf04cf1f756bdcc92eba7976c3" - integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== - dependencies: - unicode-canonical-property-names-ecmascript "^2.0.0" - unicode-property-aliases-ecmascript "^2.0.0" - -unicode-match-property-value-ecmascript@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz#cb5fffdcd16a05124f5a4b0bf7c3770208acbbe0" - integrity sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA== - -unicode-property-aliases-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz#0a36cb9a585c4f6abd51ad1deddb285c165297c8" - integrity sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ== - -unique-filename@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-1.1.1.tgz#1d69769369ada0583103a1e6ae87681b56573230" - integrity sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ== - dependencies: - unique-slug "^2.0.0" - -unique-filename@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-2.0.1.tgz#e785f8675a9a7589e0ac77e0b5c34d2eaeac6da2" - integrity sha512-ODWHtkkdx3IAR+veKxFV+VBkUMcN+FaqzUUd7IZzt+0zhDZFPFxhlqwPF3YQvMHx1TD0tdgYl+kuPnJ8E6ql7A== +unenv@^1.9.0: + version "1.9.0" + resolved "https://registry.yarnpkg.com/unenv/-/unenv-1.9.0.tgz#469502ae85be1bd3a6aa60f810972b1a904ca312" + integrity sha512-QKnFNznRxmbOF1hDgzpqrlIf6NC5sbZ2OJ+5Wl3OX8uM+LUJXbj4TXvLJCtwbPTmbMHCLIz6JLKNinNsMShK9g== dependencies: - unique-slug "^3.0.0" + consola "^3.2.3" + defu "^6.1.3" + mime "^3.0.0" + node-fetch-native "^1.6.1" + pathe "^1.1.1" -unique-slug@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-2.0.2.tgz#baabce91083fc64e945b0f3ad613e264f7cd4e6c" - integrity sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w== - dependencies: - imurmurhash "^0.1.4" +unfetch@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/unfetch/-/unfetch-4.2.0.tgz#7e21b0ef7d363d8d9af0fb929a5555f6ef97a3be" + integrity sha512-F9p7yYCn6cIW9El1zi0HI6vqpeIvBsr3dSuRO6Xuppb1u5rXpCPmMvLSyECLhybr9isec8Ohl0hPekMVrEinDA== -unique-slug@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-3.0.0.tgz#6d347cf57c8a7a7a6044aabd0e2d74e4d76dc7c9" - integrity sha512-8EyMynh679x/0gqE9fT9oilG+qEt+ibFyqjuVTsZn1+CMxH+XLlpvr2UZx4nVcCwTpx81nICr2JQFkM+HPLq4w== +unstorage@^1.9.0: + version "1.10.2" + resolved "https://registry.yarnpkg.com/unstorage/-/unstorage-1.10.2.tgz#fb7590ada8b30e83be9318f85100158b02a76dae" + integrity sha512-cULBcwDqrS8UhlIysUJs2Dk0Mmt8h7B0E6mtR+relW9nZvsf/u4SkAYyNliPiPW7XtFNb5u3IUMkxGxFTTRTgQ== + dependencies: + anymatch "^3.1.3" + chokidar "^3.6.0" + destr "^2.0.3" + h3 "^1.11.1" + listhen "^1.7.2" + lru-cache "^10.2.0" + mri "^1.2.0" + node-fetch-native "^1.6.2" + ofetch "^1.3.3" + ufo "^1.4.0" + +untun@^0.1.3: + version "0.1.3" + resolved "https://registry.yarnpkg.com/untun/-/untun-0.1.3.tgz#5d10dee37a3a5737ff03d158be877dae0a0e58a6" + integrity sha512-4luGP9LMYszMRZwsvyUd9MrxgEGZdZuZgpVQHEEX0lCYFESasVRvZd0EYpCkOIbJKHMuv0LskpXc/8Un+MJzEQ== dependencies: - imurmurhash "^0.1.4" + citty "^0.1.5" + consola "^3.2.3" + pathe "^1.1.1" -universalify@^0.1.0: +uqr@^0.1.2: version "0.1.2" - resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" - integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== - -universalify@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" - integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== - -unpipe@1.0.0, unpipe@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" - integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= - -update-browserslist-db@^1.0.13: - version "1.0.13" - resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz#3c5e4f5c083661bd38ef64b6328c26ed6c8248c4" - integrity sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg== - dependencies: - escalade "^3.1.1" - picocolors "^1.0.0" - -update-browserslist-db@^1.0.16: - version "1.0.16" - resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.16.tgz#f6d489ed90fb2f07d67784eb3f53d7891f736356" - integrity sha512-KVbTxlBYlckhF5wgfyZXTWnMn7MMZjMu9XG8bPlliUOP9ThaF4QnhP8qrjrH7DRzHfSk0oQv1wToW+iA5GajEQ== - dependencies: - escalade "^3.1.2" - picocolors "^1.0.1" + resolved "https://registry.yarnpkg.com/uqr/-/uqr-0.1.2.tgz#5c6cd5dcff9581f9bb35b982cb89e2c483a41d7d" + integrity sha512-MJu7ypHq6QasgF5YRTjqscSzQp/W11zoUk6kvmlH+fmWEs63Y0Eib13hYFwAzagRJcVY8WVnlV+eBDUGMJ5IbA== uri-js@^4.2.2: version "4.4.1" @@ -11512,33 +5718,25 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" -uri-templates@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/uri-templates/-/uri-templates-0.2.0.tgz#2b5784511cc909868731e9233c268097d10b499f" - integrity sha1-K1eEURzJCYaHMekjPCaAl9ELSZ8= - -urijs@^1.19.1, urijs@^1.19.11: +urijs@^1.19.1: version "1.19.11" resolved "https://registry.yarnpkg.com/urijs/-/urijs-1.19.11.tgz#204b0d6b605ae80bea54bea39280cdb7c9f923cc" integrity sha512-HXgFDgDommxn5/bIv0cnQZsPhHDA90NPHD6+c/v21U5+Sx5hoP8+dP9IZXBU1gIfvdRfhG8cel9QNPeionfcCQ== -url@^0.11.1: - version "0.11.3" - resolved "https://registry.yarnpkg.com/url/-/url-0.11.3.tgz#6f495f4b935de40ce4a0a52faee8954244f3d3ad" - integrity sha512-6hxOLGfZASQK/cijlZnZJTq8OXAkt/3YGfQX45vvMYXpZoo8NdWZcY73K108Jf759lS1Bv/8wXnHDTSz17dSRw== - dependencies: - punycode "^1.4.1" - qs "^6.11.2" - usb@^2.11.0: - version "2.12.1" - resolved "https://registry.yarnpkg.com/usb/-/usb-2.12.1.tgz#f7a68ddb1314d56758e3e3b1265bc467922a9503" - integrity sha512-hgtoSQUFuMXVJBApelpUTiX7ZB83MQCbYeHTBsHftA2JG7YZ76ycwIgKQhkhKqVY76C8K6xJscHpF7Ep0eG3pQ== + version "2.13.0" + resolved "https://registry.yarnpkg.com/usb/-/usb-2.13.0.tgz#521d11244cbe991a3f247c770821635abdcc9c7f" + integrity sha512-pTNKyxD1DfC1DYu8kFcIdpE8f33e0c2Sbmmi0HEs28HTVC555uocvYR1g5DDv4CBibacCh4BqRyYZJylN4mBbw== dependencies: "@types/w3c-web-usb" "^1.0.6" - node-addon-api "^7.0.0" + node-addon-api "^8.0.0" node-gyp-build "^4.5.0" +use-sync-external-store@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz#7dbefd6ef3fe4e767a0cf5d7287aacfb5846928a" + integrity sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA== + utf-8-validate@^5.0.2: version "5.0.10" resolved "https://registry.yarnpkg.com/utf-8-validate/-/utf-8-validate-5.0.10.tgz#d7d10ea39318171ca982718b6b96a8d2442571a2" @@ -11546,22 +5744,10 @@ utf-8-validate@^5.0.2: dependencies: node-gyp-build "^4.3.0" -util-deprecate@^1.0.1, util-deprecate@^1.0.2, util-deprecate@~1.0.1: +util-deprecate@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" - integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= - -util@^0.12.0: - version "0.12.4" - resolved "https://registry.npmjs.org/util/-/util-0.12.4.tgz#66121a31420df8f01ca0c464be15dfa1d1850253" - integrity sha512-bxZ9qtSlGUWSOy9Qa9Xgk11kSslpuZwaxCg4sNIDj6FLucDab2JxnHwyNTCpHMtK1MjoQiWQ6DiUMZYbSrO+Sw== - dependencies: - inherits "^2.0.3" - is-arguments "^1.0.4" - is-generator-function "^1.0.7" - is-typed-array "^1.1.3" - safe-buffer "^5.1.2" - which-typed-array "^1.1.2" + integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== util@^0.12.5: version "0.12.5" @@ -11574,194 +5760,35 @@ util@^0.12.5: is-typed-array "^1.1.3" which-typed-array "^1.1.2" -utila@~0.4: - version "0.4.0" - resolved "https://registry.yarnpkg.com/utila/-/utila-0.4.0.tgz#8a16a05d445657a3aea5eecc5b12a4fa5379772c" - integrity sha1-ihagXURWV6Oupe7MWxKk+lN5dyw= - -utils-merge@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" - integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= - uuid@^8.3.2: version "8.3.2" resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== -v8-compile-cache@^2.0.3: - version "2.3.0" - resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" - integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== - -validate-npm-package-license@^3.0.1: - version "3.0.4" - resolved "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz#fc91f6b9c7ba15c857f4cb2c5defeec39d4f410a" - integrity sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew== +valtio@1.11.2: + version "1.11.2" + resolved "https://registry.yarnpkg.com/valtio/-/valtio-1.11.2.tgz#b8049c02dfe65620635d23ebae9121a741bb6530" + integrity sha512-1XfIxnUXzyswPAPXo1P3Pdx2mq/pIqZICkWN60Hby0d9Iqb+MEIpqgYVlbflvHdrp2YR/q3jyKWRPJJ100yxaw== dependencies: - spdx-correct "^3.0.0" - spdx-expression-parse "^3.0.0" + proxy-compare "2.5.1" + use-sync-external-store "1.2.0" varuint-bitcoin@^1.1.2: version "1.1.2" - resolved "https://registry.npmjs.org/varuint-bitcoin/-/varuint-bitcoin-1.1.2.tgz#e76c138249d06138b480d4c5b40ef53693e24e92" + resolved "https://registry.yarnpkg.com/varuint-bitcoin/-/varuint-bitcoin-1.1.2.tgz#e76c138249d06138b480d4c5b40ef53693e24e92" integrity sha512-4EVb+w4rx+YfVM32HQX42AbbT7/1f5zwAYhIujKXKk8NQK+JfRVl3pqT3hjNn/L+RstigmGGKVwHA/P0wgITZw== dependencies: safe-buffer "^5.1.1" -vary@^1, vary@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" - integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= - -watchpack@^2.4.1: - version "2.4.1" - resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-2.4.1.tgz#29308f2cac150fa8e4c92f90e0ec954a9fed7fff" - integrity sha512-8wrBCMtVhqcXP2Sup1ctSkga6uc2Bx0IIvKyT7yTFier5AXHooSI+QyQQAtTb7+E0IUCCKyTFmXqdqgum2XWGg== - dependencies: - glob-to-regexp "^0.4.1" - graceful-fs "^4.1.2" - -wbuf@^1.1.0, wbuf@^1.7.3: - version "1.7.3" - resolved "https://registry.yarnpkg.com/wbuf/-/wbuf-1.7.3.tgz#c1d8d149316d3ea852848895cb6a0bfe887b87df" - integrity sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA== - dependencies: - minimalistic-assert "^1.0.0" - webidl-conversions@^3.0.0: version "3.0.1" resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" - integrity sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE= - -webpack-cli@^5.1.4: - version "5.1.4" - resolved "https://registry.yarnpkg.com/webpack-cli/-/webpack-cli-5.1.4.tgz#c8e046ba7eaae4911d7e71e2b25b776fcc35759b" - integrity sha512-pIDJHIEI9LR0yxHXQ+Qh95k2EvXpWzZ5l+d+jIo+RdSm9MiHfzazIxwwni/p7+x4eJZuvG1AJwgC4TNQ7NRgsg== - dependencies: - "@discoveryjs/json-ext" "^0.5.0" - "@webpack-cli/configtest" "^2.1.1" - "@webpack-cli/info" "^2.0.2" - "@webpack-cli/serve" "^2.0.5" - colorette "^2.0.14" - commander "^10.0.1" - cross-spawn "^7.0.3" - envinfo "^7.7.3" - fastest-levenshtein "^1.0.12" - import-local "^3.0.2" - interpret "^3.1.1" - rechoir "^0.8.0" - webpack-merge "^5.7.3" - -webpack-dev-middleware@^5.3.1: - version "5.3.3" - resolved "https://registry.yarnpkg.com/webpack-dev-middleware/-/webpack-dev-middleware-5.3.3.tgz#efae67c2793908e7311f1d9b06f2a08dcc97e51f" - integrity sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA== - dependencies: - colorette "^2.0.10" - memfs "^3.4.3" - mime-types "^2.1.31" - range-parser "^1.2.1" - schema-utils "^4.0.0" - -webpack-dev-server@^4.15.1: - version "4.15.1" - resolved "https://registry.yarnpkg.com/webpack-dev-server/-/webpack-dev-server-4.15.1.tgz#8944b29c12760b3a45bdaa70799b17cb91b03df7" - integrity sha512-5hbAst3h3C3L8w6W4P96L5vaV0PxSmJhxZvWKYIdgxOQm8pNZ5dEOmmSLBVpP85ReeyRt6AS1QJNyo/oFFPeVA== - dependencies: - "@types/bonjour" "^3.5.9" - "@types/connect-history-api-fallback" "^1.3.5" - "@types/express" "^4.17.13" - "@types/serve-index" "^1.9.1" - "@types/serve-static" "^1.13.10" - "@types/sockjs" "^0.3.33" - "@types/ws" "^8.5.5" - ansi-html-community "^0.0.8" - bonjour-service "^1.0.11" - chokidar "^3.5.3" - colorette "^2.0.10" - compression "^1.7.4" - connect-history-api-fallback "^2.0.0" - default-gateway "^6.0.3" - express "^4.17.3" - graceful-fs "^4.2.6" - html-entities "^2.3.2" - http-proxy-middleware "^2.0.3" - ipaddr.js "^2.0.1" - launch-editor "^2.6.0" - open "^8.0.9" - p-retry "^4.5.0" - rimraf "^3.0.2" - schema-utils "^4.0.0" - selfsigned "^2.1.1" - serve-index "^1.9.1" - sockjs "^0.3.24" - spdy "^4.0.2" - webpack-dev-middleware "^5.3.1" - ws "^8.13.0" - -webpack-merge@^5.7.3: - version "5.10.0" - resolved "https://registry.yarnpkg.com/webpack-merge/-/webpack-merge-5.10.0.tgz#a3ad5d773241e9c682803abf628d4cd62b8a4177" - integrity sha512-+4zXKdx7UnO+1jaN4l2lHVD+mFvnlZQP/6ljaJVb4SZiwIKeUnrT5l0gkT8z+n4hKpC+jpOv6O9R+gLtag7pSA== - dependencies: - clone-deep "^4.0.1" - flat "^5.0.2" - wildcard "^2.0.0" - -webpack-sources@^3.2.3: - version "3.2.3" - resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-3.2.3.tgz#2d4daab8451fd4b240cc27055ff6a0c2ccea0cde" - integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w== - -webpack@^5.92.0: - version "5.92.0" - resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.92.0.tgz#cc114c71e6851d220b1feaae90159ed52c876bdf" - integrity sha512-Bsw2X39MYIgxouNATyVpCNVWBCuUwDgWtN78g6lSdPJRLaQ/PUVm/oXcaRAyY/sMFoKFQrsPeqvTizWtq7QPCA== - dependencies: - "@types/eslint-scope" "^3.7.3" - "@types/estree" "^1.0.5" - "@webassemblyjs/ast" "^1.12.1" - "@webassemblyjs/wasm-edit" "^1.12.1" - "@webassemblyjs/wasm-parser" "^1.12.1" - acorn "^8.7.1" - acorn-import-attributes "^1.9.5" - browserslist "^4.21.10" - chrome-trace-event "^1.0.2" - enhanced-resolve "^5.17.0" - es-module-lexer "^1.2.1" - eslint-scope "5.1.1" - events "^3.2.0" - glob-to-regexp "^0.4.1" - graceful-fs "^4.2.11" - json-parse-even-better-errors "^2.3.1" - loader-runner "^4.2.0" - mime-types "^2.1.27" - neo-async "^2.6.2" - schema-utils "^3.2.0" - tapable "^2.1.1" - terser-webpack-plugin "^5.3.10" - watchpack "^2.4.1" - webpack-sources "^3.2.3" - -websocket-driver@>=0.5.1, websocket-driver@^0.7.4: - version "0.7.4" - resolved "https://registry.yarnpkg.com/websocket-driver/-/websocket-driver-0.7.4.tgz#89ad5295bbf64b480abcba31e4953aca706f5760" - integrity sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg== - dependencies: - http-parser-js ">=0.5.1" - safe-buffer ">=5.1.0" - websocket-extensions ">=0.1.1" - -websocket-extensions@>=0.1.1: - version "0.1.4" - resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42" - integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg== + integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== whatwg-url@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" - integrity sha1-lmRU6HZUYuN2RNNib2dCzotwll0= + integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== dependencies: tr46 "~0.0.3" webidl-conversions "^3.0.0" @@ -11796,52 +5823,38 @@ which-builtin-type@^1.1.3: which-typed-array "^1.1.9" which-collection@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/which-collection/-/which-collection-1.0.1.tgz#70eab71ebbbd2aefaf32f917082fc62cdcb70906" - integrity sha512-W8xeTUwaln8i3K/cY1nGXzdnVZlidBcagyNFtBdD5kxnb4TvGKR7FfSIS3mYpwWS1QUCutfKz8IY8RjftB0+1A== + version "1.0.2" + resolved "https://registry.yarnpkg.com/which-collection/-/which-collection-1.0.2.tgz#627ef76243920a107e7ce8e96191debe4b16c2a0" + integrity sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw== dependencies: - is-map "^2.0.1" - is-set "^2.0.1" - is-weakmap "^2.0.1" - is-weakset "^2.0.1" + is-map "^2.0.3" + is-set "^2.0.3" + is-weakmap "^2.0.2" + is-weakset "^2.0.3" -which-typed-array@^1.1.11, which-typed-array@^1.1.13, which-typed-array@^1.1.9: - version "1.1.13" - resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.13.tgz#870cd5be06ddb616f504e7b039c4c24898184d36" - integrity sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow== - dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.4" - for-each "^0.3.3" - gopd "^1.0.1" - has-tostringtag "^1.0.0" +which-module@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.1.tgz#776b1fe35d90aebe99e8ac15eb24093389a4a409" + integrity sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ== -which-typed-array@^1.1.2: - version "1.1.8" - resolved "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.8.tgz#0cfd53401a6f334d90ed1125754a42ed663eb01f" - integrity sha512-Jn4e5PItbcAHyLoRDwvPj1ypu27DJbtdYXUa5zsinrUx77Uvfb0cXwwnGMTn7cjUfhhqgVQnVJCwF+7cgU7tpw== +which-typed-array@^1.1.14, which-typed-array@^1.1.15, which-typed-array@^1.1.2, which-typed-array@^1.1.9: + version "1.1.15" + resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.15.tgz#264859e9b11a649b388bfaaf4f767df1f779b38d" + integrity sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA== dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" - es-abstract "^1.20.0" + available-typed-arrays "^1.0.7" + call-bind "^1.0.7" for-each "^0.3.3" - has-tostringtag "^1.0.0" - is-typed-array "^1.1.9" + gopd "^1.0.1" + has-tostringtag "^1.0.2" -which@2.0.2, which@^2.0.1, which@^2.0.2: +which@^2.0.1: version "2.0.2" resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== dependencies: isexe "^2.0.0" -wide-align@^1.1.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3" - integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== - dependencies: - string-width "^1.0.2 || 2 || 3 || 4" - wif@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/wif/-/wif-4.0.0.tgz#598d4659f361b1d2a8aed13214783fa374b4b146" @@ -11849,20 +5862,19 @@ wif@^4.0.0: dependencies: bs58check "^3.0.1" -wildcard@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/wildcard/-/wildcard-2.0.1.tgz#5ab10d02487198954836b6349f74fff961e10f67" - integrity sha512-CC1bOL87PIWSBhDcTrdeLo6eGT7mCFtrg0uIJtqJUFyK+eJnzl8A1niH56uu7KMa5XFrtiV+AQuHO3n7DsHnLQ== - -word-wrap@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" - integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== +word-wrap@^1.2.5: + version "1.2.5" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.5.tgz#d2c45c6dd4fbce621a66f136cbe328afd0410b34" + integrity sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA== -workerpool@6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/workerpool/-/workerpool-6.2.0.tgz#827d93c9ba23ee2019c3ffaff5c27fccea289e8b" - integrity sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A== +"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0": + version "7.0.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" + integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== + dependencies: + ansi-styles "^4.0.0" + string-width "^4.1.0" + strip-ansi "^6.0.0" wrap-ansi@^6.2.0: version "6.2.0" @@ -11873,132 +5885,89 @@ wrap-ansi@^6.2.0: string-width "^4.1.0" strip-ansi "^6.0.0" -wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== +wrap-ansi@^8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-8.1.0.tgz#56dc22368ee570face1b49819975d9b9a5ead214" + integrity sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ== dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" + ansi-styles "^6.1.0" + string-width "^5.0.1" + strip-ansi "^7.0.1" + +wrap-ansi@^9.0.0: + version "9.0.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-9.0.0.tgz#1a3dc8b70d85eeb8398ddfb1e4a02cd186e58b3e" + integrity sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q== + dependencies: + ansi-styles "^6.2.1" + string-width "^7.0.0" + strip-ansi "^7.1.0" wrappy@1: version "1.0.2" resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" - integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= - -ws@^7.2.0: - version "7.5.8" - resolved "https://registry.npmjs.org/ws/-/ws-7.5.8.tgz#ac2729881ab9e7cbaf8787fe3469a48c5c7f636a" - integrity sha512-ri1Id1WinAX5Jqn9HejiGb8crfRio0Qgu8+MtL36rlTA6RLsMdWt1Az/19A2Qij6uSHUMphEFaTKa4WG+UNHNw== + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== -ws@^7.4.5: +ws@^7.2.0, ws@^7.4.5, ws@^7.5.1: version "7.5.9" resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.9.tgz#54fa7db29f4c7cec68b1ddd3a89de099942bb591" integrity sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q== -ws@^8.13.0: - version "8.15.0" - resolved "https://registry.yarnpkg.com/ws/-/ws-8.15.0.tgz#db080a279260c5f532fc668d461b8346efdfcf86" - integrity sha512-H/Z3H55mrcrgjFwI+5jKavgXvwQLtfPCUEp6pi35VhoB0pfcHnSoyuTzkBEZpzq49g1193CUEwIvmsjcotenYw== - ws@^8.16.0, ws@^8.5.0: version "8.17.0" resolved "https://registry.yarnpkg.com/ws/-/ws-8.17.0.tgz#d145d18eca2ed25aaf791a183903f7be5e295fea" integrity sha512-uJq6108EgZMAl20KagGkzCKfMEjxmKvZHG7Tlq0Z6nOky7YF7aq4mOx6xK8TJ/i1LeK4Qus7INktacctDgY8Ow== -ws@~8.11.0: - version "8.11.0" - resolved "https://registry.yarnpkg.com/ws/-/ws-8.11.0.tgz#6a0d36b8edfd9f96d8b25683db2f8d7de6e8e143" - integrity sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg== - -xmlhttprequest-ssl@~2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/xmlhttprequest-ssl/-/xmlhttprequest-ssl-2.0.0.tgz#91360c86b914e67f44dce769180027c0da618c67" - integrity sha512-QKxVRxiRACQcVuQEYFsI1hhkrMlrXHPegbbd1yn9UHOmRxY+si12nQYzri3vbzt8VdTTRviqcKxcyllFas5z2A== - -xtend@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" - integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== - -y18n@^5.0.5: - version "5.0.8" - resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" - integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== - -yallist@^3.0.2: - version "3.1.1" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" - integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== - -yallist@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" - integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== - -yaml@^1.10.0: - version "1.10.2" - resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.2.tgz#2301c5ffbf12b467de8da2333a459e29e7920e4b" - integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== - -yargs-parser@20.2.4: - version "20.2.4" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.4.tgz#b42890f14566796f85ae8e3a25290d205f154a54" - integrity sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA== - -yargs-parser@^20.2.2, yargs-parser@^20.2.3: - version "20.2.9" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee" - integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== +y18n@^4.0.0: + version "4.0.3" + resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.3.tgz#b5f259c82cd6e336921efd7bfd8bf560de9eeedf" + integrity sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ== -yargs-parser@^21.1.1: - version "21.1.1" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-21.1.1.tgz#9096bceebf990d21bb31fa9516e0ede294a77d35" - integrity sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw== +yaml@~2.4.2: + version "2.4.5" + resolved "https://registry.yarnpkg.com/yaml/-/yaml-2.4.5.tgz#60630b206dd6d84df97003d33fc1ddf6296cca5e" + integrity sha512-aBx2bnqDzVOyNKfsysjA2ms5ZlnjSAW2eG3/L5G/CSujfjLJTJsEw1bGw8kCf04KodQWk1pxlGnZ56CRxiawmg== -yargs-unparser@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/yargs-unparser/-/yargs-unparser-2.0.0.tgz#f131f9226911ae5d9ad38c432fe809366c2325eb" - integrity sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA== - dependencies: - camelcase "^6.0.0" - decamelize "^4.0.0" - flat "^5.0.2" - is-plain-obj "^2.1.0" - -yargs@16.2.0: - version "16.2.0" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-16.2.0.tgz#1c82bf0f6b6a66eafce7ef30e376f49a12477f66" - integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== - dependencies: - cliui "^7.0.2" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.0" - y18n "^5.0.5" - yargs-parser "^20.2.2" +yargs-parser@^18.1.2: + version "18.1.3" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-18.1.3.tgz#be68c4975c6b2abf469236b0c870362fab09a7b0" + integrity sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ== + dependencies: + camelcase "^5.0.0" + decamelize "^1.2.0" -yargs@^17.2.1, yargs@^17.3.1, yargs@^17.7.2: - version "17.7.2" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.7.2.tgz#991df39aca675a192b816e1e0363f9d75d2aa269" - integrity sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w== +yargs@^15.3.1: + version "15.4.1" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-15.4.1.tgz#0d87a16de01aee9d8bec2bfbf74f67851730f4f8" + integrity sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A== dependencies: - cliui "^8.0.1" - escalade "^3.1.1" - get-caller-file "^2.0.5" + cliui "^6.0.0" + decamelize "^1.2.0" + find-up "^4.1.0" + get-caller-file "^2.0.1" require-directory "^2.1.1" - string-width "^4.2.3" - y18n "^5.0.5" - yargs-parser "^21.1.1" + require-main-filename "^2.0.0" + set-blocking "^2.0.0" + string-width "^4.2.0" + which-module "^2.0.0" + y18n "^4.0.0" + yargs-parser "^18.1.2" yocto-queue@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== -yocto-queue@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-1.0.0.tgz#7f816433fb2cbc511ec8bf7d263c3b58a1a3c251" - integrity sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g== +zustand-querystring@^0.0.19: + version "0.0.19" + resolved "https://registry.yarnpkg.com/zustand-querystring/-/zustand-querystring-0.0.19.tgz#18ac1c9258a21c6345aa09dbf8738133471c2ebd" + integrity sha512-+lLMisaJOgEiEochoCYKKwodR4Gd6RdIcJu4j2uuM5HE/8YzXVwKEAWc/XnU46ixXT8dj33wpedm0+iWqgjOSQ== + dependencies: + lodash-es "^4.17.21" + +zustand@^4.5.2: + version "4.5.2" + resolved "https://registry.yarnpkg.com/zustand/-/zustand-4.5.2.tgz#fddbe7cac1e71d45413b3682cdb47b48034c3848" + integrity sha512-2cN1tPkDVkwCy5ickKrI7vijSjPksFRfqS6237NzT0vqSsztTNnQdHw9mmN7uBdk3gceVXU0a+21jFzFzAc9+g== + dependencies: + use-sync-external-store "1.2.0"