diff --git a/advanced/dapps/chain-abstraction-demo/app/layout.tsx b/advanced/dapps/chain-abstraction-demo/app/layout.tsx index a4afc110d..f44394274 100644 --- a/advanced/dapps/chain-abstraction-demo/app/layout.tsx +++ b/advanced/dapps/chain-abstraction-demo/app/layout.tsx @@ -24,8 +24,7 @@ export default function RootLayout({ }: Readonly<{ children: React.ReactNode; }>) { - const initialState = cookieToInitialState(config, headers().get("cookie")); - + const cookies = headers().get('cookie') return ( @@ -35,7 +34,7 @@ export default function RootLayout({ fontSans.variable )} > - +
- + - +
diff --git a/advanced/dapps/chain-abstraction-demo/app/transfer.tsx b/advanced/dapps/chain-abstraction-demo/app/transfer.tsx index 0ca153181..ebda5ff7a 100644 --- a/advanced/dapps/chain-abstraction-demo/app/transfer.tsx +++ b/advanced/dapps/chain-abstraction-demo/app/transfer.tsx @@ -1,24 +1,88 @@ "use client"; import { Button } from "@/components/ui/button"; +import { Input } from "@/components/ui/input"; import useSendUsdc from "./hooks/useSendUsdc"; -import { useAccount } from "wagmi"; +import { useAccount, useReadContract } from "wagmi"; import { useState } from "react"; import { useToast } from "@/hooks/use-toast"; import { Loader2 } from "lucide-react"; +import { isAddress } from "viem"; +import { tokenAddresses } from "@/consts/tokens"; -const sendToAddress = "0x81D8C68Be5EcDC5f927eF020Da834AA57cc3Bd24"; -const sendAmount = 6000000; +interface BalanceDisplayProps { + address: `0x${string}`; + chainId: number; +} + +const BalanceDisplay: React.FC = ({ address, chainId }) => { + const { + data: usdcBalance, + isLoading: usdcBalanceLoading, + } = useReadContract({ + abi: [ + { + inputs: [{ internalType: "address", name: "owner", type: "address" }], + name: "balanceOf", + outputs: [{ internalType: "uint256", name: "", type: "uint256" }], + stateMutability: "view", + type: "function", + }, + ], + address: tokenAddresses[chainId], + functionName: 'balanceOf', + args: [address], + }); + + // Convert the balance from the smallest unit to USDC + const formattedBalance = usdcBalanceLoading + ? 'Loading...' + : usdcBalance + ? (parseFloat(usdcBalance.toString()) / 1e6).toFixed(2) // Convert to USDC and format to 2 decimal places + : '0.00'; + + return ( +

USDC Balance: {formattedBalance} USDC

+ ); +}; export default function Transfer() { const { sendUsdcAsync } = useSendUsdc(); - const { isConnected, chain } = useAccount(); + const { isConnected, chain, address } = useAccount(); const [isLoading, setIsLoading] = useState(false); const { toast } = useToast(); + const [sendToAddress, setSendToAddress] = useState(""); + const [sendAmount, setSendAmount] = useState(""); + + if (!chain || !address) { + return null; + } const onButtonClick = async () => { try { + if (!isAddress(sendToAddress)) { + toast({ + variant: "destructive", + title: "Invalid Address", + description: "Please enter a valid Ethereum address.", + }); + return; + } + + const amount = Number(sendAmount); + if (amount <= 0) { + toast({ + variant: "destructive", + title: "Invalid Amount", + description: "Please enter an amount greater than zero.", + }); + return; + } + + // Convert the amount to smallest denomination (e.g., 1 USDC = 1,000,000 in smallest unit) + const amountInSmallestDenomination = amount * 1e6; + setIsLoading(true); - const res = await sendUsdcAsync(sendToAddress, sendAmount); + const res = await sendUsdcAsync(sendToAddress, amountInSmallestDenomination); console.log("Transaction completed", res); toast({ title: "Transaction completed", @@ -39,16 +103,61 @@ export default function Transfer() { return ( <> {isConnected ? ( - - ) : null} +
+ +
{ + e.preventDefault(); + onButtonClick(); + }} + className="space-y-4" + > +
+ + setSendToAddress(e.target.value)} + className="mt-1 w-[340px] block rounded-md text-black border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 sm:text-sm p-2" + required + placeholder="Enter recipient address" + /> +
+
+ + setSendAmount(e.target.value)} + className="mt-1 block w-[340px] text-black rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 sm:text-sm p-2" + required + placeholder="Enter amount in USDC (e.g., 2 for 2 USDC)" + /> +
+ +
+
+ ) : ( +

Please connect your account to proceed.

+ )} ); -} +} \ No newline at end of file diff --git a/advanced/dapps/chain-abstraction-demo/components/ui/input.tsx b/advanced/dapps/chain-abstraction-demo/components/ui/input.tsx new file mode 100644 index 000000000..5af26b2c1 --- /dev/null +++ b/advanced/dapps/chain-abstraction-demo/components/ui/input.tsx @@ -0,0 +1,25 @@ +import * as React from "react" + +import { cn } from "@/lib/utils" + +export interface InputProps + extends React.InputHTMLAttributes {} + +const Input = React.forwardRef( + ({ className, type, ...props }, ref) => { + return ( + + ) + } +) +Input.displayName = "Input" + +export { Input } diff --git a/advanced/dapps/chain-abstraction-demo/config/index.tsx b/advanced/dapps/chain-abstraction-demo/config/index.tsx index b7c4ac16e..d93b3c562 100644 --- a/advanced/dapps/chain-abstraction-demo/config/index.tsx +++ b/advanced/dapps/chain-abstraction-demo/config/index.tsx @@ -1,28 +1,31 @@ -import { defaultWagmiConfig } from "@web3modal/wagmi/react/config"; +import { cookieStorage, createStorage, http } from '@wagmi/core' +import { WagmiAdapter } from '@reown/appkit-adapter-wagmi' +import { arbitrum, optimism, base } from '@reown/appkit/networks' -import { cookieStorage, createStorage } from "wagmi"; -import { arbitrum, base, optimism } from "wagmi/chains"; +export const projectId = process.env.NEXT_PUBLIC_PROJECT_ID -// Get projectId from https://cloud.walletconnect.com -export const projectId = process.env.NEXT_PUBLIC_PROJECT_ID; +if (!projectId) { + throw new Error('Project ID is not defined') +} + +export const networks = [base, optimism, arbitrum] + +export const wagmiAdapter = new WagmiAdapter({ + storage: createStorage({ + storage: cookieStorage + }), + ssr: true, + projectId, + networks +}) -if (!projectId) throw new Error("Project ID is not defined"); export const metadata = { - name: "AppKit", - description: "AppKit Example", + name: "Chain Abstraction Demo", + description: "A demo of Chain Abstraction", url: "https://web3modal.com", // origin must match your domain & subdomain icons: ["https://avatars.githubusercontent.com/u/37784886"], }; -// Create wagmiConfig -const chains = [base, optimism, arbitrum] as const; -export const config = defaultWagmiConfig({ - chains, - projectId, - metadata, - ssr: true, - storage: createStorage({ - storage: cookieStorage, - }), -}); + +export const config = wagmiAdapter.wagmiConfig \ No newline at end of file diff --git a/advanced/dapps/chain-abstraction-demo/consts/tokens.ts b/advanced/dapps/chain-abstraction-demo/consts/tokens.ts index 648f6ae88..02e519c80 100644 --- a/advanced/dapps/chain-abstraction-demo/consts/tokens.ts +++ b/advanced/dapps/chain-abstraction-demo/consts/tokens.ts @@ -1,5 +1,7 @@ import { Hex } from "viem"; export const tokenAddresses: Record = { - 42161: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831' // Arbitrum + 42161: '0xaf88d065e77c8cC2239327C5EDb3A432268e5831', // Arbitrum + 10: '0x0b2C639c533813f4Aa9D7837CAf62653d097Ff85', // Optimism + 8453: '0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913', // Base } \ No newline at end of file diff --git a/advanced/dapps/chain-abstraction-demo/context/index.tsx b/advanced/dapps/chain-abstraction-demo/context/index.tsx index 89a48ed28..4ec019b7f 100644 --- a/advanced/dapps/chain-abstraction-demo/context/index.tsx +++ b/advanced/dapps/chain-abstraction-demo/context/index.tsx @@ -1,37 +1,35 @@ -"use client"; +'use client' -import React, { ReactNode } from "react"; -import { config, projectId, metadata } from "@/config"; +import { wagmiAdapter, projectId, metadata } from '@/config' +import { QueryClient, QueryClientProvider } from '@tanstack/react-query' +import { createAppKit } from '@reown/appkit/react' +import { arbitrum, base, optimism } from '@reown/appkit/networks' +import React, { type ReactNode } from 'react' +import { cookieToInitialState, WagmiProvider, type Config } from 'wagmi' -import { createWeb3Modal } from "@web3modal/wagmi/react"; - -import { QueryClient, QueryClientProvider } from "@tanstack/react-query"; - -import { State, WagmiProvider } from "wagmi"; - -// Setup queryClient const queryClient = new QueryClient(); if (!projectId) throw new Error("Project ID is not defined"); -// Create modal -createWeb3Modal({ - metadata, - wagmiConfig: config, +const modal = createAppKit({ + adapters: [wagmiAdapter], projectId, - enableAnalytics: true, // Optional - defaults to your Cloud configuration -}); + networks: [base, optimism, arbitrum], + defaultNetwork: base, + metadata: metadata, + features: { + analytics: true + } +}) + +function AppKitProvider({ children, cookies }: { children: ReactNode; cookies: string | null }) { + const initialState = cookieToInitialState(wagmiAdapter.wagmiConfig as Config, cookies) -export default function AppKitProvider({ - children, - initialState, -}: { - children: ReactNode; - initialState?: State; -}) { return ( - + {children} - ); + ) } + +export default AppKitProvider diff --git a/advanced/dapps/chain-abstraction-demo/package.json b/advanced/dapps/chain-abstraction-demo/package.json index f97dff7a6..45b4f2de3 100644 --- a/advanced/dapps/chain-abstraction-demo/package.json +++ b/advanced/dapps/chain-abstraction-demo/package.json @@ -9,31 +9,35 @@ "lint": "next lint" }, "dependencies": { - "@radix-ui/react-icons": "^1.3.0", - "@radix-ui/react-slot": "^1.1.0", - "@radix-ui/react-toast": "^1.2.1", - "@tanstack/react-query": "^5.54.1", - "@web3modal/wagmi": "^5.1.6", - "class-variance-authority": "^0.7.0", - "clsx": "^2.1.1", - "lucide-react": "^0.439.0", + "@radix-ui/react-icons": "1.3.1", + "@radix-ui/react-slot": "1.1.0", + "@radix-ui/react-toast": "1.2.2", + "@reown/appkit": "1.2.1", + "@reown/appkit-adapter-wagmi": "1.2.1", + "@tanstack/react-query": "5.59.19", + "@web3modal/wagmi": "5.1.11", + "class-variance-authority": "0.7.0", + "clsx": "2.1.1", + "lucide-react": "0.439.0", "next": "14.2.7", - "next-themes": "^0.3.0", - "react": "^18", - "react-dom": "^18", - "tailwind-merge": "^2.5.2", - "tailwindcss-animate": "^1.0.7", - "viem": "^2.21.1", - "wagmi": "^2.12.8" + "next-themes": "0.3.0", + "react": "18.3.1", + "react-dom": "18.3.1", + "tailwind-merge": "2.5.2", + "tailwindcss-animate": "1.0.7", + "viem": "2.21.40", + "wagmi": "2.12.25" }, "devDependencies": { "@types/node": "^20", "@types/react": "^18", "@types/react-dom": "^18", + "encoding": "0.1.13", "eslint": "^8", "eslint-config-next": "14.2.7", + "pino-pretty": "^11.3.0", "postcss": "^8", "tailwindcss": "^3.4.1", "typescript": "^5" } -} +} \ No newline at end of file diff --git a/advanced/dapps/chain-abstraction-demo/yarn.lock b/advanced/dapps/chain-abstraction-demo/yarn.lock index a0226d4a6..f0b0b1149 100644 --- a/advanced/dapps/chain-abstraction-demo/yarn.lock +++ b/advanced/dapps/chain-abstraction-demo/yarn.lock @@ -7,6 +7,11 @@ resolved "https://registry.yarnpkg.com/@adraffy/ens-normalize/-/ens-normalize-1.10.0.tgz#d2a39395c587e092d77cbbc80acf956a54f38bf7" integrity sha512-nA9XHtlAkYfJxY7bce8DcN7eKxWWCWkU+1GR9d+U6MbNpfwQp8TI7vqOsBsMcHoT4mBu2kypKoSKnghEzOOq5Q== +"@adraffy/ens-normalize@1.11.0": + version "1.11.0" + resolved "https://registry.yarnpkg.com/@adraffy/ens-normalize/-/ens-normalize-1.11.0.tgz#42cc67c5baa407ac25059fcd7d405cc5ecdb0c33" + integrity sha512-/3DDPKHqqIqxUULp8yP4zODUY1i+2xvVWsv8A79xGWdCAG+8sb0hRh0Rk2QyOJUnnbyPUAZYcpBuRe3nS2OIUg== + "@alloc/quick-lru@^5.2.0": version "5.2.0" resolved "https://registry.yarnpkg.com/@alloc/quick-lru/-/quick-lru-5.2.0.tgz#7bf68b20c0a350f936915fcae06f58e32007ce30" @@ -19,17 +24,20 @@ dependencies: regenerator-runtime "^0.14.0" -"@coinbase/wallet-sdk@4.0.4": - version "4.0.4" - resolved "https://registry.yarnpkg.com/@coinbase/wallet-sdk/-/wallet-sdk-4.0.4.tgz#634cd89bac93eeaf381a1f026476794e53431ed6" - integrity sha512-74c040CRnGhfRjr3ArnkAgud86erIqdkPHNt5HR1k9u97uTIZCJww9eGYT67Qf7gHPpGS/xW8Be1D4dvRm63FA== +"@coinbase/wallet-sdk@4.1.0": + version "4.1.0" + resolved "https://registry.yarnpkg.com/@coinbase/wallet-sdk/-/wallet-sdk-4.1.0.tgz#3224a102b724dcb1a63005f371d596ae2999953b" + integrity sha512-SkJJ72X/AA3+aS21sPs/4o4t6RVeDSA7HuBW4zauySX3eBiPU0zmVw95tXH/eNSX50agKz9WzeN8P5F+HcwLOw== dependencies: - buffer "^6.0.3" + "@noble/hashes" "^1.4.0" clsx "^1.2.1" eventemitter3 "^5.0.1" - keccak "^3.0.3" preact "^10.16.0" - sha.js "^2.4.11" + +"@ecies/ciphers@^0.2.0": + version "0.2.1" + resolved "https://registry.yarnpkg.com/@ecies/ciphers/-/ciphers-0.2.1.tgz#a3119516fb55d27ed2d21c497b1c4988f0b4ca02" + integrity sha512-ezMihhjW24VNK/2qQR7lH8xCQY24nk0XHF/kwJ1OuiiY5iEwQXOcKVSy47fSoHPRG8gVGXcK5SgtONDk5xMwtQ== "@eslint-community/eslint-utils@^4.2.0": version "4.4.0" @@ -265,10 +273,10 @@ resolved "https://registry.yarnpkg.com/@metamask/safe-event-emitter/-/safe-event-emitter-3.1.1.tgz#e89b840a7af8097a8ed4953d8dc8470d1302d3ef" integrity sha512-ihb3B0T/wJm1eUuArYP4lCTSEoZsClHhuWyfo/kMX3m/odpqNcPfsz5O2A3NT7dXCAgWPGDQGPqygCpgeniKMw== -"@metamask/sdk-communication-layer@0.27.0": - version "0.27.0" - resolved "https://registry.yarnpkg.com/@metamask/sdk-communication-layer/-/sdk-communication-layer-0.27.0.tgz#8d618fadd39f11627d5b3ef1bc72867439e33ff4" - integrity sha512-G9LCaQzIqp5WmUmvHN6UUdjWrBh67MbRobmbbs5fcc2+9XFhj3vBgtyleUYjun91jSlPHoZeo+f/Pj4/WoPIJg== +"@metamask/sdk-communication-layer@0.30.0": + version "0.30.0" + resolved "https://registry.yarnpkg.com/@metamask/sdk-communication-layer/-/sdk-communication-layer-0.30.0.tgz#2bd252cfce3ac4260a6c8c9359732ab5e839b75e" + integrity sha512-q5nbdYkAf76MsZxi1l5MJEAyd8sY9jLRapC8a7x1Q1BNV4rzQeFeux/d0mJ/jTR2LAwbnLZs2rL226AM75oK4w== dependencies: bufferutil "^4.0.8" date-fns "^2.29.3" @@ -276,27 +284,26 @@ utf-8-validate "^5.0.2" uuid "^8.3.2" -"@metamask/sdk-install-modal-web@0.26.5": - version "0.26.5" - resolved "https://registry.yarnpkg.com/@metamask/sdk-install-modal-web/-/sdk-install-modal-web-0.26.5.tgz#b696c78818adaff85d01a4f41fecc8fd2c80bc59" - integrity sha512-qVA9Nk+NorGx5hXyODy5wskptE8R7RNYTYt49VbQpJogqbbVe1dnJ98+KaA43PBN4XYMCXmcIhULNiEHGsLynA== +"@metamask/sdk-install-modal-web@0.30.0": + version "0.30.0" + resolved "https://registry.yarnpkg.com/@metamask/sdk-install-modal-web/-/sdk-install-modal-web-0.30.0.tgz#9ec634201b1b47bb30064f42ae0efba7f204bb0a" + integrity sha512-1gT533Huja9tK3cmttvcpZirRAtWJ7vnYH+lnNRKEj2xIP335Df2cOwS+zqNC4GlRCZw7A3IsTjIzlKoxBY1uQ== dependencies: qr-code-styling "^1.6.0-rc.1" -"@metamask/sdk@0.27.0": - version "0.27.0" - resolved "https://registry.yarnpkg.com/@metamask/sdk/-/sdk-0.27.0.tgz#38617985b8305a0f5d482cdd7af8ddec87968bb7" - integrity sha512-6sMjr/0qR700X1svPGEQ4rBdtccidBLeTC27fYQc7r9ROgSixB1DUUAyu/LoySVqt3Hu/Zm7NnAHXuT228ht7A== +"@metamask/sdk@0.30.1": + version "0.30.1" + resolved "https://registry.yarnpkg.com/@metamask/sdk/-/sdk-0.30.1.tgz#63126ad769566098000cc3c2cd513d18808471f3" + integrity sha512-NelEjJZsF5wVpSQELpmvXtnS9+C6HdxGQ4GB9jMRzeejphmPyKqmrIGM6XtaPrJtlpX+40AcJ2dtBQcjJVzpbQ== dependencies: "@metamask/onboarding" "^1.0.1" "@metamask/providers" "16.1.0" - "@metamask/sdk-communication-layer" "0.27.0" - "@metamask/sdk-install-modal-web" "0.26.5" - "@types/dom-screen-wake-lock" "^1.0.0" + "@metamask/sdk-communication-layer" "0.30.0" + "@metamask/sdk-install-modal-web" "0.30.0" bowser "^2.9.0" cross-fetch "^4.0.0" debug "^4.3.4" - eciesjs "^0.3.15" + eciesjs "^0.4.8" eth-rpc-errors "^4.0.3" eventemitter2 "^6.4.7" i18next "23.11.5" @@ -306,7 +313,6 @@ qrcode-terminal-nooctal "^0.12.1" react-native-webview "^11.26.0" readable-stream "^3.6.2" - rollup-plugin-visualizer "^5.9.2" socket.io-client "^4.5.1" util "^0.12.4" uuid "^8.3.2" @@ -483,6 +489,11 @@ resolved "https://registry.yarnpkg.com/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.7.tgz#75e1d90758cb10a547e1cdfb878871da28123682" integrity sha512-pxsI23gKWRt/SPHFkDEsP+w+Nd7gK37Hpv0ngc5HpWy2e7cKx9zR/+Q2ptAUqICNTecAaGWvmhway7pj/JLEWA== +"@noble/ciphers@^1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@noble/ciphers/-/ciphers-1.0.0.tgz#34758a1cbfcd4126880f83e6b1cdeb88785b7970" + integrity sha512-wH5EHOmLi0rEazphPbecAzmjd12I6/Yv/SiHdkA9LSycsQk7RuuTp7am5/o62qYr0RScE7Pc9icXGBbsr6cesA== + "@noble/curves@1.4.0": version "1.4.0" resolved "https://registry.yarnpkg.com/@noble/curves/-/curves-1.4.0.tgz#f05771ef64da724997f69ee1261b2417a49522d6" @@ -497,7 +508,7 @@ dependencies: "@noble/hashes" "1.4.0" -"@noble/curves@^1.4.0": +"@noble/curves@1.6.0", "@noble/curves@^1.4.0", "@noble/curves@^1.6.0", "@noble/curves@~1.6.0": version "1.6.0" resolved "https://registry.yarnpkg.com/@noble/curves/-/curves-1.6.0.tgz#be5296ebcd5a1730fccea4786d420f87abfeb40b" integrity sha512-TlaHRXDehJuRNR9TfZDNQ45mMEd5dwUwmicsafcIX4SsNiqnCHKjE/1alYPd/lDRVhxdhUAlv8uEhMCI5zjIJQ== @@ -509,7 +520,7 @@ resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.4.0.tgz#45814aa329f30e4fe0ba49426f49dfccdd066426" integrity sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg== -"@noble/hashes@1.5.0", "@noble/hashes@^1.3.1", "@noble/hashes@^1.4.0": +"@noble/hashes@1.5.0", "@noble/hashes@^1.3.1", "@noble/hashes@^1.4.0", "@noble/hashes@^1.5.0", "@noble/hashes@~1.5.0": version "1.5.0" resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.5.0.tgz#abadc5ca20332db2b1b2aa3e496e9af1213570b0" integrity sha512-1j6kQFb7QRru7eKN3ZDvRcP13rugwdxZqCjbiAVZfIJwgj2A65UmT4TgARXGlXgnRkORLTDTrO19ZErt7+QXgA== @@ -662,10 +673,15 @@ resolved "https://registry.yarnpkg.com/@radix-ui/react-context/-/react-context-1.1.0.tgz#6df8d983546cfd1999c8512f3a8ad85a6e7fcee8" integrity sha512-OKrckBy+sMEgYM/sMmqmErVn0kZqrHPJze+Ql3DzYsDDp0hl0L62nx/2122/Bvps1qz645jlcu2tD9lrRSdf8A== -"@radix-ui/react-dismissable-layer@1.1.0": - version "1.1.0" - resolved "https://registry.yarnpkg.com/@radix-ui/react-dismissable-layer/-/react-dismissable-layer-1.1.0.tgz#2cd0a49a732372513733754e6032d3fb7988834e" - integrity sha512-/UovfmmXGptwGcBQawLzvn2jOfM0t4z3/uKffoBlj724+n3FvBbZ7M0aaBOmkp6pqFYpO4yx8tSVJjx3Fl2jig== +"@radix-ui/react-context@1.1.1": + version "1.1.1" + resolved "https://registry.yarnpkg.com/@radix-ui/react-context/-/react-context-1.1.1.tgz#82074aa83a472353bb22e86f11bcbd1c61c4c71a" + integrity sha512-UASk9zi+crv9WteK/NU4PLvOoL3OuE6BWVKNF6hPRBtYBDXQ2u5iu3O59zUlJiTVvkyuycnqrztsHVJwcK9K+Q== + +"@radix-ui/react-dismissable-layer@1.1.1": + version "1.1.1" + resolved "https://registry.yarnpkg.com/@radix-ui/react-dismissable-layer/-/react-dismissable-layer-1.1.1.tgz#cbdcb739c5403382bdde5f9243042ba643883396" + integrity sha512-QSxg29lfr/xcev6kSz7MAlmDnzbP1eI/Dwn3Tp1ip0KT5CUELsxkekFEMVBEoykI3oV39hKT4TKZzBNMbcTZYQ== dependencies: "@radix-ui/primitive" "1.1.0" "@radix-ui/react-compose-refs" "1.1.0" @@ -673,23 +689,23 @@ "@radix-ui/react-use-callback-ref" "1.1.0" "@radix-ui/react-use-escape-keydown" "1.1.0" -"@radix-ui/react-icons@^1.3.0": - version "1.3.0" - resolved "https://registry.yarnpkg.com/@radix-ui/react-icons/-/react-icons-1.3.0.tgz#c61af8f323d87682c5ca76b856d60c2312dbcb69" - integrity sha512-jQxj/0LKgp+j9BiTXz3O3sgs26RNet2iLWmsPyRz2SIcR4q/4SbazXfnYwbAr+vLYKSfc7qxzyGQA1HLlYiuNw== +"@radix-ui/react-icons@1.3.1": + version "1.3.1" + resolved "https://registry.yarnpkg.com/@radix-ui/react-icons/-/react-icons-1.3.1.tgz#462c85fd726a77854cd5956e29eb19a575aa7ce5" + integrity sha512-QvYompk0X+8Yjlo/Fv4McrzxohDdM5GgLHyQcPpcsPvlOSXCGFjdbuyGL5dzRbg0GpknAjQJJZzdiRK7iWVuFQ== -"@radix-ui/react-portal@1.1.1": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@radix-ui/react-portal/-/react-portal-1.1.1.tgz#1957f1eb2e1aedfb4a5475bd6867d67b50b1d15f" - integrity sha512-A3UtLk85UtqhzFqtoC8Q0KvR2GbXF3mtPgACSazajqq6A41mEQgo53iPzY4i6BwDxlIFqWIhiQ2G729n+2aw/g== +"@radix-ui/react-portal@1.1.2": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@radix-ui/react-portal/-/react-portal-1.1.2.tgz#51eb46dae7505074b306ebcb985bf65cc547d74e" + integrity sha512-WeDYLGPxJb/5EGBoedyJbT0MpoULmwnIPMJMSldkuiMsBAv7N1cRdsTWZWht9vpPOiN3qyiGAtbK2is47/uMFg== dependencies: "@radix-ui/react-primitive" "2.0.0" "@radix-ui/react-use-layout-effect" "1.1.0" -"@radix-ui/react-presence@1.1.0": - version "1.1.0" - resolved "https://registry.yarnpkg.com/@radix-ui/react-presence/-/react-presence-1.1.0.tgz#227d84d20ca6bfe7da97104b1a8b48a833bfb478" - integrity sha512-Gq6wuRN/asf9H/E/VzdKoUtT8GC9PQc9z40/vEr0VCJ4u5XvvhWIrSsCB6vD2/cH7ugTdSfYq9fLJCcM00acrQ== +"@radix-ui/react-presence@1.1.1": + version "1.1.1" + resolved "https://registry.yarnpkg.com/@radix-ui/react-presence/-/react-presence-1.1.1.tgz#98aba423dba5e0c687a782c0669dcd99de17f9b1" + integrity sha512-IeFXVi4YS1K0wVZzXNrbaaUvIJ3qdY+/Ih4eHFhWA9SwGR9UDX7Ck8abvL57C4cv3wwMvUE0OG69Qc3NCcTe/A== dependencies: "@radix-ui/react-compose-refs" "1.1.0" "@radix-ui/react-use-layout-effect" "1.1.0" @@ -701,25 +717,25 @@ dependencies: "@radix-ui/react-slot" "1.1.0" -"@radix-ui/react-slot@1.1.0", "@radix-ui/react-slot@^1.1.0": +"@radix-ui/react-slot@1.1.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@radix-ui/react-slot/-/react-slot-1.1.0.tgz#7c5e48c36ef5496d97b08f1357bb26ed7c714b84" integrity sha512-FUCf5XMfmW4dtYl69pdS4DbxKy8nj4M7SafBgPllysxmdachynNflAdp/gCsnYWNDnge6tI9onzMp5ARYc1KNw== dependencies: "@radix-ui/react-compose-refs" "1.1.0" -"@radix-ui/react-toast@^1.2.1": - version "1.2.1" - resolved "https://registry.yarnpkg.com/@radix-ui/react-toast/-/react-toast-1.2.1.tgz#4bde231ed27d007dcd0455a446565ca619f92a2d" - integrity sha512-5trl7piMXcZiCq7MW6r8YYmu0bK5qDpTWz+FdEPdKyft2UixkspheYbjbrLXVN5NGKHFbOP7lm8eD0biiSqZqg== +"@radix-ui/react-toast@1.2.2": + version "1.2.2" + resolved "https://registry.yarnpkg.com/@radix-ui/react-toast/-/react-toast-1.2.2.tgz#fdd8ed0b80f47d6631dfd90278fee6debc06bf33" + integrity sha512-Z6pqSzmAP/bFJoqMAston4eSNa+ud44NSZTiZUmUen+IOZ5nBY8kzuU5WDBVyFXPtcW6yUalOHsxM/BP6Sv8ww== dependencies: "@radix-ui/primitive" "1.1.0" "@radix-ui/react-collection" "1.1.0" "@radix-ui/react-compose-refs" "1.1.0" - "@radix-ui/react-context" "1.1.0" - "@radix-ui/react-dismissable-layer" "1.1.0" - "@radix-ui/react-portal" "1.1.1" - "@radix-ui/react-presence" "1.1.0" + "@radix-ui/react-context" "1.1.1" + "@radix-ui/react-dismissable-layer" "1.1.1" + "@radix-ui/react-portal" "1.1.2" + "@radix-ui/react-presence" "1.1.1" "@radix-ui/react-primitive" "2.0.0" "@radix-ui/react-use-callback-ref" "1.1.0" "@radix-ui/react-use-controllable-state" "1.1.0" @@ -757,6 +773,129 @@ dependencies: "@radix-ui/react-primitive" "2.0.0" +"@reown/appkit-adapter-wagmi@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-adapter-wagmi/-/appkit-adapter-wagmi-1.2.1.tgz#621d86407d8bc716bf6e47324f0ac1ce11ece3ef" + integrity sha512-iFkZRPmpg3DDWWmb4wj1aYTtCb91QMJkfYrZFQoyi4bzCt9HlTMnPR3jwDUV9h321DgT9aNkSDLvurBvq/GPBg== + dependencies: + "@reown/appkit" "1.2.1" + "@reown/appkit-common" "1.2.1" + "@reown/appkit-core" "1.2.1" + "@reown/appkit-polyfills" "1.2.1" + "@reown/appkit-scaffold-ui" "1.2.1" + "@reown/appkit-siwe" "1.2.1" + "@reown/appkit-ui" "1.2.1" + "@reown/appkit-utils" "1.2.1" + "@reown/appkit-wallet" "1.2.1" + "@walletconnect/universal-provider" "2.17.0" + "@walletconnect/utils" "2.17.0" + valtio "1.11.2" + +"@reown/appkit-common@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-common/-/appkit-common-1.2.1.tgz#8bcc5b4d4d015fc91bb9ea1ee9ef53436e8ce9fc" + integrity sha512-XOp7i0P+GR5wgJGWCAsFiY9oTAHNESDZHJAMJaQX92QfuhL+Pq2YqKuNy1gRsnAAOzUh5IaUWBAnF5UB7Sqblg== + dependencies: + bignumber.js "9.1.2" + dayjs "1.11.10" + viem "2.x" + +"@reown/appkit-core@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-core/-/appkit-core-1.2.1.tgz#8d46d9b65ee83ecd948152db10851e9591f021d7" + integrity sha512-uu4aT68XGFfQmnOyXGEdW0hagviq8ybW/XPThu1U0wTReJK23l3OuwcZEAzmniI6gvveoUrdPVLE0JgPjQ0j1Q== + dependencies: + "@reown/appkit-common" "1.2.1" + "@reown/appkit-wallet" "1.2.1" + "@walletconnect/universal-provider" "2.17.0" + valtio "1.11.2" + viem "2.x" + +"@reown/appkit-polyfills@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-polyfills/-/appkit-polyfills-1.2.1.tgz#aef81d8d602aaf718d955c58340f665d16f3f9e2" + integrity sha512-dn6A5PvB6MSKTz628CmwWNBoE3u0LLmMc0+JOexzEdwxs41DQKH9f9MqJiac7gWPTtUhkquNVnt4frZSNOzfIg== + dependencies: + buffer "6.0.3" + +"@reown/appkit-scaffold-ui@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-scaffold-ui/-/appkit-scaffold-ui-1.2.1.tgz#339aa916a4c4f1fd111a8dd2717e465375ef0ed5" + integrity sha512-dM/o7AXTpd3aBF7jnS/nCA91CWSM7kLalD0QUdmQ5FD5fxoWIxq5EgNGr9TuRsb6ibPOivGA7qz80FcZpdnjtw== + dependencies: + "@reown/appkit-common" "1.2.1" + "@reown/appkit-core" "1.2.1" + "@reown/appkit-siwe" "1.2.1" + "@reown/appkit-ui" "1.2.1" + "@reown/appkit-utils" "1.2.1" + "@reown/appkit-wallet" "1.2.1" + lit "3.1.0" + +"@reown/appkit-siwe@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-siwe/-/appkit-siwe-1.2.1.tgz#74a8f898d80675f972d9732a7a83a7f11b24a022" + integrity sha512-CRNKUTjoOmi9C+A3THqXIJ4/jWIIDTAlq00kU0XxGiwqfNHwPnOw7sNCtavRyTsTO7g7JFuy/fjwODBtumLoxA== + dependencies: + "@reown/appkit-common" "1.2.1" + "@reown/appkit-core" "1.2.1" + "@reown/appkit-ui" "1.2.1" + "@reown/appkit-utils" "1.2.1" + "@reown/appkit-wallet" "1.2.1" + "@walletconnect/utils" "2.17.0" + lit "3.1.0" + valtio "1.11.2" + +"@reown/appkit-ui@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-ui/-/appkit-ui-1.2.1.tgz#99c64f07ff5b6984831cefebbc0c423c94eea9dd" + integrity sha512-C8k4t1tVwh4f0qt8E5Q8g4NaxSXxf6BxHbzhRNOn8WJY+ByuwsmCh8AdbrUOKoMQZnmwx1/tBYGC9GLF08NSKg== + dependencies: + lit "3.1.0" + qrcode "1.5.3" + +"@reown/appkit-utils@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-utils/-/appkit-utils-1.2.1.tgz#5b1ed1b8e51b635ee659d56547673b9cd285f431" + integrity sha512-pIyx74zowVg3b+wEwegIMlOJsawff623eF3cW3l3JLfnhSqihwQlnGkb0CvsmihnZ+zkyT4pbpXVRrtRgrpcrQ== + dependencies: + "@reown/appkit-common" "1.2.1" + "@reown/appkit-core" "1.2.1" + "@reown/appkit-polyfills" "1.2.1" + "@reown/appkit-wallet" "1.2.1" + "@walletconnect/logger" "2.1.2" + "@walletconnect/universal-provider" "2.17.0" + valtio "1.11.2" + viem "2.x" + +"@reown/appkit-wallet@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit-wallet/-/appkit-wallet-1.2.1.tgz#dd53689767c6afb11072f6436ec14800b5bb26e2" + integrity sha512-kVhu1rrtrLyKLU/JTzFaESLvNKjCYgwXbOIOeYAyaOltRd74TVAx/vIzYl71oJtN/T36aL5eRAjAJ2Vfd/rKFQ== + dependencies: + "@reown/appkit-common" "1.2.1" + "@reown/appkit-polyfills" "1.2.1" + "@walletconnect/logger" "2.1.2" + zod "3.22.4" + +"@reown/appkit@1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@reown/appkit/-/appkit-1.2.1.tgz#3d9b14474f207d6c4a083581cdc2d27a90c311d0" + integrity sha512-it+WW5vjyc3HNRk1Yda8z6n57YBusEycyvL8eY4XRYWGwLlKyw18XO5VrLR9Z99/yMAWzUJF3YQsmXe222/cNA== + dependencies: + "@reown/appkit-common" "1.2.1" + "@reown/appkit-core" "1.2.1" + "@reown/appkit-polyfills" "1.2.1" + "@reown/appkit-scaffold-ui" "1.2.1" + "@reown/appkit-siwe" "1.2.1" + "@reown/appkit-ui" "1.2.1" + "@reown/appkit-utils" "1.2.1" + "@reown/appkit-wallet" "1.2.1" + "@walletconnect/types" "2.17.0" + "@walletconnect/universal-provider" "2.17.0" + "@walletconnect/utils" "2.17.0" + valtio "1.11.2" + viem "2.x" + "@rtsao/scc@^1.1.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@rtsao/scc/-/scc-1.1.0.tgz#927dd2fae9bc3361403ac2c7a00c32ddce9ad7e8" @@ -793,6 +932,11 @@ resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.8.tgz#8f23646c352f020c83bca750a82789e246d42b50" integrity sha512-6CyAclxj3Nb0XT7GHK6K4zK6k2xJm6E4Ft0Ohjt4WgegiFUHEtFb2CGzmPmGBwoIhrLsqNLYfLr04Y1GePrzZg== +"@scure/base@~1.1.7", "@scure/base@~1.1.8": + version "1.1.9" + resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.9.tgz#e5e142fbbfe251091f9c5f1dd4c834ac04c3dbd1" + integrity sha512-8YKhl8GHiNI/pU2VMaofa2Tor7PJRAjwQLBBuilkJ9L5+13yVbC7JO/wS7piioAvPSwR3JKM1IJ/u4xQzbcXKg== + "@scure/bip32@1.4.0": version "1.4.0" resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.4.0.tgz#4e1f1e196abedcef395b33b9674a042524e20d67" @@ -802,6 +946,15 @@ "@noble/hashes" "~1.4.0" "@scure/base" "~1.1.6" +"@scure/bip32@1.5.0": + version "1.5.0" + resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.5.0.tgz#dd4a2e1b8a9da60e012e776d954c4186db6328e6" + integrity sha512-8EnFYkqEQdnkuGBVpCzKxyIwDCBLDVj3oiX0EKUFre/tOjL/Hqba1D6n/8RcmaQy4f95qQFrO2A8Sr6ybh4NRw== + dependencies: + "@noble/curves" "~1.6.0" + "@noble/hashes" "~1.5.0" + "@scure/base" "~1.1.7" + "@scure/bip39@1.3.0": version "1.3.0" resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.3.0.tgz#0f258c16823ddd00739461ac31398b4e7d6a18c3" @@ -810,6 +963,14 @@ "@noble/hashes" "~1.4.0" "@scure/base" "~1.1.6" +"@scure/bip39@1.4.0": + version "1.4.0" + resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.4.0.tgz#664d4f851564e2e1d4bffa0339f9546ea55960a6" + integrity sha512-BEEm6p8IueV/ZTfQLp/0vhw4NPnT9oWf5+28nvmeUICjP99f4vr2d+qc7AVGDDtwRep6ifR43Yed9ERVmiITzw== + dependencies: + "@noble/hashes" "~1.5.0" + "@scure/base" "~1.1.8" + "@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" @@ -962,17 +1123,17 @@ "@swc/counter" "^0.1.3" tslib "^2.4.0" -"@tanstack/query-core@5.54.1": - version "5.54.1" - resolved "https://registry.yarnpkg.com/@tanstack/query-core/-/query-core-5.54.1.tgz#8d6c5e6691dd023f9181d69f7f9d790f52f1bdda" - integrity sha512-hKS+WRpT5zBFip21pB6Jx1C0hranWQrbv5EJ7qPoiV5MYI3C8rTCqWC9DdBseiPT1JgQWh8Y55YthuYZNiw3Xw== +"@tanstack/query-core@5.59.17": + version "5.59.17" + resolved "https://registry.yarnpkg.com/@tanstack/query-core/-/query-core-5.59.17.tgz#bda3bb678be48e2f6ee692abd1cfc2db3d455e4b" + integrity sha512-jWdDiif8kaqnRGHNXAa9CnudtxY5v9DUxXhodgqX2Rwzj+1UwStDHEbBd9IA5C7VYAaJ2s+BxFR6PUBs8ERorA== -"@tanstack/react-query@^5.54.1": - version "5.54.1" - resolved "https://registry.yarnpkg.com/@tanstack/react-query/-/react-query-5.54.1.tgz#55d9d9b290362160008bf5d5d7dedd485afbfc5e" - integrity sha512-SuMi4JBYv49UtmiRyqjxY7XAnE1qwLht9nlkC8sioxFXz5Uzj30lepiKf2mYXuXfC7fHYjTrAPkNx+427pRHXA== +"@tanstack/react-query@5.59.19": + version "5.59.19" + resolved "https://registry.yarnpkg.com/@tanstack/react-query/-/react-query-5.59.19.tgz#309ae0d75844e331ea72762bfe0e11fb829a69d3" + integrity sha512-xLRfyFyQOFcLltKCds0LijfC6/HQJrrTTnZB8ciyn74LIkVAm++vZJ6eUVG20RmJtdP8REdy7vSOYW4M3//XLA== dependencies: - "@tanstack/query-core" "5.54.1" + "@tanstack/query-core" "5.59.17" "@types/debug@^4.1.7": version "4.1.12" @@ -981,11 +1142,6 @@ dependencies: "@types/ms" "*" -"@types/dom-screen-wake-lock@^1.0.0": - version "1.0.3" - resolved "https://registry.yarnpkg.com/@types/dom-screen-wake-lock/-/dom-screen-wake-lock-1.0.3.tgz#c3588a5f6f40fae957f9ce5be9bc4927a61bb9a0" - integrity sha512-3Iten7X3Zgwvk6kh6/NRdwN7WbZ760YgFCsF5AxDifltUQzW1RaW+WRmcVtgwFzLjaNu64H+0MPJ13yRa8g3Dw== - "@types/json5@^0.0.29": version "0.0.29" resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" @@ -996,13 +1152,6 @@ resolved "https://registry.yarnpkg.com/@types/ms/-/ms-0.7.34.tgz#10964ba0dee6ac4cd462e2795b6bebd407303433" integrity sha512-nG96G3Wp6acyAgJqGasjODb+acrI7KltPiRxzHPXnP3NgI28bpQDRv53olbqGXbfcgF5aiiHmO3xpwEpS5Ld9g== -"@types/node@*": - version "22.5.3" - resolved "https://registry.yarnpkg.com/@types/node/-/node-22.5.3.tgz#91a374e42c6e7ccb5893a87f1775f36ce1671d65" - integrity sha512-njripolh85IA9SQGTAqbmnNZTdxv7X/4OYGPz8tgy5JDr8MP+uDBa921GpYEoDDnwm0Hmn5ZPeJgiiSTPoOzkQ== - dependencies: - undici-types "~6.19.2" - "@types/node@^20": version "20.16.4" resolved "https://registry.yarnpkg.com/@types/node/-/node-20.16.4.tgz#2e3d9e1da4761a0fdb725d9497df4bb091e9c2f1" @@ -1030,13 +1179,6 @@ "@types/prop-types" "*" csstype "^3.0.2" -"@types/secp256k1@^4.0.6": - version "4.0.6" - resolved "https://registry.yarnpkg.com/@types/secp256k1/-/secp256k1-4.0.6.tgz#d60ba2349a51c2cbc5e816dcd831a42029d376bf" - integrity sha512-hHxJU6PAEUn0TP4S/ZOzuTUvJWuZ6eIKeNKb5RBpODvSl6hp1Wrw4s7ATY50rklRCScUDpHzVA/DQdSjJ3UoYQ== - dependencies: - "@types/node" "*" - "@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" @@ -1093,32 +1235,31 @@ resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== -"@wagmi/connectors@5.1.8": - version "5.1.8" - resolved "https://registry.yarnpkg.com/@wagmi/connectors/-/connectors-5.1.8.tgz#3793fecfa8bbe7c1b675f36103fc3bfdb8262e63" - integrity sha512-LdImInHFogis83/Yhq0vJLracIFUSl9m8961JEWS+lGDPuU2QbVg4Rv2VAfratfRoR8oDuSJNTvIvp9Kyiu5ug== +"@wagmi/connectors@5.3.3": + version "5.3.3" + resolved "https://registry.yarnpkg.com/@wagmi/connectors/-/connectors-5.3.3.tgz#ef823eeebeaa72852c0e5176bc5308f5cb8699ec" + integrity sha512-RUgwgqX7H+qg1lXBhLqcG0D5xb8USlAv4MVai4r5YpRw6lxpDvELFXxHN4ldZuUARKhH7Q3ZpfvdWyEXY+wn9w== dependencies: - "@coinbase/wallet-sdk" "4.0.4" - "@metamask/sdk" "0.27.0" + "@coinbase/wallet-sdk" "4.1.0" + "@metamask/sdk" "0.30.1" "@safe-global/safe-apps-provider" "0.18.3" "@safe-global/safe-apps-sdk" "9.1.0" - "@walletconnect/ethereum-provider" "2.15.2" - "@walletconnect/modal" "2.6.2" + "@walletconnect/ethereum-provider" "2.17.0" cbw-sdk "npm:@coinbase/wallet-sdk@3.9.3" -"@wagmi/core@2.13.4": - version "2.13.4" - resolved "https://registry.yarnpkg.com/@wagmi/core/-/core-2.13.4.tgz#8d5da08e450171bfe34f72a079cfa2b81825410a" - integrity sha512-J6gfxHYr8SCc/BzEa712LnI+qLFs5K2nBLupwQqQl4WiAlCu8SdcpbZokqiwfCMYhIRMj0+YFEP9qe4ypcexmw== +"@wagmi/core@2.14.1": + version "2.14.1" + resolved "https://registry.yarnpkg.com/@wagmi/core/-/core-2.14.1.tgz#e6adb8a350cfd7be4ea9c5581768f951c60127de" + integrity sha512-Vl7VK5XdKxPfnYlp3E7U7AJSweBdfh+cd953hgAU2H+uNrekS9Nmt89l1b6WkwkYyqvccRDjsCtlcKRwvPtNAQ== dependencies: eventemitter3 "5.0.1" mipd "0.0.7" - zustand "4.4.1" + zustand "5.0.0" -"@walletconnect/core@2.15.1": - version "2.15.1" - resolved "https://registry.yarnpkg.com/@walletconnect/core/-/core-2.15.1.tgz#98536057874246988428d9aadf4b25b23c3fd57f" - integrity sha512-9MWVt33MFrLiAeK9nqY/B30/y0M4uiq8v9EXenIBQdlgkmXM++RTcOnn7u7EAbthGgzx3WLPRm4ViwIb+rI/Cg== +"@walletconnect/core@2.16.1": + version "2.16.1" + resolved "https://registry.yarnpkg.com/@walletconnect/core/-/core-2.16.1.tgz#019b181387792e0d284e75074b961b48193d9b6a" + integrity sha512-UlsnEMT5wwFvmxEjX8s4oju7R3zadxNbZgsFeHEsjh7uknY2zgmUe1Lfc5XU6zyPb1Jx7Nqpdx1KN485ee8ogw== dependencies: "@walletconnect/heartbeat" "1.2.2" "@walletconnect/jsonrpc-provider" "1.0.14" @@ -1131,16 +1272,16 @@ "@walletconnect/relay-auth" "1.0.4" "@walletconnect/safe-json" "1.0.2" "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.15.1" - "@walletconnect/utils" "2.15.1" + "@walletconnect/types" "2.16.1" + "@walletconnect/utils" "2.16.1" events "3.3.0" lodash.isequal "4.5.0" uint8arrays "3.1.0" -"@walletconnect/core@2.15.2": - version "2.15.2" - resolved "https://registry.yarnpkg.com/@walletconnect/core/-/core-2.15.2.tgz#12d9da8c4e32a6c3713f421ca65cd0605f43a080" - integrity sha512-u4BGuazSNAQ48QBY7EphanBuBN6EJWyD5MXi83n1wXwfPQWAu0XNvmOjjF+xmMI5TsYH9N6Y78O6HP/VX9EOvg== +"@walletconnect/core@2.17.0": + version "2.17.0" + resolved "https://registry.yarnpkg.com/@walletconnect/core/-/core-2.17.0.tgz#bf490e85a4702eff0f7cf81ba0d3c1016dffff33" + integrity sha512-On+uSaCfWdsMIQsECwWHZBmUXfrnqmv6B8SXRRuTJgd8tUpEvBkLQH4X7XkSm3zW6ozEkQTCagZ2ox2YPn3kbw== dependencies: "@walletconnect/heartbeat" "1.2.2" "@walletconnect/jsonrpc-provider" "1.0.14" @@ -1153,8 +1294,8 @@ "@walletconnect/relay-auth" "1.0.4" "@walletconnect/safe-json" "1.0.2" "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.15.2" - "@walletconnect/utils" "2.15.2" + "@walletconnect/types" "2.17.0" + "@walletconnect/utils" "2.17.0" events "3.3.0" lodash.isequal "4.5.0" uint8arrays "3.1.0" @@ -1166,36 +1307,36 @@ dependencies: tslib "1.14.1" -"@walletconnect/ethereum-provider@2.15.1": - version "2.15.1" - resolved "https://registry.yarnpkg.com/@walletconnect/ethereum-provider/-/ethereum-provider-2.15.1.tgz#178c2063d5830671f50450d55abeaaf7627c117b" - integrity sha512-3ssEAKc/rLYshwyE2ZIaoTxzi/p9Ws+kj/FIsd1Ed/CC37Rl5l/KYHaRJtevWeni9s4dGqyqKsYkJ0VwwUcnfQ== +"@walletconnect/ethereum-provider@2.16.1": + version "2.16.1" + resolved "https://registry.yarnpkg.com/@walletconnect/ethereum-provider/-/ethereum-provider-2.16.1.tgz#4fb8a1df39104ad3fbd02579233e796f432f6d35" + integrity sha512-oD7DNCssUX3plS5gGUZ9JQ63muQB/vxO68X6RzD2wd8gBsYtSPw4BqYFc7KTO6dUizD6gfPirw32yW2pTvy92w== dependencies: "@walletconnect/jsonrpc-http-connection" "1.0.8" "@walletconnect/jsonrpc-provider" "1.0.14" "@walletconnect/jsonrpc-types" "1.0.4" "@walletconnect/jsonrpc-utils" "1.0.8" "@walletconnect/modal" "2.6.2" - "@walletconnect/sign-client" "2.15.1" - "@walletconnect/types" "2.15.1" - "@walletconnect/universal-provider" "2.15.1" - "@walletconnect/utils" "2.15.1" + "@walletconnect/sign-client" "2.16.1" + "@walletconnect/types" "2.16.1" + "@walletconnect/universal-provider" "2.16.1" + "@walletconnect/utils" "2.16.1" events "3.3.0" -"@walletconnect/ethereum-provider@2.15.2": - version "2.15.2" - resolved "https://registry.yarnpkg.com/@walletconnect/ethereum-provider/-/ethereum-provider-2.15.2.tgz#ed465031fa5e47f808d3f1bc42ab568d458b77db" - integrity sha512-POH2Wov2cXdASDDyv2bwY9Y2JzkGzGFS4SzltMt1zxKUMTyoJ8xKAgWaxoiJw0pqsLGY7T5msmk9qeKOavQtAA== +"@walletconnect/ethereum-provider@2.17.0": + version "2.17.0" + resolved "https://registry.yarnpkg.com/@walletconnect/ethereum-provider/-/ethereum-provider-2.17.0.tgz#d74feaaed6180a6799e96760d7ee867ff3a083d2" + integrity sha512-b+KTAXOb6JjoxkwpgYQQKPUcTwENGmdEdZoIDLeRicUmZTn/IQKfkMoC2frClB4YxkyoVMtj1oMV2JAax+yu9A== dependencies: "@walletconnect/jsonrpc-http-connection" "1.0.8" "@walletconnect/jsonrpc-provider" "1.0.14" "@walletconnect/jsonrpc-types" "1.0.4" "@walletconnect/jsonrpc-utils" "1.0.8" - "@walletconnect/modal" "2.6.2" - "@walletconnect/sign-client" "2.15.2" - "@walletconnect/types" "2.15.2" - "@walletconnect/universal-provider" "2.15.2" - "@walletconnect/utils" "2.15.2" + "@walletconnect/modal" "2.7.0" + "@walletconnect/sign-client" "2.17.0" + "@walletconnect/types" "2.17.0" + "@walletconnect/universal-provider" "2.17.0" + "@walletconnect/utils" "2.17.0" events "3.3.0" "@walletconnect/events@1.0.1", "@walletconnect/events@^1.0.1": @@ -1285,6 +1426,13 @@ dependencies: valtio "1.11.2" +"@walletconnect/modal-core@2.7.0": + version "2.7.0" + resolved "https://registry.yarnpkg.com/@walletconnect/modal-core/-/modal-core-2.7.0.tgz#73c13c3b7b0abf9ccdbac9b242254a86327ce0a4" + integrity sha512-oyMIfdlNdpyKF2kTJowTixZSo0PGlCJRdssUN/EZdA6H6v03hZnf09JnwpljZNfir2M65Dvjm/15nGrDQnlxSA== + dependencies: + valtio "1.11.2" + "@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" @@ -1295,6 +1443,16 @@ motion "10.16.2" qrcode "1.5.3" +"@walletconnect/modal-ui@2.7.0": + version "2.7.0" + resolved "https://registry.yarnpkg.com/@walletconnect/modal-ui/-/modal-ui-2.7.0.tgz#dbbb7ee46a5a25f7d39db622706f2d197b268cbb" + integrity sha512-gERYvU7D7K1ANCN/8vUgsE0d2hnRemfAFZ2novm9aZBg7TEd/4EgB+AqbJ+1dc7GhOL6dazckVq78TgccHb7mQ== + dependencies: + "@walletconnect/modal-core" "2.7.0" + lit "2.8.0" + motion "10.16.2" + qrcode "1.5.3" + "@walletconnect/modal@2.6.2": version "2.6.2" resolved "https://registry.yarnpkg.com/@walletconnect/modal/-/modal-2.6.2.tgz#4b534a836f5039eeb3268b80be7217a94dd12651" @@ -1303,12 +1461,13 @@ "@walletconnect/modal-core" "2.6.2" "@walletconnect/modal-ui" "2.6.2" -"@walletconnect/relay-api@1.0.10": - version "1.0.10" - resolved "https://registry.yarnpkg.com/@walletconnect/relay-api/-/relay-api-1.0.10.tgz#5aef3cd07c21582b968136179aa75849dcc65499" - integrity sha512-tqrdd4zU9VBNqUaXXQASaexklv6A54yEyQQEXYOCr+Jz8Ket0dmPBDyg19LVSNUN2cipAghQc45/KVmfFJ0cYw== +"@walletconnect/modal@2.7.0": + version "2.7.0" + resolved "https://registry.yarnpkg.com/@walletconnect/modal/-/modal-2.7.0.tgz#55f969796d104cce1205f5f844d8f8438b79723a" + integrity sha512-RQVt58oJ+rwqnPcIvRFeMGKuXb9qkgSmwz4noF8JZGUym3gUAzVs+uW2NQ1Owm9XOJAV+sANrtJ+VoVq1ftElw== dependencies: - "@walletconnect/jsonrpc-types" "^1.0.2" + "@walletconnect/modal-core" "2.7.0" + "@walletconnect/modal-ui" "2.7.0" "@walletconnect/relay-api@1.0.11": version "1.0.11" @@ -1336,34 +1495,34 @@ dependencies: tslib "1.14.1" -"@walletconnect/sign-client@2.15.1": - version "2.15.1" - resolved "https://registry.yarnpkg.com/@walletconnect/sign-client/-/sign-client-2.15.1.tgz#95b430164a8c6f3fe629531a5481dec9c9be02b4" - integrity sha512-YnLNEmCHgZ8yBpE3hwZnHD/bVznVMguSAlwLBNOoWUH2f4d9mR8bqa6KeVXqZ3e8mVHcxKTJTjTJ3oQMLyKIjw== +"@walletconnect/sign-client@2.16.1": + version "2.16.1" + resolved "https://registry.yarnpkg.com/@walletconnect/sign-client/-/sign-client-2.16.1.tgz#94a2f630ba741bd180f540c53576c5ceaace4857" + integrity sha512-s2Tx2n2duxt+sHtuWXrN9yZVaHaYqcEcjwlTD+55/vs5NUPlISf+fFmZLwSeX1kUlrSBrAuxPUcqQuRTKcjLOA== dependencies: - "@walletconnect/core" "2.15.1" + "@walletconnect/core" "2.16.1" "@walletconnect/events" "1.0.1" "@walletconnect/heartbeat" "1.2.2" "@walletconnect/jsonrpc-utils" "1.0.8" "@walletconnect/logger" "2.1.2" "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.15.1" - "@walletconnect/utils" "2.15.1" + "@walletconnect/types" "2.16.1" + "@walletconnect/utils" "2.16.1" events "3.3.0" -"@walletconnect/sign-client@2.15.2": - version "2.15.2" - resolved "https://registry.yarnpkg.com/@walletconnect/sign-client/-/sign-client-2.15.2.tgz#4568f71f6daebc6405d86278c78b64ef646c266b" - integrity sha512-Yp4/z3IdTMngbjr7Zy7Qi1X6EZDH4nxY91X6K2KpA3MjLW0yPTGalEJgJ4p9WH7fmHRlwvfR4hjwM5eQcLo5Zg== +"@walletconnect/sign-client@2.17.0": + version "2.17.0" + resolved "https://registry.yarnpkg.com/@walletconnect/sign-client/-/sign-client-2.17.0.tgz#efe811b1bb10082d964e2f0378aaa1b40f424503" + integrity sha512-sErYwvSSHQolNXni47L3Bm10ptJc1s1YoJvJd34s5E9h9+d3rj7PrhbiW9X82deN+Dm5oA8X9tC4xty1yIBrVg== dependencies: - "@walletconnect/core" "2.15.2" + "@walletconnect/core" "2.17.0" "@walletconnect/events" "1.0.1" "@walletconnect/heartbeat" "1.2.2" "@walletconnect/jsonrpc-utils" "1.0.8" "@walletconnect/logger" "2.1.2" "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.15.2" - "@walletconnect/utils" "2.15.2" + "@walletconnect/types" "2.17.0" + "@walletconnect/utils" "2.17.0" events "3.3.0" "@walletconnect/time@1.0.2", "@walletconnect/time@^1.0.2": @@ -1373,10 +1532,10 @@ dependencies: tslib "1.14.1" -"@walletconnect/types@2.14.0": - version "2.14.0" - resolved "https://registry.yarnpkg.com/@walletconnect/types/-/types-2.14.0.tgz#af3d4799b8ac5d166251af12bc024276f82f9b91" - integrity sha512-vevMi4jZLJ55vLuFOicQFmBBbLyb+S0sZS4IsaBdZkQflfGIq34HkN13c/KPl4Ye0aoR4/cUcUSitmGIzEQM5g== +"@walletconnect/types@2.16.1": + version "2.16.1" + resolved "https://registry.yarnpkg.com/@walletconnect/types/-/types-2.16.1.tgz#6583d458d3f7b1919d482ba516ccb7878ec8c91f" + integrity sha512-9P4RG4VoDEF+yBF/n2TF12gsvT/aTaeZTVDb/AOayafqiPnmrQZMKmNCJJjq1sfdsDcHXFcZWMGsuCeSJCmrXA== dependencies: "@walletconnect/events" "1.0.1" "@walletconnect/heartbeat" "1.2.2" @@ -1385,10 +1544,10 @@ "@walletconnect/logger" "2.1.2" events "3.3.0" -"@walletconnect/types@2.15.1": - version "2.15.1" - resolved "https://registry.yarnpkg.com/@walletconnect/types/-/types-2.15.1.tgz#5a093d28a32581e88fd4246690989099789f0830" - integrity sha512-4WkMsHD8ioZI5GmxNT0qMlz6msI7ZajBcTyDxfRncaNZVau0C+Btw1U4jWO+gxwJVDJY+Ue/cb1QKJ5BanZsyw== +"@walletconnect/types@2.17.0": + version "2.17.0" + resolved "https://registry.yarnpkg.com/@walletconnect/types/-/types-2.17.0.tgz#20eda5791e3172f8ab9146caa3f317701d4b3232" + integrity sha512-i1pn9URpvt9bcjRDkabuAmpA9K7mzyKoLJlbsAujRVX7pfaG7wur7u9Jz0bk1HxvuABL5LHNncTnVKSXKQ5jZA== dependencies: "@walletconnect/events" "1.0.1" "@walletconnect/heartbeat" "1.2.2" @@ -1397,72 +1556,40 @@ "@walletconnect/logger" "2.1.2" events "3.3.0" -"@walletconnect/types@2.15.2": - version "2.15.2" - resolved "https://registry.yarnpkg.com/@walletconnect/types/-/types-2.15.2.tgz#b9e1746d8c7b9c7b08ed8f6696c86e44b645fe52" - integrity sha512-TGnQZYWZJJ3I8dqgpMPwhO1IRXDuY8/tWPI0nNWJDyTK7b3E9prDGugnPmDDjpTYVoETnUTgW/jQaHNTq4yV7Q== - dependencies: - "@walletconnect/events" "1.0.1" - "@walletconnect/heartbeat" "1.2.2" - "@walletconnect/jsonrpc-types" "1.0.4" - "@walletconnect/keyvaluestorage" "1.1.1" - "@walletconnect/logger" "2.1.2" - events "3.3.0" - -"@walletconnect/universal-provider@2.15.1": - version "2.15.1" - resolved "https://registry.yarnpkg.com/@walletconnect/universal-provider/-/universal-provider-2.15.1.tgz#2c06faa0f22232ed09fd82b8a4ae047c3e56e9b4" - integrity sha512-JvKwHoE/ugWSKOmrEr03go1V79N0bbYV6w24Lqlzz4VAoReZZo8TDKsya7UkJ1L5HUCgKVP+AVktuJv8khzJ6w== +"@walletconnect/universal-provider@2.16.1": + version "2.16.1" + resolved "https://registry.yarnpkg.com/@walletconnect/universal-provider/-/universal-provider-2.16.1.tgz#6d52c41c7388e01f89007956a1117748ab9a11e4" + integrity sha512-q/tyWUVNenizuClEiaekx9FZj/STU1F3wpDK4PUIh3xh+OmUI5fw2dY3MaNDjyb5AyrS0M8BuQDeuoSuOR/Q7w== dependencies: "@walletconnect/jsonrpc-http-connection" "1.0.8" "@walletconnect/jsonrpc-provider" "1.0.14" "@walletconnect/jsonrpc-types" "1.0.4" "@walletconnect/jsonrpc-utils" "1.0.8" "@walletconnect/logger" "2.1.2" - "@walletconnect/sign-client" "2.15.1" - "@walletconnect/types" "2.15.1" - "@walletconnect/utils" "2.15.1" + "@walletconnect/sign-client" "2.16.1" + "@walletconnect/types" "2.16.1" + "@walletconnect/utils" "2.16.1" events "3.3.0" -"@walletconnect/universal-provider@2.15.2": - version "2.15.2" - resolved "https://registry.yarnpkg.com/@walletconnect/universal-provider/-/universal-provider-2.15.2.tgz#dad244f1b2cd89b35edba02819aae536fc008340" - integrity sha512-AWK5nUA4tJ57C8JDPOmqAWf5aF1VXIN4JpkqKekNKMP4+xiBTotKrwj0XD5xvtDUyaqjhRZPvYmUk24z1udrHA== +"@walletconnect/universal-provider@2.17.0": + version "2.17.0" + resolved "https://registry.yarnpkg.com/@walletconnect/universal-provider/-/universal-provider-2.17.0.tgz#c9d4bbd9b8f0e41b500b2488ccbc207dc5f7a170" + integrity sha512-d3V5Be7AqLrvzcdMZSBS8DmGDRdqnyLk1DWmRKAGgR6ieUWykhhUKlvfeoZtvJrIXrY7rUGYpH1X41UtFkW5Pw== dependencies: "@walletconnect/jsonrpc-http-connection" "1.0.8" "@walletconnect/jsonrpc-provider" "1.0.14" "@walletconnect/jsonrpc-types" "1.0.4" "@walletconnect/jsonrpc-utils" "1.0.8" "@walletconnect/logger" "2.1.2" - "@walletconnect/sign-client" "2.15.2" - "@walletconnect/types" "2.15.2" - "@walletconnect/utils" "2.15.2" + "@walletconnect/sign-client" "2.17.0" + "@walletconnect/types" "2.17.0" + "@walletconnect/utils" "2.17.0" events "3.3.0" -"@walletconnect/utils@2.14.0": - version "2.14.0" - resolved "https://registry.yarnpkg.com/@walletconnect/utils/-/utils-2.14.0.tgz#48493ffe1e902815fda3cbd5cc5409288a066d35" - integrity sha512-vRVomYQEtEAyCK2c5bzzEvtgxaGGITF8mWuIL+WYSAMyEJLY97mirP2urDucNwcUczwxUgI+no9RiNFbUHreQQ== - 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.10" - "@walletconnect/safe-json" "1.0.2" - "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.14.0" - "@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/utils@2.15.1": - version "2.15.1" - resolved "https://registry.yarnpkg.com/@walletconnect/utils/-/utils-2.15.1.tgz#4f90abe4869ee1cff6c0102c57b45e959811ca8d" - integrity sha512-i5AR8XpZdcX8ghaCjYV13Er/KAGe56c1mLaG9c2cv9kmnZMZijeMdInjX/flnSM1RFDUiZXvKPMUNwlCL4NsWw== +"@walletconnect/utils@2.16.1": + version "2.16.1" + resolved "https://registry.yarnpkg.com/@walletconnect/utils/-/utils-2.16.1.tgz#2099cc2bd16b0edc32022f64aa2c2c323b45d1d4" + integrity sha512-aoQirVoDoiiEtYeYDtNtQxFzwO/oCrz9zqeEEXYJaAwXlGVTS34KFe7W3/Rxd/pldTYKFOZsku2EzpISfH8Wsw== dependencies: "@stablelib/chacha20poly1305" "1.0.1" "@stablelib/hkdf" "1.0.1" @@ -1470,19 +1597,21 @@ "@stablelib/sha256" "1.0.1" "@stablelib/x25519" "1.0.3" "@walletconnect/relay-api" "1.0.11" + "@walletconnect/relay-auth" "1.0.4" "@walletconnect/safe-json" "1.0.2" "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.15.1" + "@walletconnect/types" "2.16.1" "@walletconnect/window-getters" "1.0.1" "@walletconnect/window-metadata" "1.0.1" detect-browser "5.3.0" + elliptic "^6.5.7" query-string "7.1.3" uint8arrays "3.1.0" -"@walletconnect/utils@2.15.2": - version "2.15.2" - resolved "https://registry.yarnpkg.com/@walletconnect/utils/-/utils-2.15.2.tgz#6fba3e28d00afe15b499409d609e3faafcef1887" - integrity sha512-H+fNH9cHDezdaEiEsO7/3URSIzqhumuacwB/+0PX0sSCoktmU9AfTqA8fJGG43zOPixleBqOymzO6owB1Y7jtQ== +"@walletconnect/utils@2.17.0": + version "2.17.0" + resolved "https://registry.yarnpkg.com/@walletconnect/utils/-/utils-2.17.0.tgz#02b3af0b80d0c1a994d692d829d066271b04d071" + integrity sha512-1aeQvjwsXy4Yh9G6g2eGmXrEl+BzkNjHRdCrGdMYqFTFa8ROEJfTGsSH3pLsNDlOY94CoBUvJvM55q/PMoN/FQ== dependencies: "@stablelib/chacha20poly1305" "1.0.1" "@stablelib/hkdf" "1.0.1" @@ -1493,7 +1622,7 @@ "@walletconnect/relay-auth" "1.0.4" "@walletconnect/safe-json" "1.0.2" "@walletconnect/time" "1.0.2" - "@walletconnect/types" "2.15.2" + "@walletconnect/types" "2.17.0" "@walletconnect/window-getters" "1.0.1" "@walletconnect/window-metadata" "1.0.1" detect-browser "5.3.0" @@ -1516,116 +1645,116 @@ "@walletconnect/window-getters" "^1.0.1" tslib "1.14.1" -"@web3modal/base@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/base/-/base-5.1.6.tgz#0743569118c58ae8d514005cd2e8311c510b2057" - integrity sha512-6oh4YX/mgSW1UoHnIGDX76HRwry/d1sefduAHcZAIZ9pUFxIYaTGx7ivIue3xpqb54fM2IW/d1uDi5Lernpxaw== - dependencies: - "@walletconnect/utils" "2.14.0" - "@web3modal/common" "5.1.6" - "@web3modal/core" "5.1.6" - "@web3modal/polyfills" "5.1.6" - "@web3modal/scaffold-ui" "5.1.6" - "@web3modal/scaffold-utils" "5.1.6" - "@web3modal/siwe" "5.1.6" - "@web3modal/ui" "5.1.6" - "@web3modal/wallet" "5.1.6" +"@web3modal/base@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/base/-/base-5.1.11.tgz#11beaca17fd0193d249174fb20da7bbb605abb2c" + integrity sha512-wJCsqQ1FG0Isiv0Exaz2Sv+FpijVmNPNay+sGdV5HP2SpBAR/1xxHca2/vLBdACX7rYAFAj723DYQE0fmUpIaw== + dependencies: + "@walletconnect/utils" "2.16.1" + "@web3modal/common" "5.1.11" + "@web3modal/core" "5.1.11" + "@web3modal/polyfills" "5.1.11" + "@web3modal/scaffold-ui" "5.1.11" + "@web3modal/scaffold-utils" "5.1.11" + "@web3modal/siwe" "5.1.11" + "@web3modal/ui" "5.1.11" + "@web3modal/wallet" "5.1.11" optionalDependencies: borsh "0.7.0" bs58 "5.0.0" -"@web3modal/common@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/common/-/common-5.1.6.tgz#375c5b064235a5a4ec3688bac0f1f137de3d6c8c" - integrity sha512-abqOjGjcyNdGjsOam3GuawTxI7KUAUC/1p8Wah0vVDtmQ34ruRVPlKy09tWe9zD3iHynNmRIyBaRIpwWhwLUAQ== +"@web3modal/common@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/common/-/common-5.1.11.tgz#29f6a0df6d6e1df7c3adb619efab08a6f20d4eab" + integrity sha512-YfSklKjjiM1RGxFTQm3ycYZ2Ktb6vswt9eg8lGXRknxN+SC7bCtuvgtyyCO0Z9/f9dPMOGIAmoJ/y6WHXWQqcg== dependencies: bignumber.js "9.1.2" dayjs "1.11.10" -"@web3modal/core@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/core/-/core-5.1.6.tgz#bfc51ac5fede8b731af44ccbc8795d687e3a5481" - integrity sha512-PI26WJyrMsBg2u1ehe33YHl4z8UDRQ8JrgM41Anca45N7zj0H/fzybemXk/dtZZqvV4E9MZheylJTucuwpQrBw== +"@web3modal/core@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/core/-/core-5.1.11.tgz#96406333c00ca949dbd1e8469e05b65d9c15551e" + integrity sha512-ugUVFVml1vVW+V7yxkn/AYYdrUJzn4ulFbDlxDMpmukKY6sDYLMMGAJ84O8ZC/OPyC7009NYd3mKZurxEyWkHw== dependencies: - "@web3modal/common" "5.1.6" - "@web3modal/wallet" "5.1.6" + "@web3modal/common" "5.1.11" + "@web3modal/wallet" "5.1.11" valtio "1.11.2" -"@web3modal/polyfills@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/polyfills/-/polyfills-5.1.6.tgz#8058c1de1a2170537526140337dc3b216cfafb38" - integrity sha512-hAqfDsxyO/LupMbSPDVvB0yKVCiNGcTPeDP7cCw7QZuBYyyz+Uqb7sO41n3hVkKGEMbHsA7Q6TfXiPfxEotX/w== +"@web3modal/polyfills@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/polyfills/-/polyfills-5.1.11.tgz#15f946e22c8d97dd43edc6fa8b7ff724c80e613d" + integrity sha512-BDIDYA2LGTCquahbZ+wyWQy4IBOPeKVSgt4ZpFir1fnVJUPkEluSwZStcKLtCzQvxJgER1sLicUrjJQHF36TOg== dependencies: buffer "6.0.3" -"@web3modal/scaffold-ui@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/scaffold-ui/-/scaffold-ui-5.1.6.tgz#12370ee4474fb6a073e6e40ad34bc55090056450" - integrity sha512-K+bZdvgFATo+uk5HmXx6gAM5aSECBNBIccY2S1pvX+taq6eF/KWVRMlH8vdO7UtXOu5rgJSoW2CSYKjwiWn01w== - dependencies: - "@web3modal/common" "5.1.6" - "@web3modal/core" "5.1.6" - "@web3modal/scaffold-utils" "5.1.6" - "@web3modal/siwe" "5.1.6" - "@web3modal/ui" "5.1.6" - "@web3modal/wallet" "5.1.6" +"@web3modal/scaffold-ui@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/scaffold-ui/-/scaffold-ui-5.1.11.tgz#8e0e30c5da898b23b63dc4da5b9682d6ce99ca67" + integrity sha512-fBqzd7DStUaEjtdbEU86rzY4XIgt8c8JN8oxS/xnUEopmjFYvBLCCVEfbTkZyJrRvAAphz7+oS4TVzXw9k6t5A== + dependencies: + "@web3modal/common" "5.1.11" + "@web3modal/core" "5.1.11" + "@web3modal/scaffold-utils" "5.1.11" + "@web3modal/siwe" "5.1.11" + "@web3modal/ui" "5.1.11" + "@web3modal/wallet" "5.1.11" lit "3.1.0" -"@web3modal/scaffold-utils@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/scaffold-utils/-/scaffold-utils-5.1.6.tgz#fe4e1122a5ff88864fe9404c8f9e0e0deb9d6480" - integrity sha512-u0hDjbhUgSpJ0RilmnkXAHl4iPTT58/z2C4FmF3cpQRYGkF9j70E1yVYVH/a+iXVbbiQdzC+8clT8mAfLjRzzg== +"@web3modal/scaffold-utils@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/scaffold-utils/-/scaffold-utils-5.1.11.tgz#85d880ca2ddea253ffb2f9fbccb9c9c3922ad107" + integrity sha512-4bcYpQ3oxak5mDZMW5/7ayrhpaJHy6dCfUio15AGPHnQlFjkqcfSuuG0Io8Oj8VUXcK2UBLch9YiEDz4Xgce9Q== dependencies: - "@web3modal/common" "5.1.6" - "@web3modal/core" "5.1.6" - "@web3modal/polyfills" "5.1.6" - "@web3modal/wallet" "5.1.6" + "@web3modal/common" "5.1.11" + "@web3modal/core" "5.1.11" + "@web3modal/polyfills" "5.1.11" + "@web3modal/wallet" "5.1.11" valtio "1.11.2" -"@web3modal/siwe@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/siwe/-/siwe-5.1.6.tgz#37e826e5019906f3fc1f2023aee8a917f3f2107f" - integrity sha512-0usevyccWYaNNmaVvD8I2mN2xKGFyv3aMgD1fkV5NOVAJ8+mLj/TiQr3Ts/X3x7L7b1Tq/hxXkr/mF2CUh+vCA== - dependencies: - "@walletconnect/utils" "2.15.1" - "@web3modal/common" "5.1.6" - "@web3modal/core" "5.1.6" - "@web3modal/scaffold-utils" "5.1.6" - "@web3modal/ui" "5.1.6" - "@web3modal/wallet" "5.1.6" +"@web3modal/siwe@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/siwe/-/siwe-5.1.11.tgz#f68a43e7d5c5417ebfb85f82ce3478db4c5bc780" + integrity sha512-1aKEtMosACyY0SRjHjdcA/g3bRtMojTxlK7S/T6zBk57X/P3xcEZq9J8UM73plmGewjZdLaqGMgv6B/k/WleZQ== + dependencies: + "@walletconnect/utils" "2.16.1" + "@web3modal/common" "5.1.11" + "@web3modal/core" "5.1.11" + "@web3modal/scaffold-utils" "5.1.11" + "@web3modal/ui" "5.1.11" + "@web3modal/wallet" "5.1.11" lit "3.1.0" valtio "1.11.2" -"@web3modal/ui@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/ui/-/ui-5.1.6.tgz#0a75fdbc883e7609061cbd525a7d0b73097a875f" - integrity sha512-VOZ/9ioQITtQeH59I5lHQq4o0SXPzzCs4Jw72CocVZV5KhZ+BgCqGmJnAjJ0Ljq8c9ofR6Mj3E0Dzgn2lqoL7Q== +"@web3modal/ui@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/ui/-/ui-5.1.11.tgz#1bb5bdf3a54bbdf7d0068fdb65a46bc921da160c" + integrity sha512-L0L+2YOK+ONx+W7GPtkSdKZuAQ8cjcS5N8kp+WZzKOMUTeDLuXKtSnES4p/ShOVmkpV6qB8r0pPA9xgFh1D3ow== dependencies: lit "3.1.0" qrcode "1.5.3" -"@web3modal/wagmi@^5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/wagmi/-/wagmi-5.1.6.tgz#6afed0323f4a47cdcb5662e57f5f4c366917664b" - integrity sha512-zwA+4Tm9PiZxaiLqWrooacCWgzKHbxQlwUOyLtySXtTgVUK6DcLftCNaMk8MPni6ePy0pyPDngi5COUxGHy+OA== - dependencies: - "@walletconnect/ethereum-provider" "2.15.1" - "@walletconnect/utils" "2.15.1" - "@web3modal/base" "5.1.6" - "@web3modal/common" "5.1.6" - "@web3modal/polyfills" "5.1.6" - "@web3modal/scaffold-utils" "5.1.6" - "@web3modal/siwe" "5.1.6" - "@web3modal/wallet" "5.1.6" - -"@web3modal/wallet@5.1.6": - version "5.1.6" - resolved "https://registry.yarnpkg.com/@web3modal/wallet/-/wallet-5.1.6.tgz#619ea3c7620c245c7eccb4d3e022d443e201649c" - integrity sha512-ai9FquMAyWPelcS4IOSj2p/xIf6chfN9fR37o5f6719wVZzX1j+m+E2WF25QdcN8RjKep21j/dtRYIgDtTpIrA== +"@web3modal/wagmi@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/wagmi/-/wagmi-5.1.11.tgz#19835c4905458d879b797da556acbf9a9ab721ee" + integrity sha512-etV1qfBVvh41EMuBHXUpcO/W818jZVNh5/l9Z5kqRPZxlQmBaJbt5mTzw6nw/Lujoe1yYKugGQFhgjfEQK+eyA== + dependencies: + "@walletconnect/ethereum-provider" "2.16.1" + "@walletconnect/utils" "2.16.1" + "@web3modal/base" "5.1.11" + "@web3modal/common" "5.1.11" + "@web3modal/polyfills" "5.1.11" + "@web3modal/scaffold-utils" "5.1.11" + "@web3modal/siwe" "5.1.11" + "@web3modal/wallet" "5.1.11" + +"@web3modal/wallet@5.1.11": + version "5.1.11" + resolved "https://registry.yarnpkg.com/@web3modal/wallet/-/wallet-5.1.11.tgz#3118bb1fa370436c252d7d97c731eac585cdb8a7" + integrity sha512-/ooQZXK1h7LGBUemebldYPAV2oJAgxkgSiCMoHWynhuS0LO3BzhOhGL+jV19w4iU81bS1GSNFTxYT9LL6Scesw== dependencies: "@walletconnect/logger" "2.1.2" - "@web3modal/common" "5.1.6" - "@web3modal/polyfills" "5.1.6" + "@web3modal/common" "5.1.11" + "@web3modal/polyfills" "5.1.11" zod "3.22.4" abitype@1.0.5: @@ -1633,6 +1762,11 @@ abitype@1.0.5: resolved "https://registry.yarnpkg.com/abitype/-/abitype-1.0.5.tgz#29d0daa3eea867ca90f7e4123144c1d1270774b6" integrity sha512-YzDhti7cjlfaBhHutMaboYB21Ha3rXR9QTkNJFzYC4kC8YclaiwPBBBJY8ejFdu2wnJeZCVZSMlQJ7fi8S6hsw== +abitype@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/abitype/-/abitype-1.0.6.tgz#76410903e1d88e34f1362746e2d407513c38565b" + integrity sha512-MMSqYh4+C/aVqI2RQaWqbvI4Kxo5cQV40WQ4QFtDnNzCkqChm8MuENhElmynZlO0qUy/ObkEUaXtKqYnx1Kp3A== + abort-controller@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" @@ -2035,7 +2169,7 @@ citty@^0.1.5, citty@^0.1.6: dependencies: consola "^3.2.3" -class-variance-authority@^0.7.0: +class-variance-authority@0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/class-variance-authority/-/class-variance-authority-0.7.0.tgz#1c3134d634d80271b1837452b06d821915954522" integrity sha512-jFI8IQw4hczaL4ALINxqLEXQbWcNjoSkloa4IaufXCJr6QawJyw7tuRysRsrE8w2p/4gGaxKIt/hX3qz/IbD1A== @@ -2065,30 +2199,21 @@ cliui@^6.0.0: strip-ansi "^6.0.0" wrap-ansi "^6.2.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== - dependencies: - string-width "^4.2.0" - strip-ansi "^6.0.1" - wrap-ansi "^7.0.0" - clsx@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/clsx/-/clsx-2.0.0.tgz#12658f3fd98fafe62075595a5c30e43d18f3d00b" integrity sha512-rQ1+kcj+ttHG0MKVGBUXwayCCF1oh39BF5COIpRzuCEv8Mwjv0XucrI2ExNTOn9IlLifGClWQcU9BrZORvtw6Q== +clsx@2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/clsx/-/clsx-2.1.1.tgz#eed397c9fd8bd882bfb18deab7102049a2f32999" + integrity sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA== + clsx@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/clsx/-/clsx-1.2.1.tgz#0ddc4a20a549b59c93a4116bb26f5294ca17dc12" integrity sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg== -clsx@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/clsx/-/clsx-2.1.1.tgz#eed397c9fd8bd882bfb18deab7102049a2f32999" - integrity sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA== - color-convert@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" @@ -2101,6 +2226,11 @@ color-name@~1.1.4: resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== +colorette@^2.0.7: + version "2.0.20" + resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.20.tgz#9eb793e6833067f7235902fcd3b09917a000a95a" + integrity sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w== + commander@^4.0.0: version "4.1.1" resolved "https://registry.yarnpkg.com/commander/-/commander-4.1.1.tgz#9fd602bd936294e9e9ef46a3f4d6964044b18068" @@ -2213,6 +2343,11 @@ date-fns@^2.29.3: dependencies: "@babel/runtime" "^7.21.0" +dateformat@^4.6.3: + version "4.6.3" + resolved "https://registry.yarnpkg.com/dateformat/-/dateformat-4.6.3.tgz#556fa6497e5217fedb78821424f8a1c22fa3f4b5" + integrity sha512-2P0p0pFGzHS5EMnhdxQi7aJN+iMheud0UhG4dlE1DLAlvL8JHjJJTX/CSm4JXwV0Ka5nGk3zC5mcb5bUQUxxMA== + dayjs@1.11.10: version "1.11.10" resolved "https://registry.yarnpkg.com/dayjs/-/dayjs-1.11.10.tgz#68acea85317a6e164457d6d6947564029a6a16a0" @@ -2280,11 +2415,6 @@ define-data-property@^1.0.1, 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, 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" @@ -2365,16 +2495,17 @@ eastasianwidth@^0.2.0: resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.2.0.tgz#696ce2ec0aa0e6ea93a397ffcf24aa7840c827cb" integrity sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA== -eciesjs@^0.3.15: - version "0.3.20" - resolved "https://registry.yarnpkg.com/eciesjs/-/eciesjs-0.3.20.tgz#ef66d0304415e88810aef5823bfd5ce6021d2212" - integrity sha512-Rz5AB8v9+xmMdS/R7RzWPe/R8DP5QfyrkA6ce4umJopoB5su2H2aDy/GcgIfwhmCwxnBkqGf/PbGzmKcGtIgGA== +eciesjs@^0.4.8: + version "0.4.10" + resolved "https://registry.yarnpkg.com/eciesjs/-/eciesjs-0.4.10.tgz#7548ae8385809d1b81529ebe48b87d8549941270" + integrity sha512-dYAgdXAC7/d9fEC0w6kpRWj5vHah2BQgMM639g78JI0FUUffMN2Mq60HEHPkyH8ah+FX+cQd6ouDK4kWiatzyw== dependencies: - "@types/secp256k1" "^4.0.6" - futoin-hkdf "^1.5.3" - secp256k1 "^5.0.0" + "@ecies/ciphers" "^0.2.0" + "@noble/ciphers" "^1.0.0" + "@noble/curves" "^1.6.0" + "@noble/hashes" "^1.5.0" -elliptic@^6.5.4, elliptic@^6.5.7: +elliptic@^6.5.7: version "6.5.7" resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.7.tgz#8ec4da2cb2939926a1b9a73619d768207e647c8b" integrity sha512-ESVCtTwiA+XhY3wyh24QqRGBoP3rEdDUl3EDUUo9tft074fi19IrdpH7hLCMMP3CIj7jb3W96rn8lt/BqIlt5Q== @@ -2402,6 +2533,13 @@ encode-utf8@^1.0.3: resolved "https://registry.yarnpkg.com/encode-utf8/-/encode-utf8-1.0.3.tgz#f30fdd31da07fb596f281beb2f6b027851994cda" integrity sha512-ucAnuBEhUK4boH2HjVYG5Q2mQyPorvv0u/ocS+zhdw0S8AlHYY+GOFhP1Gio5z4icpP2ivFSvhtFjQi8+T9ppw== +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" + end-of-stream@^1.1.0, end-of-stream@^1.4.0, 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" @@ -2564,11 +2702,6 @@ es-to-primitive@^1.2.1: is-date-object "^1.0.1" is-symbol "^1.0.2" -escalade@^3.1.1: - version "3.2.0" - resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.2.0.tgz#011a3f69856ba189dffa7dc8fcce99d2a87903e5" - integrity sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA== - escape-string-regexp@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344" @@ -2879,6 +3012,11 @@ extension-port-stream@^3.0.0: readable-stream "^3.6.2 || ^4.4.2" webextension-polyfill ">=0.10.0 <1.0" +fast-copy@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/fast-copy/-/fast-copy-3.0.2.tgz#59c68f59ccbcac82050ba992e0d5c389097c9d35" + integrity sha512-dl0O9Vhju8IrcLndv2eU4ldt1ftXMqqfgN4H1cpmGV7P6jeB9FwpN9a2c8DPGE1Ys88rNUJVYDHq73CGAGOPfQ== + fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: version "3.1.3" resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" @@ -2910,7 +3048,7 @@ fast-redact@^3.0.0: resolved "https://registry.yarnpkg.com/fast-redact/-/fast-redact-3.5.0.tgz#e9ea02f7e57d0cd8438180083e93077e496285e4" integrity sha512-dwsoQlS7h9hMeYUq1W++23NDcBLV4KqONnITDV9DjfS3q1SgDGVrBdvvTLUotWtPSD7asWDV9/CmsZPy8Hf70A== -fast-safe-stringify@^2.0.6: +fast-safe-stringify@^2.0.6, fast-safe-stringify@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz#c406a83b6e70d9e35ce3b30a81141df30aeba884" integrity sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA== @@ -3016,12 +3154,7 @@ functions-have-names@^1.2.3: resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== -futoin-hkdf@^1.5.3: - version "1.5.3" - resolved "https://registry.yarnpkg.com/futoin-hkdf/-/futoin-hkdf-1.5.3.tgz#6c8024f2e1429da086d4e18289ef2239ad33ee35" - integrity sha512-SewY5KdMpaoCeh7jachEWFsh1nNlaDjNHZXWqL5IGwtpEYHTgkr2+AMCgNwKWkcc0wpSYrZfR7he4WdmHFtDxQ== - -get-caller-file@^2.0.1, 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== @@ -3221,6 +3354,11 @@ hasown@^2.0.0, hasown@^2.0.1, hasown@^2.0.2: dependencies: function-bind "^1.1.2" +help-me@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/help-me/-/help-me-5.0.0.tgz#b1ebe63b967b74060027c2ac61f9be12d354a6f6" + integrity sha512-7xgomUX6ADmcYzFik0HzAxh/73YlKR9bmFzf51CZwR+b6YtzU2m0u49hQCqV6SvlqIqsaxovfwdvbnsw3b/zpg== + hey-listen@^1.0.8: version "1.0.8" resolved "https://registry.yarnpkg.com/hey-listen/-/hey-listen-1.0.8.tgz#8e59561ff724908de1aa924ed6ecc84a56a9aa68" @@ -3259,6 +3397,13 @@ i18next@23.11.5: dependencies: "@babel/runtime" "^7.23.2" +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" + idb-keyval@^6.2.1: version "6.2.1" resolved "https://registry.yarnpkg.com/idb-keyval/-/idb-keyval-6.2.1.tgz#94516d625346d16f56f3b33855da11bfded2db33" @@ -3399,11 +3544,6 @@ 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" @@ -3545,13 +3685,6 @@ is-weakset@^2.0.3: call-bind "^1.0.7" get-intrinsic "^1.2.4" -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== - dependencies: - is-docker "^2.0.0" - is-wsl@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-3.1.0.tgz#e1c657e39c10090afcbedec61720f6b924c3cbd2" @@ -3586,6 +3719,11 @@ isows@1.0.4: resolved "https://registry.yarnpkg.com/isows/-/isows-1.0.4.tgz#810cd0d90cc4995c26395d2aa4cfa4037ebdf061" integrity sha512-hEzjY+x9u9hPmBom9IIAqdJCwNLax+xrPb51vEPpERoFlIxgmZcHzsT5jKG06nvInKOBGvReAVz80Umed5CczQ== +isows@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/isows/-/isows-1.0.6.tgz#0da29d706fa51551c663c627ace42769850f86e7" + integrity sha512-lPHCayd40oW98/I0uvgaHKWCSvkzY27LjWLbtzOm64yQ+G3Q5npjjbdppU65iZXkK1Zt+kH9pfegli0AYfwYYw== + iterator.prototype@^1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/iterator.prototype/-/iterator.prototype-1.1.2.tgz#5e29c8924f01916cb9335f1ff80619dcff22b0c0" @@ -3620,6 +3758,11 @@ jiti@^1.21.0: resolved "https://registry.yarnpkg.com/jiti/-/jiti-1.21.6.tgz#6c7f7398dd4b3142767f9a168af2f317a428d268" integrity sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w== +joycon@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/joycon/-/joycon-3.1.1.tgz#bce8596d6ae808f8b68168f5fc69280996894f03" + integrity sha512-34wB/Y7MW7bzjKRjUKTa46I2Z7eV62Rkhva+KkopW7Qvv/OSWBqvkSY7vusOPrNuZcUG3tApvdVgNB8POj3SPw== + "js-tokens@^3.0.0 || ^4.0.0": version "4.0.0" resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" @@ -3843,7 +3986,7 @@ lru-cache@^10.2.0, lru-cache@^10.4.3: resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-10.4.3.tgz#410fc8a17b70e598013df257c2446b7f3383f119" integrity sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ== -lucide-react@^0.439.0: +lucide-react@0.439.0: version "0.439.0" resolved "https://registry.yarnpkg.com/lucide-react/-/lucide-react-0.439.0.tgz#eb9250e7255e56460ed37b68e807717c534395d6" integrity sha512-PafSWvDTpxdtNEndS2HIHxcNAbd54OaqSYJO90/b63rab2HWYqDbH194j0i82ZFdWOAcf0AHinRykXRRK2PJbw== @@ -3993,7 +4136,7 @@ natural-compare@^1.4.0: resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== -next-themes@^0.3.0: +next-themes@0.3.0: version "0.3.0" resolved "https://registry.yarnpkg.com/next-themes/-/next-themes-0.3.0.tgz#b4d2a866137a67d42564b07f3a3e720e2ff3871a" integrity sha512-/QHIrsYpd6Kfk7xakK4svpDI5mmXP0gfvCoJdGpZQ2TOrQZmsW0QxjaiLn8wbIKjtm4BTSqLoix4lxYYOnLJ/w== @@ -4026,11 +4169,6 @@ node-addon-api@^2.0.0: resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-2.0.2.tgz#432cfa82962ce494b132e9d72a15b29f71ff5d32" integrity sha512-Ntyt4AIXyaLIuMHF6IOoTakB3K+RWxwtsHNRxllEoA6vPwP9o4866g6YWDLUdnucilZhmkxiHwHr11gAENw+QA== -node-addon-api@^5.0.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-5.1.0.tgz#49da1ca055e109a23d537e9de43c09cca21eb762" - integrity sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA== - node-addon-api@^7.0.0: version "7.1.1" resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-7.1.1.tgz#1aba6693b0f255258a049d621329329322aad558" @@ -4173,6 +4311,11 @@ on-exit-leak-free@^0.2.0: resolved "https://registry.yarnpkg.com/on-exit-leak-free/-/on-exit-leak-free-0.2.0.tgz#b39c9e3bf7690d890f4861558b0d7b90a442d209" integrity sha512-dqaz3u44QbRXQooZLTUKU41ZrzYrcvLISVgbrzbyCMxpmSLJvZ3ZamIJIZ29P6OhZIkNIQKosdeM6t1LYbA9hg== +on-exit-leak-free@^2.1.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/on-exit-leak-free/-/on-exit-leak-free-2.1.2.tgz#fed195c9ebddb7d9e4c3842f93f281ac8dadd3b8" + integrity sha512-0eJJY6hXLGf1udHwfNftBqH+g73EU4B504nZeKpz1sYRKafAghwxEJunB2O7rDZkL4PGfsMVnTXZ2EjibbqcsA== + once@^1.3.0, once@^1.3.1, once@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" @@ -4187,15 +4330,6 @@ onetime@^6.0.0: dependencies: mimic-fn "^4.0.0" -open@^8.4.0: - 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" - optionator@^0.9.3: version "0.9.4" resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.4.tgz#7ea1c1a5d91d764fb282139c88fe11e182a3a734" @@ -4321,6 +4455,13 @@ pify@^5.0.0: resolved "https://registry.yarnpkg.com/pify/-/pify-5.0.0.tgz#1f5eca3f5e87ebec28cc6d54a0e4aaf00acc127f" integrity sha512-eW/gHNMlxdSP6dmG6uJip6FXN0EQBwm2clYYd8Wul42Cwu/DK8HEftzsapcNdYe2MfLiIwZqsDk2RDEsTE79hA== +pino-abstract-transport@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/pino-abstract-transport/-/pino-abstract-transport-2.0.0.tgz#de241578406ac7b8a33ce0d77ae6e8a0b3b68a60" + integrity sha512-F63x5tizV6WCh4R6RHyi2Ml+M70DNRXt/+HANowMflpgGFMAym/VKm6G7ZOQRjqN7XbGxK1Lg9t6ZrtzOaivMw== + dependencies: + split2 "^4.0.0" + 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" @@ -4329,6 +4470,26 @@ pino-abstract-transport@v0.5.0: duplexify "^4.1.2" split2 "^4.0.0" +pino-pretty@^11.3.0: + version "11.3.0" + resolved "https://registry.yarnpkg.com/pino-pretty/-/pino-pretty-11.3.0.tgz#390b3be044cf3d2e9192c7d19d44f6b690468f2e" + integrity sha512-oXwn7ICywaZPHmu3epHGU2oJX4nPmKvHvB/bwrJHlGcbEWaVcotkpyVHMKLKmiVryWYByNp0jpgAcXpFJDXJzA== + dependencies: + colorette "^2.0.7" + dateformat "^4.6.3" + fast-copy "^3.0.2" + fast-safe-stringify "^2.1.1" + help-me "^5.0.0" + joycon "^3.1.1" + minimist "^1.2.6" + on-exit-leak-free "^2.1.0" + pino-abstract-transport "^2.0.0" + pump "^3.0.0" + readable-stream "^4.0.0" + secure-json-parse "^2.4.0" + sonic-boom "^4.0.1" + strip-json-comments "^3.1.1" + pino-std-serializers@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/pino-std-serializers/-/pino-std-serializers-4.0.0.tgz#1791ccd2539c091ae49ce9993205e2cd5dbba1e2" @@ -4546,7 +4707,7 @@ radix3@^1.1.2: resolved "https://registry.yarnpkg.com/radix3/-/radix3-1.1.2.tgz#fd27d2af3896c6bf4bcdfab6427c69c2afc69ec0" integrity sha512-b484I/7b8rDEdSDKckSSBA8knMpcdsXudlE/LNL639wFoHKwLbEkQFZHWEYwDC0wa0FKUcCY+GAF73Z7wxNVFA== -react-dom@^18: +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== @@ -4567,7 +4728,7 @@ react-native-webview@^11.26.0: escape-string-regexp "2.0.0" invariant "2.2.4" -react@^18: +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== @@ -4603,7 +4764,7 @@ readable-stream@^3.1.1, readable-stream@^3.6.0, readable-stream@^3.6.2: string_decoder "^1.1.1" util-deprecate "^1.0.1" -"readable-stream@^3.6.2 || ^4.4.2": +"readable-stream@^3.6.2 || ^4.4.2", readable-stream@^4.0.0: version "4.5.2" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-4.5.2.tgz#9e7fc4c45099baeed934bff6eb97ba6cf2729e09" integrity sha512-yjavECdqeZ3GLXNgRXgeQEdz9fvDDkNKyHnbHRFtOr7/LcfgBcmct7t/ET+HaCTqfh06OzoAxrkN/IfjJBVe+g== @@ -4704,16 +4865,6 @@ rimraf@^3.0.2: dependencies: glob "^7.1.3" -rollup-plugin-visualizer@^5.9.2: - version "5.12.0" - resolved "https://registry.yarnpkg.com/rollup-plugin-visualizer/-/rollup-plugin-visualizer-5.12.0.tgz#661542191ce78ee4f378995297260d0c1efb1302" - integrity sha512-8/NU9jXcHRs7Nnj07PF2o4gjxmm9lXIrZ8r175bT9dK8qoLlvKTwRMArRCMgpMGlq8CTLugRvEmyMeMXIU2pNQ== - dependencies: - open "^8.4.0" - picomatch "^2.3.1" - source-map "^0.7.4" - yargs "^17.5.1" - run-parallel@^1.1.9: version "1.2.0" resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" @@ -4755,6 +4906,11 @@ safe-stable-stringify@^2.1.0: resolved "https://registry.yarnpkg.com/safe-stable-stringify/-/safe-stable-stringify-2.5.0.tgz#4ca2f8e385f2831c432a719b108a3bf7af42a1dd" integrity sha512-b3rppTKm9T+PsVCBEOUR46GWI7fdOs00VKZ1+9c1EWDaDMvjQc6tUwuFyIprgGgTcWoVHSKrU8H31ZHA2e0RHA== +"safer-buffer@>= 2.1.2 < 3.0.0": + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + scheduler@^0.23.2: version "0.23.2" resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.2.tgz#414ba64a3b282892e944cf2108ecc078d115cdc3" @@ -4762,14 +4918,10 @@ scheduler@^0.23.2: dependencies: loose-envify "^1.1.0" -secp256k1@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/secp256k1/-/secp256k1-5.0.0.tgz#be6f0c8c7722e2481e9773336d351de8cddd12f7" - integrity sha512-TKWX8xvoGHrxVdqbYeZM9w+izTF4b9z3NhSaDkdn81btvuh+ivbIMGT/zQvDtTFWhRlThpoz6LEYTr7n8A5GcA== - dependencies: - elliptic "^6.5.4" - node-addon-api "^5.0.0" - node-gyp-build "^4.2.0" +secure-json-parse@^2.4.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/secure-json-parse/-/secure-json-parse-2.7.0.tgz#5a5f9cd6ae47df23dba3151edd06855d47e09862" + integrity sha512-6aU+Rwsezw7VR8/nyvKTx8QpWH9FrcYiXXlqC4z5d5XQBDRqtbfsRjnwGyqbi3gddNtWHuEk9OANUotL26qKUw== semver@^6.3.1: version "6.3.1" @@ -4873,16 +5025,18 @@ sonic-boom@^2.2.1: dependencies: atomic-sleep "^1.0.0" +sonic-boom@^4.0.1: + version "4.2.0" + resolved "https://registry.yarnpkg.com/sonic-boom/-/sonic-boom-4.2.0.tgz#e59a525f831210fa4ef1896428338641ac1c124d" + integrity sha512-INb7TM37/mAcsGmc9hyyI6+QR3rR1zVRu36B0NeGXKnOOLiZOfER5SA+N7X7k3yUYRzLWafduTDvJAfDswwEww== + dependencies: + atomic-sleep "^1.0.0" + source-map-js@^1.0.2, source-map-js@^1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.2.0.tgz#16b809c162517b5b8c3e7dcd315a2a5c2612b2af" integrity sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg== -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== - 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" @@ -4920,7 +5074,16 @@ strict-uri-encode@^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-width-cjs@npm:string-width@^4.2.0", string-width@^4.1.0, string-width@^4.2.0, 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== + dependencies: + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.1" + +string-width@^4.1.0, 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== @@ -5014,7 +5177,14 @@ string_decoder@~1.1.1: dependencies: safe-buffer "~5.1.0" -"strip-ansi-cjs@npm:strip-ansi@^6.0.1", strip-ansi@^6.0.0, strip-ansi@^6.0.1: +"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.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== @@ -5085,12 +5255,12 @@ system-architecture@^0.1.0: resolved "https://registry.yarnpkg.com/system-architecture/-/system-architecture-0.1.0.tgz#71012b3ac141427d97c67c56bc7921af6bff122d" integrity sha512-ulAk51I9UVUyJgxlv9M6lFot2WP3e7t8Kz9+IS6D4rVba1tR9kON+Ey69f+1R4Q8cd45Lod6a4IcJIxnzGc/zA== -tailwind-merge@^2.5.2: +tailwind-merge@2.5.2: version "2.5.2" resolved "https://registry.yarnpkg.com/tailwind-merge/-/tailwind-merge-2.5.2.tgz#000f05a703058f9f9f3829c644235f81d4c08a1f" integrity sha512-kjEBm+pvD+6eAwzJL2Bi+02/9LFLal1Gs61+QB7HvTfQQ0aXwC5LGT8PEt1gS0CWKktKe6ysPTAy3cBC5MeiIg== -tailwindcss-animate@^1.0.7: +tailwindcss-animate@1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/tailwindcss-animate/-/tailwindcss-animate-1.0.7.tgz#318b692c4c42676cc9e67b19b78775742388bef4" integrity sha512-bl6mpH3T7I3UFxuvDEXLxy/VuFxBk5bbzplh7tXI68mwMokNYd1t9qPBHlnyTwfa4JGC4zP516I1hYYtQ/vspA== @@ -5395,7 +5565,22 @@ valtio@1.11.2: proxy-compare "2.5.1" use-sync-external-store "1.2.0" -viem@^2.1.1, viem@^2.21.1: +viem@2.21.40, viem@2.x: + version "2.21.40" + resolved "https://registry.yarnpkg.com/viem/-/viem-2.21.40.tgz#d73a515e3eaf2a7ec2394d1de3d8409bf4bd2e21" + integrity sha512-no/mE3l7B0mdUTtvO7z/cTLENttQ/M7+ombqFGXJqsQrxv9wrYsTIGpS3za+FA5a447hY+x9D8Wxny84q1zAaA== + dependencies: + "@adraffy/ens-normalize" "1.11.0" + "@noble/curves" "1.6.0" + "@noble/hashes" "1.5.0" + "@scure/bip32" "1.5.0" + "@scure/bip39" "1.4.0" + abitype "1.0.6" + isows "1.0.6" + webauthn-p256 "0.0.10" + ws "8.18.0" + +viem@^2.1.1: version "2.21.1" resolved "https://registry.yarnpkg.com/viem/-/viem-2.21.1.tgz#7d07e4302297d1b44b4c97b8fece3b6ebb73b1ef" integrity sha512-nlIc2LLS6aqkngULS9UJ2Sg3nHKAgF9bbpDUwjUoAUBijd69mrCWPBXQ8jmbzcx12uZUfd9Nc//CHgSVZiMwyg== @@ -5410,15 +5595,23 @@ viem@^2.1.1, viem@^2.21.1: webauthn-p256 "0.0.5" ws "8.17.1" -wagmi@^2.12.8: - version "2.12.8" - resolved "https://registry.yarnpkg.com/wagmi/-/wagmi-2.12.8.tgz#1ab44cd6fa3959f72c00f4dc1732e00668299068" - integrity sha512-+HP3T02La4rIbBWF2mAVX63CykTGMQt77WN1PzZco7MWeUtjYeutwmnNjkDWWE7HFVZHZqNTVFYe3sbtu2LR4A== +wagmi@2.12.25: + version "2.12.25" + resolved "https://registry.yarnpkg.com/wagmi/-/wagmi-2.12.25.tgz#0e4f23a96e021143f202c250ec0af3a5ea0cca08" + integrity sha512-RdQCDbTv1+b7fWCAoLEYX0loymqLnhmNrMZq1gfPEs6cOhEHYOQeZtJWnyaXOD5+3xIFw+xoA0xDNvAHVbtbKw== dependencies: - "@wagmi/connectors" "5.1.8" - "@wagmi/core" "2.13.4" + "@wagmi/connectors" "5.3.3" + "@wagmi/core" "2.14.1" use-sync-external-store "1.2.0" +webauthn-p256@0.0.10: + version "0.0.10" + resolved "https://registry.yarnpkg.com/webauthn-p256/-/webauthn-p256-0.0.10.tgz#877e75abe8348d3e14485932968edf3325fd2fdd" + integrity sha512-EeYD+gmIT80YkSIDb2iWq0lq2zbHo1CxHlQTeJ+KkCILWpVy3zASH3ByD4bopzfk0uCwXxLqKGLqp2W4O28VFA== + dependencies: + "@noble/curves" "^1.4.0" + "@noble/hashes" "^1.4.0" + webauthn-p256@0.0.5: version "0.0.5" resolved "https://registry.yarnpkg.com/webauthn-p256/-/webauthn-p256-0.0.5.tgz#0baebd2ba8a414b21cc09c0d40f9dd0be96a06bd" @@ -5517,7 +5710,7 @@ word-wrap@^1.2.5: resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.5.tgz#d2c45c6dd4fbce621a66f136cbe328afd0410b34" integrity sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA== -"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0", wrap-ansi@^7.0.0: +"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== @@ -5554,6 +5747,11 @@ ws@8.17.1, ws@~8.17.1: resolved "https://registry.yarnpkg.com/ws/-/ws-8.17.1.tgz#9293da530bb548febc95371d90f9c878727d919b" integrity sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ== +ws@8.18.0: + version "8.18.0" + resolved "https://registry.yarnpkg.com/ws/-/ws-8.18.0.tgz#0d7505a6eafe2b0e712d232b42279f53bc289bbc" + integrity sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw== + ws@^7.5.1: version "7.5.10" resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.10.tgz#58b5c20dc281633f6c19113f39b349bd8bd558d9" @@ -5574,11 +5772,6 @@ y18n@^4.0.0: resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.3.tgz#b5f259c82cd6e336921efd7bfd8bf560de9eeedf" integrity sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ== -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== - yaml@^2.3.4: version "2.5.1" resolved "https://registry.yarnpkg.com/yaml/-/yaml-2.5.1.tgz#c9772aacf62cb7494a95b0c4f1fb065b563db130" @@ -5592,11 +5785,6 @@ yargs-parser@^18.1.2: camelcase "^5.0.0" decamelize "^1.2.0" -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== - yargs@^15.3.1: version "15.4.1" resolved "https://registry.yarnpkg.com/yargs/-/yargs-15.4.1.tgz#0d87a16de01aee9d8bec2bfbf74f67851730f4f8" @@ -5614,19 +5802,6 @@ yargs@^15.3.1: y18n "^4.0.0" yargs-parser "^18.1.2" -yargs@^17.5.1: - version "17.7.2" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.7.2.tgz#991df39aca675a192b816e1e0363f9d75d2aa269" - integrity sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w== - dependencies: - cliui "^8.0.1" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.3" - y18n "^5.0.5" - yargs-parser "^21.1.1" - yocto-queue@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" @@ -5637,9 +5812,7 @@ zod@3.22.4: resolved "https://registry.yarnpkg.com/zod/-/zod-3.22.4.tgz#f31c3a9386f61b1f228af56faa9255e845cf3fff" integrity sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg== -zustand@4.4.1: - version "4.4.1" - resolved "https://registry.yarnpkg.com/zustand/-/zustand-4.4.1.tgz#0cd3a3e4756f21811bd956418fdc686877e8b3b0" - integrity sha512-QCPfstAS4EBiTQzlaGP1gmorkh/UL1Leaj2tdj+zZCZ/9bm0WS7sI2wnfD5lpOszFqWJ1DcPnGoY8RDL61uokw== - dependencies: - use-sync-external-store "1.2.0" +zustand@5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/zustand/-/zustand-5.0.0.tgz#71f8aaecf185592a3ba2743d7516607361899da9" + integrity sha512-LE+VcmbartOPM+auOjCCLQOsQ05zUTp8RkgwRzefUk+2jISdMMFnxvyTjA4YNWr5ZGXYbVsEMZosttuxUBkojQ== diff --git a/advanced/dapps/react-dapp-v2/src/chains/bip122.ts b/advanced/dapps/react-dapp-v2/src/chains/bip122.ts index 88077f660..b1e490576 100644 --- a/advanced/dapps/react-dapp-v2/src/chains/bip122.ts +++ b/advanced/dapps/react-dapp-v2/src/chains/bip122.ts @@ -2,6 +2,7 @@ import { NamespaceMetadata, ChainMetadata, ChainsMap } from "../helpers"; export const BIP122_MAINNET = "000000000019d6689c085ae165831e93"; export const BIP122_TESTNET = "000000000933ea01ad0ee984209779ba"; +export const BIP122_DUST_LIMIT = "1001"; export const BtcChainData: ChainsMap = { [BIP122_MAINNET]: { diff --git a/advanced/dapps/react-dapp-v2/src/components/OriginSimulationDropdown.tsx b/advanced/dapps/react-dapp-v2/src/components/OriginSimulationDropdown.tsx index 7fab26188..9f4a72f72 100644 --- a/advanced/dapps/react-dapp-v2/src/components/OriginSimulationDropdown.tsx +++ b/advanced/dapps/react-dapp-v2/src/components/OriginSimulationDropdown.tsx @@ -27,7 +27,18 @@ const SelectOption = styled.option` `; const OriginSimulationDropdown = (props: OriginSimulationProps) => { - const { origin, show } = props; + const { show } = props; + const [selectedOrigin, setSelectedOrigin] = React.useState(props.origin); + React.useEffect(() => { + if (!show) { + return; + } + + setSelectedOrigin( + localStorage.getItem("wallet_connect_dapp_origin") || props.origin + ); + }, [show]); + const setOrigin = React.useCallback((origin: string) => { localStorage.setItem("wallet_connect_dapp_origin", origin); location.reload(); @@ -36,13 +47,15 @@ const OriginSimulationDropdown = (props: OriginSimulationProps) => {
{show && ( setOrigin(e?.target?.value)} > {ORIGIN_OPTIONS.map((e, i) => { + const seleted = e.value === selectedOrigin; + console.log("selected", seleted, e.value); return ( - + {e.label} ); diff --git a/advanced/dapps/react-dapp-v2/src/contexts/ClientContext.tsx b/advanced/dapps/react-dapp-v2/src/contexts/ClientContext.tsx index 28f1b2872..f82a8d1c9 100644 --- a/advanced/dapps/react-dapp-v2/src/contexts/ClientContext.tsx +++ b/advanced/dapps/react-dapp-v2/src/contexts/ClientContext.tsx @@ -297,8 +297,18 @@ export function ClientContextProvider({ logger: DEFAULT_LOGGER, relayUrl: relayerRegion, projectId: DEFAULT_PROJECT_ID, + metadata: { + name: "React App", + description: "App to test WalletConnect network", + url: claimedOrigin, + icons: [], + }, }); - + if (claimedOrigin === "unknown") { + //@ts-expect-error - private property + _client.core.verify.verifyUrlV3 = "0xdeafbeef"; + console.log("verify", _client.core.verify); + } setClient(_client); setOrigin(_client.metadata.url); console.log("metadata url:", _client.metadata); @@ -323,6 +333,7 @@ export function ClientContextProvider({ useEffect(() => { const claimedOrigin = localStorage.getItem("wallet_connect_dapp_origin") || origin; + console.log("claimedOrigin:", claimedOrigin); let interval: NodeJS.Timer; // simulates `UNKNOWN` validation by removing the verify iframe thus preventing POST message if (claimedOrigin === "unknown") { diff --git a/advanced/dapps/react-dapp-v2/src/contexts/JsonRpcContext.tsx b/advanced/dapps/react-dapp-v2/src/contexts/JsonRpcContext.tsx index eb8d3631f..8891bdcb5 100644 --- a/advanced/dapps/react-dapp-v2/src/contexts/JsonRpcContext.tsx +++ b/advanced/dapps/react-dapp-v2/src/contexts/JsonRpcContext.tsx @@ -78,10 +78,12 @@ import { apiGetAddressUtxos, calculateChange, getAvailableBalanceFromUtxos, + isBip122Testnet, isOrdinalAddress, isValidBip122Signature, } from "../helpers/bip122"; import { getAddressFromAccount } from "@walletconnect/utils"; +import { BIP122_DUST_LIMIT } from "../chains/bip122"; /** * Types @@ -1709,7 +1711,7 @@ export function JsonRpcContextProvider({ const req = { account: address, recipientAddress: address, - amount: "550", + amount: BIP122_DUST_LIMIT, }; console.log("request", { method, @@ -1741,19 +1743,24 @@ export function JsonRpcContextProvider({ ): Promise => { const method = DEFAULT_BIP122_METHODS.BIP122_SIGN_PSBT; + const network = isBip122Testnet(chainId) + ? bitcoin.networks.testnet + : bitcoin.networks.bitcoin; + + console.log("network", isBip122Testnet(chainId), network); const utxos = (await apiGetAddressUtxos(address, chainId)) as IUTXO[]; if (!utxos || utxos.length === 0) { throw new Error("No UTXOs found for address: " + address); } const availableBalance = getAvailableBalanceFromUtxos(utxos); // in satoshis - const satoshisToTransfer = 550; + const satoshisToTransfer = parseInt(BIP122_DUST_LIMIT, 10); if (availableBalance < satoshisToTransfer) { throw new Error( "Insufficient balance: " + availableBalance + " satoshis" ); } - const network = bitcoin.networks.testnet; + const psbt = new bitcoin.Psbt({ network }); const utxosToSpend: any[] = []; diff --git a/advanced/dapps/react-dapp-v2/src/helpers/bip122.ts b/advanced/dapps/react-dapp-v2/src/helpers/bip122.ts index 8f178f1be..d743ab86e 100644 --- a/advanced/dapps/react-dapp-v2/src/helpers/bip122.ts +++ b/advanced/dapps/react-dapp-v2/src/helpers/bip122.ts @@ -4,6 +4,7 @@ import BitcoinMessage from "bitcoinjs-message"; import { convertHexToBase64 } from "./utilities"; import { IUTXO } from "./types"; import { BIP122_TESTNET } from "../chains/bip122"; + export async function apiGetBip122AccountBalance( address: string, chainId: string @@ -70,9 +71,19 @@ export async function isValidBip122Signature( ); } - return BitcoinMessage.verify(message, address, convertHexToBase64(signature)); + return BitcoinMessage.verify( + message, + address, + convertHexToBase64(signature), + undefined, + true + ); } export function isOrdinalAddress(address: string) { return address.startsWith("tb1p"); } + +export function isBip122Testnet(chainId: string) { + return chainId.includes(BIP122_TESTNET); +} diff --git a/advanced/wallets/react-wallet-v2/src/components/MultibridgeRequestModal.tsx b/advanced/wallets/react-wallet-v2/src/components/MultibridgeRequestModal.tsx index 92bbfec3a..0262dee15 100644 --- a/advanced/wallets/react-wallet-v2/src/components/MultibridgeRequestModal.tsx +++ b/advanced/wallets/react-wallet-v2/src/components/MultibridgeRequestModal.tsx @@ -1,36 +1,42 @@ +import { useCallback, useState } from 'react' +import { Avatar, Col, Divider, Row, Text } from '@nextui-org/react' import { LoaderProps } from '@/components/ModalFooter' - import RequestMethodCard from '@/components/RequestMethodCard' -import { Avatar, Col, Container, Divider, Row, Text } from '@nextui-org/react' -import { walletkit } from '@/utils/WalletConnectUtil' import RequestModal from './RequestModal' import ModalStore from '@/store/ModalStore' -import { useCallback, useState } from 'react' -import { - bridgeFunds, - BridgingRequest, - convertTokenBalance, - getAssetByContractAddress, - supportedAssets -} from '@/utils/MultibridgeUtil' -import { getWallet } from '@/utils/EIP155WalletUtil' - import { styledToast } from '@/utils/HelperUtil' import { approveEIP155Request } from '@/utils/EIP155RequestHandlerUtil' +import { convertTokenBalance, decodeErc20Transaction, getAssetByContractAddress } from '@/utils/MultibridgeUtil' +import { getWallet } from '@/utils/EIP155WalletUtil' +import { walletkit } from '@/utils/WalletConnectUtil' import { EIP155_CHAINS, TEIP155Chain } from '@/data/EIP155Data' +import { ChainAbstractionService, Transaction } from '@/utils/ChainAbstractionService' +import { providers } from 'ethers' +import { formatJsonRpcError } from '@json-rpc-tools/utils' interface IProps { onReject: () => void - bridgingRequest?: BridgingRequest + transactions?: Transaction[] + orchestrationId: string rejectLoader?: LoaderProps } export default function MultibridgeRequestModal({ - bridgingRequest, + transactions, + orchestrationId, onReject, rejectLoader }: IProps) { - const [isLoadingApprove, setIsLoadingApprove] = useState(false) + const [isLoadingApprove, setIsLoadingApprove] = useState(false) + + const bridgingTransactions = transactions?.slice(0, transactions.length - 1) || [] + const initialTransaction = transactions?.[transactions.length - 1] + + const eip155ChainsFundsSourcedFrom = transactions + ? new Set(bridgingTransactions.map(transaction => transaction.chainId)) + : new Set() + + const eip155ChainFundsDestination = initialTransaction?.chainId // Get request and wallet data from store const requestEvent = ModalStore.state.data?.requestEvent @@ -41,45 +47,73 @@ export default function MultibridgeRequestModal({ const chainId = params?.chainId const request = params?.request + const caService = new ChainAbstractionService() - const bridge = useCallback(async () => { - if (!bridgingRequest) { - throw new Error('Bridging request is unavailable') + const bridgeFunds = useCallback(async (): Promise => { + if (!bridgingTransactions) { + throw new Error('bridgingTransactions are unavailable') } const wallet = await getWallet(params) + console.log( + 'Bridge funds from', + eip155ChainsFundsSourcedFrom, + 'to', + eip155ChainFundsDestination + ) - const asset = getAssetByContractAddress(bridgingRequest.transfer.contract) - if (!asset) { - throw new Error('Source chain asset unavailable') - } - const sourceChainAssetAddress = supportedAssets[asset][bridgingRequest.sourceChain] - if (!sourceChainAssetAddress) { - throw new Error('Source chain asset address unavailable') + for (const transaction of bridgingTransactions) { + console.log('Bridging transaction', transaction) + const chainId = transaction.chainId + const chainProvider = new providers.JsonRpcProvider(EIP155_CHAINS[chainId as TEIP155Chain].rpc) + const chainConnectedWallet = await wallet.connect(chainProvider) + const walletAddress = wallet.getAddress() + + const hash = await chainConnectedWallet.sendTransaction({ + from: walletAddress, + to: transaction.to, + value: transaction.value, + data: transaction.data, + nonce:transaction.nonce, + gasPrice: transaction.gasPrice, + gasLimit: transaction.gas + }) + const receipt = typeof hash === 'string' ? hash : hash?.hash + console.log(`Transaction broadcasted on chain ${chainId} , ${{ receipt }}`) } - await bridgeFunds( - { - fromChainId: bridgingRequest.sourceChain, - toChainId: bridgingRequest.targetChain, - fromAssetAddress: sourceChainAssetAddress, - toAssetAddress: bridgingRequest.transfer.contract, - amount: bridgingRequest.transfer.amount, - userAddress: wallet.getAddress(), - uniqueRoutesPerBridge: true, - sort: 'time', - singleTxOnly: true - }, - wallet - ) - }, [params, bridgingRequest]) + try { + await pollOrchestrationStatus(orchestrationId) + } catch (e) { + console.error(e) + onReject() + } + }, [ bridgingTransactions, orchestrationId, onReject, params]) + + async function pollOrchestrationStatus( + orchestrationId: string, + maxAttempts = 100, + interval = 1500 + ): Promise { + for (let attempt = 0; attempt < maxAttempts; attempt++) { + const { status } = await caService.getOrchestrationStatus(orchestrationId) + console.log(attempt, '- Orchestration status:', status) + if (status === 'completed') { + console.log('Bridging completed') + return + } + await new Promise(resolve => setTimeout(resolve, interval)) + } + console.log('Max attempts reached. Orchestration not completed.') + throw new Error('Max attempts reached. Orchestration not completed.') + } - const onApprove = useCallback(async () => { + const onApprove = useCallback(async (): Promise => { if (requestEvent && topic) { setIsLoadingApprove(true) try { - await bridge() performance.mark('startInititalTransactionSend') + await bridgeFunds() const response = await approveEIP155Request(requestEvent) performance.mark('endInititalTransactionSend') console.log( @@ -92,37 +126,43 @@ export default function MultibridgeRequestModal({ } ms` ) + await walletkit.respondSessionRequest({ topic, response }) + } catch (e) { + const { id } = requestEvent + const errorMessage = (e as Error).message || 'Error bridging funds' + const response = formatJsonRpcError(id, errorMessage) await walletkit.respondSessionRequest({ topic, response }) - } catch (e) { - console.log('Error') + styledToast((e as Error).message, 'error') console.error(e) - + } finally { setIsLoadingApprove(false) - styledToast((e as Error).message, 'error') - return } - setIsLoadingApprove(false) ModalStore.close() } - }, [requestEvent, topic]) + }, [bridgeFunds, requestEvent, topic]) - if (!request || !requestSession || !bridgingRequest) { + if (!request || !requestSession || !bridgingTransactions || bridgingTransactions.length === 0) { return Request not found } - const asset = getAssetByContractAddress(bridgingRequest.transfer.contract) - const amount = convertTokenBalance(asset, bridgingRequest.transfer.amount) - const destination = bridgingRequest.transfer.to - const sourceChain = EIP155_CHAINS[`eip155:${bridgingRequest.sourceChain}` as TEIP155Chain] - const targetChain = EIP155_CHAINS[`eip155:${bridgingRequest.targetChain}` as TEIP155Chain] + const transfer = decodeErc20Transaction(request.params[0]) + if (!transfer) { + return Invalid transfer request + } + + const asset = getAssetByContractAddress(transfer.contract) + const amount = convertTokenBalance(asset, transfer.amount) + const destination = transfer.to + const sourceChain = EIP155_CHAINS[Array.from(eip155ChainsFundsSourcedFrom)[0] as TEIP155Chain] + const targetChain = EIP155_CHAINS[eip155ChainFundsDestination as TEIP155Chain] return ( Transaction details - + Sending {amount} {asset} to: @@ -150,17 +186,13 @@ export default function MultibridgeRequestModal({ Chain details Target chain: - - - + {targetChain.name} Sourcing funds from: - - - + {sourceChain.name} diff --git a/advanced/wallets/react-wallet-v2/src/utils/ChainAbstractionService.ts b/advanced/wallets/react-wallet-v2/src/utils/ChainAbstractionService.ts new file mode 100644 index 000000000..54e7a0403 --- /dev/null +++ b/advanced/wallets/react-wallet-v2/src/utils/ChainAbstractionService.ts @@ -0,0 +1,78 @@ +import axios from 'axios' +import { CA_ORCHESTRATOR_BASE_URL } from './ConstantsUtil' + +export interface Transaction { + from: string + to: string + value: string + gas: string + gasPrice: string + data: string + nonce: string + maxFeePerGas: string + maxPriorityFeePerGas: string + chainId: string +} + +interface CheckResponse { + requiresMultiChain: boolean +} + +interface RouteResponse { + transactions: Transaction[] + orchestrationId: string +} +interface OrchestrationStatusResponse { + status: 'pending' | 'completed' | 'error' + createdAt: number +} + +export class ChainAbstractionService { + private baseUrl: string + private projectId: string + + constructor() { + this.baseUrl = CA_ORCHESTRATOR_BASE_URL + if (!process.env.NEXT_PUBLIC_PROJECT_ID) { + throw new Error('Project ID is not defined') + } + this.projectId = process.env.NEXT_PUBLIC_PROJECT_ID + } + + async checkTransaction(transaction: Transaction): Promise { + try { + const response = await axios.post( + `${this.baseUrl}/check?projectId=${this.projectId}`, + { transaction } + ) + return response.data.requiresMultiChain + } catch (error) { + console.error('ChainAbstractionService: Error checking transaction:', error) + throw error + } + } + + async routeTransaction(transaction: Transaction): Promise { + try { + const response = await axios.post( + `${this.baseUrl}/route?projectId=${this.projectId}`, + { transaction } + ) + return response.data + } catch (error) { + console.error('ChainAbstractionService: Error routing transaction:', error) + throw error + } + } + async getOrchestrationStatus(orchestrationId: string): Promise { + try { + const response = await axios.get( + `${this.baseUrl}/status?projectId=${this.projectId}&orchestrationId=${orchestrationId}` + ) + return response.data + } catch (error) { + console.error('ChainAbstractionService: Error getting orchestration status :', error) + throw error + } + } +} diff --git a/advanced/wallets/react-wallet-v2/src/utils/ConstantsUtil.ts b/advanced/wallets/react-wallet-v2/src/utils/ConstantsUtil.ts index c3dc1a74e..43b1ecee0 100644 --- a/advanced/wallets/react-wallet-v2/src/utils/ConstantsUtil.ts +++ b/advanced/wallets/react-wallet-v2/src/utils/ConstantsUtil.ts @@ -1 +1,2 @@ export const COSIGNER_BASE_URL = 'https://rpc.walletconnect.org/v1/sessions' +export const CA_ORCHESTRATOR_BASE_URL = 'https://rpc.walletconnect.org/v1/ca/orchestrator' diff --git a/advanced/wallets/react-wallet-v2/src/utils/MultibridgeUtil.ts b/advanced/wallets/react-wallet-v2/src/utils/MultibridgeUtil.ts index 63508b3e4..1fc7e03be 100644 --- a/advanced/wallets/react-wallet-v2/src/utils/MultibridgeUtil.ts +++ b/advanced/wallets/react-wallet-v2/src/utils/MultibridgeUtil.ts @@ -1,8 +1,6 @@ import { createPublicClient, decodeFunctionData, erc20Abi, getContract, Hex, http } from 'viem' import { arbitrum, base, optimism } from 'viem/chains' import { getChainById } from './ChainUtil' -import EIP155Lib from '@/lib/EIP155Lib' -import { SmartAccountLib } from '@/lib/smart-accounts/SmartAccountLib' import { providers } from 'ethers' import { EIP155_CHAINS, TEIP155Chain } from '@/data/EIP155Data' @@ -82,12 +80,6 @@ export async function getErc20TokenBalance( return Number(balance) } -export type BridgingRequest = { - transfer: Erc20Transfer - sourceChain: number - targetChain: number -} - type Erc20Transfer = { from: Hex to: Hex @@ -326,38 +318,3 @@ async function getBridgingTransactions( }) return transactions } - -export async function bridgeFunds( - bridgingParams: BridgingParams, - wallet: EIP155Lib | SmartAccountLib -): Promise { - const originalAmount = bridgingParams.amount - const sourceChainProvider = new providers.JsonRpcProvider( - EIP155_CHAINS[`eip155:${bridgingParams.fromChainId}` as TEIP155Chain].rpc - ) - const sourceChainConnectedWallet = await wallet.connect(sourceChainProvider) - const walletAddress = wallet.getAddress() - console.log('Getting bridging transactions') - const transactions = await getBridgingTransactions(bridgingParams, walletAddress) - console.log('Bridging transactions', transactions) - for (const transaction of transactions) { - const hash = await sourceChainConnectedWallet.sendTransaction(transaction) - const receipt = typeof hash === 'string' ? hash : hash?.hash - console.log('Transaction broadcasted', { receipt }) - } - let interations = 0 - while (interations < 20) { - const balance = await getErc20TokenBalance( - bridgingParams.toAssetAddress as Hex, - bridgingParams.toChainId, - walletAddress as Hex, - false - ) - if (balance >= originalAmount) { - console.log('Bridging completed') - return - } - await new Promise(resolve => setTimeout(resolve, 1500)) - interations++ - } -} diff --git a/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx b/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx index 837b5e98d..f563b6026 100644 --- a/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx +++ b/advanced/wallets/react-wallet-v2/src/views/SessionProposalModal.tsx @@ -408,7 +408,7 @@ export default function SessionProposalModal() { Smart Accounts {smartAccountEnabled && namespaces && - getAvailableSmartAccountsOnNamespaceChains(namespaces.eip155.chains).map( + getAvailableSmartAccountsOnNamespaceChains(namespaces?.eip155?.chains).map( (account, i) => { if (!account) { return <> @@ -443,7 +443,7 @@ export default function SessionProposalModal() { {smartAccountEnabled && namespaces && - getAvailableSmartAccountsOnNamespaceChains(namespaces.eip155.chains).map( + getAvailableSmartAccountsOnNamespaceChains(namespaces?.eip155?.chains).map( ({ chain }, i) => { if (!chain) { return <> diff --git a/advanced/wallets/react-wallet-v2/src/views/SessionSendTransactionModal.tsx b/advanced/wallets/react-wallet-v2/src/views/SessionSendTransactionModal.tsx index 279ed5393..cac73e433 100644 --- a/advanced/wallets/react-wallet-v2/src/views/SessionSendTransactionModal.tsx +++ b/advanced/wallets/react-wallet-v2/src/views/SessionSendTransactionModal.tsx @@ -1,182 +1,234 @@ import { useCallback, useEffect, useState } from 'react' import { Card, Divider, Loading, Text } from '@nextui-org/react' - -import RequestDataCard from '@/components/RequestDataCard' -import RequesDetailsCard from '@/components/RequestDetalilsCard' -import RequestMethodCard from '@/components/RequestMethodCard' -import ModalStore from '@/store/ModalStore' import { approveEIP155Request, rejectEIP155Request } from '@/utils/EIP155RequestHandlerUtil' import { styledToast } from '@/utils/HelperUtil' import { walletkit } from '@/utils/WalletConnectUtil' +import { ChainAbstractionService, Transaction } from '@/utils/ChainAbstractionService' +import ModalStore from '@/store/ModalStore' +import SettingsStore from '@/store/SettingsStore' + +import RequestDataCard from '@/components/RequestDataCard' +import RequestDetailsCard from '@/components/RequestDetalilsCard' +import RequestMethodCard from '@/components/RequestMethodCard' import RequestModal from '@/components/RequestModal' -import { - BridgingRequest, - decodeErc20Transaction, - getCrossChainTokens, - getErc20TokenBalance -} from '@/utils/MultibridgeUtil' import MultibridgeRequestModal from '@/components/MultibridgeRequestModal' -import SettingsStore from '@/store/SettingsStore' + +// Types for props used in individual components +type Session = { + peer: { + metadata: { name: string; description: string; url: string; icons: string[] } + } + relay: { protocol: string } +} export default function SessionSendTransactionModal() { - const [isLoadingApprove, setIsLoadingApprove] = useState(false) - const [isLoadingReject, setIsLoadingReject] = useState(false) - const [isTypeResolved, setIsTypeResolved] = useState(false) - const [shouldUseMultibridge, setShouldUseMultibridge] = useState(false) - const [bridgingRequest, setBirdgingRequest] = useState() + const [isLoadingApprove, setIsLoadingApprove] = useState(false) + const [isLoadingReject, setIsLoadingReject] = useState(false) + const [isReadyForRender, setIsReadyForRender] = useState(false) + const [requiresMultiChain, setRequiresMultiChain] = useState(false) + const [routeTransactions, setRouteTransactions] = useState([]) + const [orchestrationId, setOrchestrationId] = useState(null) - // Get request and wallet data from store + // Extract request and wallet data from store const requestEvent = ModalStore.state.data?.requestEvent const requestSession = ModalStore.state.data?.requestSession - - const topic = requestEvent?.topic - const params = requestEvent?.params - const chainId = params?.chainId - const request = params?.request + const { topic, params } = requestEvent || {} + const { chainId, request } = params || {} const transaction = request?.params[0] + // Check for multi-chain requirement and handle routing useEffect(() => { - const multibridgeCheck = async () => { - setIsTypeResolved(false) + const initializeMultiChainCheck = async (): Promise => { + setIsReadyForRender(false) + + if (!chainId) { + console.error('Chain ID is not available') + setIsReadyForRender(true) + return + } + + if (!SettingsStore.state.chainAbstractionEnabled || !request) { + setIsReadyForRender(true) + return + } + try { - if (!request) { - setIsTypeResolved(true) - return - } - if (!SettingsStore.state.chainAbstractionEnabled) { - setIsTypeResolved(true) - return - } - const transfer = decodeErc20Transaction(request.params[0]) - if (!transfer) { - setIsTypeResolved(true) - return - } - const parsedChainId = chainId?.split(':')[1] - const tokenBalance = await getErc20TokenBalance( - transfer.contract, - Number(parsedChainId), - transfer.from, - false - ) - if (transfer.amount <= tokenBalance) { - setIsTypeResolved(true) - return - } - const otherTokens = getCrossChainTokens(transfer.contract) - let otherBalance = 0 - let otherChain = 0 - - for (const chain in otherTokens) { - const balance = await getErc20TokenBalance( - otherTokens[Number(chain)], - Number(chain), - transfer.from, - false - ) - if (balance >= transfer.amount) { - otherBalance = balance - otherChain = Number(chain) - - console.log('Found chain to bridge from', { - otherBalance, - requiredBalance: transfer.amount, - otherChain - }) - const bridgingRequest = { - transfer, - sourceChain: otherChain, - targetChain: Number(parsedChainId) - } - console.log({ bridgingRequest }) - setBirdgingRequest(bridgingRequest) - setShouldUseMultibridge(true) - setIsTypeResolved(true) - return - } + const caService = new ChainAbstractionService() + const isMultiChain = await checkMultiChainRequirement(caService, request, chainId) + if (isMultiChain) { + await setupRouteTransactions(caService, request, chainId) } } catch (error) { - console.log('Unable to check multibridge availability', error) + console.error('Error during multi-chain check:', error) + styledToast('Unable to check multibridge availability', 'error') } finally { - setIsTypeResolved(true) + setIsReadyForRender(true) } } - multibridgeCheck() + + initializeMultiChainCheck() }, [request, chainId]) - // Handle approve action - const onApprove = useCallback(async () => { + const checkMultiChainRequirement = async ( + caService: ChainAbstractionService, + request: { params: [{ from: string; to: string; data: string }] }, + chainId: string + ): Promise => { + const { data, from, to } = request.params[0] + const isMultiChain = await caService.checkTransaction({ + from, + to, + value: '0', + gas: '0', + gasPrice: '0', + data, + nonce: '0', + maxFeePerGas: '0', + maxPriorityFeePerGas: '0', + chainId + }) + setRequiresMultiChain(isMultiChain) + return isMultiChain + } + + const setupRouteTransactions = async ( + caService: ChainAbstractionService, + request: { params: [{ from: string; to: string; data: string }] }, + chainId: string + ): Promise => { + const { data, from, to } = request.params[0] + const routeResult = await caService.routeTransaction({ + from, + to, + value: '0', + gas: '0', + gasPrice: '0', + data, + nonce: '0', + maxFeePerGas: '0', + maxPriorityFeePerGas: '0', + chainId + }) + setRouteTransactions(routeResult.transactions) + setOrchestrationId(routeResult.orchestrationId) + } + + const handleApproval = useCallback(async (): Promise => { + if (!requestEvent || !topic) return + setIsLoadingApprove(true) try { - if (requestEvent && topic) { - setIsLoadingApprove(true) - const response = await approveEIP155Request(requestEvent) - await walletkit.respondSessionRequest({ - topic, - response - }) - } - } catch (e) { - styledToast((e as Error).message, 'error') + const response = await approveEIP155Request(requestEvent) + await walletkit.respondSessionRequest({ topic, response }) + ModalStore.close() + } catch (error) { + styledToast((error as Error).message, 'error') } finally { setIsLoadingApprove(false) - ModalStore.close() } }, [requestEvent, topic]) - // Handle reject action - const onReject = useCallback(async () => { - if (requestEvent && topic) { - setIsLoadingReject(true) + const handleRejection = useCallback(async (): Promise => { + if (!requestEvent || !topic) return + setIsLoadingReject(true) + try { const response = rejectEIP155Request(requestEvent) - try { - await walletkit.respondSessionRequest({ - topic, - response - }) - } catch (e) { - setIsLoadingReject(false) - styledToast((e as Error).message, 'error') - return - } - setIsLoadingReject(false) + await walletkit.respondSessionRequest({ topic, response }) ModalStore.close() + } catch (error) { + styledToast((error as Error).message, 'error') + } finally { + setIsLoadingReject(false) } }, [requestEvent, topic]) - if (!request || !requestSession) { - return Request not found - } - - if (!isTypeResolved) { - return ( - - - - - - ) - } + if (!request || !requestSession) return Request not found + if (!isReadyForRender) return - return !shouldUseMultibridge && isTypeResolved ? ( - - - - - - - + return !requiresMultiChain || orchestrationId == null ? ( + ) : ( - ) } + +// Extracted Components for Loading, Single-Chain, and Multi-Chain Modals + +const LoadingComponent = (): JSX.Element => ( + + + + + +) + +type SingleChainModalProps = { + session: Session + transaction: any + chainId: string + method: string + onApprove: () => Promise + onReject: () => Promise + loadingApprove: boolean + loadingReject: boolean +} + +const SingleChainModal = ({ + session, + transaction, + chainId, + method, + onApprove, + onReject, + loadingApprove, + loadingReject +}: SingleChainModalProps): JSX.Element => ( + + + + + + + +) + +type MultiChainModalProps = { + transactions: Transaction[] + orchestrationId: string + onReject: () => Promise + loadingReject: boolean +} + +const MultiChainModal = ({ + transactions, + orchestrationId, + onReject, + loadingReject +}: MultiChainModalProps): JSX.Element => ( + +)