@wallet-ui/react 1.1.0-canary-20250412011829 → 1.1.0-canary-20250415022403

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/base-button.tsx","../src/wallet-ui-context.tsx","../src/use-wallet-ui.tsx","../src/wallet-ui-account-context.tsx","../src/use-wallet-ui-account.tsx","../src/use-wallet-ui-wallet.tsx","../src/base-dropdown.tsx","../src/base-svg.tsx","../src/wallet-ui-icon-close.tsx","../src/base-modal.tsx","../src/use-base-dropdown.tsx","../src/use-base-modal.tsx","../src/wallet-ui-cluster-context.tsx","../src/use-wallet-ui-cluster.tsx","../src/wallet-ui-icon.tsx","../src/use-wallet-ui-dropdown.tsx","../src/wallet-ui-solana-client-context.tsx","../src/use-wallet-ui-solana-client.tsx","../src/use-wallet-ui-wallets.tsx","../src/wallet-ui-account-context-provider.tsx","../src/wallet-ui-cluster-context-provider.tsx","../src/wallet-ui-context-provider.tsx","../src/wallet-ui-solana-client-context-provider.tsx","../src/wallet-ui.tsx","../src/wallet-ui-button.tsx","../src/wallet-ui-cluster-dropdown.tsx","../src/wallet-ui-dropdown.tsx","../src/wallet-ui-icon-no-wallet.tsx","../src/wallet-ui-label.tsx","../src/wallet-ui-list-button.tsx","../src/wallet-ui-list.tsx","../src/wallet-ui-modal.tsx","../src/wallet-ui-modal-trigger.tsx"],"names":["React","connect","BaseDropdownItemType","useMachine","useId","normalizeProps","createContext","useContext","useMemo","useWallets","useEffect","useStore","clusterId","cluster","account"],"mappings":"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","file":"index.native.mjs","sourcesContent":["import React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface BaseButtonProps extends Omit<WalletUiButton, 'children'> {\n label: React.ReactNode;\n leftSection?: React.ReactNode;\n onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n rightSection?: React.ReactNode;\n size?: WalletUiSize;\n}\n\nexport function BaseButton({ className, label, leftSection, onClick, rightSection, size, ...props }: BaseButtonProps) {\n return (\n <button className={`wallet-ui-base-button ${size ?? 'md'} ${className ?? ''}`} onClick={onClick} {...props}>\n {leftSection ? <span className=\"wallet-ui-base-button-left-section\">{leftSection}</span> : null}\n {label}\n {rightSection ? <span className=\"wallet-ui-base-button-right-section\">{rightSection}</span> : null}\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport { SolanaClient } from 'gill';\nimport React, { ReactNode } from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport interface WalletUiContextValue {\n account?: UiWalletAccount;\n accountKeys: string[];\n client: SolanaClient;\n connect: (wallet: UiWalletAccount) => void;\n connected: boolean;\n copy: () => void;\n disconnect: () => void;\n size: WalletUiSize;\n wallet?: UiWallet;\n wallets: UiWallet[];\n}\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport const WalletUiContext = React.createContext<WalletUiContextValue>({} as WalletUiContextValue);\n","import React from 'react';\n\nimport { WalletUiContext } from './wallet-ui-context';\n\nexport function useWalletUi() {\n return React.useContext(WalletUiContext);\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { createContext } from 'react';\n\nexport interface WalletUiAccountInfo {\n account: UiWalletAccount;\n accountKeys: string[];\n wallet: UiWallet | undefined;\n}\n\nexport interface WalletUiAccountState extends Omit<WalletUiAccountInfo, 'account'> {\n account: UiWalletAccount | undefined;\n setAccount: React.Dispatch<React.SetStateAction<UiWalletAccount | undefined>>;\n}\n\nexport const WalletUiAccountContext = createContext<WalletUiAccountState>({} as WalletUiAccountState);\n","import { useContext } from 'react';\n\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nexport function useWalletUiAccount() {\n return useContext(WalletUiAccountContext);\n}\n","import { UiWallet, useConnect, useDisconnect } from '@wallet-standard/react';\nimport { useEffect } from 'react';\n\nimport { useWalletUi } from './use-wallet-ui';\nimport { useWalletUiAccount } from './use-wallet-ui-account';\n\nexport function useWalletUiWallet({ wallet }: { wallet: UiWallet }) {\n const { connect: connectAccount } = useWalletUi();\n const { setAccount } = useWalletUiAccount();\n const [isConnecting, connect] = useConnect(wallet);\n const [isDisconnecting, disconnect] = useDisconnect(wallet);\n useEffect(() => {}, [isDisconnecting]);\n\n return {\n connect: async () => {\n const connectedAccount = await connect();\n console.log('connectedAccount', connectedAccount);\n if (!connectedAccount.length) {\n console.log('connect, no accounts');\n return connectedAccount;\n }\n const first = connectedAccount[0];\n console.log('connect, setting first account => ', first);\n setAccount(first);\n connectAccount(first);\n return connectedAccount;\n },\n disconnect,\n isConnecting,\n isDisconnecting,\n };\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React, { HTMLAttributes } from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseDropdownControl } from './use-base-dropdown';\nimport { useWalletUiWallet } from './use-wallet-ui-wallet';\n\nexport enum BaseDropdownItemType {\n Item = 'Item',\n WalletConnect = 'WalletConnect',\n WalletCopy = 'WalletCopy',\n WalletDisconnect = 'WalletDisconnect',\n WalletNeeded = 'WalletNeeded',\n}\n\nexport interface BaseDropdownItem {\n closeMenu?: boolean;\n disabled?: boolean;\n handler: () => Promise<void>;\n label: string;\n leftSection?: React.ReactNode;\n rightSection?: React.ReactNode;\n type: BaseDropdownItemType;\n value: string;\n wallet?: UiWallet;\n}\n\nexport interface BaseDropdownProps {\n buttonProps: BaseButtonProps;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n showIndicator?: boolean;\n}\n\nexport function BaseDropdown({ buttonProps, dropdown, showIndicator, items }: BaseDropdownProps) {\n const api = dropdown.api;\n const trigger = (\n <BaseButton\n {...api.getTriggerProps()}\n className={`wallet-ui-base-dropdown-trigger`}\n data-part=\"trigger\"\n rightSection={\n showIndicator ? (\n <span className=\"wallet-actions\">\n <span {...api.getIndicatorProps()} className=\"indicator\">\n <BaseDropdownChevronDown size={12} />\n </span>\n </span>\n ) : null\n }\n {...buttonProps}\n />\n );\n\n return (\n <div className=\"wallet-ui-base-dropdown\">\n {trigger}\n <div {...api.getPositionerProps()} className=\"wallet-positioner\">\n <div {...api.getContentProps()} className=\"wallet-ui-base-dropdown-list\" data-part=\"content\">\n {items.map(item => {\n return (\n <BaseDropdownItem\n {...api.getItemProps({ value: item.value })}\n key={item.value}\n item={item}\n afterClick={() => {\n if (item.disabled) {\n return;\n }\n if (item.closeMenu !== false) {\n dropdown.close();\n }\n }}\n />\n );\n })}\n </div>\n </div>\n </div>\n );\n}\n\nfunction BaseDropdownItem({ afterClick, item }: BaseDropdownItemRenderProps) {\n if (!item.wallet) {\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n }\n switch (item.type) {\n case BaseDropdownItemType.Item:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n case BaseDropdownItemType.WalletConnect:\n return <BaseDropdownItemWalletConnect afterClick={afterClick} item={item} wallet={item.wallet} />;\n case BaseDropdownItemType.WalletCopy:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} />;\n case BaseDropdownItemType.WalletDisconnect:\n return <BaseDropdownItemWalletDisconnect afterClick={afterClick} item={item} wallet={item.wallet} />;\n }\n}\n\nfunction BaseDropdownItemWalletConnect({\n afterClick,\n item,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { connect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await connect();\n return await item.handler();\n },\n }}\n />\n );\n}\n\nfunction BaseDropdownItemWalletDisconnect({\n afterClick,\n item,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { disconnect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await disconnect();\n return await item.handler();\n },\n }}\n />\n );\n}\n\ninterface BaseDropdownItemRenderProps {\n afterClick: () => void;\n item: BaseDropdownItem;\n}\n\nfunction BaseDropdownItemRender({ afterClick, item }: BaseDropdownItemRenderProps) {\n function onClick() {\n if (item.disabled) {\n return;\n }\n void item.handler().then(() => {\n afterClick();\n });\n }\n\n return (\n <div className=\"wallet-ui-base-dropdown-item\" data-part=\"item\" onClick={onClick}>\n {item.leftSection ? (\n <span className=\"wallet-ui-base-dropdown-item-left-section\">{item.leftSection}</span>\n ) : null}\n {item.label}\n {item.rightSection ? (\n <span className=\"wallet-ui-base-dropdown-item-right-section\">{item.rightSection}</span>\n ) : null}\n </div>\n );\n}\n\nexport function BaseDropdownChevronDown(props: HTMLAttributes<SVGElement> & { size?: number }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={props.size ?? 24}\n height={props.size ?? 24}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n {...props}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n","import React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiSvg } from './types/wallet-ui-svg';\n\nexport interface BaseSvgProps extends WalletUiSvg {\n size: WalletUiSize;\n sizes: { [key: string]: number };\n viewBox: string;\n}\n\nexport function BaseSvg({ sizes = {}, ...props }: BaseSvgProps) {\n const size = props.size ? sizes[props.size] : 12;\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width={size} height={size} {...props}>\n {props.children}\n </svg>\n );\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconClose({ size = 'md', ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg\n size={size}\n sizes={{ lg: 16, md: 12, sm: 8 }}\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"3\"\n viewBox=\"0 0 14 14\"\n {...props}\n >\n <path d=\"M14 12.461 8.3 6.772l5.234-5.233L12.006 0 6.772 5.234 1.54 0 0 1.539l5.234 5.233L0 12.006l1.539 1.528L6.772 8.3l5.69 5.7L14 12.461z\"></path>\n </BaseSvg>\n );\n}\n","import { Portal } from '@zag-js/react';\nimport React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseModalControl } from './use-base-modal';\nimport { WalletUiIconClose } from './wallet-ui-icon-close';\n\nexport interface BaseModalProps {\n buttonLabel?: React.ReactNode;\n buttonProps?: Partial<BaseButtonProps>;\n children: React.ReactNode;\n description?: React.ReactNode;\n modal: BaseModalControl;\n size?: WalletUiSize;\n title?: React.ReactNode;\n}\n\nexport function BaseModal({ modal, buttonLabel, buttonProps = {}, size = 'md', ...props }: BaseModalProps) {\n const api = modal.api;\n return (\n <>\n {buttonLabel ? (\n <BaseButton label={buttonLabel} size={size} {...buttonProps} {...api.getTriggerProps()} />\n ) : null}\n {api.open && (\n <Portal>\n <div {...api.getBackdropProps()} />\n <div {...api.getPositionerProps()}>\n <div {...api.getContentProps()} className={size}>\n <header>\n <button {...api.getCloseTriggerProps()}>\n <WalletUiIconClose size={size} />\n </button>\n </header>\n {props.description ? <p {...api.getDescriptionProps()}>{props.description}</p> : null}\n <main>{props.children}</main>\n </div>\n </div>\n </Portal>\n )}\n </>\n );\n}\n","import * as menu from '@zag-js/menu';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseDropdownApi = ReturnType<typeof menu.connect>;\n\nexport interface BaseDropdownControl {\n api: BaseDropdownApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseDropdown(): BaseDropdownControl {\n const service = useMachine(menu.machine, { id: useId() });\n const api = menu.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import * as dialog from '@zag-js/dialog';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseModalApi = ReturnType<typeof dialog.connect>;\n\nexport interface BaseModalControl {\n api: BaseModalApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseModal(): BaseModalControl {\n const service = useMachine(dialog.machine, { id: useId(), modal: true });\n const api = dialog.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import { SolanaCluster, SolanaClusterId, StorageCluster } from '@wallet-ui/core';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiClusterContextProviderProps {\n clusters: SolanaCluster[];\n render: (props: WalletUiClusterContextValue) => ReactNode;\n storage?: StorageCluster;\n}\n\nexport interface WalletUiClusterContextValue {\n cluster: SolanaCluster;\n clusters: SolanaCluster[];\n\n setCluster(cluster: SolanaClusterId): void;\n}\n\nexport const WalletUiClusterContext = createContext<WalletUiClusterContextValue>({} as WalletUiClusterContextValue);\n","import { useContext } from 'react';\n\nimport { WalletUiClusterContext } from './wallet-ui-cluster-context';\n\nexport function useWalletUiCluster() {\n return useContext(WalletUiClusterContext);\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiImg } from './types/wallet-ui-img';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiIconProps extends WalletUiImg {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'icon' | 'name'>;\n}\n\nexport function WalletUiIcon({ className, size, wallet, ...props }: WalletUiIconProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <img\n src={wallet.icon}\n alt={wallet.name}\n className={`wallet-ui-list-icon ${size ?? 'md'} ${className ?? ''}`}\n {...props}\n />\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { useMemo } from 'react';\n\nimport { BaseButtonProps } from './base-button';\nimport { BaseDropdownItem, BaseDropdownItemType } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseDropdownControl, useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUi } from './use-wallet-ui';\nimport { WalletUiIcon } from './wallet-ui-icon';\n\nfunction getDropdownItemsWallets({\n wallets,\n connect,\n size,\n}: {\n connect: (wallet: UiWalletAccount) => void;\n size: WalletUiSize;\n wallets: UiWallet[];\n}): BaseDropdownItem[] {\n return wallets.length\n ? wallets.map(wallet => ({\n handler: async () => {\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n connect(account);\n await Promise.resolve();\n },\n label: wallet.name,\n leftSection: <WalletUiIcon wallet={wallet} size={size} />,\n type: BaseDropdownItemType.WalletConnect,\n value: wallet.name,\n wallet,\n }))\n : [\n {\n handler: async () => {\n window.open('https://solana.com/solana-wallets', '_blank');\n await Promise.resolve();\n },\n label: \"You'll need a wallet on Solana to continue\",\n type: BaseDropdownItemType.WalletNeeded,\n value: 'no-wallets',\n },\n ];\n}\n\nexport function useWalletUiDropdown({ size = 'md' }: { size?: WalletUiSize } = {}): {\n buttonProps: BaseButtonProps;\n connected: boolean;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n} {\n const dropdown = useBaseDropdown();\n\n const { account, connect, copy, disconnect, connected, wallet, wallets } = useWalletUi();\n\n const itemsWallets = useMemo(() => {\n return getDropdownItemsWallets({ connect, size, wallets });\n }, [wallets, size, connect]);\n\n const itemsConnected: BaseDropdownItem[] = useMemo(\n () => [\n {\n handler: async () => {\n copy();\n void (await Promise.resolve());\n },\n label: 'Copy Address',\n type: BaseDropdownItemType.WalletCopy,\n value: 'copy',\n },\n {\n handler: async () => {\n disconnect();\n dropdown.close();\n await Promise.resolve();\n },\n label: 'Disconnect',\n type: BaseDropdownItemType.WalletDisconnect,\n value: 'disconnect',\n },\n ...itemsWallets,\n ],\n [connect, copy, disconnect, dropdown, size, wallets],\n );\n const items = useMemo(() => {\n return connected ? itemsConnected : itemsWallets;\n }, [connected, itemsConnected, itemsWallets]);\n\n const buttonProps: BaseButtonProps = useMemo(() => {\n return {\n label: connected ? ((account ? ellipsify(account.address) : wallet?.name) ?? 'Connected') : 'Select Wallet',\n leftSection: connected ? <WalletUiIcon size={size} wallet={wallet} /> : undefined,\n };\n }, [account, connected, size, wallet]);\n\n return {\n buttonProps,\n connected,\n dropdown,\n items,\n };\n}\n\nexport function ellipsify(str = '', len = 4, delimiter = '..') {\n const strLen = str.length;\n const limit = len * 2 + delimiter.length;\n\n return strLen >= limit ? str.substring(0, len) + delimiter + str.substring(strLen - len, strLen) : str;\n}\n","import { SolanaClient, SolanaClientUrlOrMoniker } from 'gill';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiSolanaClientContextProviderProps {\n children: ReactNode;\n urlOrMoniker: SolanaClientUrlOrMoniker;\n}\n\nexport const WalletUiSolanaClientContext = createContext<SolanaClient>({} as SolanaClient);\n","import { useContext } from 'react';\n\nimport { WalletUiSolanaClientContext } from './wallet-ui-solana-client-context';\n\nexport function useWalletUiSolanaClient() {\n return useContext(WalletUiSolanaClientContext);\n}\n","import { useWallets } from '@wallet-standard/react';\nimport { useMemo } from 'react';\n\nexport function useWalletUiWallets() {\n const readonlyWallets = useWallets();\n return useMemo(\n () =>\n readonlyWallets\n .filter(wallet => wallet.chains.some(i => i.startsWith('solana:')))\n .sort((a, b) => a.name.localeCompare(b.name)),\n [readonlyWallets],\n );\n}\n","import { useStore } from '@nanostores/react';\nimport {\n getUiWalletAccountStorageKey,\n UiWallet,\n UiWalletAccount,\n uiWalletAccountBelongsToUiWallet,\n uiWalletAccountsAreSame,\n useWallets,\n} from '@wallet-standard/react';\nimport { createStorageAccount, StorageAccount } from '@wallet-ui/core';\nimport React, { useEffect, useMemo, useState } from 'react';\n\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nlet wasSetterInvoked = false;\n\nfunction getSavedWalletAccount(\n wallets: readonly UiWallet[],\n savedWalletNameAndAddress?: string,\n): UiWalletAccount | undefined {\n if (wasSetterInvoked) {\n // After the user makes an explicit choice of wallet, stop trying to auto-select the\n // saved wallet, if and when it appears.\n return;\n }\n if (!savedWalletNameAndAddress || typeof savedWalletNameAndAddress !== 'string') {\n return;\n }\n const [savedWalletName, savedAccountAddress] = savedWalletNameAndAddress.split(':');\n if (!savedWalletName || !savedAccountAddress) {\n return;\n }\n const wallet = wallets.find(w => w.name === savedWalletName);\n if (!wallet) {\n return;\n }\n return wallet.accounts.find(a => a.address === savedAccountAddress);\n}\n\n/**\n * Saves the selected wallet account's storage key to the browser's local storage. In future\n * sessions it will try to return that same wallet account, or at least one from the same brand of\n * wallet if the wallet from which it came is still in the Wallet Standard registry.\n */\nexport function WalletUiAccountContextProvider({\n children,\n storage = createStorageAccount(),\n}: {\n children: React.ReactNode;\n storage?: StorageAccount;\n}) {\n const { cluster } = useWalletUiCluster();\n const wallets = useWallets();\n const accountId = useStore(storage.value);\n const [account, setAccountInternal] = useState<UiWalletAccount | undefined>(() =>\n getSavedWalletAccount(wallets, accountId),\n );\n\n function setAccount(setStateAction: React.SetStateAction<UiWalletAccount | undefined>) {\n setAccountInternal(prevAccount => {\n wasSetterInvoked = true;\n const nextWalletAccount =\n typeof setStateAction === 'function' ? setStateAction(prevAccount) : setStateAction;\n const accountKey = nextWalletAccount ? getUiWalletAccountStorageKey(nextWalletAccount) : undefined;\n storage.set(accountKey ? accountKey : undefined);\n return nextWalletAccount;\n });\n }\n\n useEffect(() => {\n const savedWalletAccount = getSavedWalletAccount(wallets, accountId);\n if (savedWalletAccount) {\n setAccountInternal(savedWalletAccount);\n }\n }, [accountId, wallets]);\n const walletAccount = useMemo(() => {\n if (account) {\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(account, uiWalletAccount)) {\n return uiWalletAccount;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(account, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet.accounts[0];\n }\n }\n }\n }, [account, wallets]);\n useEffect(() => {\n // If there is a selected wallet account but the wallet to which it belongs has since\n // disconnected, clear the selected wallet.\n if (account && !walletAccount) {\n setAccountInternal(undefined);\n }\n }, [account, walletAccount]);\n\n const wallet = useMemo(() => {\n if (!walletAccount) {\n return undefined;\n }\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(walletAccount, uiWalletAccount)) {\n return uiWallet;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(walletAccount, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet;\n }\n }\n }, [walletAccount, wallets]);\n\n // Expose the error boundary reset keys to the context\n const accountKeys = useMemo(() => {\n if (!account) {\n return [];\n }\n return [cluster.id, getUiWalletAccountStorageKey(account)].filter(Boolean);\n }, [account, cluster.id]);\n return (\n <WalletUiAccountContext.Provider\n value={useMemo(\n () => ({\n account: walletAccount,\n accountKeys,\n setAccount,\n wallet,\n }),\n [walletAccount, wallet, accountKeys],\n )}\n >\n {children}\n </WalletUiAccountContext.Provider>\n );\n}\n","import { useStore } from '@nanostores/react';\nimport { createStorageCluster, SolanaClusterId } from '@wallet-ui/core';\nimport React from 'react';\n\nimport {\n WalletUiClusterContext,\n WalletUiClusterContextProviderProps,\n WalletUiClusterContextValue,\n} from './wallet-ui-cluster-context';\n\nexport function WalletUiClusterContextProvider({\n clusters,\n render,\n storage = createStorageCluster(),\n}: WalletUiClusterContextProviderProps) {\n const clusterId = useStore(storage.value);\n if (!clusterId) {\n throw new Error('Error reading cluster id from storage');\n }\n if (!clusters.length) {\n throw new Error('No clusters provided');\n }\n\n const cluster = clusters.find(c => c.id === clusterId);\n if (!cluster) {\n throw new Error(`Cluster ${clusterId.toString()} not found`);\n }\n\n const value: WalletUiClusterContextValue = {\n cluster,\n clusters,\n setCluster: (clusterId: SolanaClusterId) => {\n const cluster = clusters.find(c => c.id === clusterId);\n if (!cluster) {\n throw new Error(`Cluster ${clusterId} not found`);\n }\n storage.set(clusterId);\n },\n };\n\n return <WalletUiClusterContext.Provider value={value}>{render(value)}</WalletUiClusterContext.Provider>;\n}\n","import { UiWalletAccount } from '@wallet-standard/react';\nimport { handleCopyText } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { useWalletUiAccount } from './use-wallet-ui-account';\nimport { useWalletUiSolanaClient } from './use-wallet-ui-solana-client';\nimport { useWalletUiWallets } from './use-wallet-ui-wallets';\nimport { WalletUiContext, WalletUiContextProviderProps, WalletUiContextValue } from './wallet-ui-context';\n\nexport function WalletUiContextProvider({ children, size = 'md' }: WalletUiContextProviderProps) {\n const { account, accountKeys, setAccount, wallet } = useWalletUiAccount();\n const wallets = useWalletUiWallets();\n const client = useWalletUiSolanaClient();\n const connected = Boolean(wallet && wallet?.accounts.length > 0);\n\n function connect(account: UiWalletAccount) {\n setAccount(account);\n }\n\n function disconnect() {\n setAccount(undefined);\n }\n\n function copy() {\n if (!account) {\n return;\n }\n handleCopyText(account.address);\n }\n\n const value: WalletUiContextValue = {\n account,\n accountKeys,\n client,\n connect,\n connected,\n copy,\n disconnect,\n size,\n wallet,\n wallets,\n };\n\n return <WalletUiContext.Provider value={value}>{children}</WalletUiContext.Provider>;\n}\n","import { createSolanaClient, SolanaClient } from 'gill';\nimport React, { useMemo } from 'react';\n\nimport {\n WalletUiSolanaClientContext,\n WalletUiSolanaClientContextProviderProps,\n} from './wallet-ui-solana-client-context';\n\nexport function WalletUiSolanaClientContextProvider({\n children,\n urlOrMoniker,\n}: WalletUiSolanaClientContextProviderProps) {\n return (\n <WalletUiSolanaClientContext.Provider\n value={useMemo(() => createSolanaClient({ urlOrMoniker }) as SolanaClient, [urlOrMoniker])}\n >\n {children}\n </WalletUiSolanaClientContext.Provider>\n );\n}\n","import { SolanaCluster, StorageAccount, StorageCluster } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { WalletUiAccountContextProvider } from './wallet-ui-account-context-provider';\nimport { WalletUiClusterContextProvider } from './wallet-ui-cluster-context-provider';\nimport { WalletUiContextProviderProps } from './wallet-ui-context';\nimport { WalletUiContextProvider } from './wallet-ui-context-provider';\nimport { WalletUiSolanaClientContextProvider } from './wallet-ui-solana-client-context-provider';\n\nexport interface WalletUiConfig extends Omit<WalletUiContextProviderProps, 'children'> {\n accountStorage?: StorageAccount;\n clusterStorage?: StorageCluster;\n clusters: SolanaCluster[];\n}\n\nexport function createWalletUiConfig(props: WalletUiConfig): WalletUiConfig {\n return { ...props };\n}\n\nexport interface WalletUiProps {\n children: React.ReactNode;\n config: WalletUiConfig;\n}\n\nexport function WalletUi({ children, config: { accountStorage, clusters, clusterStorage, ...config } }: WalletUiProps) {\n return (\n <React.Fragment>\n <WalletUiClusterContextProvider\n clusters={clusters}\n storage={clusterStorage}\n render={({ cluster }) => {\n return (\n <WalletUiSolanaClientContextProvider urlOrMoniker={cluster.urlOrMoniker}>\n <WalletUiAccountContextProvider storage={accountStorage}>\n <WalletUiContextProvider {...config}>{children}</WalletUiContextProvider>\n </WalletUiAccountContextProvider>\n </WalletUiSolanaClientContextProvider>\n );\n }}\n />\n </React.Fragment>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiButtonProps extends Omit<BaseButtonProps, 'label'> {\n size?: WalletUiSize;\n}\n\nexport function WalletUiButton({ ...props }: WalletUiButtonProps) {\n return <BaseButton {...props} label={'CLICK'} />;\n}\n","import React from 'react';\n\nimport { BaseDropdown, BaseDropdownItemType, BaseDropdownProps } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\n\nexport interface WalletUiClusterDropdownProps\n extends Omit<BaseDropdownProps, 'buttonProps' | 'dropdown' | 'items' | 'label'> {\n buttonProps?: Partial<BaseDropdownProps['buttonProps']>;\n size?: WalletUiSize;\n}\n\nexport function WalletUiClusterDropdown({ buttonProps, size = 'md', ...props }: WalletUiClusterDropdownProps) {\n const dropdown = useBaseDropdown();\n const { cluster, clusters, setCluster } = useWalletUiCluster();\n return (\n <BaseDropdown\n buttonProps={{ ...buttonProps, label: cluster.label, size: size }}\n items={clusters.map(cluster => ({\n handler: async () => {\n setCluster(cluster.id);\n await Promise.resolve();\n },\n label: cluster.label,\n type: BaseDropdownItemType.Item,\n value: cluster.id,\n }))}\n dropdown={dropdown}\n {...props}\n />\n );\n}\n","import React from 'react';\n\nimport { BaseDropdown } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useWalletUiDropdown } from './use-wallet-ui-dropdown';\n\nexport interface WalletUiDropdownProps {\n label?: string;\n size?: WalletUiSize;\n}\n\nexport function WalletUiDropdown({ size = 'md', ...props }: WalletUiDropdownProps) {\n const { buttonProps, items, dropdown } = useWalletUiDropdown({ size });\n return <BaseDropdown {...props} buttonProps={{ ...buttonProps, size }} items={items} dropdown={dropdown} />;\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconNoWallet({ size, ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg size={size} sizes={{ lg: 125, md: 100, sm: 75 }} fill=\"none\" viewBox=\"0 0 97 96\" {...props}>\n <circle cx=\"48.5\" cy=\"48\" r=\"48\" fill=\"url(#paint0_linear_880_5115)\" fillOpacity=\"0.1\"></circle>\n <circle\n cx=\"48.5\"\n cy=\"48\"\n r=\"47\"\n stroke=\"url(#paint1_linear_880_5115)\"\n strokeOpacity=\"0.4\"\n strokeWidth=\"2\"\n ></circle>\n <g clipPath=\"url(#clip0_880_5115)\">\n <path\n d=\"M65.5769 28.1523H31.4231C27.6057 28.1523 24.5 31.258 24.5 35.0754V60.9215C24.5 64.7389 27.6057 67.8446 31.4231 67.8446H65.5769C69.3943 67.8446 72.5 64.7389 72.5 60.9215V35.0754C72.5 31.258 69.3943 28.1523 65.5769 28.1523ZM69.7308 52.1523H59.5769C57.2865 52.1523 55.4231 50.289 55.4231 47.9985C55.4231 45.708 57.2864 43.8446 59.5769 43.8446H69.7308V52.1523ZM69.7308 41.0754H59.5769C55.7595 41.0754 52.6539 44.1811 52.6539 47.9985C52.6539 51.8159 55.7595 54.9215 59.5769 54.9215H69.7308V60.9215C69.7308 63.2119 67.8674 65.0754 65.5769 65.0754H31.4231C29.1327 65.0754 27.2692 63.212 27.2692 60.9215V35.0754C27.2692 32.785 29.1326 30.9215 31.4231 30.9215H65.5769C67.8673 30.9215 69.7308 32.7849 69.7308 35.0754V41.0754Z\"\n fill=\"url(#paint2_linear_880_5115)\"\n ></path>\n <path\n d=\"M61.4231 46.6172H59.577C58.8123 46.6172 58.1924 47.2371 58.1924 48.0018C58.1924 48.7665 58.8123 49.3863 59.577 49.3863H61.4231C62.1878 49.3863 62.8077 48.7664 62.8077 48.0018C62.8077 47.2371 62.1878 46.6172 61.4231 46.6172Z\"\n fill=\"url(#paint3_linear_880_5115)\"\n ></path>\n </g>\n <defs>\n <linearGradient\n id=\"paint0_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint1_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint2_linear_880_5115\"\n x1=\"25.9583\"\n y1=\"68.7101\"\n x2=\"67.2337\"\n y2=\"23.7879\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint3_linear_880_5115\"\n x1=\"58.3326\"\n y1=\"49.4467\"\n x2=\"61.0002\"\n y2=\"45.4453\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <clipPath id=\"clip0_880_5115\">\n <rect width=\"48\" height=\"48\" fill=\"white\" transform=\"translate(24.5 24)\"></rect>\n </clipPath>\n </defs>\n </BaseSvg>\n );\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiLabelProps\n extends React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement> {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'name'>;\n}\n\nexport function WalletUiLabel({ className, size, wallet, ...props }: WalletUiLabelProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <span className={`wallet-ui-list-label ${size ?? 'md'} ${className ?? ''}`} {...props}>\n {wallet.name}\n </span>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiIcon } from './wallet-ui-icon';\nimport { WalletUiLabel } from './wallet-ui-label';\n\nexport interface WalletUiListButtonProps extends Omit<WalletUiButton, 'onClick'> {\n select?: (wallet: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallet: UiWallet;\n}\n\nexport function WalletUiListButton({ className, select, size = 'md', wallet, ...props }: WalletUiListButtonProps) {\n const [pending, setPending] = React.useState(false);\n\n function handleSelect() {\n if (!select) {\n return;\n }\n setPending(true);\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n void select(account).finally(() => setPending(false));\n }\n\n return (\n <button\n disabled={pending}\n className={`wallet-ui-list-button ${size} ${pending ? 'wallet-ui-list-button-pending' : ''} ${className ?? ''}`}\n onClick={handleSelect}\n {...props}\n >\n <WalletUiIcon className=\"wallet-ui-list-button-icon\" wallet={wallet} size={size} />\n <WalletUiLabel className=\"wallet-ui-list-button-label\" wallet={wallet} size={size} />\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiDiv } from './types/wallet-ui-div';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiListButton } from './wallet-ui-list-button';\n\nexport interface WalletUiListProps extends WalletUiDiv {\n select?: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiList({ className, select, size = 'md', wallets, ...props }: WalletUiListProps) {\n return (\n <div className={`wallet-ui-list ${size} ${className ?? ''}`} {...props}>\n {wallets.map(wallet => (\n <WalletUiListButton key={wallet.name} select={select} size={size} wallet={wallet} />\n ))}\n </div>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { BaseModal, BaseModalProps } from './base-modal';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiList } from './wallet-ui-list';\n\nexport interface WalletUiModalProps extends Omit<BaseModalProps, 'children'> {\n select: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiModal({ size = 'md', wallets, select, ...props }: WalletUiModalProps) {\n return (\n <BaseModal description=\"Connect a wallet on Solana to continue\" size={size} {...props}>\n <WalletUiList size={size} wallets={wallets} select={select} />\n </BaseModal>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseModalControl } from './use-base-modal';\n\nexport interface WalletUiModalTriggerProps extends Omit<BaseButtonProps, 'label'> {\n label?: string;\n modal: BaseModalControl;\n}\n\nexport function WalletUiModalTrigger({ label = 'Select Wallet', modal, ...props }: WalletUiModalTriggerProps) {\n return <BaseButton label={label} onClick={() => void modal.open()} {...props} />;\n}\n"]}
1
+ {"version":3,"sources":["../src/base-button.tsx","../src/wallet-ui-context.tsx","../src/use-wallet-ui.tsx","../src/wallet-ui-account-context.tsx","../src/use-wallet-ui-account.tsx","../src/use-wallet-ui-wallet.tsx","../src/wallet-ui-icon.tsx","../src/base-dropdown.tsx","../src/base-svg.tsx","../src/wallet-ui-icon-close.tsx","../src/base-modal.tsx","../src/use-base-dropdown.tsx","../src/use-base-modal.tsx","../src/wallet-ui-cluster-context.tsx","../src/use-wallet-ui-cluster.tsx","../src/use-wallet-ui-dropdown.tsx","../src/wallet-ui-solana-client-context.tsx","../src/use-wallet-ui-solana-client.tsx","../src/use-wallet-ui-wallets.tsx","../src/wallet-ui-account-context-provider.tsx","../src/wallet-ui-cluster-context-provider.tsx","../src/wallet-ui-context-provider.tsx","../src/wallet-ui-solana-client-context-provider.tsx","../src/wallet-ui.tsx","../src/wallet-ui-button.tsx","../src/wallet-ui-cluster-dropdown.tsx","../src/wallet-ui-dropdown.tsx","../src/wallet-ui-icon-no-wallet.tsx","../src/wallet-ui-label.tsx","../src/wallet-ui-list-button.tsx","../src/wallet-ui-list.tsx","../src/wallet-ui-modal.tsx","../src/wallet-ui-modal-trigger.tsx"],"names":["React","connect","BaseDropdownItemType","useMachine","useId","normalizeProps","createContext","useContext","useMemo","useWallets","useEffect","useStore","clusterId","cluster","account"],"mappings":"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","file":"index.native.mjs","sourcesContent":["import React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface BaseButtonProps extends Omit<WalletUiButton, 'children'> {\n label: React.ReactNode;\n leftSection?: React.ReactNode;\n onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n rightSection?: React.ReactNode;\n size?: WalletUiSize;\n}\n\nexport function BaseButton({ className, label, leftSection, onClick, rightSection, size, ...props }: BaseButtonProps) {\n return (\n <button data-ui=\"base-button\" className={`${size ?? 'md'} ${className ?? ''}`} onClick={onClick} {...props}>\n {leftSection ? <span data-ui=\"base-button-left-section\">{leftSection}</span> : null}\n {label}\n {rightSection ? <span data-ui=\"base-button-right-section\">{rightSection}</span> : null}\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport { SolanaClient } from 'gill';\nimport React, { ReactNode } from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport interface WalletUiContextValue {\n account?: UiWalletAccount;\n accountKeys: string[];\n client: SolanaClient;\n connect: (wallet: UiWalletAccount) => void;\n connected: boolean;\n copy: () => void;\n disconnect: () => void;\n size: WalletUiSize;\n wallet?: UiWallet;\n wallets: UiWallet[];\n}\n\nexport interface WalletUiContextProviderProps {\n children: ReactNode;\n size?: WalletUiSize;\n}\n\nexport const WalletUiContext = React.createContext<WalletUiContextValue>({} as WalletUiContextValue);\n","import React from 'react';\n\nimport { WalletUiContext } from './wallet-ui-context';\n\nexport function useWalletUi() {\n return React.useContext(WalletUiContext);\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { createContext } from 'react';\n\nexport interface WalletUiAccountInfo {\n account: UiWalletAccount;\n accountKeys: string[];\n wallet: UiWallet | undefined;\n}\n\nexport interface WalletUiAccountState extends Omit<WalletUiAccountInfo, 'account'> {\n account: UiWalletAccount | undefined;\n setAccount: React.Dispatch<React.SetStateAction<UiWalletAccount | undefined>>;\n}\n\nexport const WalletUiAccountContext = createContext<WalletUiAccountState>({} as WalletUiAccountState);\n","import { useContext } from 'react';\n\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nexport function useWalletUiAccount() {\n return useContext(WalletUiAccountContext);\n}\n","import { UiWallet, useConnect, useDisconnect } from '@wallet-standard/react';\nimport { useEffect } from 'react';\n\nimport { useWalletUi } from './use-wallet-ui';\nimport { useWalletUiAccount } from './use-wallet-ui-account';\n\nexport function useWalletUiWallet({ wallet }: { wallet: UiWallet }) {\n const { connect: connectAccount } = useWalletUi();\n const { setAccount } = useWalletUiAccount();\n const [isConnecting, connect] = useConnect(wallet);\n const [isDisconnecting, disconnect] = useDisconnect(wallet);\n useEffect(() => {}, [isDisconnecting]);\n\n return {\n connect: async () => {\n const connectedAccount = await connect();\n console.log('connectedAccount', connectedAccount);\n if (!connectedAccount.length) {\n console.log('connect, no accounts');\n return connectedAccount;\n }\n const first = connectedAccount[0];\n console.log('connect, setting first account => ', first);\n setAccount(first);\n connectAccount(first);\n return connectedAccount;\n },\n disconnect,\n isConnecting,\n isDisconnecting,\n };\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiImg } from './types/wallet-ui-img';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiIconProps extends WalletUiImg {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'icon' | 'name'>;\n}\n\nexport function WalletUiIcon({ className, size, wallet, ...props }: WalletUiIconProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <img\n data-ui=\"wallet-ui-icon\"\n src={wallet.icon}\n alt={wallet.name}\n className={`${size ?? 'md'} ${className ?? ''}`}\n {...props}\n />\n );\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React, { HTMLAttributes } from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseDropdownControl } from './use-base-dropdown';\nimport { useWalletUiWallet } from './use-wallet-ui-wallet';\nimport { WalletUiIcon } from './wallet-ui-icon';\n\nexport enum BaseDropdownItemType {\n Item = 'Item',\n WalletConnect = 'WalletConnect',\n WalletCopy = 'WalletCopy',\n WalletDisconnect = 'WalletDisconnect',\n WalletNeeded = 'WalletNeeded',\n}\n\nexport interface BaseDropdownItem {\n closeMenu?: boolean;\n disabled?: boolean;\n handler: () => Promise<void>;\n label: string;\n leftSection?: React.ReactNode;\n rightSection?: React.ReactNode;\n type: BaseDropdownItemType;\n value: string;\n wallet?: UiWallet;\n}\n\nexport interface BaseDropdownProps {\n buttonProps: BaseButtonProps;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n showIndicator?: boolean;\n size?: WalletUiSize;\n}\n\nexport function BaseDropdown({ buttonProps, dropdown, items, showIndicator, size = 'md' }: BaseDropdownProps) {\n const api = dropdown.api;\n const trigger = (\n <BaseButton\n {...api.getTriggerProps()}\n size={size}\n rightSection={\n showIndicator ? (\n <span {...api.getIndicatorProps()}>\n <BaseDropdownChevronDown size={12} />\n </span>\n ) : null\n }\n {...buttonProps}\n />\n );\n\n return (\n <div data-ui=\"base-dropdown\">\n {trigger}\n <div {...api.getPositionerProps()}>\n <div {...api.getContentProps()} data-ui=\"base-dropdown-list\" data-part=\"content\">\n {items.map(item => {\n return (\n <BaseDropdownItem\n {...api.getItemProps({ value: item.value })}\n key={item.value}\n item={item}\n size={size}\n afterClick={() => {\n if (item.disabled) {\n return;\n }\n if (item.closeMenu !== false) {\n dropdown.close();\n }\n }}\n />\n );\n })}\n </div>\n </div>\n </div>\n );\n}\n\nfunction BaseDropdownItem({ afterClick, item, size }: BaseDropdownItemRenderProps) {\n console.log('BaseDropdownItem', item, size);\n if (!item.wallet) {\n return <BaseDropdownItemRender afterClick={afterClick} item={item} size={size} />;\n }\n switch (item.type) {\n case BaseDropdownItemType.Item:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} size={size} />;\n case BaseDropdownItemType.WalletConnect:\n return (\n <BaseDropdownItemWalletConnect afterClick={afterClick} item={item} size={size} wallet={item.wallet} />\n );\n case BaseDropdownItemType.WalletCopy:\n return <BaseDropdownItemRender afterClick={afterClick} item={item} size={size} />;\n case BaseDropdownItemType.WalletDisconnect:\n return (\n <BaseDropdownItemWalletDisconnect\n afterClick={afterClick}\n item={item}\n size={size}\n wallet={item.wallet}\n />\n );\n }\n}\n\nfunction BaseDropdownItemWalletConnect({\n afterClick,\n item,\n size,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { connect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await connect();\n return await item.handler();\n },\n leftSection: wallet ? <WalletUiIcon wallet={wallet} size={size} /> : undefined,\n }}\n size={size}\n />\n );\n}\n\nfunction BaseDropdownItemWalletDisconnect({\n afterClick,\n item,\n size,\n wallet,\n}: BaseDropdownItemRenderProps & {\n wallet: UiWallet;\n}) {\n const { disconnect } = useWalletUiWallet({ wallet });\n return (\n <BaseDropdownItemRender\n afterClick={afterClick}\n item={{\n ...item,\n handler: async () => {\n //\n await disconnect();\n return await item.handler();\n },\n }}\n size={size}\n />\n );\n}\n\ninterface BaseDropdownItemRenderProps {\n afterClick: () => void;\n item: BaseDropdownItem;\n size: WalletUiSize;\n}\n\nfunction BaseDropdownItemRender({ afterClick, item, size }: BaseDropdownItemRenderProps) {\n function onClick() {\n if (item.disabled) {\n return;\n }\n void item.handler().then(() => {\n afterClick();\n });\n }\n\n return (\n <div data-ui=\"base-dropdown-item\" className={size} data-part=\"item\" onClick={onClick}>\n {item.leftSection ? <span data-ui=\"base-dropdown-item-left-section\">{item.leftSection}</span> : null}\n {item.label}\n {item.rightSection ? <span data-ui=\"base-dropdown-item-right-section\">{item.rightSection}</span> : null}\n </div>\n );\n}\n\nexport function BaseDropdownChevronDown(props: HTMLAttributes<SVGElement> & { size?: number }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width={props.size ?? 24}\n height={props.size ?? 24}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n {...props}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n","import React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiSvg } from './types/wallet-ui-svg';\n\nexport interface BaseSvgProps extends WalletUiSvg {\n size: WalletUiSize;\n sizes: { [key: string]: number };\n viewBox: string;\n}\n\nexport function BaseSvg({ sizes = {}, ...props }: BaseSvgProps) {\n const size = props.size ? sizes[props.size] : 12;\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width={size} height={size} {...props}>\n {props.children}\n </svg>\n );\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconClose({ size = 'md', ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg\n size={size}\n sizes={{ lg: 16, md: 12, sm: 8 }}\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"3\"\n viewBox=\"0 0 14 14\"\n {...props}\n >\n <path d=\"M14 12.461 8.3 6.772l5.234-5.233L12.006 0 6.772 5.234 1.54 0 0 1.539l5.234 5.233L0 12.006l1.539 1.528L6.772 8.3l5.69 5.7L14 12.461z\"></path>\n </BaseSvg>\n );\n}\n","import { Portal } from '@zag-js/react';\nimport React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseModalControl } from './use-base-modal';\nimport { WalletUiIconClose } from './wallet-ui-icon-close';\n\nexport interface BaseModalProps {\n buttonLabel?: React.ReactNode;\n buttonProps?: Partial<BaseButtonProps>;\n children: React.ReactNode;\n description?: React.ReactNode;\n modal: BaseModalControl;\n size?: WalletUiSize;\n title?: React.ReactNode;\n}\n\nexport function BaseModal({ modal, buttonLabel, buttonProps = {}, size = 'md', ...props }: BaseModalProps) {\n const api = modal.api;\n return (\n <>\n {buttonLabel ? (\n <BaseButton label={buttonLabel} size={size} {...buttonProps} {...api.getTriggerProps()} />\n ) : null}\n {api.open && (\n <Portal>\n <div {...api.getBackdropProps()} />\n <div {...api.getPositionerProps()}>\n <div {...api.getContentProps()} className={size}>\n <header>\n <button {...api.getCloseTriggerProps()}>\n <WalletUiIconClose size={size} />\n </button>\n </header>\n {props.description ? <p {...api.getDescriptionProps()}>{props.description}</p> : null}\n <main>{props.children}</main>\n </div>\n </div>\n </Portal>\n )}\n </>\n );\n}\n","import * as menu from '@zag-js/menu';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseDropdownApi = ReturnType<typeof menu.connect>;\n\nexport interface BaseDropdownControl {\n api: BaseDropdownApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseDropdown(): BaseDropdownControl {\n const service = useMachine(menu.machine, { id: useId() });\n const api = menu.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import * as dialog from '@zag-js/dialog';\nimport { normalizeProps, useMachine } from '@zag-js/react';\nimport { useId } from 'react';\n\nexport type BaseModalApi = ReturnType<typeof dialog.connect>;\n\nexport interface BaseModalControl {\n api: BaseModalApi;\n close: () => void;\n open: () => void;\n}\n\nexport function useBaseModal(): BaseModalControl {\n const service = useMachine(dialog.machine, { id: useId(), modal: true });\n const api = dialog.connect(service, normalizeProps);\n\n return {\n api,\n close: () => service.send({ type: 'CLOSE' }),\n open: () => service.send({ type: 'OPEN' }),\n };\n}\n","import { SolanaCluster, SolanaClusterId, StorageCluster } from '@wallet-ui/core';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiClusterContextProviderProps {\n clusters: SolanaCluster[];\n render: (props: WalletUiClusterContextValue) => ReactNode;\n storage?: StorageCluster;\n}\n\nexport interface WalletUiClusterContextValue {\n cluster: SolanaCluster;\n clusters: SolanaCluster[];\n\n setCluster(cluster: SolanaClusterId): void;\n}\n\nexport const WalletUiClusterContext = createContext<WalletUiClusterContextValue>({} as WalletUiClusterContextValue);\n","import { useContext } from 'react';\n\nimport { WalletUiClusterContext } from './wallet-ui-cluster-context';\n\nexport function useWalletUiCluster() {\n return useContext(WalletUiClusterContext);\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React, { useMemo } from 'react';\n\nimport { BaseButtonProps } from './base-button';\nimport { BaseDropdownItem, BaseDropdownItemType } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { BaseDropdownControl, useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUi } from './use-wallet-ui';\nimport { WalletUiIcon } from './wallet-ui-icon';\n\nfunction getDropdownItemsWallets({\n wallets,\n connect,\n}: {\n connect: (wallet: UiWalletAccount) => void;\n wallets: UiWallet[];\n}): BaseDropdownItem[] {\n return wallets.length\n ? wallets.map(wallet => ({\n handler: async () => {\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n connect(account);\n await Promise.resolve();\n },\n label: wallet.name,\n\n type: BaseDropdownItemType.WalletConnect,\n value: wallet.name,\n wallet,\n }))\n : [\n {\n handler: async () => {\n window.open('https://solana.com/solana-wallets', '_blank');\n await Promise.resolve();\n },\n label: \"You'll need a wallet on Solana to continue\",\n type: BaseDropdownItemType.WalletNeeded,\n value: 'no-wallets',\n },\n ];\n}\n\nexport function useWalletUiDropdown({ size = 'md' }: { size?: WalletUiSize } = {}): {\n buttonProps: BaseButtonProps;\n connected: boolean;\n dropdown: BaseDropdownControl;\n items: BaseDropdownItem[];\n} {\n const dropdown = useBaseDropdown();\n\n const { account, connect, copy, disconnect, connected, wallet, wallets } = useWalletUi();\n\n const itemsWallets = useMemo(() => getDropdownItemsWallets({ connect, wallets }), [wallets, connect]);\n\n const itemsConnected: BaseDropdownItem[] = useMemo(\n () => [\n {\n handler: async () => {\n copy();\n void (await Promise.resolve());\n },\n label: 'Copy Address',\n type: BaseDropdownItemType.WalletCopy,\n value: 'copy',\n },\n {\n handler: async () => {\n disconnect();\n dropdown.close();\n await Promise.resolve();\n },\n label: 'Disconnect',\n type: BaseDropdownItemType.WalletDisconnect,\n value: 'disconnect',\n },\n ...itemsWallets,\n ],\n [copy, disconnect, dropdown, itemsWallets],\n );\n const items = useMemo(() => {\n return connected ? itemsConnected : itemsWallets;\n }, [connected, itemsConnected, itemsWallets]);\n\n const buttonProps: BaseButtonProps = useMemo(() => {\n return {\n label: connected ? ((account ? ellipsify(account.address) : wallet?.name) ?? 'Connected') : 'Select Wallet',\n leftSection: connected ? <WalletUiIcon size={size} wallet={wallet} /> : undefined,\n };\n }, [account, connected, size, wallet]);\n\n return {\n buttonProps,\n connected,\n dropdown,\n items,\n };\n}\n\nexport function ellipsify(str = '', len = 4, delimiter = '..') {\n const strLen = str.length;\n const limit = len * 2 + delimiter.length;\n\n return strLen >= limit ? str.substring(0, len) + delimiter + str.substring(strLen - len, strLen) : str;\n}\n","import { SolanaClient, SolanaClientUrlOrMoniker } from 'gill';\nimport { createContext, ReactNode } from 'react';\n\nexport interface WalletUiSolanaClientContextProviderProps {\n children: ReactNode;\n urlOrMoniker: SolanaClientUrlOrMoniker;\n}\n\nexport const WalletUiSolanaClientContext = createContext<SolanaClient>({} as SolanaClient);\n","import { useContext } from 'react';\n\nimport { WalletUiSolanaClientContext } from './wallet-ui-solana-client-context';\n\nexport function useWalletUiSolanaClient() {\n return useContext(WalletUiSolanaClientContext);\n}\n","import { useWallets } from '@wallet-standard/react';\nimport { useMemo } from 'react';\n\nexport function useWalletUiWallets() {\n const readonlyWallets = useWallets();\n return useMemo(\n () =>\n readonlyWallets\n .filter(wallet => wallet.chains.some(i => i.startsWith('solana:')))\n .sort((a, b) => a.name.localeCompare(b.name)),\n [readonlyWallets],\n );\n}\n","import { useStore } from '@nanostores/react';\nimport {\n getUiWalletAccountStorageKey,\n UiWallet,\n UiWalletAccount,\n uiWalletAccountBelongsToUiWallet,\n uiWalletAccountsAreSame,\n useWallets,\n} from '@wallet-standard/react';\nimport { createStorageAccount, StorageAccount } from '@wallet-ui/core';\nimport React, { useEffect, useMemo, useState } from 'react';\n\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\nimport { WalletUiAccountContext } from './wallet-ui-account-context';\n\nlet wasSetterInvoked = false;\n\nfunction getSavedWalletAccount(\n wallets: readonly UiWallet[],\n savedWalletNameAndAddress?: string,\n): UiWalletAccount | undefined {\n if (wasSetterInvoked) {\n // After the user makes an explicit choice of wallet, stop trying to auto-select the\n // saved wallet, if and when it appears.\n return;\n }\n if (!savedWalletNameAndAddress || typeof savedWalletNameAndAddress !== 'string') {\n return;\n }\n const [savedWalletName, savedAccountAddress] = savedWalletNameAndAddress.split(':');\n if (!savedWalletName || !savedAccountAddress) {\n return;\n }\n const wallet = wallets.find(w => w.name === savedWalletName);\n if (!wallet) {\n return;\n }\n return wallet.accounts.find(a => a.address === savedAccountAddress);\n}\n\n/**\n * Saves the selected wallet account's storage key to the browser's local storage. In future\n * sessions it will try to return that same wallet account, or at least one from the same brand of\n * wallet if the wallet from which it came is still in the Wallet Standard registry.\n */\nexport function WalletUiAccountContextProvider({\n children,\n storage = createStorageAccount(),\n}: {\n children: React.ReactNode;\n storage?: StorageAccount;\n}) {\n const { cluster } = useWalletUiCluster();\n const wallets = useWallets();\n const accountId = useStore(storage.value);\n const [account, setAccountInternal] = useState<UiWalletAccount | undefined>(() =>\n getSavedWalletAccount(wallets, accountId),\n );\n\n function setAccount(setStateAction: React.SetStateAction<UiWalletAccount | undefined>) {\n setAccountInternal(prevAccount => {\n wasSetterInvoked = true;\n const nextWalletAccount =\n typeof setStateAction === 'function' ? setStateAction(prevAccount) : setStateAction;\n const accountKey = nextWalletAccount ? getUiWalletAccountStorageKey(nextWalletAccount) : undefined;\n storage.set(accountKey ? accountKey : undefined);\n return nextWalletAccount;\n });\n }\n\n useEffect(() => {\n const savedWalletAccount = getSavedWalletAccount(wallets, accountId);\n if (savedWalletAccount) {\n setAccountInternal(savedWalletAccount);\n }\n }, [accountId, wallets]);\n const walletAccount = useMemo(() => {\n if (account) {\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(account, uiWalletAccount)) {\n return uiWalletAccount;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(account, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet.accounts[0];\n }\n }\n }\n }, [account, wallets]);\n useEffect(() => {\n // If there is a selected wallet account but the wallet to which it belongs has since\n // disconnected, clear the selected wallet.\n if (account && !walletAccount) {\n setAccountInternal(undefined);\n }\n }, [account, walletAccount]);\n\n const wallet = useMemo(() => {\n if (!walletAccount) {\n return undefined;\n }\n for (const uiWallet of wallets) {\n for (const uiWalletAccount of uiWallet.accounts) {\n if (uiWalletAccountsAreSame(walletAccount, uiWalletAccount)) {\n return uiWallet;\n }\n }\n if (uiWalletAccountBelongsToUiWallet(walletAccount, uiWallet) && uiWallet.accounts[0]) {\n // If the selected account belongs to this connected wallet, at least, then\n // select one of its accounts.\n return uiWallet;\n }\n }\n }, [walletAccount, wallets]);\n\n // Expose the error boundary reset keys to the context\n const accountKeys = useMemo(() => {\n if (!account) {\n return [];\n }\n return [cluster.id, getUiWalletAccountStorageKey(account)].filter(Boolean);\n }, [account, cluster.id]);\n return (\n <WalletUiAccountContext.Provider\n value={useMemo(\n () => ({\n account: walletAccount,\n accountKeys,\n setAccount,\n wallet,\n }),\n [walletAccount, wallet, accountKeys],\n )}\n >\n {children}\n </WalletUiAccountContext.Provider>\n );\n}\n","import { useStore } from '@nanostores/react';\nimport { createStorageCluster, SolanaClusterId } from '@wallet-ui/core';\nimport React from 'react';\n\nimport {\n WalletUiClusterContext,\n WalletUiClusterContextProviderProps,\n WalletUiClusterContextValue,\n} from './wallet-ui-cluster-context';\n\nexport function WalletUiClusterContextProvider({\n clusters,\n render,\n storage = createStorageCluster(),\n}: WalletUiClusterContextProviderProps) {\n const clusterId = useStore(storage.value);\n if (!clusterId) {\n throw new Error('Error reading cluster id from storage');\n }\n if (!clusters.length) {\n throw new Error('No clusters provided');\n }\n\n const cluster = clusters.find(c => c.id === clusterId);\n if (!cluster) {\n throw new Error(`Cluster ${clusterId.toString()} not found`);\n }\n\n const value: WalletUiClusterContextValue = {\n cluster,\n clusters,\n setCluster: (clusterId: SolanaClusterId) => {\n const cluster = clusters.find(c => c.id === clusterId);\n if (!cluster) {\n throw new Error(`Cluster ${clusterId} not found`);\n }\n storage.set(clusterId);\n },\n };\n\n return <WalletUiClusterContext.Provider value={value}>{render(value)}</WalletUiClusterContext.Provider>;\n}\n","import { UiWalletAccount } from '@wallet-standard/react';\nimport { handleCopyText } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { useWalletUiAccount } from './use-wallet-ui-account';\nimport { useWalletUiSolanaClient } from './use-wallet-ui-solana-client';\nimport { useWalletUiWallets } from './use-wallet-ui-wallets';\nimport { WalletUiContext, WalletUiContextProviderProps, WalletUiContextValue } from './wallet-ui-context';\n\nexport function WalletUiContextProvider({ children, size = 'md' }: WalletUiContextProviderProps) {\n const { account, accountKeys, setAccount, wallet } = useWalletUiAccount();\n const wallets = useWalletUiWallets();\n const client = useWalletUiSolanaClient();\n const connected = Boolean(wallet && wallet?.accounts.length > 0);\n\n function connect(account: UiWalletAccount) {\n setAccount(account);\n }\n\n function disconnect() {\n setAccount(undefined);\n }\n\n function copy() {\n if (!account) {\n return;\n }\n handleCopyText(account.address);\n }\n\n const value: WalletUiContextValue = {\n account,\n accountKeys,\n client,\n connect,\n connected,\n copy,\n disconnect,\n size,\n wallet,\n wallets,\n };\n\n return <WalletUiContext.Provider value={value}>{children}</WalletUiContext.Provider>;\n}\n","import { createSolanaClient, SolanaClient } from 'gill';\nimport React, { useMemo } from 'react';\n\nimport {\n WalletUiSolanaClientContext,\n WalletUiSolanaClientContextProviderProps,\n} from './wallet-ui-solana-client-context';\n\nexport function WalletUiSolanaClientContextProvider({\n children,\n urlOrMoniker,\n}: WalletUiSolanaClientContextProviderProps) {\n return (\n <WalletUiSolanaClientContext.Provider\n value={useMemo(() => createSolanaClient({ urlOrMoniker }) as SolanaClient, [urlOrMoniker])}\n >\n {children}\n </WalletUiSolanaClientContext.Provider>\n );\n}\n","import { SolanaCluster, StorageAccount, StorageCluster } from '@wallet-ui/core';\nimport React from 'react';\n\nimport { WalletUiAccountContextProvider } from './wallet-ui-account-context-provider';\nimport { WalletUiClusterContextProvider } from './wallet-ui-cluster-context-provider';\nimport { WalletUiContextProviderProps } from './wallet-ui-context';\nimport { WalletUiContextProvider } from './wallet-ui-context-provider';\nimport { WalletUiSolanaClientContextProvider } from './wallet-ui-solana-client-context-provider';\n\nexport interface WalletUiConfig extends Omit<WalletUiContextProviderProps, 'children'> {\n accountStorage?: StorageAccount;\n clusterStorage?: StorageCluster;\n clusters: SolanaCluster[];\n}\n\nexport function createWalletUiConfig(props: WalletUiConfig): WalletUiConfig {\n return { ...props };\n}\n\nexport interface WalletUiProps {\n children: React.ReactNode;\n config: WalletUiConfig;\n}\n\nexport function WalletUi({ children, config: { accountStorage, clusters, clusterStorage, ...config } }: WalletUiProps) {\n return (\n <React.Fragment>\n <WalletUiClusterContextProvider\n clusters={clusters}\n storage={clusterStorage}\n render={({ cluster }) => {\n return (\n <WalletUiSolanaClientContextProvider urlOrMoniker={cluster.urlOrMoniker}>\n <WalletUiAccountContextProvider storage={accountStorage}>\n <WalletUiContextProvider {...config}>{children}</WalletUiContextProvider>\n </WalletUiAccountContextProvider>\n </WalletUiSolanaClientContextProvider>\n );\n }}\n />\n </React.Fragment>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiButtonProps extends Omit<BaseButtonProps, 'label'> {\n size?: WalletUiSize;\n}\n\nexport function WalletUiButton({ ...props }: WalletUiButtonProps) {\n return <BaseButton {...props} label={'CLICK'} />;\n}\n","import React from 'react';\n\nimport { BaseDropdown, BaseDropdownItemType, BaseDropdownProps } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useBaseDropdown } from './use-base-dropdown';\nimport { useWalletUiCluster } from './use-wallet-ui-cluster';\n\nexport interface WalletUiClusterDropdownProps\n extends Omit<BaseDropdownProps, 'buttonProps' | 'dropdown' | 'items' | 'label'> {\n buttonProps?: Partial<BaseDropdownProps['buttonProps']>;\n size?: WalletUiSize;\n}\n\nexport function WalletUiClusterDropdown({ buttonProps, size = 'md', ...props }: WalletUiClusterDropdownProps) {\n const dropdown = useBaseDropdown();\n const { cluster, clusters, setCluster } = useWalletUiCluster();\n return (\n <BaseDropdown\n buttonProps={{ ...buttonProps, label: cluster.label, size: size }}\n items={clusters.map(cluster => ({\n handler: async () => {\n setCluster(cluster.id);\n await Promise.resolve();\n },\n label: cluster.label,\n type: BaseDropdownItemType.Item,\n value: cluster.id,\n }))}\n dropdown={dropdown}\n {...props}\n />\n );\n}\n","import React from 'react';\n\nimport { BaseDropdown } from './base-dropdown';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { useWalletUiDropdown } from './use-wallet-ui-dropdown';\n\nexport interface WalletUiDropdownProps {\n label?: string;\n size?: WalletUiSize;\n}\n\nexport function WalletUiDropdown({ size = 'md', ...props }: WalletUiDropdownProps) {\n const { buttonProps, items, dropdown } = useWalletUiDropdown({ size });\n return <BaseDropdown {...props} buttonProps={{ ...buttonProps }} dropdown={dropdown} items={items} size={size} />;\n}\n","import React from 'react';\n\nimport { BaseSvg, BaseSvgProps } from './base-svg';\n\nexport function WalletUiIconNoWallet({ size, ...props }: Omit<BaseSvgProps, 'sizes' | 'viewBox'>) {\n return (\n <BaseSvg size={size} sizes={{ lg: 125, md: 100, sm: 75 }} fill=\"none\" viewBox=\"0 0 97 96\" {...props}>\n <circle cx=\"48.5\" cy=\"48\" r=\"48\" fill=\"url(#paint0_linear_880_5115)\" fillOpacity=\"0.1\"></circle>\n <circle\n cx=\"48.5\"\n cy=\"48\"\n r=\"47\"\n stroke=\"url(#paint1_linear_880_5115)\"\n strokeOpacity=\"0.4\"\n strokeWidth=\"2\"\n ></circle>\n <g clipPath=\"url(#clip0_880_5115)\">\n <path\n d=\"M65.5769 28.1523H31.4231C27.6057 28.1523 24.5 31.258 24.5 35.0754V60.9215C24.5 64.7389 27.6057 67.8446 31.4231 67.8446H65.5769C69.3943 67.8446 72.5 64.7389 72.5 60.9215V35.0754C72.5 31.258 69.3943 28.1523 65.5769 28.1523ZM69.7308 52.1523H59.5769C57.2865 52.1523 55.4231 50.289 55.4231 47.9985C55.4231 45.708 57.2864 43.8446 59.5769 43.8446H69.7308V52.1523ZM69.7308 41.0754H59.5769C55.7595 41.0754 52.6539 44.1811 52.6539 47.9985C52.6539 51.8159 55.7595 54.9215 59.5769 54.9215H69.7308V60.9215C69.7308 63.2119 67.8674 65.0754 65.5769 65.0754H31.4231C29.1327 65.0754 27.2692 63.212 27.2692 60.9215V35.0754C27.2692 32.785 29.1326 30.9215 31.4231 30.9215H65.5769C67.8673 30.9215 69.7308 32.7849 69.7308 35.0754V41.0754Z\"\n fill=\"url(#paint2_linear_880_5115)\"\n ></path>\n <path\n d=\"M61.4231 46.6172H59.577C58.8123 46.6172 58.1924 47.2371 58.1924 48.0018C58.1924 48.7665 58.8123 49.3863 59.577 49.3863H61.4231C62.1878 49.3863 62.8077 48.7664 62.8077 48.0018C62.8077 47.2371 62.1878 46.6172 61.4231 46.6172Z\"\n fill=\"url(#paint3_linear_880_5115)\"\n ></path>\n </g>\n <defs>\n <linearGradient\n id=\"paint0_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint1_linear_880_5115\"\n x1=\"3.41664\"\n y1=\"98.0933\"\n x2=\"103.05\"\n y2=\"8.42498\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint2_linear_880_5115\"\n x1=\"25.9583\"\n y1=\"68.7101\"\n x2=\"67.2337\"\n y2=\"23.7879\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <linearGradient\n id=\"paint3_linear_880_5115\"\n x1=\"58.3326\"\n y1=\"49.4467\"\n x2=\"61.0002\"\n y2=\"45.4453\"\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#9945FF\"></stop>\n <stop offset=\"0.14\" stopColor=\"#8A53F4\"></stop>\n <stop offset=\"0.42\" stopColor=\"#6377D6\"></stop>\n <stop offset=\"0.79\" stopColor=\"#24B0A7\"></stop>\n <stop offset=\"0.99\" stopColor=\"#00D18C\"></stop>\n <stop offset=\"1\" stopColor=\"#00D18C\"></stop>\n </linearGradient>\n <clipPath id=\"clip0_880_5115\">\n <rect width=\"48\" height=\"48\" fill=\"white\" transform=\"translate(24.5 24)\"></rect>\n </clipPath>\n </defs>\n </BaseSvg>\n );\n}\n","import { UiWallet } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiSize } from './types/wallet-ui-size';\n\nexport interface WalletUiLabelProps\n extends React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement> {\n size?: WalletUiSize;\n wallet?: Pick<UiWallet, 'name'>;\n}\n\nexport function WalletUiLabel({ className, size, wallet, ...props }: WalletUiLabelProps) {\n if (!wallet) {\n return null;\n }\n\n return (\n <span data-ui=\"wallet-ui-label\" className={`${size ?? 'md'} ${className ?? ''}`} {...props}>\n {wallet.name}\n </span>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiButton } from './types/wallet-ui-button';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiIcon } from './wallet-ui-icon';\nimport { WalletUiLabel } from './wallet-ui-label';\n\nexport interface WalletUiListButtonProps extends Omit<WalletUiButton, 'onClick'> {\n select?: (wallet: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallet: UiWallet;\n}\n\nexport function WalletUiListButton({ className, select, size = 'md', wallet, ...props }: WalletUiListButtonProps) {\n const [pending, setPending] = React.useState(false);\n\n function handleSelect() {\n if (!select) {\n return;\n }\n setPending(true);\n // TODO: Add support for multiple accounts, properly handle no accounts\n const account = wallet.accounts.length > 0 ? wallet.accounts[0] : undefined;\n if (!account) {\n return;\n }\n void select(account).finally(() => setPending(false));\n }\n\n return (\n <button\n disabled={pending}\n data-ui=\"wallet-ui-list-button\"\n className={`${size} ${pending ? 'pending' : ''} ${className ?? ''}`}\n onClick={handleSelect}\n {...props}\n >\n <WalletUiIcon wallet={wallet} size={size} />\n <WalletUiLabel wallet={wallet} size={size} />\n </button>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { WalletUiDiv } from './types/wallet-ui-div';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiListButton } from './wallet-ui-list-button';\n\nexport interface WalletUiListProps extends WalletUiDiv {\n select?: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiList({ className, select, size = 'md', wallets, ...props }: WalletUiListProps) {\n return (\n <div data-ui=\"wallet-ui-list\" className={`${size} ${className ?? ''}`} {...props}>\n {wallets.map(wallet => (\n <WalletUiListButton key={wallet.name} select={select} size={size} wallet={wallet} />\n ))}\n </div>\n );\n}\n","import { UiWallet, UiWalletAccount } from '@wallet-standard/react';\nimport React from 'react';\n\nimport { BaseModal, BaseModalProps } from './base-modal';\nimport { WalletUiSize } from './types/wallet-ui-size';\nimport { WalletUiList } from './wallet-ui-list';\n\nexport interface WalletUiModalProps extends Omit<BaseModalProps, 'children'> {\n select: (account: UiWalletAccount) => Promise<void>;\n size?: WalletUiSize;\n wallets: UiWallet[];\n}\n\nexport function WalletUiModal({ size = 'md', wallets, select, ...props }: WalletUiModalProps) {\n return (\n <BaseModal description=\"Connect a wallet on Solana to continue\" size={size} {...props}>\n <WalletUiList size={size} wallets={wallets} select={select} />\n </BaseModal>\n );\n}\n","import React from 'react';\n\nimport { BaseButton, BaseButtonProps } from './base-button';\nimport { BaseModalControl } from './use-base-modal';\n\nexport interface WalletUiModalTriggerProps extends Omit<BaseButtonProps, 'label'> {\n label?: string;\n modal: BaseModalControl;\n}\n\nexport function WalletUiModalTrigger({ label = 'Select Wallet', modal, ...props }: WalletUiModalTriggerProps) {\n return <BaseButton label={label} onClick={() => void modal.open()} {...props} />;\n}\n"]}
@@ -38,7 +38,7 @@ var dialog__namespace = /*#__PURE__*/_interopNamespace(dialog);
38
38
 
39
39
  // src/base-button.tsx
40
40
  function BaseButton({ className, label, leftSection, onClick, rightSection, size, ...props }) {
41
- return /* @__PURE__ */ React19__default.default.createElement("button", { className: `wallet-ui-base-button ${size ?? "md"} ${className ?? ""}`, onClick, ...props }, leftSection ? /* @__PURE__ */ React19__default.default.createElement("span", { className: "wallet-ui-base-button-left-section" }, leftSection) : null, label, rightSection ? /* @__PURE__ */ React19__default.default.createElement("span", { className: "wallet-ui-base-button-right-section" }, rightSection) : null);
41
+ return /* @__PURE__ */ React19__default.default.createElement("button", { "data-ui": "base-button", className: `${size ?? "md"} ${className ?? ""}`, onClick, ...props }, leftSection ? /* @__PURE__ */ React19__default.default.createElement("span", { "data-ui": "base-button-left-section" }, leftSection) : null, label, rightSection ? /* @__PURE__ */ React19__default.default.createElement("span", { "data-ui": "base-button-right-section" }, rightSection) : null);
42
42
  }
43
43
  var WalletUiContext = React19__default.default.createContext({});
44
44
 
@@ -80,6 +80,21 @@ function useWalletUiWallet({ wallet }) {
80
80
  isDisconnecting
81
81
  };
82
82
  }
