@haneullabs/dapp-kit 0.1.0
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.
- package/CHANGELOG.md +1445 -0
- package/LICENSE +201 -0
- package/README.md +97 -0
- package/dist/cjs/components/AccountDropdownMenu.css +177 -0
- package/dist/cjs/components/AccountDropdownMenu.css.css +49 -0
- package/dist/cjs/components/AccountDropdownMenu.css.css.map +7 -0
- package/dist/cjs/components/AccountDropdownMenu.css.d.ts +6 -0
- package/dist/cjs/components/AccountDropdownMenu.css.js +37 -0
- package/dist/cjs/components/AccountDropdownMenu.css.js.map +7 -0
- package/dist/cjs/components/AccountDropdownMenu.css.map +7 -0
- package/dist/cjs/components/AccountDropdownMenu.d.ts +10 -0
- package/dist/cjs/components/AccountDropdownMenu.js +423 -0
- package/dist/cjs/components/AccountDropdownMenu.js.map +7 -0
- package/dist/cjs/components/ConnectButton.css +458 -0
- package/dist/cjs/components/ConnectButton.css.map +7 -0
- package/dist/cjs/components/ConnectButton.d.ts +9 -0
- package/dist/cjs/components/ConnectButton.js +880 -0
- package/dist/cjs/components/ConnectButton.js.map +7 -0
- package/dist/cjs/components/HaneulClientProvider.d.ts +25 -0
- package/dist/cjs/components/HaneulClientProvider.js +70 -0
- package/dist/cjs/components/HaneulClientProvider.js.map +7 -0
- package/dist/cjs/components/WalletProvider.d.ts +26 -0
- package/dist/cjs/components/WalletProvider.js +853 -0
- package/dist/cjs/components/WalletProvider.js.map +7 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css +409 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css.css +115 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css.d.ts +11 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css.js +47 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/ConnectModal.css.map +7 -0
- package/dist/cjs/components/connect-modal/ConnectModal.d.ts +23 -0
- package/dist/cjs/components/connect-modal/ConnectModal.js +604 -0
- package/dist/cjs/components/connect-modal/ConnectModal.js.map +7 -0
- package/dist/cjs/components/connect-modal/InfoSection.css +78 -0
- package/dist/cjs/components/connect-modal/InfoSection.css.css +8 -0
- package/dist/cjs/components/connect-modal/InfoSection.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/InfoSection.css.d.ts +1 -0
- package/dist/cjs/components/connect-modal/InfoSection.css.js +27 -0
- package/dist/cjs/components/connect-modal/InfoSection.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/InfoSection.css.map +7 -0
- package/dist/cjs/components/connect-modal/InfoSection.d.ts +6 -0
- package/dist/cjs/components/connect-modal/InfoSection.js +119 -0
- package/dist/cjs/components/connect-modal/InfoSection.js.map +7 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css +146 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.css +32 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.d.ts +5 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.js +35 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.map +7 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.d.ts +8 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.js +165 -0
- package/dist/cjs/components/connect-modal/views/ConnectionStatus.js.map +7 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css +145 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css.css +23 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css.d.ts +3 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css.js +31 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.css.map +7 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.d.ts +1 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.js +172 -0
- package/dist/cjs/components/connect-modal/views/GettingStarted.js.map +7 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css +95 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.css +17 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.d.ts +2 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.js +29 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.map +7 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.d.ts +1 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.js +135 -0
- package/dist/cjs/components/connect-modal/views/WhatIsAWallet.js.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css +73 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.css +8 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.d.ts +1 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.js +27 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.d.ts +9 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.js +135 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletList.js.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css +65 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.css +33 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.css.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.d.ts +4 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.js +33 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.js.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.map +7 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.d.ts +9 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.js +95 -0
- package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.js.map +7 -0
- package/dist/cjs/components/icons/BackIcon.d.ts +2 -0
- package/dist/cjs/components/icons/BackIcon.js +36 -0
- package/dist/cjs/components/icons/BackIcon.js.map +7 -0
- package/dist/cjs/components/icons/CheckIcon.d.ts +2 -0
- package/dist/cjs/components/icons/CheckIcon.js +36 -0
- package/dist/cjs/components/icons/CheckIcon.js.map +7 -0
- package/dist/cjs/components/icons/ChevronIcon.d.ts +2 -0
- package/dist/cjs/components/icons/ChevronIcon.js +39 -0
- package/dist/cjs/components/icons/ChevronIcon.js.map +7 -0
- package/dist/cjs/components/icons/CloseIcon.d.ts +2 -0
- package/dist/cjs/components/icons/CloseIcon.js +36 -0
- package/dist/cjs/components/icons/CloseIcon.js.map +7 -0
- package/dist/cjs/components/styling/InjectedThemeStyles.d.ts +6 -0
- package/dist/cjs/components/styling/InjectedThemeStyles.js +125 -0
- package/dist/cjs/components/styling/InjectedThemeStyles.js.map +7 -0
- package/dist/cjs/components/styling/StyleMarker.css +46 -0
- package/dist/cjs/components/styling/StyleMarker.css.css +46 -0
- package/dist/cjs/components/styling/StyleMarker.css.css.map +7 -0
- package/dist/cjs/components/styling/StyleMarker.css.d.ts +1 -0
- package/dist/cjs/components/styling/StyleMarker.css.js +2 -0
- package/dist/cjs/components/styling/StyleMarker.css.js.map +7 -0
- package/dist/cjs/components/styling/StyleMarker.css.map +7 -0
- package/dist/cjs/components/styling/StyleMarker.d.ts +2 -0
- package/dist/cjs/components/styling/StyleMarker.js +69 -0
- package/dist/cjs/components/styling/StyleMarker.js.map +7 -0
- package/dist/cjs/components/ui/Button.css +44 -0
- package/dist/cjs/components/ui/Button.css.css +44 -0
- package/dist/cjs/components/ui/Button.css.css.map +7 -0
- package/dist/cjs/components/ui/Button.css.d.ts +33 -0
- package/dist/cjs/components/ui/Button.css.js +28 -0
- package/dist/cjs/components/ui/Button.css.js.map +7 -0
- package/dist/cjs/components/ui/Button.css.map +7 -0
- package/dist/cjs/components/ui/Button.d.ts +8 -0
- package/dist/cjs/components/ui/Button.js +60 -0
- package/dist/cjs/components/ui/Button.js.map +7 -0
- package/dist/cjs/components/ui/Heading.css +32 -0
- package/dist/cjs/components/ui/Heading.css.css +32 -0
- package/dist/cjs/components/ui/Heading.css.css.map +7 -0
- package/dist/cjs/components/ui/Heading.css.d.ts +33 -0
- package/dist/cjs/components/ui/Heading.css.js +28 -0
- package/dist/cjs/components/ui/Heading.css.js.map +7 -0
- package/dist/cjs/components/ui/Heading.css.map +7 -0
- package/dist/cjs/components/ui/Heading.d.ts +12 -0
- package/dist/cjs/components/ui/Heading.js +69 -0
- package/dist/cjs/components/ui/Heading.js.map +7 -0
- package/dist/cjs/components/ui/IconButton.css +13 -0
- package/dist/cjs/components/ui/IconButton.css.css +13 -0
- package/dist/cjs/components/ui/IconButton.css.css.map +7 -0
- package/dist/cjs/components/ui/IconButton.css.d.ts +1 -0
- package/dist/cjs/components/ui/IconButton.css.js +27 -0
- package/dist/cjs/components/ui/IconButton.css.js.map +7 -0
- package/dist/cjs/components/ui/IconButton.css.map +7 -0
- package/dist/cjs/components/ui/IconButton.d.ts +6 -0
- package/dist/cjs/components/ui/IconButton.js +52 -0
- package/dist/cjs/components/ui/IconButton.js.map +7 -0
- package/dist/cjs/components/ui/Text.css +38 -0
- package/dist/cjs/components/ui/Text.css.css +38 -0
- package/dist/cjs/components/ui/Text.css.css.map +7 -0
- package/dist/cjs/components/ui/Text.css.d.ts +33 -0
- package/dist/cjs/components/ui/Text.css.js +28 -0
- package/dist/cjs/components/ui/Text.css.js.map +7 -0
- package/dist/cjs/components/ui/Text.css.map +7 -0
- package/dist/cjs/components/ui/Text.d.ts +12 -0
- package/dist/cjs/components/ui/Text.js +70 -0
- package/dist/cjs/components/ui/Text.js.map +7 -0
- package/dist/cjs/constants/styleDataAttribute.d.ts +5 -0
- package/dist/cjs/constants/styleDataAttribute.js +31 -0
- package/dist/cjs/constants/styleDataAttribute.js.map +7 -0
- package/dist/cjs/constants/walletDefaults.d.ts +6 -0
- package/dist/cjs/constants/walletDefaults.js +58 -0
- package/dist/cjs/constants/walletDefaults.js.map +7 -0
- package/dist/cjs/constants/walletMutationKeys.d.ts +14 -0
- package/dist/cjs/constants/walletMutationKeys.js +42 -0
- package/dist/cjs/constants/walletMutationKeys.js.map +7 -0
- package/dist/cjs/contexts/walletContext.d.ts +11 -0
- package/dist/cjs/contexts/walletContext.js +28 -0
- package/dist/cjs/contexts/walletContext.js.map +7 -0
- package/dist/cjs/errors/walletErrors.d.ts +22 -0
- package/dist/cjs/errors/walletErrors.js +37 -0
- package/dist/cjs/errors/walletErrors.js.map +7 -0
- package/dist/cjs/hooks/networkConfig.d.ts +10 -0
- package/dist/cjs/hooks/networkConfig.js +74 -0
- package/dist/cjs/hooks/networkConfig.js.map +7 -0
- package/dist/cjs/hooks/useHaneulClient.d.ts +3 -0
- package/dist/cjs/hooks/useHaneulClient.js +51 -0
- package/dist/cjs/hooks/useHaneulClient.js.map +7 -0
- package/dist/cjs/hooks/useHaneulClientInfiniteQuery.d.ts +25 -0
- package/dist/cjs/hooks/useHaneulClientInfiniteQuery.js +71 -0
- package/dist/cjs/hooks/useHaneulClientInfiniteQuery.js.map +7 -0
- package/dist/cjs/hooks/useHaneulClientMutation.d.ts +4 -0
- package/dist/cjs/hooks/useHaneulClientMutation.js +61 -0
- package/dist/cjs/hooks/useHaneulClientMutation.js.map +7 -0
- package/dist/cjs/hooks/useHaneulClientQueries.d.ts +27 -0
- package/dist/cjs/hooks/useHaneulClientQueries.js +71 -0
- package/dist/cjs/hooks/useHaneulClientQueries.js.map +7 -0
- package/dist/cjs/hooks/useHaneulClientQuery.d.ts +38 -0
- package/dist/cjs/hooks/useHaneulClientQuery.js +95 -0
- package/dist/cjs/hooks/useHaneulClientQuery.js.map +7 -0
- package/dist/cjs/hooks/useResolveHaneulNSNames.d.ts +3 -0
- package/dist/cjs/hooks/useResolveHaneulNSNames.js +84 -0
- package/dist/cjs/hooks/useResolveHaneulNSNames.js.map +7 -0
- package/dist/cjs/hooks/wallet/useAccounts.d.ts +5 -0
- package/dist/cjs/hooks/wallet/useAccounts.js +50 -0
- package/dist/cjs/hooks/wallet/useAccounts.js.map +7 -0
- package/dist/cjs/hooks/wallet/useAutoConnectWallet.d.ts +1 -0
- package/dist/cjs/hooks/wallet/useAutoConnectWallet.js +229 -0
- package/dist/cjs/hooks/wallet/useAutoConnectWallet.js.map +7 -0
- package/dist/cjs/hooks/wallet/useConnectWallet.d.ts +15 -0
- package/dist/cjs/hooks/wallet/useConnectWallet.js +106 -0
- package/dist/cjs/hooks/wallet/useConnectWallet.js.map +7 -0
- package/dist/cjs/hooks/wallet/useCurrentAccount.d.ts +5 -0
- package/dist/cjs/hooks/wallet/useCurrentAccount.js +50 -0
- package/dist/cjs/hooks/wallet/useCurrentAccount.js.map +7 -0
- package/dist/cjs/hooks/wallet/useCurrentWallet.d.ts +25 -0
- package/dist/cjs/hooks/wallet/useCurrentWallet.js +82 -0
- package/dist/cjs/hooks/wallet/useCurrentWallet.js.map +7 -0
- package/dist/cjs/hooks/wallet/useDisconnectWallet.d.ts +9 -0
- package/dist/cjs/hooks/wallet/useDisconnectWallet.js +129 -0
- package/dist/cjs/hooks/wallet/useDisconnectWallet.js.map +7 -0
- package/dist/cjs/hooks/wallet/useReportTransactionEffects.d.ts +15 -0
- package/dist/cjs/hooks/wallet/useReportTransactionEffects.js +144 -0
- package/dist/cjs/hooks/wallet/useReportTransactionEffects.js.map +7 -0
- package/dist/cjs/hooks/wallet/useSignAndExecuteTransaction.d.ts +29 -0
- package/dist/cjs/hooks/wallet/useSignAndExecuteTransaction.js +248 -0
- package/dist/cjs/hooks/wallet/useSignAndExecuteTransaction.js.map +7 -0
- package/dist/cjs/hooks/wallet/useSignPersonalMessage.d.ts +13 -0
- package/dist/cjs/hooks/wallet/useSignPersonalMessage.js +184 -0
- package/dist/cjs/hooks/wallet/useSignPersonalMessage.js.map +7 -0
- package/dist/cjs/hooks/wallet/useSignTransaction.d.ts +18 -0
- package/dist/cjs/hooks/wallet/useSignTransaction.js +230 -0
- package/dist/cjs/hooks/wallet/useSignTransaction.js.map +7 -0
- package/dist/cjs/hooks/wallet/useSlushWallet.d.ts +5 -0
- package/dist/cjs/hooks/wallet/useSlushWallet.js +53 -0
- package/dist/cjs/hooks/wallet/useSlushWallet.js.map +7 -0
- package/dist/cjs/hooks/wallet/useSwitchAccount.d.ts +14 -0
- package/dist/cjs/hooks/wallet/useSwitchAccount.js +134 -0
- package/dist/cjs/hooks/wallet/useSwitchAccount.js.map +7 -0
- package/dist/cjs/hooks/wallet/useUnsafeBurnerWallet.d.ts +1 -0
- package/dist/cjs/hooks/wallet/useUnsafeBurnerWallet.js +229 -0
- package/dist/cjs/hooks/wallet/useUnsafeBurnerWallet.js.map +7 -0
- package/dist/cjs/hooks/wallet/useWalletPropertiesChanged.d.ts +4 -0
- package/dist/cjs/hooks/wallet/useWalletPropertiesChanged.js +100 -0
- package/dist/cjs/hooks/wallet/useWalletPropertiesChanged.js.map +7 -0
- package/dist/cjs/hooks/wallet/useWalletStore.d.ts +2 -0
- package/dist/cjs/hooks/wallet/useWalletStore.js +43 -0
- package/dist/cjs/hooks/wallet/useWalletStore.js.map +7 -0
- package/dist/cjs/hooks/wallet/useWallets.d.ts +4 -0
- package/dist/cjs/hooks/wallet/useWallets.js +50 -0
- package/dist/cjs/hooks/wallet/useWallets.js.map +7 -0
- package/dist/cjs/hooks/wallet/useWalletsChanged.d.ts +5 -0
- package/dist/cjs/hooks/wallet/useWalletsChanged.js +86 -0
- package/dist/cjs/hooks/wallet/useWalletsChanged.js.map +7 -0
- package/dist/cjs/index.css +458 -0
- package/dist/cjs/index.css.map +7 -0
- package/dist/cjs/index.d.ts +26 -0
- package/dist/cjs/index.js +1924 -0
- package/dist/cjs/index.js.map +7 -0
- package/dist/cjs/package.json +4 -0
- package/dist/cjs/themes/lightTheme.d.ts +2 -0
- package/dist/cjs/themes/lightTheme.js +83 -0
- package/dist/cjs/themes/lightTheme.js.map +7 -0
- package/dist/cjs/themes/themeContract.d.ts +140 -0
- package/dist/cjs/themes/themeContract.js +88 -0
- package/dist/cjs/themes/themeContract.js.map +7 -0
- package/dist/cjs/types/utilityTypes.d.ts +1 -0
- package/dist/cjs/types/utilityTypes.js +19 -0
- package/dist/cjs/types/utilityTypes.js.map +7 -0
- package/dist/cjs/types.d.ts +2 -0
- package/dist/cjs/types.js +19 -0
- package/dist/cjs/types.js.map +7 -0
- package/dist/cjs/utils/assertUnreachable.d.ts +4 -0
- package/dist/cjs/utils/assertUnreachable.js +29 -0
- package/dist/cjs/utils/assertUnreachable.js.map +7 -0
- package/dist/cjs/utils/stateStorage.d.ts +2 -0
- package/dist/cjs/utils/stateStorage.js +40 -0
- package/dist/cjs/utils/stateStorage.js.map +7 -0
- package/dist/cjs/utils/walletUtils.d.ts +3 -0
- package/dist/cjs/utils/walletUtils.js +44 -0
- package/dist/cjs/utils/walletUtils.js.map +7 -0
- package/dist/cjs/walletStore.d.ts +42 -0
- package/dist/cjs/walletStore.js +125 -0
- package/dist/cjs/walletStore.js.map +7 -0
- package/dist/esm/components/AccountDropdownMenu.css +177 -0
- package/dist/esm/components/AccountDropdownMenu.css.css +49 -0
- package/dist/esm/components/AccountDropdownMenu.css.css.map +7 -0
- package/dist/esm/components/AccountDropdownMenu.css.d.ts +6 -0
- package/dist/esm/components/AccountDropdownMenu.css.js +16 -0
- package/dist/esm/components/AccountDropdownMenu.css.js.map +7 -0
- package/dist/esm/components/AccountDropdownMenu.css.map +7 -0
- package/dist/esm/components/AccountDropdownMenu.d.ts +10 -0
- package/dist/esm/components/AccountDropdownMenu.js +415 -0
- package/dist/esm/components/AccountDropdownMenu.js.map +7 -0
- package/dist/esm/components/ConnectButton.css +458 -0
- package/dist/esm/components/ConnectButton.css.map +7 -0
- package/dist/esm/components/ConnectButton.d.ts +9 -0
- package/dist/esm/components/ConnectButton.js +870 -0
- package/dist/esm/components/ConnectButton.js.map +7 -0
- package/dist/esm/components/HaneulClientProvider.d.ts +25 -0
- package/dist/esm/components/HaneulClientProvider.js +49 -0
- package/dist/esm/components/HaneulClientProvider.js.map +7 -0
- package/dist/esm/components/WalletProvider.d.ts +26 -0
- package/dist/esm/components/WalletProvider.js +833 -0
- package/dist/esm/components/WalletProvider.js.map +7 -0
- package/dist/esm/components/connect-modal/ConnectModal.css +409 -0
- package/dist/esm/components/connect-modal/ConnectModal.css.css +115 -0
- package/dist/esm/components/connect-modal/ConnectModal.css.css.map +7 -0
- package/dist/esm/components/connect-modal/ConnectModal.css.d.ts +11 -0
- package/dist/esm/components/connect-modal/ConnectModal.css.js +26 -0
- package/dist/esm/components/connect-modal/ConnectModal.css.js.map +7 -0
- package/dist/esm/components/connect-modal/ConnectModal.css.map +7 -0
- package/dist/esm/components/connect-modal/ConnectModal.d.ts +23 -0
- package/dist/esm/components/connect-modal/ConnectModal.js +596 -0
- package/dist/esm/components/connect-modal/ConnectModal.js.map +7 -0
- package/dist/esm/components/connect-modal/InfoSection.css +78 -0
- package/dist/esm/components/connect-modal/InfoSection.css.css +8 -0
- package/dist/esm/components/connect-modal/InfoSection.css.css.map +7 -0
- package/dist/esm/components/connect-modal/InfoSection.css.d.ts +1 -0
- package/dist/esm/components/connect-modal/InfoSection.css.js +6 -0
- package/dist/esm/components/connect-modal/InfoSection.css.js.map +7 -0
- package/dist/esm/components/connect-modal/InfoSection.css.map +7 -0
- package/dist/esm/components/connect-modal/InfoSection.d.ts +6 -0
- package/dist/esm/components/connect-modal/InfoSection.js +86 -0
- package/dist/esm/components/connect-modal/InfoSection.js.map +7 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css +146 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css.css +32 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css.css.map +7 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css.d.ts +5 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css.js +14 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css.js.map +7 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.css.map +7 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.d.ts +8 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.js +132 -0
- package/dist/esm/components/connect-modal/views/ConnectionStatus.js.map +7 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css +145 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css.css +23 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css.css.map +7 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css.d.ts +3 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css.js +10 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css.js.map +7 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.css.map +7 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.d.ts +1 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.js +139 -0
- package/dist/esm/components/connect-modal/views/GettingStarted.js.map +7 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css +95 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.css +17 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.css.map +7 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.d.ts +2 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.js +8 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.js.map +7 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.map +7 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.d.ts +1 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.js +102 -0
- package/dist/esm/components/connect-modal/views/WhatIsAWallet.js.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css +73 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css.css +8 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css.css.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css.d.ts +1 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css.js +6 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css.js.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.css.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.d.ts +9 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.js +104 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletList.js.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css +65 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.css +33 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.css.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.d.ts +4 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.js +12 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.js.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.map +7 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.d.ts +9 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.js +64 -0
- package/dist/esm/components/connect-modal/wallet-list/WalletListItem.js.map +7 -0
- package/dist/esm/components/icons/BackIcon.d.ts +2 -0
- package/dist/esm/components/icons/BackIcon.js +15 -0
- package/dist/esm/components/icons/BackIcon.js.map +7 -0
- package/dist/esm/components/icons/CheckIcon.d.ts +2 -0
- package/dist/esm/components/icons/CheckIcon.js +15 -0
- package/dist/esm/components/icons/CheckIcon.js.map +7 -0
- package/dist/esm/components/icons/ChevronIcon.d.ts +2 -0
- package/dist/esm/components/icons/ChevronIcon.js +18 -0
- package/dist/esm/components/icons/ChevronIcon.js.map +7 -0
- package/dist/esm/components/icons/CloseIcon.d.ts +2 -0
- package/dist/esm/components/icons/CloseIcon.js +15 -0
- package/dist/esm/components/icons/CloseIcon.js.map +7 -0
- package/dist/esm/components/styling/InjectedThemeStyles.d.ts +6 -0
- package/dist/esm/components/styling/InjectedThemeStyles.js +104 -0
- package/dist/esm/components/styling/InjectedThemeStyles.js.map +7 -0
- package/dist/esm/components/styling/StyleMarker.css +46 -0
- package/dist/esm/components/styling/StyleMarker.css.css +46 -0
- package/dist/esm/components/styling/StyleMarker.css.css.map +7 -0
- package/dist/esm/components/styling/StyleMarker.css.d.ts +1 -0
- package/dist/esm/components/styling/StyleMarker.css.js +22 -0
- package/dist/esm/components/styling/StyleMarker.css.js.map +7 -0
- package/dist/esm/components/styling/StyleMarker.css.map +7 -0
- package/dist/esm/components/styling/StyleMarker.d.ts +2 -0
- package/dist/esm/components/styling/StyleMarker.js +61 -0
- package/dist/esm/components/styling/StyleMarker.js.map +7 -0
- package/dist/esm/components/ui/Button.css +44 -0
- package/dist/esm/components/ui/Button.css.css +44 -0
- package/dist/esm/components/ui/Button.css.css.map +7 -0
- package/dist/esm/components/ui/Button.css.d.ts +33 -0
- package/dist/esm/components/ui/Button.css.js +7 -0
- package/dist/esm/components/ui/Button.css.js.map +7 -0
- package/dist/esm/components/ui/Button.css.map +7 -0
- package/dist/esm/components/ui/Button.d.ts +8 -0
- package/dist/esm/components/ui/Button.js +29 -0
- package/dist/esm/components/ui/Button.js.map +7 -0
- package/dist/esm/components/ui/Heading.css +32 -0
- package/dist/esm/components/ui/Heading.css.css +32 -0
- package/dist/esm/components/ui/Heading.css.css.map +7 -0
- package/dist/esm/components/ui/Heading.css.d.ts +33 -0
- package/dist/esm/components/ui/Heading.css.js +7 -0
- package/dist/esm/components/ui/Heading.css.js.map +7 -0
- package/dist/esm/components/ui/Heading.css.map +7 -0
- package/dist/esm/components/ui/Heading.d.ts +12 -0
- package/dist/esm/components/ui/Heading.js +38 -0
- package/dist/esm/components/ui/Heading.js.map +7 -0
- package/dist/esm/components/ui/IconButton.css +13 -0
- package/dist/esm/components/ui/IconButton.css.css +13 -0
- package/dist/esm/components/ui/IconButton.css.css.map +7 -0
- package/dist/esm/components/ui/IconButton.css.d.ts +1 -0
- package/dist/esm/components/ui/IconButton.css.js +6 -0
- package/dist/esm/components/ui/IconButton.css.js.map +7 -0
- package/dist/esm/components/ui/IconButton.css.map +7 -0
- package/dist/esm/components/ui/IconButton.d.ts +6 -0
- package/dist/esm/components/ui/IconButton.js +21 -0
- package/dist/esm/components/ui/IconButton.js.map +7 -0
- package/dist/esm/components/ui/Text.css +38 -0
- package/dist/esm/components/ui/Text.css.css +38 -0
- package/dist/esm/components/ui/Text.css.css.map +7 -0
- package/dist/esm/components/ui/Text.css.d.ts +33 -0
- package/dist/esm/components/ui/Text.css.js +7 -0
- package/dist/esm/components/ui/Text.css.js.map +7 -0
- package/dist/esm/components/ui/Text.css.map +7 -0
- package/dist/esm/components/ui/Text.d.ts +12 -0
- package/dist/esm/components/ui/Text.js +39 -0
- package/dist/esm/components/ui/Text.js.map +7 -0
- package/dist/esm/constants/styleDataAttribute.d.ts +5 -0
- package/dist/esm/constants/styleDataAttribute.js +10 -0
- package/dist/esm/constants/styleDataAttribute.js.map +7 -0
- package/dist/esm/constants/walletDefaults.d.ts +6 -0
- package/dist/esm/constants/walletDefaults.js +37 -0
- package/dist/esm/constants/walletDefaults.js.map +7 -0
- package/dist/esm/constants/walletMutationKeys.d.ts +14 -0
- package/dist/esm/constants/walletMutationKeys.js +21 -0
- package/dist/esm/constants/walletMutationKeys.js.map +7 -0
- package/dist/esm/contexts/walletContext.d.ts +11 -0
- package/dist/esm/contexts/walletContext.js +7 -0
- package/dist/esm/contexts/walletContext.js.map +7 -0
- package/dist/esm/errors/walletErrors.d.ts +22 -0
- package/dist/esm/errors/walletErrors.js +16 -0
- package/dist/esm/errors/walletErrors.js.map +7 -0
- package/dist/esm/hooks/networkConfig.d.ts +10 -0
- package/dist/esm/hooks/networkConfig.js +51 -0
- package/dist/esm/hooks/networkConfig.js.map +7 -0
- package/dist/esm/hooks/useHaneulClient.d.ts +3 -0
- package/dist/esm/hooks/useHaneulClient.js +30 -0
- package/dist/esm/hooks/useHaneulClient.js.map +7 -0
- package/dist/esm/hooks/useHaneulClientInfiniteQuery.d.ts +25 -0
- package/dist/esm/hooks/useHaneulClientInfiniteQuery.js +50 -0
- package/dist/esm/hooks/useHaneulClientInfiniteQuery.js.map +7 -0
- package/dist/esm/hooks/useHaneulClientMutation.d.ts +4 -0
- package/dist/esm/hooks/useHaneulClientMutation.js +40 -0
- package/dist/esm/hooks/useHaneulClientMutation.js.map +7 -0
- package/dist/esm/hooks/useHaneulClientQueries.d.ts +27 -0
- package/dist/esm/hooks/useHaneulClientQueries.js +50 -0
- package/dist/esm/hooks/useHaneulClientQueries.js.map +7 -0
- package/dist/esm/hooks/useHaneulClientQuery.d.ts +38 -0
- package/dist/esm/hooks/useHaneulClientQuery.js +74 -0
- package/dist/esm/hooks/useHaneulClientQuery.js.map +7 -0
- package/dist/esm/hooks/useResolveHaneulNSNames.d.ts +3 -0
- package/dist/esm/hooks/useResolveHaneulNSNames.js +61 -0
- package/dist/esm/hooks/useResolveHaneulNSNames.js.map +7 -0
- package/dist/esm/hooks/wallet/useAccounts.d.ts +5 -0
- package/dist/esm/hooks/wallet/useAccounts.js +27 -0
- package/dist/esm/hooks/wallet/useAccounts.js.map +7 -0
- package/dist/esm/hooks/wallet/useAutoConnectWallet.d.ts +1 -0
- package/dist/esm/hooks/wallet/useAutoConnectWallet.js +208 -0
- package/dist/esm/hooks/wallet/useAutoConnectWallet.js.map +7 -0
- package/dist/esm/hooks/wallet/useConnectWallet.d.ts +15 -0
- package/dist/esm/hooks/wallet/useConnectWallet.js +85 -0
- package/dist/esm/hooks/wallet/useConnectWallet.js.map +7 -0
- package/dist/esm/hooks/wallet/useCurrentAccount.d.ts +5 -0
- package/dist/esm/hooks/wallet/useCurrentAccount.js +27 -0
- package/dist/esm/hooks/wallet/useCurrentAccount.js.map +7 -0
- package/dist/esm/hooks/wallet/useCurrentWallet.d.ts +25 -0
- package/dist/esm/hooks/wallet/useCurrentWallet.js +59 -0
- package/dist/esm/hooks/wallet/useCurrentWallet.js.map +7 -0
- package/dist/esm/hooks/wallet/useDisconnectWallet.d.ts +9 -0
- package/dist/esm/hooks/wallet/useDisconnectWallet.js +108 -0
- package/dist/esm/hooks/wallet/useDisconnectWallet.js.map +7 -0
- package/dist/esm/hooks/wallet/useReportTransactionEffects.d.ts +15 -0
- package/dist/esm/hooks/wallet/useReportTransactionEffects.js +123 -0
- package/dist/esm/hooks/wallet/useReportTransactionEffects.js.map +7 -0
- package/dist/esm/hooks/wallet/useSignAndExecuteTransaction.d.ts +29 -0
- package/dist/esm/hooks/wallet/useSignAndExecuteTransaction.js +227 -0
- package/dist/esm/hooks/wallet/useSignAndExecuteTransaction.js.map +7 -0
- package/dist/esm/hooks/wallet/useSignPersonalMessage.d.ts +13 -0
- package/dist/esm/hooks/wallet/useSignPersonalMessage.js +163 -0
- package/dist/esm/hooks/wallet/useSignPersonalMessage.js.map +7 -0
- package/dist/esm/hooks/wallet/useSignTransaction.d.ts +18 -0
- package/dist/esm/hooks/wallet/useSignTransaction.js +209 -0
- package/dist/esm/hooks/wallet/useSignTransaction.js.map +7 -0
- package/dist/esm/hooks/wallet/useSlushWallet.d.ts +5 -0
- package/dist/esm/hooks/wallet/useSlushWallet.js +32 -0
- package/dist/esm/hooks/wallet/useSlushWallet.js.map +7 -0
- package/dist/esm/hooks/wallet/useSwitchAccount.d.ts +14 -0
- package/dist/esm/hooks/wallet/useSwitchAccount.js +113 -0
- package/dist/esm/hooks/wallet/useSwitchAccount.js.map +7 -0
- package/dist/esm/hooks/wallet/useUnsafeBurnerWallet.d.ts +1 -0
- package/dist/esm/hooks/wallet/useUnsafeBurnerWallet.js +209 -0
- package/dist/esm/hooks/wallet/useUnsafeBurnerWallet.js.map +7 -0
- package/dist/esm/hooks/wallet/useWalletPropertiesChanged.d.ts +4 -0
- package/dist/esm/hooks/wallet/useWalletPropertiesChanged.js +79 -0
- package/dist/esm/hooks/wallet/useWalletPropertiesChanged.js.map +7 -0
- package/dist/esm/hooks/wallet/useWalletStore.d.ts +2 -0
- package/dist/esm/hooks/wallet/useWalletStore.js +22 -0
- package/dist/esm/hooks/wallet/useWalletStore.js.map +7 -0
- package/dist/esm/hooks/wallet/useWallets.d.ts +4 -0
- package/dist/esm/hooks/wallet/useWallets.js +27 -0
- package/dist/esm/hooks/wallet/useWallets.js.map +7 -0
- package/dist/esm/hooks/wallet/useWalletsChanged.d.ts +5 -0
- package/dist/esm/hooks/wallet/useWalletsChanged.js +65 -0
- package/dist/esm/hooks/wallet/useWalletsChanged.js.map +7 -0
- package/dist/esm/index.css +458 -0
- package/dist/esm/index.css.map +7 -0
- package/dist/esm/index.d.ts +26 -0
- package/dist/esm/index.js +1914 -0
- package/dist/esm/index.js.map +7 -0
- package/dist/esm/package.json +4 -0
- package/dist/esm/themes/lightTheme.d.ts +2 -0
- package/dist/esm/themes/lightTheme.js +62 -0
- package/dist/esm/themes/lightTheme.js.map +7 -0
- package/dist/esm/themes/themeContract.d.ts +140 -0
- package/dist/esm/themes/themeContract.js +67 -0
- package/dist/esm/themes/themeContract.js.map +7 -0
- package/dist/esm/types/utilityTypes.d.ts +1 -0
- package/dist/esm/types/utilityTypes.js +1 -0
- package/dist/esm/types/utilityTypes.js.map +7 -0
- package/dist/esm/types.d.ts +2 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +7 -0
- package/dist/esm/utils/assertUnreachable.d.ts +4 -0
- package/dist/esm/utils/assertUnreachable.js +8 -0
- package/dist/esm/utils/assertUnreachable.js.map +7 -0
- package/dist/esm/utils/stateStorage.d.ts +2 -0
- package/dist/esm/utils/stateStorage.js +19 -0
- package/dist/esm/utils/stateStorage.js.map +7 -0
- package/dist/esm/utils/walletUtils.d.ts +3 -0
- package/dist/esm/utils/walletUtils.js +23 -0
- package/dist/esm/utils/walletUtils.js.map +7 -0
- package/dist/esm/walletStore.d.ts +42 -0
- package/dist/esm/walletStore.js +104 -0
- package/dist/esm/walletStore.js.map +7 -0
- package/dist/index.css/package.json +5 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +106 -0
- package/src/components/AccountDropdownMenu.css.ts +52 -0
- package/src/components/AccountDropdownMenu.tsx +87 -0
- package/src/components/ConnectButton.tsx +37 -0
- package/src/components/HaneulClientProvider.tsx +96 -0
- package/src/components/WalletProvider.tsx +114 -0
- package/src/components/connect-modal/ConnectModal.css.ts +124 -0
- package/src/components/connect-modal/ConnectModal.tsx +174 -0
- package/src/components/connect-modal/InfoSection.css.ts +10 -0
- package/src/components/connect-modal/InfoSection.tsx +24 -0
- package/src/components/connect-modal/views/ConnectionStatus.css.ts +35 -0
- package/src/components/connect-modal/views/ConnectionStatus.tsx +52 -0
- package/src/components/connect-modal/views/GettingStarted.css.ts +25 -0
- package/src/components/connect-modal/views/GettingStarted.tsx +38 -0
- package/src/components/connect-modal/views/WhatIsAWallet.css.ts +19 -0
- package/src/components/connect-modal/views/WhatIsAWallet.tsx +23 -0
- package/src/components/connect-modal/wallet-list/WalletList.css.ts +10 -0
- package/src/components/connect-modal/wallet-list/WalletList.tsx +46 -0
- package/src/components/connect-modal/wallet-list/WalletListItem.css.ts +35 -0
- package/src/components/connect-modal/wallet-list/WalletListItem.tsx +36 -0
- package/src/components/icons/BackIcon.tsx +17 -0
- package/src/components/icons/CheckIcon.tsx +15 -0
- package/src/components/icons/ChevronIcon.tsx +18 -0
- package/src/components/icons/CloseIcon.tsx +15 -0
- package/src/components/styling/InjectedThemeStyles.tsx +51 -0
- package/src/components/styling/StyleMarker.css.ts +48 -0
- package/src/components/styling/StyleMarker.tsx +24 -0
- package/src/components/ui/Button.css.ts +50 -0
- package/src/components/ui/Button.tsx +31 -0
- package/src/components/ui/Heading.css.ts +43 -0
- package/src/components/ui/Heading.tsx +52 -0
- package/src/components/ui/IconButton.css.ts +16 -0
- package/src/components/ui/IconButton.tsx +24 -0
- package/src/components/ui/Text.css.ts +38 -0
- package/src/components/ui/Text.tsx +50 -0
- package/src/constants/styleDataAttribute.ts +8 -0
- package/src/constants/walletDefaults.ts +24 -0
- package/src/constants/walletMutationKeys.ts +22 -0
- package/src/contexts/walletContext.ts +8 -0
- package/src/errors/walletErrors.ts +24 -0
- package/src/hooks/networkConfig.ts +45 -0
- package/src/hooks/useHaneulClient.ts +23 -0
- package/src/hooks/useHaneulClientInfiniteQuery.ts +78 -0
- package/src/hooks/useHaneulClientMutation.ts +27 -0
- package/src/hooks/useHaneulClientQueries.ts +68 -0
- package/src/hooks/useHaneulClientQuery.ts +123 -0
- package/src/hooks/useResolveHaneulNSNames.ts +30 -0
- package/src/hooks/wallet/useAccounts.ts +13 -0
- package/src/hooks/wallet/useAutoConnectWallet.ts +92 -0
- package/src/hooks/wallet/useConnectWallet.ts +86 -0
- package/src/hooks/wallet/useCurrentAccount.ts +13 -0
- package/src/hooks/wallet/useCurrentWallet.ts +44 -0
- package/src/hooks/wallet/useDisconnectWallet.ts +53 -0
- package/src/hooks/wallet/useReportTransactionEffects.ts +82 -0
- package/src/hooks/wallet/useSignAndExecuteTransaction.ts +171 -0
- package/src/hooks/wallet/useSignPersonalMessage.ts +100 -0
- package/src/hooks/wallet/useSignTransaction.ts +124 -0
- package/src/hooks/wallet/useSlushWallet.ts +40 -0
- package/src/hooks/wallet/useSwitchAccount.ts +60 -0
- package/src/hooks/wallet/useUnsafeBurnerWallet.ts +207 -0
- package/src/hooks/wallet/useWalletPropertiesChanged.ts +29 -0
- package/src/hooks/wallet/useWalletStore.ts +18 -0
- package/src/hooks/wallet/useWallets.ts +11 -0
- package/src/hooks/wallet/useWalletsChanged.ts +41 -0
- package/src/index.ts +30 -0
- package/src/themes/lightTheme.ts +63 -0
- package/src/themes/themeContract.ts +97 -0
- package/src/types/utilityTypes.ts +4 -0
- package/src/types.ts +5 -0
- package/src/utils/assertUnreachable.ts +9 -0
- package/src/utils/stateStorage.ts +19 -0
- package/src/utils/walletUtils.ts +37 -0
- package/src/walletStore.ts +144 -0
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
5
|
+
import clsx from 'clsx';
|
|
6
|
+
import { forwardRef } from 'react';
|
|
7
|
+
|
|
8
|
+
import { headingVariants } from './Heading.css.js';
|
|
9
|
+
import type { HeadingVariants } from './Heading.css.js';
|
|
10
|
+
|
|
11
|
+
type HeadingAsChildProps = {
|
|
12
|
+
asChild?: boolean;
|
|
13
|
+
as?: never;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
type HeadingAsProps = {
|
|
17
|
+
as?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
|
|
18
|
+
asChild?: never;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
type HeadingProps = (HeadingAsChildProps | HeadingAsProps) &
|
|
22
|
+
React.HTMLAttributes<HTMLHeadingElement> &
|
|
23
|
+
HeadingVariants;
|
|
24
|
+
|
|
25
|
+
const Heading = forwardRef<HTMLHeadingElement, HeadingProps>(
|
|
26
|
+
(
|
|
27
|
+
{
|
|
28
|
+
children,
|
|
29
|
+
className,
|
|
30
|
+
asChild = false,
|
|
31
|
+
as: Tag = 'h1',
|
|
32
|
+
size,
|
|
33
|
+
weight,
|
|
34
|
+
truncate,
|
|
35
|
+
...headingProps
|
|
36
|
+
},
|
|
37
|
+
forwardedRef,
|
|
38
|
+
) => {
|
|
39
|
+
return (
|
|
40
|
+
<Slot
|
|
41
|
+
{...headingProps}
|
|
42
|
+
ref={forwardedRef}
|
|
43
|
+
className={clsx(headingVariants({ size, weight, truncate }), className)}
|
|
44
|
+
>
|
|
45
|
+
{asChild ? children : <Tag>{children}</Tag>}
|
|
46
|
+
</Slot>
|
|
47
|
+
);
|
|
48
|
+
},
|
|
49
|
+
);
|
|
50
|
+
Heading.displayName = 'Heading';
|
|
51
|
+
|
|
52
|
+
export { Heading };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { style } from '@vanilla-extract/css';
|
|
5
|
+
|
|
6
|
+
import { themeVars } from '../../themes/themeContract.js';
|
|
7
|
+
|
|
8
|
+
export const container = style({
|
|
9
|
+
borderRadius: 9999,
|
|
10
|
+
padding: 8,
|
|
11
|
+
color: themeVars.colors.iconButton,
|
|
12
|
+
backgroundColor: themeVars.backgroundColors.iconButton,
|
|
13
|
+
':hover': {
|
|
14
|
+
backgroundColor: themeVars.backgroundColors.iconButtonHover,
|
|
15
|
+
},
|
|
16
|
+
});
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
5
|
+
import clsx from 'clsx';
|
|
6
|
+
import type { ButtonHTMLAttributes } from 'react';
|
|
7
|
+
import { forwardRef } from 'react';
|
|
8
|
+
|
|
9
|
+
import * as styles from './IconButton.css.js';
|
|
10
|
+
|
|
11
|
+
type IconButtonProps = {
|
|
12
|
+
asChild?: boolean;
|
|
13
|
+
'aria-label': string;
|
|
14
|
+
} & ButtonHTMLAttributes<HTMLButtonElement>;
|
|
15
|
+
|
|
16
|
+
const IconButton = forwardRef<HTMLButtonElement, IconButtonProps>(
|
|
17
|
+
({ className, asChild = false, ...props }, forwardedRef) => {
|
|
18
|
+
const Comp = asChild ? Slot : 'button';
|
|
19
|
+
return <Comp {...props} className={clsx(styles.container, className)} ref={forwardedRef} />;
|
|
20
|
+
},
|
|
21
|
+
);
|
|
22
|
+
IconButton.displayName = 'Button';
|
|
23
|
+
|
|
24
|
+
export { IconButton };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { RecipeVariants } from '@vanilla-extract/recipes';
|
|
5
|
+
import { recipe } from '@vanilla-extract/recipes';
|
|
6
|
+
|
|
7
|
+
import { themeVars } from '../../themes/themeContract.js';
|
|
8
|
+
|
|
9
|
+
export const textVariants = recipe({
|
|
10
|
+
variants: {
|
|
11
|
+
size: {
|
|
12
|
+
sm: {
|
|
13
|
+
fontSize: themeVars.fontSizes.small,
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
weight: {
|
|
17
|
+
normal: { fontWeight: themeVars.fontWeights.normal },
|
|
18
|
+
medium: { fontWeight: themeVars.fontWeights.medium },
|
|
19
|
+
bold: { fontWeight: themeVars.fontWeights.bold },
|
|
20
|
+
},
|
|
21
|
+
color: {
|
|
22
|
+
muted: { color: themeVars.colors.bodyMuted },
|
|
23
|
+
danger: { color: themeVars.colors.bodyDanger },
|
|
24
|
+
},
|
|
25
|
+
mono: {
|
|
26
|
+
true: {
|
|
27
|
+
fontFamily:
|
|
28
|
+
'ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace',
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
defaultVariants: {
|
|
33
|
+
size: 'sm',
|
|
34
|
+
weight: 'normal',
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
export type TextVariants = RecipeVariants<typeof textVariants>;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
5
|
+
import clsx from 'clsx';
|
|
6
|
+
import { forwardRef } from 'react';
|
|
7
|
+
|
|
8
|
+
import { textVariants } from './Text.css.js';
|
|
9
|
+
import type { TextVariants } from './Text.css.js';
|
|
10
|
+
|
|
11
|
+
type TextAsChildProps = {
|
|
12
|
+
asChild?: boolean;
|
|
13
|
+
as?: never;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
type TextDivProps = { as: 'div'; asChild?: never };
|
|
17
|
+
|
|
18
|
+
type TextProps = (TextAsChildProps | TextDivProps) &
|
|
19
|
+
React.HTMLAttributes<HTMLDivElement> &
|
|
20
|
+
TextVariants;
|
|
21
|
+
|
|
22
|
+
const Text = forwardRef<HTMLDivElement, TextProps>(
|
|
23
|
+
(
|
|
24
|
+
{
|
|
25
|
+
children,
|
|
26
|
+
className,
|
|
27
|
+
asChild = false,
|
|
28
|
+
as: Tag = 'div',
|
|
29
|
+
size,
|
|
30
|
+
weight,
|
|
31
|
+
color,
|
|
32
|
+
mono,
|
|
33
|
+
...textProps
|
|
34
|
+
},
|
|
35
|
+
forwardedRef,
|
|
36
|
+
) => {
|
|
37
|
+
return (
|
|
38
|
+
<Slot
|
|
39
|
+
{...textProps}
|
|
40
|
+
ref={forwardedRef}
|
|
41
|
+
className={clsx(textVariants({ size, weight, color, mono }), className)}
|
|
42
|
+
>
|
|
43
|
+
{asChild ? children : <Tag>{children}</Tag>}
|
|
44
|
+
</Slot>
|
|
45
|
+
);
|
|
46
|
+
},
|
|
47
|
+
);
|
|
48
|
+
Text.displayName = 'Text';
|
|
49
|
+
|
|
50
|
+
export { Text };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
export const styleDataAttributeName = 'data-dapp-kit';
|
|
5
|
+
|
|
6
|
+
export const styleDataAttributeSelector = `[${styleDataAttributeName}]`;
|
|
7
|
+
|
|
8
|
+
export const styleDataAttribute = { [styleDataAttributeName]: '' };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HaneulWalletFeatures, WalletWithRequiredFeatures } from '@haneullabs/wallet-standard';
|
|
5
|
+
import { SLUSH_WALLET_NAME } from '@haneullabs/slush-wallet';
|
|
6
|
+
|
|
7
|
+
import { createInMemoryStore } from '../utils/stateStorage.js';
|
|
8
|
+
|
|
9
|
+
export const SUI_WALLET_NAME = 'Sui Wallet';
|
|
10
|
+
|
|
11
|
+
export const DEFAULT_STORAGE =
|
|
12
|
+
typeof window !== 'undefined' && window.localStorage ? localStorage : createInMemoryStore();
|
|
13
|
+
|
|
14
|
+
export const DEFAULT_STORAGE_KEY = 'sui-dapp-kit:wallet-connection-info';
|
|
15
|
+
|
|
16
|
+
const SIGN_FEATURES = [
|
|
17
|
+
'sui:signTransaction',
|
|
18
|
+
'sui:signTransactionBlock',
|
|
19
|
+
] satisfies (keyof HaneulWalletFeatures)[];
|
|
20
|
+
|
|
21
|
+
export const DEFAULT_WALLET_FILTER = (wallet: WalletWithRequiredFeatures) =>
|
|
22
|
+
SIGN_FEATURES.some((feature) => wallet.features[feature]);
|
|
23
|
+
|
|
24
|
+
export const DEFAULT_PREFERRED_WALLETS = [SUI_WALLET_NAME, SLUSH_WALLET_NAME];
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { MutationKey } from '@tanstack/react-query';
|
|
5
|
+
|
|
6
|
+
export const walletMutationKeys = {
|
|
7
|
+
all: { baseScope: 'wallet' },
|
|
8
|
+
connectWallet: formMutationKeyFn('connect-wallet'),
|
|
9
|
+
autoconnectWallet: formMutationKeyFn('autoconnect-wallet'),
|
|
10
|
+
disconnectWallet: formMutationKeyFn('disconnect-wallet'),
|
|
11
|
+
signPersonalMessage: formMutationKeyFn('sign-personal-message'),
|
|
12
|
+
signTransaction: formMutationKeyFn('sign-transaction'),
|
|
13
|
+
signAndExecuteTransaction: formMutationKeyFn('sign-and-execute-transaction'),
|
|
14
|
+
switchAccount: formMutationKeyFn('switch-account'),
|
|
15
|
+
reportTransactionEffects: formMutationKeyFn('report-transaction-effects'),
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
function formMutationKeyFn(baseEntity: string) {
|
|
19
|
+
return function mutationKeyFn(additionalKeys: MutationKey = []) {
|
|
20
|
+
return [{ ...walletMutationKeys.all, baseEntity }, ...additionalKeys];
|
|
21
|
+
};
|
|
22
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* An error that is instantiated when someone attempts to perform an action that requires an active wallet connection.
|
|
6
|
+
*/
|
|
7
|
+
export class WalletNotConnectedError extends Error {}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* An error that is instantiated when someone attempts to perform an action that requires a selected wallet account.
|
|
11
|
+
* This is more of an edge case stemming from the fact that wallets don't technically require you to authorize any
|
|
12
|
+
* accounts when connecting a wallet.
|
|
13
|
+
*/
|
|
14
|
+
export class WalletNoAccountSelectedError extends Error {}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* An error that is instantiated when someone attempts to perform an action that isn't supported by a wallet.
|
|
18
|
+
*/
|
|
19
|
+
export class WalletFeatureNotSupportedError extends Error {}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* An error that is instantiated when a wallet account can't be found for a specific wallet.
|
|
23
|
+
*/
|
|
24
|
+
export class WalletAccountNotFoundError extends Error {}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HaneulClientOptions } from '@haneullabs/haneul/client';
|
|
5
|
+
|
|
6
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
7
|
+
|
|
8
|
+
export type NetworkConfig<T extends object = object> = HaneulClientOptions & {
|
|
9
|
+
variables?: T;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export function createNetworkConfig<
|
|
13
|
+
const T extends Record<string, Config>,
|
|
14
|
+
Config extends NetworkConfig<Variables> = T[keyof T],
|
|
15
|
+
Variables extends object = NonNullable<Config['variables']>,
|
|
16
|
+
>(networkConfig: T) {
|
|
17
|
+
function useNetworkConfig(): Config {
|
|
18
|
+
const { config } = useHaneulClientContext();
|
|
19
|
+
|
|
20
|
+
if (!config) {
|
|
21
|
+
throw new Error('No network config found');
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
return config as T[keyof T];
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function useNetworkVariables(): Variables {
|
|
28
|
+
const { variables } = useNetworkConfig();
|
|
29
|
+
|
|
30
|
+
return (variables ?? {}) as Variables;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function useNetworkVariable<K extends keyof Variables>(name: K): Variables[K] {
|
|
34
|
+
const variables = useNetworkVariables();
|
|
35
|
+
|
|
36
|
+
return variables[name];
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return {
|
|
40
|
+
networkConfig,
|
|
41
|
+
useNetworkConfig,
|
|
42
|
+
useNetworkVariables,
|
|
43
|
+
useNetworkVariable,
|
|
44
|
+
};
|
|
45
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HaneulClient } from '@haneullabs/haneul/client';
|
|
5
|
+
import { useContext } from 'react';
|
|
6
|
+
|
|
7
|
+
import { HaneulClientContext } from '../components/HaneulClientProvider.js';
|
|
8
|
+
|
|
9
|
+
export function useHaneulClientContext() {
|
|
10
|
+
const haneulClient = useContext(HaneulClientContext);
|
|
11
|
+
|
|
12
|
+
if (!haneulClient) {
|
|
13
|
+
throw new Error(
|
|
14
|
+
'Could not find HaneulClientContext. Ensure that you have set up the HaneulClientProvider',
|
|
15
|
+
);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
return haneulClient;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export function useHaneulClient(): HaneulClient {
|
|
22
|
+
return useHaneulClientContext().client;
|
|
23
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HaneulClient } from '@haneullabs/haneul/client';
|
|
5
|
+
import type {
|
|
6
|
+
InfiniteData,
|
|
7
|
+
UseInfiniteQueryOptions,
|
|
8
|
+
UseInfiniteQueryResult,
|
|
9
|
+
} from '@tanstack/react-query';
|
|
10
|
+
import { useInfiniteQuery } from '@tanstack/react-query';
|
|
11
|
+
|
|
12
|
+
import type { PartialBy } from '../types/utilityTypes.js';
|
|
13
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
14
|
+
|
|
15
|
+
interface PaginatedResult {
|
|
16
|
+
data?: unknown;
|
|
17
|
+
nextCursor?: unknown;
|
|
18
|
+
hasNextPage: boolean;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export type SuiRpcPaginatedMethodName = {
|
|
22
|
+
[K in keyof HaneulClient]: HaneulClient[K] extends (input: any) => Promise<PaginatedResult> ? K : never;
|
|
23
|
+
}[keyof HaneulClient];
|
|
24
|
+
|
|
25
|
+
export type SuiRpcPaginatedMethods = {
|
|
26
|
+
[K in SuiRpcPaginatedMethodName]: HaneulClient[K] extends (
|
|
27
|
+
input: infer Params,
|
|
28
|
+
) => Promise<
|
|
29
|
+
infer Result extends { hasNextPage?: boolean | null; nextCursor?: infer Cursor | null }
|
|
30
|
+
>
|
|
31
|
+
? {
|
|
32
|
+
name: K;
|
|
33
|
+
result: Result;
|
|
34
|
+
params: Params;
|
|
35
|
+
cursor: Cursor;
|
|
36
|
+
}
|
|
37
|
+
: never;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export type UseHaneulClientInfiniteQueryOptions<
|
|
41
|
+
T extends keyof SuiRpcPaginatedMethods,
|
|
42
|
+
TData,
|
|
43
|
+
> = PartialBy<
|
|
44
|
+
Omit<
|
|
45
|
+
UseInfiniteQueryOptions<SuiRpcPaginatedMethods[T]['result'], Error, TData, unknown[]>,
|
|
46
|
+
'queryFn' | 'initialPageParam' | 'getNextPageParam'
|
|
47
|
+
>,
|
|
48
|
+
'queryKey'
|
|
49
|
+
>;
|
|
50
|
+
|
|
51
|
+
export function useHaneulClientInfiniteQuery<
|
|
52
|
+
T extends keyof SuiRpcPaginatedMethods,
|
|
53
|
+
TData = InfiniteData<SuiRpcPaginatedMethods[T]['result']>,
|
|
54
|
+
>(
|
|
55
|
+
method: T,
|
|
56
|
+
params: SuiRpcPaginatedMethods[T]['params'],
|
|
57
|
+
{
|
|
58
|
+
queryKey = [],
|
|
59
|
+
enabled = !!params,
|
|
60
|
+
...options
|
|
61
|
+
}: UseHaneulClientInfiniteQueryOptions<T, TData> = {},
|
|
62
|
+
): UseInfiniteQueryResult<TData, Error> {
|
|
63
|
+
const suiContext = useHaneulClientContext();
|
|
64
|
+
|
|
65
|
+
return useInfiniteQuery({
|
|
66
|
+
...options,
|
|
67
|
+
initialPageParam: null,
|
|
68
|
+
queryKey: [suiContext.network, method, params, ...queryKey],
|
|
69
|
+
enabled,
|
|
70
|
+
queryFn: ({ pageParam }) =>
|
|
71
|
+
suiContext.client[method]({
|
|
72
|
+
// oxlint-disable-next-line no-useless-fallback-in-spread
|
|
73
|
+
...(params ?? {}),
|
|
74
|
+
cursor: pageParam,
|
|
75
|
+
} as never),
|
|
76
|
+
getNextPageParam: (lastPage) => (lastPage.hasNextPage ? (lastPage.nextCursor ?? null) : null),
|
|
77
|
+
});
|
|
78
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
|
|
5
|
+
import { useMutation } from '@tanstack/react-query';
|
|
6
|
+
|
|
7
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
8
|
+
import type { SuiRpcMethods } from './useHaneulClientQuery.js';
|
|
9
|
+
|
|
10
|
+
export type UseHaneulClientMutationOptions<T extends keyof SuiRpcMethods> = Omit<
|
|
11
|
+
UseMutationOptions<SuiRpcMethods[T]['result'], Error, SuiRpcMethods[T]['params'], unknown[]>,
|
|
12
|
+
'mutationFn'
|
|
13
|
+
>;
|
|
14
|
+
|
|
15
|
+
export function useHaneulClientMutation<T extends keyof SuiRpcMethods>(
|
|
16
|
+
method: T,
|
|
17
|
+
options: UseHaneulClientMutationOptions<T> = {},
|
|
18
|
+
): UseMutationResult<SuiRpcMethods[T]['result'], Error, SuiRpcMethods[T]['params'], unknown[]> {
|
|
19
|
+
const suiContext = useHaneulClientContext();
|
|
20
|
+
|
|
21
|
+
return useMutation({
|
|
22
|
+
...options,
|
|
23
|
+
mutationFn: async (params) => {
|
|
24
|
+
return await suiContext.client[method](params as never);
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { UseQueryResult } from '@tanstack/react-query';
|
|
5
|
+
import { useQueries } from '@tanstack/react-query';
|
|
6
|
+
|
|
7
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
8
|
+
import type { SuiRpcMethods, UseHaneulClientQueryOptions } from './useHaneulClientQuery.js';
|
|
9
|
+
|
|
10
|
+
type HaneulClientQueryOptions = SuiRpcMethods[keyof SuiRpcMethods] extends infer Method
|
|
11
|
+
? Method extends {
|
|
12
|
+
name: infer M extends keyof SuiRpcMethods;
|
|
13
|
+
params?: infer P;
|
|
14
|
+
}
|
|
15
|
+
? undefined extends P
|
|
16
|
+
? {
|
|
17
|
+
method: M;
|
|
18
|
+
params?: P;
|
|
19
|
+
options?: UseHaneulClientQueryOptions<M, unknown>;
|
|
20
|
+
}
|
|
21
|
+
: {
|
|
22
|
+
method: M;
|
|
23
|
+
params: P;
|
|
24
|
+
options?: UseHaneulClientQueryOptions<M, unknown>;
|
|
25
|
+
}
|
|
26
|
+
: never
|
|
27
|
+
: never;
|
|
28
|
+
|
|
29
|
+
export type UseHaneulClientQueriesResults<Args extends readonly HaneulClientQueryOptions[]> = {
|
|
30
|
+
-readonly [K in keyof Args]: Args[K] extends {
|
|
31
|
+
method: infer M extends keyof SuiRpcMethods;
|
|
32
|
+
readonly options?:
|
|
33
|
+
| {
|
|
34
|
+
select?: (...args: any[]) => infer R;
|
|
35
|
+
}
|
|
36
|
+
| object;
|
|
37
|
+
}
|
|
38
|
+
? UseQueryResult<unknown extends R ? SuiRpcMethods[M]['result'] : R>
|
|
39
|
+
: never;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export function useHaneulClientQueries<
|
|
43
|
+
const Queries extends readonly HaneulClientQueryOptions[],
|
|
44
|
+
Results = UseHaneulClientQueriesResults<Queries>,
|
|
45
|
+
>({
|
|
46
|
+
queries,
|
|
47
|
+
combine,
|
|
48
|
+
}: {
|
|
49
|
+
queries: Queries;
|
|
50
|
+
combine?: (results: UseHaneulClientQueriesResults<Queries>) => Results;
|
|
51
|
+
}): Results {
|
|
52
|
+
const suiContext = useHaneulClientContext();
|
|
53
|
+
|
|
54
|
+
return useQueries({
|
|
55
|
+
combine: combine as never,
|
|
56
|
+
queries: queries.map((query) => {
|
|
57
|
+
const { method, params, options: { queryKey = [], ...restOptions } = {} } = query;
|
|
58
|
+
|
|
59
|
+
return {
|
|
60
|
+
...restOptions,
|
|
61
|
+
queryKey: [suiContext.network, method, params, ...queryKey],
|
|
62
|
+
queryFn: async () => {
|
|
63
|
+
return await suiContext.client[method](params as never);
|
|
64
|
+
},
|
|
65
|
+
};
|
|
66
|
+
}) as [],
|
|
67
|
+
});
|
|
68
|
+
}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HaneulClient } from '@haneullabs/haneul/client';
|
|
5
|
+
import type {
|
|
6
|
+
UndefinedInitialDataOptions,
|
|
7
|
+
UseQueryOptions,
|
|
8
|
+
UseQueryResult,
|
|
9
|
+
} from '@tanstack/react-query';
|
|
10
|
+
import { queryOptions, useQuery, useSuspenseQuery } from '@tanstack/react-query';
|
|
11
|
+
import { useMemo } from 'react';
|
|
12
|
+
|
|
13
|
+
import type { PartialBy } from '../types/utilityTypes.js';
|
|
14
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
15
|
+
|
|
16
|
+
export type SuiRpcMethodName = {
|
|
17
|
+
[K in keyof HaneulClient]: HaneulClient[K] extends ((input: any) => Promise<any>) | (() => Promise<any>)
|
|
18
|
+
? K
|
|
19
|
+
: never;
|
|
20
|
+
}[keyof HaneulClient];
|
|
21
|
+
|
|
22
|
+
export type SuiRpcMethods = {
|
|
23
|
+
[K in SuiRpcMethodName]: HaneulClient[K] extends (input: infer P) => Promise<infer R>
|
|
24
|
+
? {
|
|
25
|
+
name: K;
|
|
26
|
+
result: R;
|
|
27
|
+
params: P;
|
|
28
|
+
}
|
|
29
|
+
: HaneulClient[K] extends () => Promise<infer R>
|
|
30
|
+
? {
|
|
31
|
+
name: K;
|
|
32
|
+
result: R;
|
|
33
|
+
params: undefined | object;
|
|
34
|
+
}
|
|
35
|
+
: never;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
export type UseHaneulClientQueryOptions<T extends keyof SuiRpcMethods, TData> = PartialBy<
|
|
39
|
+
Omit<UseQueryOptions<SuiRpcMethods[T]['result'], Error, TData, unknown[]>, 'queryFn'>,
|
|
40
|
+
'queryKey'
|
|
41
|
+
>;
|
|
42
|
+
|
|
43
|
+
export type GetHaneulClientQueryOptions<T extends keyof SuiRpcMethods> = {
|
|
44
|
+
client: HaneulClient;
|
|
45
|
+
network: string;
|
|
46
|
+
method: T;
|
|
47
|
+
options?: PartialBy<
|
|
48
|
+
Omit<UndefinedInitialDataOptions<SuiRpcMethods[T]['result']>, 'queryFn'>,
|
|
49
|
+
'queryKey'
|
|
50
|
+
>;
|
|
51
|
+
} & (undefined extends SuiRpcMethods[T]['params']
|
|
52
|
+
? { params?: SuiRpcMethods[T]['params'] }
|
|
53
|
+
: { params: SuiRpcMethods[T]['params'] });
|
|
54
|
+
|
|
55
|
+
export function getHaneulClientQuery<T extends keyof SuiRpcMethods>({
|
|
56
|
+
client,
|
|
57
|
+
network,
|
|
58
|
+
method,
|
|
59
|
+
params,
|
|
60
|
+
options,
|
|
61
|
+
}: GetHaneulClientQueryOptions<T>) {
|
|
62
|
+
return queryOptions<SuiRpcMethods[T]['result']>({
|
|
63
|
+
...options,
|
|
64
|
+
queryKey: [network, method, params],
|
|
65
|
+
queryFn: async () => {
|
|
66
|
+
return await client[method](params as never);
|
|
67
|
+
},
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export function useHaneulClientQuery<
|
|
72
|
+
T extends keyof SuiRpcMethods,
|
|
73
|
+
TData = SuiRpcMethods[T]['result'],
|
|
74
|
+
>(
|
|
75
|
+
...args: undefined extends SuiRpcMethods[T]['params']
|
|
76
|
+
? [method: T, params?: SuiRpcMethods[T]['params'], options?: UseHaneulClientQueryOptions<T, TData>]
|
|
77
|
+
: [method: T, params: SuiRpcMethods[T]['params'], options?: UseHaneulClientQueryOptions<T, TData>]
|
|
78
|
+
): UseQueryResult<TData, Error> {
|
|
79
|
+
const [method, params, { queryKey = [], ...options } = {}] = args as [
|
|
80
|
+
method: T,
|
|
81
|
+
params?: SuiRpcMethods[T]['params'],
|
|
82
|
+
options?: UseHaneulClientQueryOptions<T, TData>,
|
|
83
|
+
];
|
|
84
|
+
|
|
85
|
+
const suiContext = useHaneulClientContext();
|
|
86
|
+
|
|
87
|
+
return useQuery({
|
|
88
|
+
...options,
|
|
89
|
+
queryKey: [suiContext.network, method, params, ...queryKey],
|
|
90
|
+
queryFn: async () => {
|
|
91
|
+
return await suiContext.client[method](params as never);
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
export function useHaneulClientSuspenseQuery<
|
|
97
|
+
T extends keyof SuiRpcMethods,
|
|
98
|
+
TData = SuiRpcMethods[T]['result'],
|
|
99
|
+
>(
|
|
100
|
+
...args: undefined extends SuiRpcMethods[T]['params']
|
|
101
|
+
? [method: T, params?: SuiRpcMethods[T]['params'], options?: UndefinedInitialDataOptions<TData>]
|
|
102
|
+
: [method: T, params: SuiRpcMethods[T]['params'], options?: UndefinedInitialDataOptions<TData>]
|
|
103
|
+
) {
|
|
104
|
+
const [method, params, options = {}] = args as [
|
|
105
|
+
method: T,
|
|
106
|
+
params?: SuiRpcMethods[T]['params'],
|
|
107
|
+
options?: UndefinedInitialDataOptions<TData>,
|
|
108
|
+
];
|
|
109
|
+
|
|
110
|
+
const suiContext = useHaneulClientContext();
|
|
111
|
+
|
|
112
|
+
const query = useMemo(() => {
|
|
113
|
+
return getHaneulClientQuery<T>({
|
|
114
|
+
client: suiContext.client,
|
|
115
|
+
network: suiContext.network,
|
|
116
|
+
method,
|
|
117
|
+
params,
|
|
118
|
+
options,
|
|
119
|
+
});
|
|
120
|
+
}, [suiContext.client, suiContext.network, method, params, options]);
|
|
121
|
+
|
|
122
|
+
return useSuspenseQuery(query);
|
|
123
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { ResolvedNameServiceNames } from '@haneullabs/haneul/client';
|
|
5
|
+
import type { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
6
|
+
|
|
7
|
+
import { useHaneulClientQuery } from './useHaneulClientQuery.js';
|
|
8
|
+
|
|
9
|
+
export function useResolveHaneulNSName(
|
|
10
|
+
address?: string | null,
|
|
11
|
+
options?: Omit<
|
|
12
|
+
UseQueryOptions<ResolvedNameServiceNames, Error, string | null, unknown[]>,
|
|
13
|
+
'queryFn' | 'queryKey' | 'select'
|
|
14
|
+
>,
|
|
15
|
+
): UseQueryResult<string | null, Error> {
|
|
16
|
+
return useHaneulClientQuery(
|
|
17
|
+
'resolveNameServiceNames',
|
|
18
|
+
{
|
|
19
|
+
address: address!,
|
|
20
|
+
limit: 1,
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
...options,
|
|
24
|
+
refetchOnWindowFocus: false,
|
|
25
|
+
retry: false,
|
|
26
|
+
select: (data) => (data.data.length > 0 ? data.data[0] : null),
|
|
27
|
+
enabled: !!address && options?.enabled !== false,
|
|
28
|
+
},
|
|
29
|
+
);
|
|
30
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// Copyright (c) Mysten Labs, Inc.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { WalletAccount } from '@haneullabs/wallet-standard';
|
|
5
|
+
|
|
6
|
+
import { useWalletStore } from './useWalletStore.js';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Retrieves a list of connected accounts authorized by the dApp.
|
|
10
|
+
*/
|
|
11
|
+
export function useAccounts(): readonly WalletAccount[] {
|
|
12
|
+
return useWalletStore((state) => state.accounts);
|
|
13
|
+
}
|