83
+ function WalletUiIcon({ className, size, wallet, ...props }) {
84
+ if (!wallet) {
85
+ return null;
86
+ }
87
+ return /* @__PURE__ */ React19__default.default.createElement(
88
+ "img",
89
+ {
90
+ "data-ui": "wallet-ui-icon",
91
+ src: wallet.icon,
92
+ alt: wallet.name,
93
+ className: `${size ?? "md"} ${className ?? ""}`,
94
+ ...props
95
+ }
96
+ );
97
+ }
83
98
 
84
99
  // src/base-dropdown.tsx
85
100
  var BaseDropdownItemType = /* @__PURE__ */ ((BaseDropdownItemType2) => {
@@ -90,25 +105,25 @@ var BaseDropdownItemType = /* @__PURE__ */ ((BaseDropdownItemType2) => {
90
105
  BaseDropdownItemType2["WalletNeeded"] = "WalletNeeded";
91
106
  return BaseDropdownItemType2;
92
107
  })(BaseDropdownItemType || {});
93
- function BaseDropdown({ buttonProps, dropdown, showIndicator, items }) {
108
+ function BaseDropdown({ buttonProps, dropdown, items, showIndicator, size = "md" }) {
94
109
  const api = dropdown.api;
95
110
  const trigger = /* @__PURE__ */ React19__default.default.createElement(
96
111
  BaseButton,
97
112
  {
98
113
  ...api.getTriggerProps(),
99
- className: `wallet-ui-base-dropdown-trigger`,
100
- "data-part": "trigger",
101
- rightSection: showIndicator ? /* @__PURE__ */ React19__default.default.createElement("span", { className: "wallet-actions" }, /* @__PURE__ */ React19__default.default.createElement("span", { ...api.getIndicatorProps(), className: "indicator" }, /* @__PURE__ */ React19__default.default.createElement(BaseDropdownChevronDown, { size: 12 }))) : null,
114
+ size,
115
+ rightSection: showIndicator ? /* @__PURE__ */ React19__default.default.createElement("span", { ...api.getIndicatorProps() }, /* @__PURE__ */ React19__default.default.createElement(BaseDropdownChevronDown, { size: 12 })) : null,
102
116
  ...buttonProps
103
117
  }
104
118
  );
105
- return /* @__PURE__ */ React19__default.default.createElement("div", { className: "wallet-ui-base-dropdown" }, trigger, /* @__PURE__ */ React19__default.default.createElement("div", { ...api.getPositionerProps(), className: "wallet-positioner" }, /* @__PURE__ */ React19__default.default.createElement("div", { ...api.getContentProps(), className: "wallet-ui-base-dropdown-list", "data-part": "content" }, items.map((item) => {
119
+ return /* @__PURE__ */ React19__default.default.createElement("div", { "data-ui": "base-dropdown" }, trigger, /* @__PURE__ */ React19__default.default.createElement("div", { ...api.getPositionerProps() }, /* @__PURE__ */ React19__default.default.createElement("div", { ...api.getContentProps(), "data-ui": "base-dropdown-list", "data-part": "content" }, items.map((item) => {
106
120
  return /* @__PURE__ */ React19__default.default.createElement(
107
121
  BaseDropdownItem,
108
122
  {
109
123
  ...api.getItemProps({ value: item.value }),
110
124
  key: item.value,
111
125
  item,
126
+ size,
112
127
  afterClick: () => {
113
128
  if (item.disabled) {
114
129
  return;
@@ -121,24 +136,34 @@ function BaseDropdown({ buttonProps, dropdown, showIndicator, items }) {
121
136
  );
122
137
  }))));
123
138
  }
124
- function BaseDropdownItem({ afterClick, item }) {
139
+ function BaseDropdownItem({ afterClick, item, size }) {
140
+ console.log("BaseDropdownItem", item, size);
125
141
  if (!item.wallet) {
126
- return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemRender, { afterClick, item });
142
+ return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemRender, { afterClick, item, size });
127
143
  }
128
144
  switch (item.type) {
129
145
  case "Item" /* Item */:
130
- return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemRender, { afterClick, item });
146
+ return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemRender, { afterClick, item, size });
131
147
  case "WalletConnect" /* WalletConnect */:
132
- return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemWalletConnect, { afterClick, item, wallet: item.wallet });
148
+ return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemWalletConnect, { afterClick, item, size, wallet: item.wallet });
133
149
  case "WalletCopy" /* WalletCopy */:
134
- return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemRender, { afterClick, item });
150
+ return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemRender, { afterClick, item, size });
135
151
  case "WalletDisconnect" /* WalletDisconnect */:
136
- return /* @__PURE__ */ React19__default.default.createElement(BaseDropdownItemWalletDisconnect, { afterClick, item, wallet: item.wallet });
152
+ return /* @__PURE__ */ React19__default.default.createElement(
153
+ BaseDropdownItemWalletDisconnect,
154
+ {
155
+ afterClick,
156
+ item,
157
+ size,
158
+ wallet: item.wallet
159
+ }
160
+ );
137
161
  }
138
162
  }
139
163
  function BaseDropdownItemWalletConnect({
140
164
  afterClick,
141
165
  item,
166
+ size,
142
167
  wallet
143
168
  }) {
144
169
  const { connect: connect3 } = useWalletUiWallet({ wallet });
@@ -151,14 +176,17 @@ function BaseDropdownItemWalletConnect({
151
176
  handler: async () => {
152
177
  await connect3();
153
178
  return await item.handler();
154
- }
155
- }
179
+ },
180
+ leftSection: wallet ? /* @__PURE__ */ React19__default.default.createElement(WalletUiIcon, { wallet, size }) : void 0
181
+ },
182
+ size
156
183
  }
157
184
  );
158
185
  }
159
186
  function BaseDropdownItemWalletDisconnect({
160
187
  afterClick,
161
188
  item,
189
+ size,
162
190
  wallet
163
191
  }) {
164
192
  const { disconnect } = useWalletUiWallet({ wallet });
@@ -172,11 +200,12 @@ function BaseDropdownItemWalletDisconnect({
172
200
  await disconnect();
173
201
  return await item.handler();
174
202
  }
175
- }
203
+ },
204
+ size
176
205
  }
177
206
  );
178
207
  }
179
- function BaseDropdownItemRender({ afterClick, item }) {
208
+ function BaseDropdownItemRender({ afterClick, item, size }) {
180
209
  function onClick() {
181
210
  if (item.disabled) {
182
211
  return;
@@ -185,7 +214,7 @@ function BaseDropdownItemRender({ afterClick, item }) {
185
214
  afterClick();
186
215
  });
187
216
  }
188
- return /* @__PURE__ */ React19__default.default.createElement("div", { className: "wallet-ui-base-dropdown-item", "data-part": "item", onClick }, item.leftSection ? /* @__PURE__ */ React19__default.default.createElement("span", { className: "wallet-ui-base-dropdown-item-left-section" }, item.leftSection) : null, item.label, item.rightSection ? /* @__PURE__ */ React19__default.default.createElement("span", { className: "wallet-ui-base-dropdown-item-right-section" }, item.rightSection) : null);
217
+ return /* @__PURE__ */ React19__default.default.createElement("div", { "data-ui": "base-dropdown-item", className: size, "data-part": "item", onClick }, item.leftSection ? /* @__PURE__ */ React19__default.default.createElement("span", { "data-ui": "base-dropdown-item-left-section" }, item.leftSection) : null, item.label, item.rightSection ? /* @__PURE__ */ React19__default.default.createElement("span", { "data-ui": "base-dropdown-item-right-section" }, item.rightSection) : null);
189
218
  }
190
219
  function BaseDropdownChevronDown(props) {
191
220
  return /* @__PURE__ */ React19__default.default.createElement(
@@ -256,26 +285,9 @@ var WalletUiClusterContext = React19.createContext({});
256
285
  function useWalletUiCluster() {
257
286
  return React19.useContext(WalletUiClusterContext);
258
287
  }
259
- function WalletUiIcon({ className, size, wallet, ...props }) {
260
- if (!wallet) {
261
- return null;
262
- }
263
- return /* @__PURE__ */ React19__default.default.createElement(
264
- "img",
265
- {
266
- src: wallet.icon,
267
- alt: wallet.name,
268
- className: `wallet-ui-list-icon ${size ?? "md"} ${className ?? ""}`,
269
- ...props
270
- }
271
- );
272
- }
273
-
274
- // src/use-wallet-ui-dropdown.tsx
275
288
  function getDropdownItemsWallets({
276
289
  wallets,
277
- connect: connect3,
278
- size
290
+ connect: connect3
279
291
  }) {
280
292
  return wallets.length ? wallets.map((wallet) => ({
281
293
  handler: async () => {
@@ -287,7 +299,6 @@ function getDropdownItemsWallets({
287
299
  await Promise.resolve();
288
300
  },
289
301
  label: wallet.name,
290
- leftSection: /* @__PURE__ */ React19__default.default.createElement(WalletUiIcon, { wallet, size }),
291
302
  type: "WalletConnect" /* WalletConnect */,
292
303
  value: wallet.name,
293
304
  wallet
@@ -306,9 +317,7 @@ function getDropdownItemsWallets({
306
317
  function useWalletUiDropdown({ size = "md" } = {}) {
307
318
  const dropdown = useBaseDropdown();
308
319
  const { account, connect: connect3, copy, disconnect, connected, wallet, wallets } = useWalletUi();
309
- const itemsWallets = React19.useMemo(() => {
310
- return getDropdownItemsWallets({ connect: connect3, size, wallets });
311
- }, [wallets, size, connect3]);
320
+ const itemsWallets = React19.useMemo(() => getDropdownItemsWallets({ connect: connect3, wallets }), [wallets, connect3]);
312
321
  const itemsConnected = React19.useMemo(
313
322
  () => [
314
323
  {
@@ -332,7 +341,7 @@ function useWalletUiDropdown({ size = "md" } = {}) {
332
341
  },
333
342
  ...itemsWallets
334
343
  ],
335
- [connect3, copy, disconnect, dropdown, size, wallets]
344
+ [copy, disconnect, dropdown, itemsWallets]
336
345
  );
337
346
  const items = React19.useMemo(() => {
338
347
  return connected ? itemsConnected : itemsWallets;
@@ -582,7 +591,7 @@ function WalletUiClusterDropdown({ buttonProps, size = "md", ...props }) {
582
591
  }
583
592
  function WalletUiDropdown({ size = "md", ...props }) {
584
593
  const { buttonProps, items, dropdown } = useWalletUiDropdown({ size });
585
- return /* @__PURE__ */ React19__default.default.createElement(BaseDropdown, { ...props, buttonProps: { ...buttonProps, size }, items, dropdown });
594
+ return /* @__PURE__ */ React19__default.default.createElement(BaseDropdown, { ...props, buttonProps: { ...buttonProps }, dropdown, items, size });
586
595
  }
587
596
  function WalletUiIconNoWallet({ size, ...props }) {
588
597
  return /* @__PURE__ */ React19__default.default.createElement(BaseSvg, { size, sizes: { lg: 125, md: 100, sm: 75 }, fill: "none", viewBox: "0 0 97 96", ...props }, /* @__PURE__ */ React19__default.default.createElement("circle", { cx: "48.5", cy: "48", r: "48", fill: "url(#paint0_linear_880_5115)", fillOpacity: "0.1" }), /* @__PURE__ */ React19__default.default.createElement(
@@ -677,7 +686,7 @@ function WalletUiLabel({ className, size, wallet, ...props }) {
677
686
  if (!wallet) {
678
687
  return null;
679
688
  }
680
- return /* @__PURE__ */ React19__default.default.createElement("span", { className: `wallet-ui-list-label ${size ?? "md"} ${className ?? ""}`, ...props }, wallet.name);
689
+ return /* @__PURE__ */ React19__default.default.createElement("span", { "data-ui": "wallet-ui-label", className: `${size ?? "md"} ${className ?? ""}`, ...props }, wallet.name);
681
690
  }
682
691
  function WalletUiListButton({ className, select, size = "md", wallet, ...props }) {
683
692
  const [pending, setPending] = React19__default.default.useState(false);
@@ -696,18 +705,19 @@ function WalletUiListButton({ className, select, size = "md", wallet, ...props }
696
705
  "button",
697
706
  {
698
707
  disabled: pending,
699
- className: `wallet-ui-list-button ${size} ${pending ? "wallet-ui-list-button-pending" : ""} ${className ?? ""}`,
708
+ "data-ui": "wallet-ui-list-button",
709
+ className: `${size} ${pending ? "pending" : ""} ${className ?? ""}`,
700
710
  onClick: handleSelect,
701
711
  ...props
702
712
  },
703
- /* @__PURE__ */ React19__default.default.createElement(WalletUiIcon, { className: "wallet-ui-list-button-icon", wallet, size }),
704
- /* @__PURE__ */ React19__default.default.createElement(WalletUiLabel, { className: "wallet-ui-list-button-label", wallet, size })
713
+ /* @__PURE__ */ React19__default.default.createElement(WalletUiIcon, { wallet, size }),
714
+ /* @__PURE__ */ React19__default.default.createElement(WalletUiLabel, { wallet, size })
705
715
  );
706
716
  }
707
717
 
708
718
  // src/wallet-ui-list.tsx
709
719
  function WalletUiList({ className, select, size = "md", wallets, ...props }) {
710
- return /* @__PURE__ */ React19__default.default.createElement("div", { className: `wallet-ui-list ${size} ${className ?? ""}`, ...props }, wallets.map((wallet) => /* @__PURE__ */ React19__default.default.createElement(WalletUiListButton, { key: wallet.name, select, size, wallet })));
720
+ return /* @__PURE__ */ React19__default.default.createElement("div", { "data-ui": "wallet-ui-list", className: `${size} ${className ?? ""}`, ...props }, wallets.map((wallet) => /* @__PURE__ */ React19__default.default.createElement(WalletUiListButton, { key: wallet.name, select, size, wallet })));
711
721
  }
712
722
  function WalletUiModal({ size = "md", wallets, select, ...props }) {
713
723
  return /* @__PURE__ */ React19__default.default.createElement(BaseModal, { description: "Connect a wallet on Solana to continue", size, ...props }, /* @__PURE__ */ React19__default.default.createElement(WalletUiList, { size, wallets, select }));