@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.
Files changed (625) hide show
  1. package/CHANGELOG.md +1445 -0
  2. package/LICENSE +201 -0
  3. package/README.md +97 -0
  4. package/dist/cjs/components/AccountDropdownMenu.css +177 -0
  5. package/dist/cjs/components/AccountDropdownMenu.css.css +49 -0
  6. package/dist/cjs/components/AccountDropdownMenu.css.css.map +7 -0
  7. package/dist/cjs/components/AccountDropdownMenu.css.d.ts +6 -0
  8. package/dist/cjs/components/AccountDropdownMenu.css.js +37 -0
  9. package/dist/cjs/components/AccountDropdownMenu.css.js.map +7 -0
  10. package/dist/cjs/components/AccountDropdownMenu.css.map +7 -0
  11. package/dist/cjs/components/AccountDropdownMenu.d.ts +10 -0
  12. package/dist/cjs/components/AccountDropdownMenu.js +423 -0
  13. package/dist/cjs/components/AccountDropdownMenu.js.map +7 -0
  14. package/dist/cjs/components/ConnectButton.css +458 -0
  15. package/dist/cjs/components/ConnectButton.css.map +7 -0
  16. package/dist/cjs/components/ConnectButton.d.ts +9 -0
  17. package/dist/cjs/components/ConnectButton.js +880 -0
  18. package/dist/cjs/components/ConnectButton.js.map +7 -0
  19. package/dist/cjs/components/HaneulClientProvider.d.ts +25 -0
  20. package/dist/cjs/components/HaneulClientProvider.js +70 -0
  21. package/dist/cjs/components/HaneulClientProvider.js.map +7 -0
  22. package/dist/cjs/components/WalletProvider.d.ts +26 -0
  23. package/dist/cjs/components/WalletProvider.js +853 -0
  24. package/dist/cjs/components/WalletProvider.js.map +7 -0
  25. package/dist/cjs/components/connect-modal/ConnectModal.css +409 -0
  26. package/dist/cjs/components/connect-modal/ConnectModal.css.css +115 -0
  27. package/dist/cjs/components/connect-modal/ConnectModal.css.css.map +7 -0
  28. package/dist/cjs/components/connect-modal/ConnectModal.css.d.ts +11 -0
  29. package/dist/cjs/components/connect-modal/ConnectModal.css.js +47 -0
  30. package/dist/cjs/components/connect-modal/ConnectModal.css.js.map +7 -0
  31. package/dist/cjs/components/connect-modal/ConnectModal.css.map +7 -0
  32. package/dist/cjs/components/connect-modal/ConnectModal.d.ts +23 -0
  33. package/dist/cjs/components/connect-modal/ConnectModal.js +604 -0
  34. package/dist/cjs/components/connect-modal/ConnectModal.js.map +7 -0
  35. package/dist/cjs/components/connect-modal/InfoSection.css +78 -0
  36. package/dist/cjs/components/connect-modal/InfoSection.css.css +8 -0
  37. package/dist/cjs/components/connect-modal/InfoSection.css.css.map +7 -0
  38. package/dist/cjs/components/connect-modal/InfoSection.css.d.ts +1 -0
  39. package/dist/cjs/components/connect-modal/InfoSection.css.js +27 -0
  40. package/dist/cjs/components/connect-modal/InfoSection.css.js.map +7 -0
  41. package/dist/cjs/components/connect-modal/InfoSection.css.map +7 -0
  42. package/dist/cjs/components/connect-modal/InfoSection.d.ts +6 -0
  43. package/dist/cjs/components/connect-modal/InfoSection.js +119 -0
  44. package/dist/cjs/components/connect-modal/InfoSection.js.map +7 -0
  45. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css +146 -0
  46. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.css +32 -0
  47. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.css.map +7 -0
  48. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.d.ts +5 -0
  49. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.js +35 -0
  50. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.js.map +7 -0
  51. package/dist/cjs/components/connect-modal/views/ConnectionStatus.css.map +7 -0
  52. package/dist/cjs/components/connect-modal/views/ConnectionStatus.d.ts +8 -0
  53. package/dist/cjs/components/connect-modal/views/ConnectionStatus.js +165 -0
  54. package/dist/cjs/components/connect-modal/views/ConnectionStatus.js.map +7 -0
  55. package/dist/cjs/components/connect-modal/views/GettingStarted.css +145 -0
  56. package/dist/cjs/components/connect-modal/views/GettingStarted.css.css +23 -0
  57. package/dist/cjs/components/connect-modal/views/GettingStarted.css.css.map +7 -0
  58. package/dist/cjs/components/connect-modal/views/GettingStarted.css.d.ts +3 -0
  59. package/dist/cjs/components/connect-modal/views/GettingStarted.css.js +31 -0
  60. package/dist/cjs/components/connect-modal/views/GettingStarted.css.js.map +7 -0
  61. package/dist/cjs/components/connect-modal/views/GettingStarted.css.map +7 -0
  62. package/dist/cjs/components/connect-modal/views/GettingStarted.d.ts +1 -0
  63. package/dist/cjs/components/connect-modal/views/GettingStarted.js +172 -0
  64. package/dist/cjs/components/connect-modal/views/GettingStarted.js.map +7 -0
  65. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css +95 -0
  66. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.css +17 -0
  67. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.css.map +7 -0
  68. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.d.ts +2 -0
  69. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.js +29 -0
  70. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.js.map +7 -0
  71. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.css.map +7 -0
  72. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.d.ts +1 -0
  73. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.js +135 -0
  74. package/dist/cjs/components/connect-modal/views/WhatIsAWallet.js.map +7 -0
  75. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css +73 -0
  76. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.css +8 -0
  77. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.css.map +7 -0
  78. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.d.ts +1 -0
  79. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.js +27 -0
  80. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.js.map +7 -0
  81. package/dist/cjs/components/connect-modal/wallet-list/WalletList.css.map +7 -0
  82. package/dist/cjs/components/connect-modal/wallet-list/WalletList.d.ts +9 -0
  83. package/dist/cjs/components/connect-modal/wallet-list/WalletList.js +135 -0
  84. package/dist/cjs/components/connect-modal/wallet-list/WalletList.js.map +7 -0
  85. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css +65 -0
  86. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.css +33 -0
  87. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.css.map +7 -0
  88. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.d.ts +4 -0
  89. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.js +33 -0
  90. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.js.map +7 -0
  91. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.css.map +7 -0
  92. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.d.ts +9 -0
  93. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.js +95 -0
  94. package/dist/cjs/components/connect-modal/wallet-list/WalletListItem.js.map +7 -0
  95. package/dist/cjs/components/icons/BackIcon.d.ts +2 -0
  96. package/dist/cjs/components/icons/BackIcon.js +36 -0
  97. package/dist/cjs/components/icons/BackIcon.js.map +7 -0
  98. package/dist/cjs/components/icons/CheckIcon.d.ts +2 -0
  99. package/dist/cjs/components/icons/CheckIcon.js +36 -0
  100. package/dist/cjs/components/icons/CheckIcon.js.map +7 -0
  101. package/dist/cjs/components/icons/ChevronIcon.d.ts +2 -0
  102. package/dist/cjs/components/icons/ChevronIcon.js +39 -0
  103. package/dist/cjs/components/icons/ChevronIcon.js.map +7 -0
  104. package/dist/cjs/components/icons/CloseIcon.d.ts +2 -0
  105. package/dist/cjs/components/icons/CloseIcon.js +36 -0
  106. package/dist/cjs/components/icons/CloseIcon.js.map +7 -0
  107. package/dist/cjs/components/styling/InjectedThemeStyles.d.ts +6 -0
  108. package/dist/cjs/components/styling/InjectedThemeStyles.js +125 -0
  109. package/dist/cjs/components/styling/InjectedThemeStyles.js.map +7 -0
  110. package/dist/cjs/components/styling/StyleMarker.css +46 -0
  111. package/dist/cjs/components/styling/StyleMarker.css.css +46 -0
  112. package/dist/cjs/components/styling/StyleMarker.css.css.map +7 -0
  113. package/dist/cjs/components/styling/StyleMarker.css.d.ts +1 -0
  114. package/dist/cjs/components/styling/StyleMarker.css.js +2 -0
  115. package/dist/cjs/components/styling/StyleMarker.css.js.map +7 -0
  116. package/dist/cjs/components/styling/StyleMarker.css.map +7 -0
  117. package/dist/cjs/components/styling/StyleMarker.d.ts +2 -0
  118. package/dist/cjs/components/styling/StyleMarker.js +69 -0
  119. package/dist/cjs/components/styling/StyleMarker.js.map +7 -0
  120. package/dist/cjs/components/ui/Button.css +44 -0
  121. package/dist/cjs/components/ui/Button.css.css +44 -0
  122. package/dist/cjs/components/ui/Button.css.css.map +7 -0
  123. package/dist/cjs/components/ui/Button.css.d.ts +33 -0
  124. package/dist/cjs/components/ui/Button.css.js +28 -0
  125. package/dist/cjs/components/ui/Button.css.js.map +7 -0
  126. package/dist/cjs/components/ui/Button.css.map +7 -0
  127. package/dist/cjs/components/ui/Button.d.ts +8 -0
  128. package/dist/cjs/components/ui/Button.js +60 -0
  129. package/dist/cjs/components/ui/Button.js.map +7 -0
  130. package/dist/cjs/components/ui/Heading.css +32 -0
  131. package/dist/cjs/components/ui/Heading.css.css +32 -0
  132. package/dist/cjs/components/ui/Heading.css.css.map +7 -0
  133. package/dist/cjs/components/ui/Heading.css.d.ts +33 -0
  134. package/dist/cjs/components/ui/Heading.css.js +28 -0
  135. package/dist/cjs/components/ui/Heading.css.js.map +7 -0
  136. package/dist/cjs/components/ui/Heading.css.map +7 -0
  137. package/dist/cjs/components/ui/Heading.d.ts +12 -0
  138. package/dist/cjs/components/ui/Heading.js +69 -0
  139. package/dist/cjs/components/ui/Heading.js.map +7 -0
  140. package/dist/cjs/components/ui/IconButton.css +13 -0
  141. package/dist/cjs/components/ui/IconButton.css.css +13 -0
  142. package/dist/cjs/components/ui/IconButton.css.css.map +7 -0
  143. package/dist/cjs/components/ui/IconButton.css.d.ts +1 -0
  144. package/dist/cjs/components/ui/IconButton.css.js +27 -0
  145. package/dist/cjs/components/ui/IconButton.css.js.map +7 -0
  146. package/dist/cjs/components/ui/IconButton.css.map +7 -0
  147. package/dist/cjs/components/ui/IconButton.d.ts +6 -0
  148. package/dist/cjs/components/ui/IconButton.js +52 -0
  149. package/dist/cjs/components/ui/IconButton.js.map +7 -0
  150. package/dist/cjs/components/ui/Text.css +38 -0
  151. package/dist/cjs/components/ui/Text.css.css +38 -0
  152. package/dist/cjs/components/ui/Text.css.css.map +7 -0
  153. package/dist/cjs/components/ui/Text.css.d.ts +33 -0
  154. package/dist/cjs/components/ui/Text.css.js +28 -0
  155. package/dist/cjs/components/ui/Text.css.js.map +7 -0
  156. package/dist/cjs/components/ui/Text.css.map +7 -0
  157. package/dist/cjs/components/ui/Text.d.ts +12 -0
  158. package/dist/cjs/components/ui/Text.js +70 -0
  159. package/dist/cjs/components/ui/Text.js.map +7 -0
  160. package/dist/cjs/constants/styleDataAttribute.d.ts +5 -0
  161. package/dist/cjs/constants/styleDataAttribute.js +31 -0
  162. package/dist/cjs/constants/styleDataAttribute.js.map +7 -0
  163. package/dist/cjs/constants/walletDefaults.d.ts +6 -0
  164. package/dist/cjs/constants/walletDefaults.js +58 -0
  165. package/dist/cjs/constants/walletDefaults.js.map +7 -0
  166. package/dist/cjs/constants/walletMutationKeys.d.ts +14 -0
  167. package/dist/cjs/constants/walletMutationKeys.js +42 -0
  168. package/dist/cjs/constants/walletMutationKeys.js.map +7 -0
  169. package/dist/cjs/contexts/walletContext.d.ts +11 -0
  170. package/dist/cjs/contexts/walletContext.js +28 -0
  171. package/dist/cjs/contexts/walletContext.js.map +7 -0
  172. package/dist/cjs/errors/walletErrors.d.ts +22 -0
  173. package/dist/cjs/errors/walletErrors.js +37 -0
  174. package/dist/cjs/errors/walletErrors.js.map +7 -0
  175. package/dist/cjs/hooks/networkConfig.d.ts +10 -0
  176. package/dist/cjs/hooks/networkConfig.js +74 -0
  177. package/dist/cjs/hooks/networkConfig.js.map +7 -0
  178. package/dist/cjs/hooks/useHaneulClient.d.ts +3 -0
  179. package/dist/cjs/hooks/useHaneulClient.js +51 -0
  180. package/dist/cjs/hooks/useHaneulClient.js.map +7 -0
  181. package/dist/cjs/hooks/useHaneulClientInfiniteQuery.d.ts +25 -0
  182. package/dist/cjs/hooks/useHaneulClientInfiniteQuery.js +71 -0
  183. package/dist/cjs/hooks/useHaneulClientInfiniteQuery.js.map +7 -0
  184. package/dist/cjs/hooks/useHaneulClientMutation.d.ts +4 -0
  185. package/dist/cjs/hooks/useHaneulClientMutation.js +61 -0
  186. package/dist/cjs/hooks/useHaneulClientMutation.js.map +7 -0
  187. package/dist/cjs/hooks/useHaneulClientQueries.d.ts +27 -0
  188. package/dist/cjs/hooks/useHaneulClientQueries.js +71 -0
  189. package/dist/cjs/hooks/useHaneulClientQueries.js.map +7 -0
  190. package/dist/cjs/hooks/useHaneulClientQuery.d.ts +38 -0
  191. package/dist/cjs/hooks/useHaneulClientQuery.js +95 -0
  192. package/dist/cjs/hooks/useHaneulClientQuery.js.map +7 -0
  193. package/dist/cjs/hooks/useResolveHaneulNSNames.d.ts +3 -0
  194. package/dist/cjs/hooks/useResolveHaneulNSNames.js +84 -0
  195. package/dist/cjs/hooks/useResolveHaneulNSNames.js.map +7 -0
  196. package/dist/cjs/hooks/wallet/useAccounts.d.ts +5 -0
  197. package/dist/cjs/hooks/wallet/useAccounts.js +50 -0
  198. package/dist/cjs/hooks/wallet/useAccounts.js.map +7 -0
  199. package/dist/cjs/hooks/wallet/useAutoConnectWallet.d.ts +1 -0
  200. package/dist/cjs/hooks/wallet/useAutoConnectWallet.js +229 -0
  201. package/dist/cjs/hooks/wallet/useAutoConnectWallet.js.map +7 -0
  202. package/dist/cjs/hooks/wallet/useConnectWallet.d.ts +15 -0
  203. package/dist/cjs/hooks/wallet/useConnectWallet.js +106 -0
  204. package/dist/cjs/hooks/wallet/useConnectWallet.js.map +7 -0
  205. package/dist/cjs/hooks/wallet/useCurrentAccount.d.ts +5 -0
  206. package/dist/cjs/hooks/wallet/useCurrentAccount.js +50 -0
  207. package/dist/cjs/hooks/wallet/useCurrentAccount.js.map +7 -0
  208. package/dist/cjs/hooks/wallet/useCurrentWallet.d.ts +25 -0
  209. package/dist/cjs/hooks/wallet/useCurrentWallet.js +82 -0
  210. package/dist/cjs/hooks/wallet/useCurrentWallet.js.map +7 -0
  211. package/dist/cjs/hooks/wallet/useDisconnectWallet.d.ts +9 -0
  212. package/dist/cjs/hooks/wallet/useDisconnectWallet.js +129 -0
  213. package/dist/cjs/hooks/wallet/useDisconnectWallet.js.map +7 -0
  214. package/dist/cjs/hooks/wallet/useReportTransactionEffects.d.ts +15 -0
  215. package/dist/cjs/hooks/wallet/useReportTransactionEffects.js +144 -0
  216. package/dist/cjs/hooks/wallet/useReportTransactionEffects.js.map +7 -0
  217. package/dist/cjs/hooks/wallet/useSignAndExecuteTransaction.d.ts +29 -0
  218. package/dist/cjs/hooks/wallet/useSignAndExecuteTransaction.js +248 -0
  219. package/dist/cjs/hooks/wallet/useSignAndExecuteTransaction.js.map +7 -0
  220. package/dist/cjs/hooks/wallet/useSignPersonalMessage.d.ts +13 -0
  221. package/dist/cjs/hooks/wallet/useSignPersonalMessage.js +184 -0
  222. package/dist/cjs/hooks/wallet/useSignPersonalMessage.js.map +7 -0
  223. package/dist/cjs/hooks/wallet/useSignTransaction.d.ts +18 -0
  224. package/dist/cjs/hooks/wallet/useSignTransaction.js +230 -0
  225. package/dist/cjs/hooks/wallet/useSignTransaction.js.map +7 -0
  226. package/dist/cjs/hooks/wallet/useSlushWallet.d.ts +5 -0
  227. package/dist/cjs/hooks/wallet/useSlushWallet.js +53 -0
  228. package/dist/cjs/hooks/wallet/useSlushWallet.js.map +7 -0
  229. package/dist/cjs/hooks/wallet/useSwitchAccount.d.ts +14 -0
  230. package/dist/cjs/hooks/wallet/useSwitchAccount.js +134 -0
  231. package/dist/cjs/hooks/wallet/useSwitchAccount.js.map +7 -0
  232. package/dist/cjs/hooks/wallet/useUnsafeBurnerWallet.d.ts +1 -0
  233. package/dist/cjs/hooks/wallet/useUnsafeBurnerWallet.js +229 -0
  234. package/dist/cjs/hooks/wallet/useUnsafeBurnerWallet.js.map +7 -0
  235. package/dist/cjs/hooks/wallet/useWalletPropertiesChanged.d.ts +4 -0
  236. package/dist/cjs/hooks/wallet/useWalletPropertiesChanged.js +100 -0
  237. package/dist/cjs/hooks/wallet/useWalletPropertiesChanged.js.map +7 -0
  238. package/dist/cjs/hooks/wallet/useWalletStore.d.ts +2 -0
  239. package/dist/cjs/hooks/wallet/useWalletStore.js +43 -0
  240. package/dist/cjs/hooks/wallet/useWalletStore.js.map +7 -0
  241. package/dist/cjs/hooks/wallet/useWallets.d.ts +4 -0
  242. package/dist/cjs/hooks/wallet/useWallets.js +50 -0
  243. package/dist/cjs/hooks/wallet/useWallets.js.map +7 -0
  244. package/dist/cjs/hooks/wallet/useWalletsChanged.d.ts +5 -0
  245. package/dist/cjs/hooks/wallet/useWalletsChanged.js +86 -0
  246. package/dist/cjs/hooks/wallet/useWalletsChanged.js.map +7 -0
  247. package/dist/cjs/index.css +458 -0
  248. package/dist/cjs/index.css.map +7 -0
  249. package/dist/cjs/index.d.ts +26 -0
  250. package/dist/cjs/index.js +1924 -0
  251. package/dist/cjs/index.js.map +7 -0
  252. package/dist/cjs/package.json +4 -0
  253. package/dist/cjs/themes/lightTheme.d.ts +2 -0
  254. package/dist/cjs/themes/lightTheme.js +83 -0
  255. package/dist/cjs/themes/lightTheme.js.map +7 -0
  256. package/dist/cjs/themes/themeContract.d.ts +140 -0
  257. package/dist/cjs/themes/themeContract.js +88 -0
  258. package/dist/cjs/themes/themeContract.js.map +7 -0
  259. package/dist/cjs/types/utilityTypes.d.ts +1 -0
  260. package/dist/cjs/types/utilityTypes.js +19 -0
  261. package/dist/cjs/types/utilityTypes.js.map +7 -0
  262. package/dist/cjs/types.d.ts +2 -0
  263. package/dist/cjs/types.js +19 -0
  264. package/dist/cjs/types.js.map +7 -0
  265. package/dist/cjs/utils/assertUnreachable.d.ts +4 -0
  266. package/dist/cjs/utils/assertUnreachable.js +29 -0
  267. package/dist/cjs/utils/assertUnreachable.js.map +7 -0
  268. package/dist/cjs/utils/stateStorage.d.ts +2 -0
  269. package/dist/cjs/utils/stateStorage.js +40 -0
  270. package/dist/cjs/utils/stateStorage.js.map +7 -0
  271. package/dist/cjs/utils/walletUtils.d.ts +3 -0
  272. package/dist/cjs/utils/walletUtils.js +44 -0
  273. package/dist/cjs/utils/walletUtils.js.map +7 -0
  274. package/dist/cjs/walletStore.d.ts +42 -0
  275. package/dist/cjs/walletStore.js +125 -0
  276. package/dist/cjs/walletStore.js.map +7 -0
  277. package/dist/esm/components/AccountDropdownMenu.css +177 -0
  278. package/dist/esm/components/AccountDropdownMenu.css.css +49 -0
  279. package/dist/esm/components/AccountDropdownMenu.css.css.map +7 -0
  280. package/dist/esm/components/AccountDropdownMenu.css.d.ts +6 -0
  281. package/dist/esm/components/AccountDropdownMenu.css.js +16 -0
  282. package/dist/esm/components/AccountDropdownMenu.css.js.map +7 -0
  283. package/dist/esm/components/AccountDropdownMenu.css.map +7 -0
  284. package/dist/esm/components/AccountDropdownMenu.d.ts +10 -0
  285. package/dist/esm/components/AccountDropdownMenu.js +415 -0
  286. package/dist/esm/components/AccountDropdownMenu.js.map +7 -0
  287. package/dist/esm/components/ConnectButton.css +458 -0
  288. package/dist/esm/components/ConnectButton.css.map +7 -0
  289. package/dist/esm/components/ConnectButton.d.ts +9 -0
  290. package/dist/esm/components/ConnectButton.js +870 -0
  291. package/dist/esm/components/ConnectButton.js.map +7 -0
  292. package/dist/esm/components/HaneulClientProvider.d.ts +25 -0
  293. package/dist/esm/components/HaneulClientProvider.js +49 -0
  294. package/dist/esm/components/HaneulClientProvider.js.map +7 -0
  295. package/dist/esm/components/WalletProvider.d.ts +26 -0
  296. package/dist/esm/components/WalletProvider.js +833 -0
  297. package/dist/esm/components/WalletProvider.js.map +7 -0
  298. package/dist/esm/components/connect-modal/ConnectModal.css +409 -0
  299. package/dist/esm/components/connect-modal/ConnectModal.css.css +115 -0
  300. package/dist/esm/components/connect-modal/ConnectModal.css.css.map +7 -0
  301. package/dist/esm/components/connect-modal/ConnectModal.css.d.ts +11 -0
  302. package/dist/esm/components/connect-modal/ConnectModal.css.js +26 -0
  303. package/dist/esm/components/connect-modal/ConnectModal.css.js.map +7 -0
  304. package/dist/esm/components/connect-modal/ConnectModal.css.map +7 -0
  305. package/dist/esm/components/connect-modal/ConnectModal.d.ts +23 -0
  306. package/dist/esm/components/connect-modal/ConnectModal.js +596 -0
  307. package/dist/esm/components/connect-modal/ConnectModal.js.map +7 -0
  308. package/dist/esm/components/connect-modal/InfoSection.css +78 -0
  309. package/dist/esm/components/connect-modal/InfoSection.css.css +8 -0
  310. package/dist/esm/components/connect-modal/InfoSection.css.css.map +7 -0
  311. package/dist/esm/components/connect-modal/InfoSection.css.d.ts +1 -0
  312. package/dist/esm/components/connect-modal/InfoSection.css.js +6 -0
  313. package/dist/esm/components/connect-modal/InfoSection.css.js.map +7 -0
  314. package/dist/esm/components/connect-modal/InfoSection.css.map +7 -0
  315. package/dist/esm/components/connect-modal/InfoSection.d.ts +6 -0
  316. package/dist/esm/components/connect-modal/InfoSection.js +86 -0
  317. package/dist/esm/components/connect-modal/InfoSection.js.map +7 -0
  318. package/dist/esm/components/connect-modal/views/ConnectionStatus.css +146 -0
  319. package/dist/esm/components/connect-modal/views/ConnectionStatus.css.css +32 -0
  320. package/dist/esm/components/connect-modal/views/ConnectionStatus.css.css.map +7 -0
  321. package/dist/esm/components/connect-modal/views/ConnectionStatus.css.d.ts +5 -0
  322. package/dist/esm/components/connect-modal/views/ConnectionStatus.css.js +14 -0
  323. package/dist/esm/components/connect-modal/views/ConnectionStatus.css.js.map +7 -0
  324. package/dist/esm/components/connect-modal/views/ConnectionStatus.css.map +7 -0
  325. package/dist/esm/components/connect-modal/views/ConnectionStatus.d.ts +8 -0
  326. package/dist/esm/components/connect-modal/views/ConnectionStatus.js +132 -0
  327. package/dist/esm/components/connect-modal/views/ConnectionStatus.js.map +7 -0
  328. package/dist/esm/components/connect-modal/views/GettingStarted.css +145 -0
  329. package/dist/esm/components/connect-modal/views/GettingStarted.css.css +23 -0
  330. package/dist/esm/components/connect-modal/views/GettingStarted.css.css.map +7 -0
  331. package/dist/esm/components/connect-modal/views/GettingStarted.css.d.ts +3 -0
  332. package/dist/esm/components/connect-modal/views/GettingStarted.css.js +10 -0
  333. package/dist/esm/components/connect-modal/views/GettingStarted.css.js.map +7 -0
  334. package/dist/esm/components/connect-modal/views/GettingStarted.css.map +7 -0
  335. package/dist/esm/components/connect-modal/views/GettingStarted.d.ts +1 -0
  336. package/dist/esm/components/connect-modal/views/GettingStarted.js +139 -0
  337. package/dist/esm/components/connect-modal/views/GettingStarted.js.map +7 -0
  338. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css +95 -0
  339. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.css +17 -0
  340. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.css.map +7 -0
  341. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.d.ts +2 -0
  342. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.js +8 -0
  343. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.js.map +7 -0
  344. package/dist/esm/components/connect-modal/views/WhatIsAWallet.css.map +7 -0
  345. package/dist/esm/components/connect-modal/views/WhatIsAWallet.d.ts +1 -0
  346. package/dist/esm/components/connect-modal/views/WhatIsAWallet.js +102 -0
  347. package/dist/esm/components/connect-modal/views/WhatIsAWallet.js.map +7 -0
  348. package/dist/esm/components/connect-modal/wallet-list/WalletList.css +73 -0
  349. package/dist/esm/components/connect-modal/wallet-list/WalletList.css.css +8 -0
  350. package/dist/esm/components/connect-modal/wallet-list/WalletList.css.css.map +7 -0
  351. package/dist/esm/components/connect-modal/wallet-list/WalletList.css.d.ts +1 -0
  352. package/dist/esm/components/connect-modal/wallet-list/WalletList.css.js +6 -0
  353. package/dist/esm/components/connect-modal/wallet-list/WalletList.css.js.map +7 -0
  354. package/dist/esm/components/connect-modal/wallet-list/WalletList.css.map +7 -0
  355. package/dist/esm/components/connect-modal/wallet-list/WalletList.d.ts +9 -0
  356. package/dist/esm/components/connect-modal/wallet-list/WalletList.js +104 -0
  357. package/dist/esm/components/connect-modal/wallet-list/WalletList.js.map +7 -0
  358. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css +65 -0
  359. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.css +33 -0
  360. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.css.map +7 -0
  361. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.d.ts +4 -0
  362. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.js +12 -0
  363. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.js.map +7 -0
  364. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.css.map +7 -0
  365. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.d.ts +9 -0
  366. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.js +64 -0
  367. package/dist/esm/components/connect-modal/wallet-list/WalletListItem.js.map +7 -0
  368. package/dist/esm/components/icons/BackIcon.d.ts +2 -0
  369. package/dist/esm/components/icons/BackIcon.js +15 -0
  370. package/dist/esm/components/icons/BackIcon.js.map +7 -0
  371. package/dist/esm/components/icons/CheckIcon.d.ts +2 -0
  372. package/dist/esm/components/icons/CheckIcon.js +15 -0
  373. package/dist/esm/components/icons/CheckIcon.js.map +7 -0
  374. package/dist/esm/components/icons/ChevronIcon.d.ts +2 -0
  375. package/dist/esm/components/icons/ChevronIcon.js +18 -0
  376. package/dist/esm/components/icons/ChevronIcon.js.map +7 -0
  377. package/dist/esm/components/icons/CloseIcon.d.ts +2 -0
  378. package/dist/esm/components/icons/CloseIcon.js +15 -0
  379. package/dist/esm/components/icons/CloseIcon.js.map +7 -0
  380. package/dist/esm/components/styling/InjectedThemeStyles.d.ts +6 -0
  381. package/dist/esm/components/styling/InjectedThemeStyles.js +104 -0
  382. package/dist/esm/components/styling/InjectedThemeStyles.js.map +7 -0
  383. package/dist/esm/components/styling/StyleMarker.css +46 -0
  384. package/dist/esm/components/styling/StyleMarker.css.css +46 -0
  385. package/dist/esm/components/styling/StyleMarker.css.css.map +7 -0
  386. package/dist/esm/components/styling/StyleMarker.css.d.ts +1 -0
  387. package/dist/esm/components/styling/StyleMarker.css.js +22 -0
  388. package/dist/esm/components/styling/StyleMarker.css.js.map +7 -0
  389. package/dist/esm/components/styling/StyleMarker.css.map +7 -0
  390. package/dist/esm/components/styling/StyleMarker.d.ts +2 -0
  391. package/dist/esm/components/styling/StyleMarker.js +61 -0
  392. package/dist/esm/components/styling/StyleMarker.js.map +7 -0
  393. package/dist/esm/components/ui/Button.css +44 -0
  394. package/dist/esm/components/ui/Button.css.css +44 -0
  395. package/dist/esm/components/ui/Button.css.css.map +7 -0
  396. package/dist/esm/components/ui/Button.css.d.ts +33 -0
  397. package/dist/esm/components/ui/Button.css.js +7 -0
  398. package/dist/esm/components/ui/Button.css.js.map +7 -0
  399. package/dist/esm/components/ui/Button.css.map +7 -0
  400. package/dist/esm/components/ui/Button.d.ts +8 -0
  401. package/dist/esm/components/ui/Button.js +29 -0
  402. package/dist/esm/components/ui/Button.js.map +7 -0
  403. package/dist/esm/components/ui/Heading.css +32 -0
  404. package/dist/esm/components/ui/Heading.css.css +32 -0
  405. package/dist/esm/components/ui/Heading.css.css.map +7 -0
  406. package/dist/esm/components/ui/Heading.css.d.ts +33 -0
  407. package/dist/esm/components/ui/Heading.css.js +7 -0
  408. package/dist/esm/components/ui/Heading.css.js.map +7 -0
  409. package/dist/esm/components/ui/Heading.css.map +7 -0
  410. package/dist/esm/components/ui/Heading.d.ts +12 -0
  411. package/dist/esm/components/ui/Heading.js +38 -0
  412. package/dist/esm/components/ui/Heading.js.map +7 -0
  413. package/dist/esm/components/ui/IconButton.css +13 -0
  414. package/dist/esm/components/ui/IconButton.css.css +13 -0
  415. package/dist/esm/components/ui/IconButton.css.css.map +7 -0
  416. package/dist/esm/components/ui/IconButton.css.d.ts +1 -0
  417. package/dist/esm/components/ui/IconButton.css.js +6 -0
  418. package/dist/esm/components/ui/IconButton.css.js.map +7 -0
  419. package/dist/esm/components/ui/IconButton.css.map +7 -0
  420. package/dist/esm/components/ui/IconButton.d.ts +6 -0
  421. package/dist/esm/components/ui/IconButton.js +21 -0
  422. package/dist/esm/components/ui/IconButton.js.map +7 -0
  423. package/dist/esm/components/ui/Text.css +38 -0
  424. package/dist/esm/components/ui/Text.css.css +38 -0
  425. package/dist/esm/components/ui/Text.css.css.map +7 -0
  426. package/dist/esm/components/ui/Text.css.d.ts +33 -0
  427. package/dist/esm/components/ui/Text.css.js +7 -0
  428. package/dist/esm/components/ui/Text.css.js.map +7 -0
  429. package/dist/esm/components/ui/Text.css.map +7 -0
  430. package/dist/esm/components/ui/Text.d.ts +12 -0
  431. package/dist/esm/components/ui/Text.js +39 -0
  432. package/dist/esm/components/ui/Text.js.map +7 -0
  433. package/dist/esm/constants/styleDataAttribute.d.ts +5 -0
  434. package/dist/esm/constants/styleDataAttribute.js +10 -0
  435. package/dist/esm/constants/styleDataAttribute.js.map +7 -0
  436. package/dist/esm/constants/walletDefaults.d.ts +6 -0
  437. package/dist/esm/constants/walletDefaults.js +37 -0
  438. package/dist/esm/constants/walletDefaults.js.map +7 -0
  439. package/dist/esm/constants/walletMutationKeys.d.ts +14 -0
  440. package/dist/esm/constants/walletMutationKeys.js +21 -0
  441. package/dist/esm/constants/walletMutationKeys.js.map +7 -0
  442. package/dist/esm/contexts/walletContext.d.ts +11 -0
  443. package/dist/esm/contexts/walletContext.js +7 -0
  444. package/dist/esm/contexts/walletContext.js.map +7 -0
  445. package/dist/esm/errors/walletErrors.d.ts +22 -0
  446. package/dist/esm/errors/walletErrors.js +16 -0
  447. package/dist/esm/errors/walletErrors.js.map +7 -0
  448. package/dist/esm/hooks/networkConfig.d.ts +10 -0
  449. package/dist/esm/hooks/networkConfig.js +51 -0
  450. package/dist/esm/hooks/networkConfig.js.map +7 -0
  451. package/dist/esm/hooks/useHaneulClient.d.ts +3 -0
  452. package/dist/esm/hooks/useHaneulClient.js +30 -0
  453. package/dist/esm/hooks/useHaneulClient.js.map +7 -0
  454. package/dist/esm/hooks/useHaneulClientInfiniteQuery.d.ts +25 -0
  455. package/dist/esm/hooks/useHaneulClientInfiniteQuery.js +50 -0
  456. package/dist/esm/hooks/useHaneulClientInfiniteQuery.js.map +7 -0
  457. package/dist/esm/hooks/useHaneulClientMutation.d.ts +4 -0
  458. package/dist/esm/hooks/useHaneulClientMutation.js +40 -0
  459. package/dist/esm/hooks/useHaneulClientMutation.js.map +7 -0
  460. package/dist/esm/hooks/useHaneulClientQueries.d.ts +27 -0
  461. package/dist/esm/hooks/useHaneulClientQueries.js +50 -0
  462. package/dist/esm/hooks/useHaneulClientQueries.js.map +7 -0
  463. package/dist/esm/hooks/useHaneulClientQuery.d.ts +38 -0
  464. package/dist/esm/hooks/useHaneulClientQuery.js +74 -0
  465. package/dist/esm/hooks/useHaneulClientQuery.js.map +7 -0
  466. package/dist/esm/hooks/useResolveHaneulNSNames.d.ts +3 -0
  467. package/dist/esm/hooks/useResolveHaneulNSNames.js +61 -0
  468. package/dist/esm/hooks/useResolveHaneulNSNames.js.map +7 -0
  469. package/dist/esm/hooks/wallet/useAccounts.d.ts +5 -0
  470. package/dist/esm/hooks/wallet/useAccounts.js +27 -0
  471. package/dist/esm/hooks/wallet/useAccounts.js.map +7 -0
  472. package/dist/esm/hooks/wallet/useAutoConnectWallet.d.ts +1 -0
  473. package/dist/esm/hooks/wallet/useAutoConnectWallet.js +208 -0
  474. package/dist/esm/hooks/wallet/useAutoConnectWallet.js.map +7 -0
  475. package/dist/esm/hooks/wallet/useConnectWallet.d.ts +15 -0
  476. package/dist/esm/hooks/wallet/useConnectWallet.js +85 -0
  477. package/dist/esm/hooks/wallet/useConnectWallet.js.map +7 -0
  478. package/dist/esm/hooks/wallet/useCurrentAccount.d.ts +5 -0
  479. package/dist/esm/hooks/wallet/useCurrentAccount.js +27 -0
  480. package/dist/esm/hooks/wallet/useCurrentAccount.js.map +7 -0
  481. package/dist/esm/hooks/wallet/useCurrentWallet.d.ts +25 -0
  482. package/dist/esm/hooks/wallet/useCurrentWallet.js +59 -0
  483. package/dist/esm/hooks/wallet/useCurrentWallet.js.map +7 -0
  484. package/dist/esm/hooks/wallet/useDisconnectWallet.d.ts +9 -0
  485. package/dist/esm/hooks/wallet/useDisconnectWallet.js +108 -0
  486. package/dist/esm/hooks/wallet/useDisconnectWallet.js.map +7 -0
  487. package/dist/esm/hooks/wallet/useReportTransactionEffects.d.ts +15 -0
  488. package/dist/esm/hooks/wallet/useReportTransactionEffects.js +123 -0
  489. package/dist/esm/hooks/wallet/useReportTransactionEffects.js.map +7 -0
  490. package/dist/esm/hooks/wallet/useSignAndExecuteTransaction.d.ts +29 -0
  491. package/dist/esm/hooks/wallet/useSignAndExecuteTransaction.js +227 -0
  492. package/dist/esm/hooks/wallet/useSignAndExecuteTransaction.js.map +7 -0
  493. package/dist/esm/hooks/wallet/useSignPersonalMessage.d.ts +13 -0
  494. package/dist/esm/hooks/wallet/useSignPersonalMessage.js +163 -0
  495. package/dist/esm/hooks/wallet/useSignPersonalMessage.js.map +7 -0
  496. package/dist/esm/hooks/wallet/useSignTransaction.d.ts +18 -0
  497. package/dist/esm/hooks/wallet/useSignTransaction.js +209 -0
  498. package/dist/esm/hooks/wallet/useSignTransaction.js.map +7 -0
  499. package/dist/esm/hooks/wallet/useSlushWallet.d.ts +5 -0
  500. package/dist/esm/hooks/wallet/useSlushWallet.js +32 -0
  501. package/dist/esm/hooks/wallet/useSlushWallet.js.map +7 -0
  502. package/dist/esm/hooks/wallet/useSwitchAccount.d.ts +14 -0
  503. package/dist/esm/hooks/wallet/useSwitchAccount.js +113 -0
  504. package/dist/esm/hooks/wallet/useSwitchAccount.js.map +7 -0
  505. package/dist/esm/hooks/wallet/useUnsafeBurnerWallet.d.ts +1 -0
  506. package/dist/esm/hooks/wallet/useUnsafeBurnerWallet.js +209 -0
  507. package/dist/esm/hooks/wallet/useUnsafeBurnerWallet.js.map +7 -0
  508. package/dist/esm/hooks/wallet/useWalletPropertiesChanged.d.ts +4 -0
  509. package/dist/esm/hooks/wallet/useWalletPropertiesChanged.js +79 -0
  510. package/dist/esm/hooks/wallet/useWalletPropertiesChanged.js.map +7 -0
  511. package/dist/esm/hooks/wallet/useWalletStore.d.ts +2 -0
  512. package/dist/esm/hooks/wallet/useWalletStore.js +22 -0
  513. package/dist/esm/hooks/wallet/useWalletStore.js.map +7 -0
  514. package/dist/esm/hooks/wallet/useWallets.d.ts +4 -0
  515. package/dist/esm/hooks/wallet/useWallets.js +27 -0
  516. package/dist/esm/hooks/wallet/useWallets.js.map +7 -0
  517. package/dist/esm/hooks/wallet/useWalletsChanged.d.ts +5 -0
  518. package/dist/esm/hooks/wallet/useWalletsChanged.js +65 -0
  519. package/dist/esm/hooks/wallet/useWalletsChanged.js.map +7 -0
  520. package/dist/esm/index.css +458 -0
  521. package/dist/esm/index.css.map +7 -0
  522. package/dist/esm/index.d.ts +26 -0
  523. package/dist/esm/index.js +1914 -0
  524. package/dist/esm/index.js.map +7 -0
  525. package/dist/esm/package.json +4 -0
  526. package/dist/esm/themes/lightTheme.d.ts +2 -0
  527. package/dist/esm/themes/lightTheme.js +62 -0
  528. package/dist/esm/themes/lightTheme.js.map +7 -0
  529. package/dist/esm/themes/themeContract.d.ts +140 -0
  530. package/dist/esm/themes/themeContract.js +67 -0
  531. package/dist/esm/themes/themeContract.js.map +7 -0
  532. package/dist/esm/types/utilityTypes.d.ts +1 -0
  533. package/dist/esm/types/utilityTypes.js +1 -0
  534. package/dist/esm/types/utilityTypes.js.map +7 -0
  535. package/dist/esm/types.d.ts +2 -0
  536. package/dist/esm/types.js +1 -0
  537. package/dist/esm/types.js.map +7 -0
  538. package/dist/esm/utils/assertUnreachable.d.ts +4 -0
  539. package/dist/esm/utils/assertUnreachable.js +8 -0
  540. package/dist/esm/utils/assertUnreachable.js.map +7 -0
  541. package/dist/esm/utils/stateStorage.d.ts +2 -0
  542. package/dist/esm/utils/stateStorage.js +19 -0
  543. package/dist/esm/utils/stateStorage.js.map +7 -0
  544. package/dist/esm/utils/walletUtils.d.ts +3 -0
  545. package/dist/esm/utils/walletUtils.js +23 -0
  546. package/dist/esm/utils/walletUtils.js.map +7 -0
  547. package/dist/esm/walletStore.d.ts +42 -0
  548. package/dist/esm/walletStore.js +104 -0
  549. package/dist/esm/walletStore.js.map +7 -0
  550. package/dist/index.css/package.json +5 -0
  551. package/dist/tsconfig.esm.tsbuildinfo +1 -0
  552. package/dist/tsconfig.tsbuildinfo +1 -0
  553. package/package.json +106 -0
  554. package/src/components/AccountDropdownMenu.css.ts +52 -0
  555. package/src/components/AccountDropdownMenu.tsx +87 -0
  556. package/src/components/ConnectButton.tsx +37 -0
  557. package/src/components/HaneulClientProvider.tsx +96 -0
  558. package/src/components/WalletProvider.tsx +114 -0
  559. package/src/components/connect-modal/ConnectModal.css.ts +124 -0
  560. package/src/components/connect-modal/ConnectModal.tsx +174 -0
  561. package/src/components/connect-modal/InfoSection.css.ts +10 -0
  562. package/src/components/connect-modal/InfoSection.tsx +24 -0
  563. package/src/components/connect-modal/views/ConnectionStatus.css.ts +35 -0
  564. package/src/components/connect-modal/views/ConnectionStatus.tsx +52 -0
  565. package/src/components/connect-modal/views/GettingStarted.css.ts +25 -0
  566. package/src/components/connect-modal/views/GettingStarted.tsx +38 -0
  567. package/src/components/connect-modal/views/WhatIsAWallet.css.ts +19 -0
  568. package/src/components/connect-modal/views/WhatIsAWallet.tsx +23 -0
  569. package/src/components/connect-modal/wallet-list/WalletList.css.ts +10 -0
  570. package/src/components/connect-modal/wallet-list/WalletList.tsx +46 -0
  571. package/src/components/connect-modal/wallet-list/WalletListItem.css.ts +35 -0
  572. package/src/components/connect-modal/wallet-list/WalletListItem.tsx +36 -0
  573. package/src/components/icons/BackIcon.tsx +17 -0
  574. package/src/components/icons/CheckIcon.tsx +15 -0
  575. package/src/components/icons/ChevronIcon.tsx +18 -0
  576. package/src/components/icons/CloseIcon.tsx +15 -0
  577. package/src/components/styling/InjectedThemeStyles.tsx +51 -0
  578. package/src/components/styling/StyleMarker.css.ts +48 -0
  579. package/src/components/styling/StyleMarker.tsx +24 -0
  580. package/src/components/ui/Button.css.ts +50 -0
  581. package/src/components/ui/Button.tsx +31 -0
  582. package/src/components/ui/Heading.css.ts +43 -0
  583. package/src/components/ui/Heading.tsx +52 -0
  584. package/src/components/ui/IconButton.css.ts +16 -0
  585. package/src/components/ui/IconButton.tsx +24 -0
  586. package/src/components/ui/Text.css.ts +38 -0
  587. package/src/components/ui/Text.tsx +50 -0
  588. package/src/constants/styleDataAttribute.ts +8 -0
  589. package/src/constants/walletDefaults.ts +24 -0
  590. package/src/constants/walletMutationKeys.ts +22 -0
  591. package/src/contexts/walletContext.ts +8 -0
  592. package/src/errors/walletErrors.ts +24 -0
  593. package/src/hooks/networkConfig.ts +45 -0
  594. package/src/hooks/useHaneulClient.ts +23 -0
  595. package/src/hooks/useHaneulClientInfiniteQuery.ts +78 -0
  596. package/src/hooks/useHaneulClientMutation.ts +27 -0
  597. package/src/hooks/useHaneulClientQueries.ts +68 -0
  598. package/src/hooks/useHaneulClientQuery.ts +123 -0
  599. package/src/hooks/useResolveHaneulNSNames.ts +30 -0
  600. package/src/hooks/wallet/useAccounts.ts +13 -0
  601. package/src/hooks/wallet/useAutoConnectWallet.ts +92 -0
  602. package/src/hooks/wallet/useConnectWallet.ts +86 -0
  603. package/src/hooks/wallet/useCurrentAccount.ts +13 -0
  604. package/src/hooks/wallet/useCurrentWallet.ts +44 -0
  605. package/src/hooks/wallet/useDisconnectWallet.ts +53 -0
  606. package/src/hooks/wallet/useReportTransactionEffects.ts +82 -0
  607. package/src/hooks/wallet/useSignAndExecuteTransaction.ts +171 -0
  608. package/src/hooks/wallet/useSignPersonalMessage.ts +100 -0
  609. package/src/hooks/wallet/useSignTransaction.ts +124 -0
  610. package/src/hooks/wallet/useSlushWallet.ts +40 -0
  611. package/src/hooks/wallet/useSwitchAccount.ts +60 -0
  612. package/src/hooks/wallet/useUnsafeBurnerWallet.ts +207 -0
  613. package/src/hooks/wallet/useWalletPropertiesChanged.ts +29 -0
  614. package/src/hooks/wallet/useWalletStore.ts +18 -0
  615. package/src/hooks/wallet/useWallets.ts +11 -0
  616. package/src/hooks/wallet/useWalletsChanged.ts +41 -0
  617. package/src/index.ts +30 -0
  618. package/src/themes/lightTheme.ts +63 -0
  619. package/src/themes/themeContract.ts +97 -0
  620. package/src/types/utilityTypes.ts +4 -0
  621. package/src/types.ts +5 -0
  622. package/src/utils/assertUnreachable.ts +9 -0
  623. package/src/utils/stateStorage.ts +19 -0
  624. package/src/utils/walletUtils.ts +37 -0
  625. package/src/walletStore.ts +144 -0
@@ -0,0 +1,1924 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __typeError = (msg) => {
9
+ throw TypeError(msg);
10
+ };
11
+ var __esm = (fn, res) => function __init() {
12
+ return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
13
+ };
14
+ var __commonJS = (cb, mod) => function __require() {
15
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
16
+ };
17
+ var __export = (target, all) => {
18
+ for (var name in all)
19
+ __defProp(target, name, { get: all[name], enumerable: true });
20
+ };
21
+ var __copyProps = (to, from, except, desc) => {
22
+ if (from && typeof from === "object" || typeof from === "function") {
23
+ for (let key of __getOwnPropNames(from))
24
+ if (!__hasOwnProp.call(to, key) && key !== except)
25
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
26
+ }
27
+ return to;
28
+ };
29
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
30
+ // If the importer is in node compatibility mode or this is not an ESM
31
+ // file that has been converted to a CommonJS file using a Babel-
32
+ // compatible transform (i.e. "__esModule" has not been set), then set
33
+ // "default" to the CommonJS "module.exports" for node compatibility.
34
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
35
+ mod
36
+ ));
37
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
38
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
39
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
40
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
41
+
42
+ // vanilla-extract-css-ns:src/components/styling/StyleMarker.css.ts.vanilla.css?source=OndoZXJlKCopIHsKICBib3gtc2l6aW5nOiBib3JkZXItYm94OwogIGNvbG9yOiB2YXIoLS1kYXBwLWtpdC1jb2xvcnMtYm9keSk7CiAgZm9udC1mYW1pbHk6IHZhcigtLWRhcHAta2l0LXR5cG9ncmFwaHktZm9udEZhbWlseSk7CiAgZm9udC1zaXplOiB2YXIoLS1kYXBwLWtpdC1mb250V2VpZ2h0cy1ub3JtYWwpOwogIGZvbnQtc3R5bGU6IHZhcigtLWRhcHAta2l0LXR5cG9ncmFwaHktZm9udFN0eWxlKTsKICBmb250LXdlaWdodDogdmFyKC0tZGFwcC1raXQtZm9udFdlaWdodHMtbm9ybWFsKTsKICBsaW5lLWhlaWdodDogdmFyKC0tZGFwcC1raXQtdHlwb2dyYXBoeS1saW5lSGVpZ2h0KTsKICBsZXR0ZXItc3BhY2luZzogdmFyKC0tZGFwcC1raXQtdHlwb2dyYXBoeS1sZXR0ZXJTcGFjaW5nKTsKfQo6d2hlcmUoYnV0dG9uKSB7CiAgYXBwZWFyYW5jZTogbm9uZTsKICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDsKICBmb250LXNpemU6IGluaGVyaXQ7CiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7CiAgbGluZS1oZWlnaHQ6IGluaGVyaXQ7CiAgbGV0dGVyLXNwYWNpbmc6IGluaGVyaXQ7CiAgY29sb3I6IGluaGVyaXQ7CiAgYm9yZGVyOiAwOwogIHBhZGRpbmc6IDA7CiAgbWFyZ2luOiAwOwp9Cjp3aGVyZShhKSB7CiAgdGV4dC1kZWNvcmF0aW9uOiBub25lOwogIGNvbG9yOiBpbmhlcml0OwogIG91dGxpbmU6IG5vbmU7Cn0KOndoZXJlKG9sLCB1bCkgewogIGxpc3Qtc3R5bGU6IG5vbmU7CiAgbWFyZ2luOiAwOwogIHBhZGRpbmc6IDA7Cn0KOndoZXJlKGgxLCBoMiwgaDMsIGg0LCBoNSwgaDYpIHsKICBmb250LXNpemU6IGluaGVyaXQ7CiAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7CiAgbWFyZ2luOiAwOwp9
43
+ var init_StyleMarker_css_ts_vanilla = __esm({
44
+ "vanilla-extract-css-ns:src/components/styling/StyleMarker.css.ts.vanilla.css?source=OndoZXJlKCopIHsKICBib3gtc2l6aW5nOiBib3JkZXItYm94OwogIGNvbG9yOiB2YXIoLS1kYXBwLWtpdC1jb2xvcnMtYm9keSk7CiAgZm9udC1mYW1pbHk6IHZhcigtLWRhcHAta2l0LXR5cG9ncmFwaHktZm9udEZhbWlseSk7CiAgZm9udC1zaXplOiB2YXIoLS1kYXBwLWtpdC1mb250V2VpZ2h0cy1ub3JtYWwpOwogIGZvbnQtc3R5bGU6IHZhcigtLWRhcHAta2l0LXR5cG9ncmFwaHktZm9udFN0eWxlKTsKICBmb250LXdlaWdodDogdmFyKC0tZGFwcC1raXQtZm9udFdlaWdodHMtbm9ybWFsKTsKICBsaW5lLWhlaWdodDogdmFyKC0tZGFwcC1raXQtdHlwb2dyYXBoeS1saW5lSGVpZ2h0KTsKICBsZXR0ZXItc3BhY2luZzogdmFyKC0tZGFwcC1raXQtdHlwb2dyYXBoeS1sZXR0ZXJTcGFjaW5nKTsKfQo6d2hlcmUoYnV0dG9uKSB7CiAgYXBwZWFyYW5jZTogbm9uZTsKICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDsKICBmb250LXNpemU6IGluaGVyaXQ7CiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7CiAgbGluZS1oZWlnaHQ6IGluaGVyaXQ7CiAgbGV0dGVyLXNwYWNpbmc6IGluaGVyaXQ7CiAgY29sb3I6IGluaGVyaXQ7CiAgYm9yZGVyOiAwOwogIHBhZGRpbmc6IDA7CiAgbWFyZ2luOiAwOwp9Cjp3aGVyZShhKSB7CiAgdGV4dC1kZWNvcmF0aW9uOiBub25lOwogIGNvbG9yOiBpbmhlcml0OwogIG91dGxpbmU6IG5vbmU7Cn0KOndoZXJlKG9sLCB1bCkgewogIGxpc3Qtc3R5bGU6IG5vbmU7CiAgbWFyZ2luOiAwOwogIHBhZGRpbmc6IDA7Cn0KOndoZXJlKGgxLCBoMiwgaDMsIGg0LCBoNSwgaDYpIHsKICBmb250LXNpemU6IGluaGVyaXQ7CiAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7CiAgbWFyZ2luOiAwOwp9"() {
45
+ }
46
+ });
47
+
48
+ // src/components/styling/StyleMarker.css.ts
49
+ var require_StyleMarker_css = __commonJS({
50
+ "src/components/styling/StyleMarker.css.ts"() {
51
+ "use strict";
52
+ init_StyleMarker_css_ts_vanilla();
53
+ }
54
+ });
55
+
56
+ // src/index.ts
57
+ var index_exports = {};
58
+ __export(index_exports, {
59
+ ConnectButton: () => ConnectButton,
60
+ ConnectModal: () => ConnectModal,
61
+ HaneulClientContext: () => HaneulClientContext,
62
+ HaneulClientProvider: () => HaneulClientProvider,
63
+ WalletProvider: () => WalletProvider,
64
+ createNetworkConfig: () => createNetworkConfig,
65
+ getHaneulClientQuery: () => getHaneulClientQuery,
66
+ lightTheme: () => lightTheme,
67
+ useAccounts: () => useAccounts,
68
+ useAutoConnectWallet: () => useAutoConnectWallet,
69
+ useConnectWallet: () => useConnectWallet,
70
+ useCurrentAccount: () => useCurrentAccount,
71
+ useCurrentWallet: () => useCurrentWallet,
72
+ useDisconnectWallet: () => useDisconnectWallet,
73
+ useHaneulClient: () => useHaneulClient,
74
+ useHaneulClientContext: () => useHaneulClientContext,
75
+ useHaneulClientInfiniteQuery: () => useHaneulClientInfiniteQuery,
76
+ useHaneulClientMutation: () => useHaneulClientMutation,
77
+ useHaneulClientQueries: () => useHaneulClientQueries,
78
+ useHaneulClientQuery: () => useHaneulClientQuery,
79
+ useHaneulClientSuspenseQuery: () => useHaneulClientSuspenseQuery,
80
+ useReportTransactionEffects: () => useReportTransactionEffects,
81
+ useResolveHaneulNSName: () => useResolveHaneulNSName,
82
+ useSignAndExecuteTransaction: () => useSignAndExecuteTransaction,
83
+ useSignPersonalMessage: () => useSignPersonalMessage,
84
+ useSignTransaction: () => useSignTransaction,
85
+ useSwitchAccount: () => useSwitchAccount,
86
+ useWallets: () => useWallets
87
+ });
88
+ module.exports = __toCommonJS(index_exports);
89
+
90
+ // src/components/connect-modal/ConnectModal.tsx
91
+ var Dialog = __toESM(require("@radix-ui/react-dialog"));
92
+ var import_clsx6 = __toESM(require("clsx"));
93
+ var import_react8 = require("react");
94
+
95
+ // src/constants/walletDefaults.ts
96
+ var import_slush_wallet = require("@haneullabs/slush-wallet");
97
+
98
+ // src/utils/stateStorage.ts
99
+ function createInMemoryStore() {
100
+ const store = /* @__PURE__ */ new Map();
101
+ return {
102
+ getItem(key) {
103
+ return store.get(key);
104
+ },
105
+ setItem(key, value) {
106
+ store.set(key, value);
107
+ },
108
+ removeItem(key) {
109
+ store.delete(key);
110
+ }
111
+ };
112
+ }
113
+
114
+ // src/constants/walletDefaults.ts
115
+ var SUI_WALLET_NAME = "Sui Wallet";
116
+ var DEFAULT_STORAGE = typeof window !== "undefined" && window.localStorage ? localStorage : createInMemoryStore();
117
+ var DEFAULT_STORAGE_KEY = "sui-dapp-kit:wallet-connection-info";
118
+ var SIGN_FEATURES = [
119
+ "sui:signTransaction",
120
+ "sui:signTransactionBlock"
121
+ ];
122
+ var DEFAULT_WALLET_FILTER = (wallet) => SIGN_FEATURES.some((feature) => wallet.features[feature]);
123
+ var DEFAULT_PREFERRED_WALLETS = [SUI_WALLET_NAME, import_slush_wallet.SLUSH_WALLET_NAME];
124
+
125
+ // src/hooks/wallet/useConnectWallet.ts
126
+ var import_react_query = require("@tanstack/react-query");
127
+
128
+ // src/constants/walletMutationKeys.ts
129
+ var walletMutationKeys = {
130
+ all: { baseScope: "wallet" },
131
+ connectWallet: formMutationKeyFn("connect-wallet"),
132
+ autoconnectWallet: formMutationKeyFn("autoconnect-wallet"),
133
+ disconnectWallet: formMutationKeyFn("disconnect-wallet"),
134
+ signPersonalMessage: formMutationKeyFn("sign-personal-message"),
135
+ signTransaction: formMutationKeyFn("sign-transaction"),
136
+ signAndExecuteTransaction: formMutationKeyFn("sign-and-execute-transaction"),
137
+ switchAccount: formMutationKeyFn("switch-account"),
138
+ reportTransactionEffects: formMutationKeyFn("report-transaction-effects")
139
+ };
140
+ function formMutationKeyFn(baseEntity) {
141
+ return function mutationKeyFn(additionalKeys = []) {
142
+ return [{ ...walletMutationKeys.all, baseEntity }, ...additionalKeys];
143
+ };
144
+ }
145
+
146
+ // src/hooks/wallet/useWalletStore.ts
147
+ var import_react2 = require("react");
148
+ var import_zustand = require("zustand");
149
+
150
+ // src/contexts/walletContext.ts
151
+ var import_react = require("react");
152
+ var WalletContext = (0, import_react.createContext)(null);
153
+
154
+ // src/hooks/wallet/useWalletStore.ts
155
+ function useWalletStore(selector) {
156
+ const store = (0, import_react2.useContext)(WalletContext);
157
+ if (!store) {
158
+ throw new Error(
159
+ "Could not find WalletContext. Ensure that you have set up the WalletProvider."
160
+ );
161
+ }
162
+ return (0, import_zustand.useStore)(store, selector);
163
+ }
164
+
165
+ // src/hooks/wallet/useConnectWallet.ts
166
+ function useConnectWallet({
167
+ mutationKey,
168
+ ...mutationOptions
169
+ } = {}) {
170
+ const setWalletConnected = useWalletStore((state) => state.setWalletConnected);
171
+ const setConnectionStatus = useWalletStore((state) => state.setConnectionStatus);
172
+ return (0, import_react_query.useMutation)({
173
+ mutationKey: walletMutationKeys.connectWallet(mutationKey),
174
+ mutationFn: async ({ wallet, accountAddress, ...connectArgs }) => {
175
+ try {
176
+ setConnectionStatus("connecting");
177
+ const connectResult = await wallet.features["standard:connect"].connect(connectArgs);
178
+ let supportedIntents = connectResult.supportedIntents;
179
+ if (!supportedIntents && wallet.features["sui:getCapabilities"]) {
180
+ supportedIntents = (await wallet.features["sui:getCapabilities"].getCapabilities()).supportedIntents ?? [];
181
+ }
182
+ const connectedHaneulAccounts = connectResult.accounts.filter(
183
+ (account) => account.chains.some((chain) => chain.split(":")[0] === "sui")
184
+ );
185
+ const selectedAccount = getSelectedAccount(connectedHaneulAccounts, accountAddress);
186
+ setWalletConnected(wallet, connectedHaneulAccounts, selectedAccount, supportedIntents);
187
+ return { accounts: connectedHaneulAccounts };
188
+ } catch (error) {
189
+ setConnectionStatus("disconnected");
190
+ throw error;
191
+ }
192
+ },
193
+ ...mutationOptions
194
+ });
195
+ }
196
+ function getSelectedAccount(connectedAccounts, accountAddress) {
197
+ if (connectedAccounts.length === 0) {
198
+ return null;
199
+ }
200
+ if (accountAddress) {
201
+ const selectedAccount = connectedAccounts.find((account) => account.address === accountAddress);
202
+ return selectedAccount ?? connectedAccounts[0];
203
+ }
204
+ return connectedAccounts[0];
205
+ }
206
+
207
+ // src/hooks/wallet/useWallets.ts
208
+ function useWallets() {
209
+ return useWalletStore((state) => state.wallets);
210
+ }
211
+
212
+ // src/utils/walletUtils.ts
213
+ var import_wallet_standard = require("@haneullabs/wallet-standard");
214
+ function getRegisteredWallets(preferredWallets, walletFilter) {
215
+ const walletsApi = (0, import_wallet_standard.getWallets)();
216
+ const wallets = walletsApi.get();
217
+ const suiWallets = wallets.filter(
218
+ (wallet) => (0, import_wallet_standard.isWalletWithRequiredFeatureSet)(wallet) && (!walletFilter || walletFilter(wallet))
219
+ );
220
+ return [
221
+ // Preferred wallets, in order:
222
+ ...preferredWallets.map((name) => suiWallets.find((wallet) => wallet.name === name)).filter(Boolean),
223
+ // Wallets in default order:
224
+ ...suiWallets.filter((wallet) => !preferredWallets.includes(wallet.name))
225
+ ];
226
+ }
227
+ function getWalletUniqueIdentifier(wallet) {
228
+ return wallet?.id ?? wallet?.name;
229
+ }
230
+
231
+ // src/components/icons/BackIcon.tsx
232
+ var import_jsx_runtime = require("react/jsx-runtime");
233
+ function BackIcon(props) {
234
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("svg", { width: 24, height: 24, fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
235
+ "path",
236
+ {
237
+ d: "M7.57 12.262c0 .341.13.629.403.895l5.175 5.059c.204.205.45.307.751.307.609 0 1.101-.485 1.101-1.087 0-.293-.123-.574-.349-.8L10.14 12.27l4.511-4.375A1.13 1.13 0 0 0 15 7.087C15 6.485 14.508 6 13.9 6c-.295 0-.54.103-.752.308l-5.175 5.058c-.28.28-.404.56-.404.896Z",
238
+ fill: "currentColor"
239
+ }
240
+ ) });
241
+ }
242
+
243
+ // src/components/icons/CloseIcon.tsx
244
+ var import_jsx_runtime2 = require("react/jsx-runtime");
245
+ function CloseIcon(props) {
246
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("svg", { width: 10, height: 10, fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props, children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
247
+ "path",
248
+ {
249
+ d: "M9.708.292a.999.999 0 0 0-1.413 0l-3.289 3.29L1.717.291A.999.999 0 0 0 .305 1.705l3.289 3.289-3.29 3.289a.999.999 0 1 0 1.413 1.412l3.29-3.289 3.288 3.29a.999.999 0 0 0 1.413-1.413l-3.29-3.29 3.29-3.288a.999.999 0 0 0 0-1.413Z",
250
+ fill: "currentColor"
251
+ }
252
+ ) });
253
+ }
254
+
255
+ // src/components/styling/StyleMarker.tsx
256
+ var import_react_slot = require("@radix-ui/react-slot");
257
+ var import_react3 = require("react");
258
+
259
+ // src/constants/styleDataAttribute.ts
260
+ var styleDataAttributeName = "data-dapp-kit";
261
+ var styleDataAttributeSelector = `[${styleDataAttributeName}]`;
262
+ var styleDataAttribute = { [styleDataAttributeName]: "" };
263
+
264
+ // src/components/styling/StyleMarker.tsx
265
+ var import_StyleMarker_css = __toESM(require_StyleMarker_css());
266
+ var import_jsx_runtime3 = require("react/jsx-runtime");
267
+ var StyleMarker = (0, import_react3.forwardRef)(({ children, ...props }, forwardedRef) => /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_slot.Slot, { ref: forwardedRef, ...props, ...styleDataAttribute, children }));
268
+ StyleMarker.displayName = "StyleMarker";
269
+
270
+ // src/components/ui/Heading.tsx
271
+ var import_react_slot2 = require("@radix-ui/react-slot");
272
+ var import_clsx = __toESM(require("clsx"));
273
+ var import_react4 = require("react");
274
+
275
+ // src/components/ui/Heading.css.ts
276
+ var import_createRuntimeFn = require("@vanilla-extract/recipes/createRuntimeFn");
277
+ var headingVariants = (0, import_createRuntimeFn.createRuntimeFn)({ defaultClassName: "Heading__ryq85s0", variantClassNames: { size: { sm: "Heading_headingVariants_size_sm__ryq85s1", md: "Heading_headingVariants_size_md__ryq85s2", lg: "Heading_headingVariants_size_lg__ryq85s3", xl: "Heading_headingVariants_size_xl__ryq85s4" }, weight: { normal: "Heading_headingVariants_weight_normal__ryq85s5", bold: "Heading_headingVariants_weight_bold__ryq85s6" }, truncate: { true: "Heading_headingVariants_truncate_true__ryq85s7" } }, defaultVariants: { size: "lg", weight: "bold" }, compoundVariants: [] });
278
+
279
+ // src/components/ui/Heading.tsx
280
+ var import_jsx_runtime4 = require("react/jsx-runtime");
281
+ var Heading = (0, import_react4.forwardRef)(
282
+ ({
283
+ children,
284
+ className,
285
+ asChild = false,
286
+ as: Tag = "h1",
287
+ size,
288
+ weight,
289
+ truncate,
290
+ ...headingProps
291
+ }, forwardedRef) => {
292
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
293
+ import_react_slot2.Slot,
294
+ {
295
+ ...headingProps,
296
+ ref: forwardedRef,
297
+ className: (0, import_clsx.default)(headingVariants({ size, weight, truncate }), className),
298
+ children: asChild ? children : /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(Tag, { children })
299
+ }
300
+ );
301
+ }
302
+ );
303
+ Heading.displayName = "Heading";
304
+
305
+ // src/components/ui/IconButton.tsx
306
+ var import_react_slot3 = require("@radix-ui/react-slot");
307
+ var import_clsx2 = __toESM(require("clsx"));
308
+ var import_react5 = require("react");
309
+
310
+ // src/components/ui/IconButton.css.ts
311
+ var container = "IconButton_container__eyhmcb0";
312
+
313
+ // src/components/ui/IconButton.tsx
314
+ var import_jsx_runtime5 = require("react/jsx-runtime");
315
+ var IconButton = (0, import_react5.forwardRef)(
316
+ ({ className, asChild = false, ...props }, forwardedRef) => {
317
+ const Comp = asChild ? import_react_slot3.Slot : "button";
318
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(Comp, { ...props, className: (0, import_clsx2.default)(container, className), ref: forwardedRef });
319
+ }
320
+ );
321
+ IconButton.displayName = "Button";
322
+
323
+ // src/components/connect-modal/ConnectModal.css.ts
324
+ var backButtonContainer = "ConnectModal_backButtonContainer__1v6eqwu6";
325
+ var closeButtonContainer = "ConnectModal_closeButtonContainer__1v6eqwu7";
326
+ var content = "ConnectModal_content__1v6eqwu2";
327
+ var overlay = "ConnectModal_overlay__1v6eqwu0";
328
+ var selectedViewContainer = "ConnectModal_selectedViewContainer__1v6eqwu5";
329
+ var title = "ConnectModal_title__1v6eqwu1";
330
+ var viewContainer = "ConnectModal_viewContainer__1v6eqwu4";
331
+ var walletListContainer = "ConnectModal_walletListContainer__1v6eqwu9";
332
+ var walletListContainerWithViewSelected = "ConnectModal_walletListContainerWithViewSelected__1v6eqwua";
333
+ var walletListContent = "ConnectModal_walletListContent__1v6eqwu8";
334
+ var whatIsAWalletButton = "ConnectModal_whatIsAWalletButton__1v6eqwu3";
335
+
336
+ // src/components/ui/Button.tsx
337
+ var import_react_slot4 = require("@radix-ui/react-slot");
338
+ var import_clsx3 = __toESM(require("clsx"));
339
+ var import_react6 = require("react");
340
+
341
+ // src/components/ui/Button.css.ts
342
+ var import_createRuntimeFn2 = require("@vanilla-extract/recipes/createRuntimeFn");
343
+ var buttonVariants = (0, import_createRuntimeFn2.createRuntimeFn)({ defaultClassName: "Button_buttonVariants__eqsvud0", variantClassNames: { variant: { primary: "Button_buttonVariants_variant_primary__eqsvud1", outline: "Button_buttonVariants_variant_outline__eqsvud2" }, size: { md: "Button_buttonVariants_size_md__eqsvud3", lg: "Button_buttonVariants_size_lg__eqsvud4" } }, defaultVariants: { variant: "primary", size: "md" }, compoundVariants: [] });
344
+
345
+ // src/components/ui/Button.tsx
346
+ var import_jsx_runtime6 = require("react/jsx-runtime");
347
+ var Button = (0, import_react6.forwardRef)(
348
+ ({ className, variant, size, asChild = false, ...props }, forwardedRef) => {
349
+ const Comp = asChild ? import_react_slot4.Slot : "button";
350
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
351
+ Comp,
352
+ {
353
+ ...props,
354
+ className: (0, import_clsx3.default)(buttonVariants({ variant, size }), className),
355
+ ref: forwardedRef
356
+ }
357
+ );
358
+ }
359
+ );
360
+ Button.displayName = "Button";
361
+
362
+ // src/components/ui/Text.tsx
363
+ var import_react_slot5 = require("@radix-ui/react-slot");
364
+ var import_clsx4 = __toESM(require("clsx"));
365
+ var import_react7 = require("react");
366
+
367
+ // src/components/ui/Text.css.ts
368
+ var import_createRuntimeFn3 = require("@vanilla-extract/recipes/createRuntimeFn");
369
+ var textVariants = (0, import_createRuntimeFn3.createRuntimeFn)({ defaultClassName: "Text__1qqbr020", variantClassNames: { size: { sm: "Text_textVariants_size_sm__1qqbr021" }, weight: { normal: "Text_textVariants_weight_normal__1qqbr022", medium: "Text_textVariants_weight_medium__1qqbr023", bold: "Text_textVariants_weight_bold__1qqbr024" }, color: { muted: "Text_textVariants_color_muted__1qqbr025", danger: "Text_textVariants_color_danger__1qqbr026" }, mono: { true: "Text_textVariants_mono_true__1qqbr027" } }, defaultVariants: { size: "sm", weight: "normal" }, compoundVariants: [] });
370
+
371
+ // src/components/ui/Text.tsx
372
+ var import_jsx_runtime7 = require("react/jsx-runtime");
373
+ var Text = (0, import_react7.forwardRef)(
374
+ ({
375
+ children,
376
+ className,
377
+ asChild = false,
378
+ as: Tag = "div",
379
+ size,
380
+ weight,
381
+ color,
382
+ mono,
383
+ ...textProps
384
+ }, forwardedRef) => {
385
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
386
+ import_react_slot5.Slot,
387
+ {
388
+ ...textProps,
389
+ ref: forwardedRef,
390
+ className: (0, import_clsx4.default)(textVariants({ size, weight, color, mono }), className),
391
+ children: asChild ? children : /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(Tag, { children })
392
+ }
393
+ );
394
+ }
395
+ );
396
+ Text.displayName = "Text";
397
+
398
+ // src/components/connect-modal/views/ConnectionStatus.css.ts
399
+ var connectionStatus = "ConnectionStatus_connectionStatus__12luu73";
400
+ var container2 = "ConnectionStatus_container__12luu70";
401
+ var retryButtonContainer = "ConnectionStatus_retryButtonContainer__12luu74";
402
+ var title2 = "ConnectionStatus_title__12luu72";
403
+ var walletIcon = "ConnectionStatus_walletIcon__12luu71";
404
+
405
+ // src/components/connect-modal/views/ConnectionStatus.tsx
406
+ var import_jsx_runtime8 = require("react/jsx-runtime");
407
+ function ConnectionStatus({
408
+ selectedWallet,
409
+ hadConnectionError,
410
+ onRetryConnection
411
+ }) {
412
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { className: container2, children: [
413
+ selectedWallet.icon && /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
414
+ "img",
415
+ {
416
+ className: walletIcon,
417
+ src: selectedWallet.icon,
418
+ alt: `${selectedWallet.name} logo`
419
+ }
420
+ ),
421
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { className: title2, children: /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(Heading, { as: "h2", size: "xl", children: [
422
+ "Opening ",
423
+ selectedWallet.name
424
+ ] }) }),
425
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { className: connectionStatus, children: hadConnectionError ? /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(Text, { color: "danger", children: "Connection failed" }) : /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(Text, { color: "muted", children: "Confirm connection in the wallet..." }) }),
426
+ hadConnectionError ? /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { className: retryButtonContainer, children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(Button, { type: "button", variant: "outline", onClick: () => onRetryConnection(selectedWallet), children: "Retry Connection" }) }) : null
427
+ ] });
428
+ }
429
+
430
+ // src/components/connect-modal/InfoSection.css.ts
431
+ var container3 = "InfoSection_container__1spjbyh0";
432
+
433
+ // src/components/connect-modal/InfoSection.tsx
434
+ var import_jsx_runtime9 = require("react/jsx-runtime");
435
+ function InfoSection({ title: title3, children }) {
436
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("section", { className: container3, children: [
437
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Heading, { as: "h3", size: "sm", weight: "normal", children: title3 }),
438
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Text, { weight: "medium", color: "muted", children })
439
+ ] });
440
+ }
441
+
442
+ // src/components/connect-modal/views/GettingStarted.css.ts
443
+ var container4 = "GettingStarted_container__uhj11t0";
444
+ var content2 = "GettingStarted_content__uhj11t1";
445
+ var installButtonContainer = "GettingStarted_installButtonContainer__uhj11t2";
446
+
447
+ // src/components/connect-modal/views/GettingStarted.tsx
448
+ var import_jsx_runtime10 = require("react/jsx-runtime");
449
+ function GettingStarted() {
450
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: container4, children: [
451
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(Heading, { as: "h2", children: "Get Started with Sui" }),
452
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)("div", { className: content2, children: [
453
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(InfoSection, { title: "Install the Slush Extension", children: "We recommend pinning Slush to your taskbar for quicker access." }),
454
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(InfoSection, { title: "Create or Import a Wallet", children: "Be sure to back up your wallet using a secure method. Never share your secret phrase with anyone." }),
455
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(InfoSection, { title: "Refresh Your Browser", children: "Once you set up your wallet, refresh this window browser to load up the extension." }),
456
+ /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("div", { className: installButtonContainer, children: /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(Button, { variant: "outline", asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
457
+ "a",
458
+ {
459
+ href: "https://chromewebstore.google.com/detail/slush-%E2%80%94-a-sui-wallet/opcgpfmipidbgpenhmajoajpbobppdi",
460
+ target: "_blank",
461
+ rel: "noreferrer",
462
+ children: "Install Wallet Extension"
463
+ }
464
+ ) }) })
465
+ ] })
466
+ ] });
467
+ }
468
+
469
+ // src/components/connect-modal/views/WhatIsAWallet.css.ts
470
+ var container5 = "WhatIsAWallet_container__1id5knn0";
471
+ var content3 = "WhatIsAWallet_content__1id5knn1";
472
+
473
+ // src/components/connect-modal/views/WhatIsAWallet.tsx
474
+ var import_jsx_runtime11 = require("react/jsx-runtime");
475
+ function WhatIsAWallet() {
476
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)("div", { className: container5, children: [
477
+ /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(Heading, { as: "h2", children: "What is a Wallet" }),
478
+ /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)("div", { className: content3, children: [
479
+ /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(InfoSection, { title: "Easy Login", children: "No need to create new accounts and passwords for every website. Just connect your wallet and get going." }),
480
+ /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(InfoSection, { title: "Store your Digital Assets", children: "Send, receive, store, and display your digital assets like NFTs & coins." })
481
+ ] })
482
+ ] });
483
+ }
484
+
485
+ // src/components/connect-modal/wallet-list/WalletList.tsx
486
+ var import_slush_wallet2 = require("@haneullabs/slush-wallet");
487
+
488
+ // src/components/connect-modal/wallet-list/WalletList.css.ts
489
+ var container6 = "WalletList_container__6e9k7k0";
490
+
491
+ // src/components/connect-modal/wallet-list/WalletListItem.tsx
492
+ var import_clsx5 = require("clsx");
493
+
494
+ // src/components/connect-modal/wallet-list/WalletListItem.css.ts
495
+ var container7 = "WalletListItem_container__1k9sfe90";
496
+ var selectedWalletItem = "WalletListItem_selectedWalletItem__1k9sfe92";
497
+ var walletIcon2 = "WalletListItem_walletIcon__1k9sfe93";
498
+ var walletItem = "WalletListItem_walletItem__1k9sfe91";
499
+
500
+ // src/components/connect-modal/wallet-list/WalletListItem.tsx
501
+ var import_jsx_runtime12 = require("react/jsx-runtime");
502
+ function WalletListItem({ name, icon, onClick, isSelected = false }) {
503
+ return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("li", { className: container7, children: /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)(
504
+ "button",
505
+ {
506
+ className: (0, import_clsx5.clsx)(walletItem, { [selectedWalletItem]: isSelected }),
507
+ type: "button",
508
+ onClick,
509
+ children: [
510
+ icon && typeof icon === "string" ? /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("img", { className: walletIcon2, src: icon, alt: `${name} logo` }) : icon,
511
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(Heading, { size: "md", truncate: true, asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("div", { children: name }) })
512
+ ]
513
+ }
514
+ ) });
515
+ }
516
+
517
+ // src/components/connect-modal/wallet-list/WalletList.tsx
518
+ var import_jsx_runtime13 = require("react/jsx-runtime");
519
+ function WalletList({
520
+ selectedWalletName,
521
+ onPlaceholderClick,
522
+ onSelect,
523
+ wallets
524
+ }) {
525
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("ul", { className: container6, children: wallets.length > 0 ? wallets.map((wallet) => /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
526
+ WalletListItem,
527
+ {
528
+ name: wallet.name,
529
+ icon: wallet.icon,
530
+ isSelected: getWalletUniqueIdentifier(wallet) === selectedWalletName,
531
+ onClick: () => onSelect(wallet)
532
+ },
533
+ getWalletUniqueIdentifier(wallet)
534
+ )) : /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(
535
+ WalletListItem,
536
+ {
537
+ name: import_slush_wallet2.SLUSH_WALLET_NAME,
538
+ icon: import_slush_wallet2.SLUSH_WALLET_ICON,
539
+ onClick: onPlaceholderClick,
540
+ isSelected: true
541
+ }
542
+ ) });
543
+ }
544
+
545
+ // src/components/connect-modal/ConnectModal.tsx
546
+ var import_jsx_runtime14 = require("react/jsx-runtime");
547
+ function ConnectModal({
548
+ trigger,
549
+ open,
550
+ defaultOpen,
551
+ onOpenChange,
552
+ walletFilter = DEFAULT_WALLET_FILTER
553
+ }) {
554
+ const [isModalOpen, setModalOpen] = (0, import_react8.useState)(open ?? defaultOpen);
555
+ const [currentView, setCurrentView] = (0, import_react8.useState)();
556
+ const [selectedWallet, setSelectedWallet] = (0, import_react8.useState)();
557
+ const wallets = useWallets().filter(walletFilter);
558
+ const { mutate, isError } = useConnectWallet();
559
+ const resetSelection = () => {
560
+ setSelectedWallet(void 0);
561
+ setCurrentView(void 0);
562
+ };
563
+ const handleOpenChange = (open2) => {
564
+ if (!open2) {
565
+ resetSelection();
566
+ }
567
+ setModalOpen(open2);
568
+ onOpenChange?.(open2);
569
+ };
570
+ const connectWallet = (wallet) => {
571
+ setCurrentView("connection-status");
572
+ mutate(
573
+ { wallet },
574
+ {
575
+ onSuccess: () => handleOpenChange(false)
576
+ }
577
+ );
578
+ };
579
+ let modalContent;
580
+ switch (currentView) {
581
+ case "what-is-a-wallet":
582
+ modalContent = /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(WhatIsAWallet, {});
583
+ break;
584
+ case "getting-started":
585
+ modalContent = /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(GettingStarted, {});
586
+ break;
587
+ case "connection-status":
588
+ modalContent = /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
589
+ ConnectionStatus,
590
+ {
591
+ selectedWallet,
592
+ hadConnectionError: isError,
593
+ onRetryConnection: connectWallet
594
+ }
595
+ );
596
+ break;
597
+ default:
598
+ modalContent = /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(WhatIsAWallet, {});
599
+ }
600
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(Dialog.Root, { open: open ?? isModalOpen, onOpenChange: handleOpenChange, children: [
601
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Dialog.Trigger, { asChild: true, children: trigger }),
602
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Dialog.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(StyleMarker, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Dialog.Overlay, { className: overlay, children: /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(Dialog.Content, { className: content, "aria-describedby": void 0, children: [
603
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(
604
+ "div",
605
+ {
606
+ className: (0, import_clsx6.default)(walletListContainer, {
607
+ [walletListContainerWithViewSelected]: !!currentView
608
+ }),
609
+ children: [
610
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)("div", { className: walletListContent, children: [
611
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Dialog.Title, { className: title, asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Heading, { as: "h2", children: "Connect a Wallet" }) }),
612
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
613
+ WalletList,
614
+ {
615
+ wallets,
616
+ selectedWalletName: getWalletUniqueIdentifier(selectedWallet),
617
+ onPlaceholderClick: () => setCurrentView("getting-started"),
618
+ onSelect: (wallet) => {
619
+ if (getWalletUniqueIdentifier(selectedWallet) !== getWalletUniqueIdentifier(wallet)) {
620
+ setSelectedWallet(wallet);
621
+ connectWallet(wallet);
622
+ }
623
+ }
624
+ }
625
+ )
626
+ ] }),
627
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
628
+ "button",
629
+ {
630
+ className: whatIsAWalletButton,
631
+ onClick: () => setCurrentView("what-is-a-wallet"),
632
+ type: "button",
633
+ children: "What is a Wallet?"
634
+ }
635
+ )
636
+ ]
637
+ }
638
+ ),
639
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(
640
+ "div",
641
+ {
642
+ className: (0, import_clsx6.default)(viewContainer, {
643
+ [selectedViewContainer]: !!currentView
644
+ }),
645
+ children: [
646
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: backButtonContainer, children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(IconButton, { type: "button", "aria-label": "Back", onClick: () => resetSelection(), children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(BackIcon, {}) }) }),
647
+ modalContent
648
+ ]
649
+ }
650
+ ),
651
+ /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(Dialog.Close, { className: closeButtonContainer, asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(IconButton, { type: "button", "aria-label": "Close", children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(CloseIcon, {}) }) })
652
+ ] }) }) }) })
653
+ ] });
654
+ }
655
+
656
+ // src/hooks/wallet/useCurrentAccount.ts
657
+ function useCurrentAccount() {
658
+ return useWalletStore((state) => state.currentAccount);
659
+ }
660
+
661
+ // src/components/AccountDropdownMenu.tsx
662
+ var import_utils = require("@haneullabs/haneul/utils");
663
+ var DropdownMenu = __toESM(require("@radix-ui/react-dropdown-menu"));
664
+ var import_clsx7 = __toESM(require("clsx"));
665
+
666
+ // src/hooks/useHaneulClientQuery.ts
667
+ var import_react_query2 = require("@tanstack/react-query");
668
+ var import_react11 = require("react");
669
+
670
+ // src/hooks/useHaneulClient.ts
671
+ var import_react10 = require("react");
672
+
673
+ // src/components/HaneulClientProvider.tsx
674
+ var import_client = require("@haneullabs/haneul/client");
675
+ var import_react9 = require("react");
676
+ var import_jsx_runtime15 = require("react/jsx-runtime");
677
+ var HaneulClientContext = (0, import_react9.createContext)(null);
678
+ var DEFAULT_NETWORKS = {
679
+ localnet: { url: (0, import_client.getFullnodeUrl)("localnet") }
680
+ };
681
+ var DEFAULT_CREATE_CLIENT = function createClient(_name, config) {
682
+ if ((0, import_client.isHaneulClient)(config)) {
683
+ return config;
684
+ }
685
+ return new import_client.HaneulClient(config);
686
+ };
687
+ function HaneulClientProvider(props) {
688
+ const { onNetworkChange, network, children } = props;
689
+ const networks = props.networks ?? DEFAULT_NETWORKS;
690
+ const createClient2 = props.createClient ?? DEFAULT_CREATE_CLIENT;
691
+ const [selectedNetwork, setSelectedNetwork] = (0, import_react9.useState)(
692
+ props.network ?? props.defaultNetwork ?? Object.keys(networks)[0]
693
+ );
694
+ const currentNetwork = props.network ?? selectedNetwork;
695
+ const client = (0, import_react9.useMemo)(() => {
696
+ return createClient2(currentNetwork, networks[currentNetwork]);
697
+ }, [createClient2, currentNetwork, networks]);
698
+ const ctx = (0, import_react9.useMemo)(() => {
699
+ return {
700
+ client,
701
+ networks,
702
+ network: currentNetwork,
703
+ config: networks[currentNetwork] instanceof import_client.HaneulClient ? null : networks[currentNetwork],
704
+ selectNetwork: (newNetwork) => {
705
+ if (currentNetwork === newNetwork) {
706
+ return;
707
+ }
708
+ if (!network && newNetwork !== selectedNetwork) {
709
+ setSelectedNetwork(newNetwork);
710
+ }
711
+ onNetworkChange?.(newNetwork);
712
+ }
713
+ };
714
+ }, [client, networks, selectedNetwork, currentNetwork, network, onNetworkChange]);
715
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(HaneulClientContext.Provider, { value: ctx, children });
716
+ }
717
+
718
+ // src/hooks/useHaneulClient.ts
719
+ function useHaneulClientContext() {
720
+ const haneulClient = (0, import_react10.useContext)(HaneulClientContext);
721
+ if (!haneulClient) {
722
+ throw new Error(
723
+ "Could not find HaneulClientContext. Ensure that you have set up the HaneulClientProvider"
724
+ );
725
+ }
726
+ return haneulClient;
727
+ }
728
+ function useHaneulClient() {
729
+ return useHaneulClientContext().client;
730
+ }
731
+
732
+ // src/hooks/useHaneulClientQuery.ts
733
+ function getHaneulClientQuery({
734
+ client,
735
+ network,
736
+ method,
737
+ params,
738
+ options
739
+ }) {
740
+ return (0, import_react_query2.queryOptions)({
741
+ ...options,
742
+ queryKey: [network, method, params],
743
+ queryFn: async () => {
744
+ return await client[method](params);
745
+ }
746
+ });
747
+ }
748
+ function useHaneulClientQuery(...args) {
749
+ const [method, params, { queryKey = [], ...options } = {}] = args;
750
+ const suiContext = useHaneulClientContext();
751
+ return (0, import_react_query2.useQuery)({
752
+ ...options,
753
+ queryKey: [suiContext.network, method, params, ...queryKey],
754
+ queryFn: async () => {
755
+ return await suiContext.client[method](params);
756
+ }
757
+ });
758
+ }
759
+ function useHaneulClientSuspenseQuery(...args) {
760
+ const [method, params, options = {}] = args;
761
+ const suiContext = useHaneulClientContext();
762
+ const query = (0, import_react11.useMemo)(() => {
763
+ return getHaneulClientQuery({
764
+ client: suiContext.client,
765
+ network: suiContext.network,
766
+ method,
767
+ params,
768
+ options
769
+ });
770
+ }, [suiContext.client, suiContext.network, method, params, options]);
771
+ return (0, import_react_query2.useSuspenseQuery)(query);
772
+ }
773
+
774
+ // src/hooks/useResolveHaneulNSNames.ts
775
+ function useResolveHaneulNSName(address, options) {
776
+ return useHaneulClientQuery(
777
+ "resolveNameServiceNames",
778
+ {
779
+ address,
780
+ limit: 1
781
+ },
782
+ {
783
+ ...options,
784
+ refetchOnWindowFocus: false,
785
+ retry: false,
786
+ select: (data) => data.data.length > 0 ? data.data[0] : null,
787
+ enabled: !!address && options?.enabled !== false
788
+ }
789
+ );
790
+ }
791
+
792
+ // src/hooks/wallet/useAccounts.ts
793
+ function useAccounts() {
794
+ return useWalletStore((state) => state.accounts);
795
+ }
796
+
797
+ // src/hooks/wallet/useDisconnectWallet.ts
798
+ var import_react_query3 = require("@tanstack/react-query");
799
+
800
+ // src/errors/walletErrors.ts
801
+ var WalletNotConnectedError = class extends Error {
802
+ };
803
+ var WalletNoAccountSelectedError = class extends Error {
804
+ };
805
+ var WalletFeatureNotSupportedError = class extends Error {
806
+ };
807
+ var WalletAccountNotFoundError = class extends Error {
808
+ };
809
+
810
+ // src/hooks/wallet/useCurrentWallet.ts
811
+ function useCurrentWallet() {
812
+ const currentWallet = useWalletStore((state) => state.currentWallet);
813
+ const connectionStatus2 = useWalletStore((state) => state.connectionStatus);
814
+ const supportedIntents = useWalletStore((state) => state.supportedIntents);
815
+ switch (connectionStatus2) {
816
+ case "connecting":
817
+ return {
818
+ connectionStatus: connectionStatus2,
819
+ currentWallet: null,
820
+ isDisconnected: false,
821
+ isConnecting: true,
822
+ isConnected: false,
823
+ supportedIntents: []
824
+ };
825
+ case "disconnected":
826
+ return {
827
+ connectionStatus: connectionStatus2,
828
+ currentWallet: null,
829
+ isDisconnected: true,
830
+ isConnecting: false,
831
+ isConnected: false,
832
+ supportedIntents: []
833
+ };
834
+ case "connected": {
835
+ return {
836
+ connectionStatus: connectionStatus2,
837
+ currentWallet,
838
+ isDisconnected: false,
839
+ isConnecting: false,
840
+ isConnected: true,
841
+ supportedIntents
842
+ };
843
+ }
844
+ }
845
+ }
846
+
847
+ // src/hooks/wallet/useDisconnectWallet.ts
848
+ function useDisconnectWallet({
849
+ mutationKey,
850
+ ...mutationOptions
851
+ } = {}) {
852
+ const { currentWallet } = useCurrentWallet();
853
+ const setWalletDisconnected = useWalletStore((state) => state.setWalletDisconnected);
854
+ return (0, import_react_query3.useMutation)({
855
+ mutationKey: walletMutationKeys.disconnectWallet(mutationKey),
856
+ mutationFn: async () => {
857
+ if (!currentWallet) {
858
+ throw new WalletNotConnectedError("No wallet is connected.");
859
+ }
860
+ try {
861
+ await currentWallet.features["standard:disconnect"]?.disconnect();
862
+ } catch (error) {
863
+ console.error("Failed to disconnect the application from the current wallet.", error);
864
+ }
865
+ setWalletDisconnected();
866
+ },
867
+ ...mutationOptions
868
+ });
869
+ }
870
+
871
+ // src/hooks/wallet/useSwitchAccount.ts
872
+ var import_react_query4 = require("@tanstack/react-query");
873
+ function useSwitchAccount({
874
+ mutationKey,
875
+ ...mutationOptions
876
+ } = {}) {
877
+ const { currentWallet } = useCurrentWallet();
878
+ const setAccountSwitched = useWalletStore((state) => state.setAccountSwitched);
879
+ return (0, import_react_query4.useMutation)({
880
+ mutationKey: walletMutationKeys.switchAccount(mutationKey),
881
+ mutationFn: async ({ account }) => {
882
+ if (!currentWallet) {
883
+ throw new WalletNotConnectedError("No wallet is connected.");
884
+ }
885
+ const accountToSelect = currentWallet.accounts.find(
886
+ (walletAccount) => walletAccount.address === account.address
887
+ );
888
+ if (!accountToSelect) {
889
+ throw new WalletAccountNotFoundError(
890
+ `No account with address ${account.address} is connected to ${currentWallet.name}.`
891
+ );
892
+ }
893
+ setAccountSwitched(accountToSelect);
894
+ },
895
+ ...mutationOptions
896
+ });
897
+ }
898
+
899
+ // src/components/AccountDropdownMenu.css.ts
900
+ var connectedAccount = "AccountDropdownMenu_connectedAccount__14ml3c80";
901
+ var menuContainer = "AccountDropdownMenu_menuContainer__14ml3c81";
902
+ var menuContent = "AccountDropdownMenu_menuContent__14ml3c82";
903
+ var menuItem = "AccountDropdownMenu_menuItem__14ml3c83";
904
+ var separator = "AccountDropdownMenu_separator__14ml3c85";
905
+ var switchAccountMenuItem = "AccountDropdownMenu_switchAccountMenuItem__14ml3c84";
906
+
907
+ // src/components/icons/CheckIcon.tsx
908
+ var import_jsx_runtime16 = require("react/jsx-runtime");
909
+ function CheckIcon(props) {
910
+ return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", width: 16, height: 16, fill: "none", ...props, children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
911
+ "path",
912
+ {
913
+ fill: "currentColor",
914
+ d: "m11.726 5.048-4.73 5.156-1.722-1.879a.72.72 0 0 0-.529-.23.722.722 0 0 0-.525.24.858.858 0 0 0-.22.573.86.86 0 0 0 .211.576l2.255 2.458c.14.153.332.24.53.24.2 0 .391-.087.532-.24l5.261-5.735A.86.86 0 0 0 13 5.63a.858.858 0 0 0-.22-.572.722.722 0 0 0-.525-.24.72.72 0 0 0-.529.23Z"
915
+ }
916
+ ) });
917
+ }
918
+
919
+ // src/components/icons/ChevronIcon.tsx
920
+ var import_jsx_runtime17 = require("react/jsx-runtime");
921
+ function ChevronIcon(props) {
922
+ return /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", width: 16, height: 16, fill: "none", ...props, children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
923
+ "path",
924
+ {
925
+ stroke: "#A0B6C3",
926
+ strokeLinecap: "round",
927
+ strokeLinejoin: "round",
928
+ strokeWidth: 1.5,
929
+ d: "m4 6 4 4 4-4"
930
+ }
931
+ ) });
932
+ }
933
+
934
+ // src/components/AccountDropdownMenu.tsx
935
+ var import_jsx_runtime18 = require("react/jsx-runtime");
936
+ function AccountDropdownMenu({ currentAccount }) {
937
+ const { mutate: disconnectWallet } = useDisconnectWallet();
938
+ const { data: domain } = useResolveHaneulNSName(
939
+ currentAccount.label ? null : currentAccount.address
940
+ );
941
+ const accounts = useAccounts();
942
+ return /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)(DropdownMenu.Root, { modal: false, children: [
943
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(StyleMarker, { children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(DropdownMenu.Trigger, { asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)(Button, { size: "lg", className: connectedAccount, children: [
944
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(Text, { mono: true, weight: "bold", children: currentAccount.label ?? domain ?? (0, import_utils.formatAddress)(currentAccount.address) }),
945
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(ChevronIcon, {})
946
+ ] }) }) }),
947
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(DropdownMenu.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(StyleMarker, { className: menuContainer, children: /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)(DropdownMenu.Content, { className: menuContent, children: [
948
+ accounts.map((account) => /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
949
+ AccountDropdownMenuItem,
950
+ {
951
+ account,
952
+ active: currentAccount.address === account.address
953
+ },
954
+ account.address
955
+ )),
956
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(DropdownMenu.Separator, { className: separator }),
957
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
958
+ DropdownMenu.Item,
959
+ {
960
+ className: (0, import_clsx7.default)(menuItem),
961
+ onSelect: () => disconnectWallet(),
962
+ children: "Disconnect"
963
+ }
964
+ )
965
+ ] }) }) })
966
+ ] });
967
+ }
968
+ function AccountDropdownMenuItem({
969
+ account,
970
+ active
971
+ }) {
972
+ const { mutate: switchAccount } = useSwitchAccount();
973
+ const { data: domain } = useResolveHaneulNSName(account.label ? null : account.address);
974
+ return /* @__PURE__ */ (0, import_jsx_runtime18.jsxs)(
975
+ DropdownMenu.Item,
976
+ {
977
+ className: (0, import_clsx7.default)(menuItem, switchAccountMenuItem),
978
+ onSelect: () => switchAccount({ account }),
979
+ children: [
980
+ /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(Text, { mono: true, children: account.label ?? domain ?? (0, import_utils.formatAddress)(account.address) }),
981
+ active ? /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(CheckIcon, {}) : null
982
+ ]
983
+ }
984
+ );
985
+ }
986
+
987
+ // src/components/ConnectButton.tsx
988
+ var import_jsx_runtime19 = require("react/jsx-runtime");
989
+ function ConnectButton({
990
+ connectText = "Connect Wallet",
991
+ walletFilter,
992
+ ...buttonProps
993
+ }) {
994
+ const currentAccount = useCurrentAccount();
995
+ return currentAccount ? /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(AccountDropdownMenu, { currentAccount }) : /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
996
+ ConnectModal,
997
+ {
998
+ walletFilter,
999
+ trigger: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(StyleMarker, { children: /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(Button, { ...buttonProps, children: connectText }) })
1000
+ }
1001
+ );
1002
+ }
1003
+
1004
+ // src/components/WalletProvider.tsx
1005
+ var import_react17 = require("react");
1006
+
1007
+ // src/hooks/wallet/useAutoConnectWallet.ts
1008
+ var import_react_query5 = require("@tanstack/react-query");
1009
+ var import_react12 = require("react");
1010
+ function useAutoConnectWallet() {
1011
+ const { mutateAsync: connectWallet } = useConnectWallet();
1012
+ const autoConnectEnabled = useWalletStore((state) => state.autoConnectEnabled);
1013
+ const lastConnectedWalletName = useWalletStore((state) => state.lastConnectedWalletName);
1014
+ const lastConnectedAccountAddress = useWalletStore((state) => state.lastConnectedAccountAddress);
1015
+ const wallets = useWallets();
1016
+ const { isConnected } = useCurrentWallet();
1017
+ const [clientOnly, setClientOnly] = (0, import_react12.useState)(false);
1018
+ (0, import_react12.useLayoutEffect)(() => {
1019
+ setClientOnly(true);
1020
+ }, []);
1021
+ const { data, isError } = (0, import_react_query5.useQuery)({
1022
+ queryKey: [
1023
+ "@haneullabs/dapp-kit",
1024
+ "autoconnect",
1025
+ {
1026
+ isConnected,
1027
+ autoConnectEnabled,
1028
+ lastConnectedWalletName,
1029
+ lastConnectedAccountAddress,
1030
+ walletCount: wallets.length
1031
+ }
1032
+ ],
1033
+ queryFn: async () => {
1034
+ if (!autoConnectEnabled) {
1035
+ return "disabled";
1036
+ }
1037
+ if (!lastConnectedWalletName || !lastConnectedAccountAddress || isConnected) {
1038
+ return "attempted";
1039
+ }
1040
+ const wallet = wallets.find(
1041
+ (wallet2) => getWalletUniqueIdentifier(wallet2) === lastConnectedWalletName
1042
+ );
1043
+ if (wallet) {
1044
+ await connectWallet({
1045
+ wallet,
1046
+ accountAddress: lastConnectedAccountAddress,
1047
+ silent: true
1048
+ });
1049
+ }
1050
+ return "attempted";
1051
+ },
1052
+ enabled: autoConnectEnabled,
1053
+ persister: void 0,
1054
+ gcTime: 0,
1055
+ staleTime: 0,
1056
+ networkMode: "always",
1057
+ retry: false,
1058
+ retryOnMount: false,
1059
+ refetchInterval: false,
1060
+ refetchIntervalInBackground: false,
1061
+ refetchOnMount: false,
1062
+ refetchOnReconnect: false,
1063
+ refetchOnWindowFocus: false
1064
+ });
1065
+ if (!autoConnectEnabled) {
1066
+ return "disabled";
1067
+ }
1068
+ if (!clientOnly) {
1069
+ return "idle";
1070
+ }
1071
+ if (isConnected) {
1072
+ return "attempted";
1073
+ }
1074
+ if (!lastConnectedWalletName) {
1075
+ return "attempted";
1076
+ }
1077
+ return isError ? "attempted" : data ?? "idle";
1078
+ }
1079
+
1080
+ // src/hooks/wallet/useSlushWallet.ts
1081
+ var import_slush_wallet3 = require("@haneullabs/slush-wallet");
1082
+ var import_react13 = require("react");
1083
+ function useSlushWallet(config) {
1084
+ (0, import_react13.useLayoutEffect)(() => {
1085
+ if (!config?.name) {
1086
+ return;
1087
+ }
1088
+ let cleanup;
1089
+ let isMounted = true;
1090
+ try {
1091
+ const result = (0, import_slush_wallet3.registerSlushWallet)(config.name, {
1092
+ origin: config.origin
1093
+ });
1094
+ if (isMounted && result) {
1095
+ cleanup = result.unregister;
1096
+ } else if (result) {
1097
+ result.unregister();
1098
+ }
1099
+ } catch (error) {
1100
+ console.error("Failed to register Slush wallet:", error);
1101
+ }
1102
+ return () => {
1103
+ isMounted = false;
1104
+ if (cleanup) cleanup();
1105
+ };
1106
+ }, [config?.name, config?.origin]);
1107
+ }
1108
+
1109
+ // src/hooks/wallet/useUnsafeBurnerWallet.ts
1110
+ var import_ed25519 = require("@haneullabs/haneul/keypairs/ed25519");
1111
+ var import_transactions = require("@haneullabs/haneul/transactions");
1112
+ var import_utils2 = require("@haneullabs/haneul/utils");
1113
+ var import_wallet_standard2 = require("@haneullabs/wallet-standard");
1114
+ var import_react14 = require("react");
1115
+ var WALLET_NAME = "Unsafe Burner Wallet";
1116
+ function useUnsafeBurnerWallet(enabled) {
1117
+ const haneulClient = useHaneulClient();
1118
+ (0, import_react14.useEffect)(() => {
1119
+ if (!enabled) {
1120
+ return;
1121
+ }
1122
+ const unregister = registerUnsafeBurnerWallet(haneulClient);
1123
+ return unregister;
1124
+ }, [enabled, haneulClient]);
1125
+ }
1126
+ function registerUnsafeBurnerWallet(haneulClient) {
1127
+ var _on, _connect, _signPersonalMessage, _signTransactionBlock, _signTransaction, _signAndExecuteTransactionBlock, _signAndExecuteTransaction;
1128
+ const walletsApi = (0, import_wallet_standard2.getWallets)();
1129
+ const registeredWallets = walletsApi.get();
1130
+ if (registeredWallets.find((wallet) => wallet.name === WALLET_NAME)) {
1131
+ console.warn(
1132
+ "registerUnsafeBurnerWallet: Unsafe Burner Wallet already registered, skipping duplicate registration."
1133
+ );
1134
+ return;
1135
+ }
1136
+ console.warn(
1137
+ "Your application is currently using the unsafe burner wallet. Make sure that this wallet is disabled in production."
1138
+ );
1139
+ const keypair = new import_ed25519.Ed25519Keypair();
1140
+ const account = new import_wallet_standard2.ReadonlyWalletAccount({
1141
+ address: keypair.getPublicKey().toHaneulAddress(),
1142
+ publicKey: keypair.getPublicKey().toHaneulBytes(),
1143
+ chains: ["sui:unknown"],
1144
+ features: [
1145
+ "sui:signAndExecuteTransactionBlock",
1146
+ "sui:signTransactionBlock",
1147
+ "sui:signTransaction",
1148
+ "sui:signAndExecuteTransaction"
1149
+ ]
1150
+ });
1151
+ class UnsafeBurnerWallet {
1152
+ constructor() {
1153
+ __privateAdd(this, _on, () => {
1154
+ return () => {
1155
+ };
1156
+ });
1157
+ __privateAdd(this, _connect, async () => {
1158
+ return { accounts: this.accounts };
1159
+ });
1160
+ __privateAdd(this, _signPersonalMessage, async (messageInput) => {
1161
+ const { bytes, signature } = await keypair.signPersonalMessage(messageInput.message);
1162
+ return { bytes, signature };
1163
+ });
1164
+ __privateAdd(this, _signTransactionBlock, async (transactionInput) => {
1165
+ const { bytes, signature } = await transactionInput.transactionBlock.sign({
1166
+ client: haneulClient,
1167
+ signer: keypair
1168
+ });
1169
+ return {
1170
+ transactionBlockBytes: bytes,
1171
+ signature
1172
+ };
1173
+ });
1174
+ __privateAdd(this, _signTransaction, async (transactionInput) => {
1175
+ const { bytes, signature } = await import_transactions.Transaction.from(
1176
+ await transactionInput.transaction.toJSON()
1177
+ ).sign({
1178
+ client: haneulClient,
1179
+ signer: keypair
1180
+ });
1181
+ transactionInput.signal?.throwIfAborted();
1182
+ return {
1183
+ bytes,
1184
+ signature
1185
+ };
1186
+ });
1187
+ __privateAdd(this, _signAndExecuteTransactionBlock, async (transactionInput) => {
1188
+ const { bytes, signature } = await transactionInput.transactionBlock.sign({
1189
+ client: haneulClient,
1190
+ signer: keypair
1191
+ });
1192
+ return haneulClient.executeTransactionBlock({
1193
+ signature,
1194
+ transactionBlock: bytes,
1195
+ options: transactionInput.options
1196
+ });
1197
+ });
1198
+ __privateAdd(this, _signAndExecuteTransaction, async (transactionInput) => {
1199
+ const { bytes, signature } = await import_transactions.Transaction.from(
1200
+ await transactionInput.transaction.toJSON()
1201
+ ).sign({
1202
+ client: haneulClient,
1203
+ signer: keypair
1204
+ });
1205
+ transactionInput.signal?.throwIfAborted();
1206
+ const { rawEffects, digest } = await haneulClient.executeTransactionBlock({
1207
+ signature,
1208
+ transactionBlock: bytes,
1209
+ options: {
1210
+ showRawEffects: true
1211
+ }
1212
+ });
1213
+ return {
1214
+ bytes,
1215
+ signature,
1216
+ digest,
1217
+ effects: (0, import_utils2.toBase64)(new Uint8Array(rawEffects))
1218
+ };
1219
+ });
1220
+ }
1221
+ get version() {
1222
+ return "1.0.0";
1223
+ }
1224
+ get name() {
1225
+ return WALLET_NAME;
1226
+ }
1227
+ get icon() {
1228
+ return "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADwAAAA8CAYAAAA6/NlyAAAJrElEQVR42tWbe2xT1x3H7UxAyD3XrdrSbGXlUbKWsq5rWdVuVOMRSEqSOmnVRZMmJqZNYv1nf3R/jWmVmVrtRRM/YwPd1nVTNcrE3pQCoikrIRAC4VVNY0hlD9ZOo1uCfe3ra9979v0dcy3s5Pper76Oh/STE+495/4+5/c85zqe2f7HAx5vKsS+monJj/CdHi/f4/HWW4f6AwdblmXjTM0NyS+movKtw9v+j6C5gKhyTMTTpA2x15Qwy+Pz75motOGdgKep8WF5ATgVZIt5NeO2wMqD0hfVGNPh3oYaYflsjG0l63PeyLCDnqbsLpZIhaRNFI+Ox+Le5KB0RybK8gDmJOkI07U4i/FhT1NDQl8Me5rUIfaDfELOJ0NsFa/SJQHm1WLsHcDqRWiy9BCL8s0N5t6UWWFVvxplejYm60hC91cNjPtzCTZsAptCVoeLP8PDDQJNCSodap6H+LtE8ZcdkvVkkD38vwDn4/Jvy4EhBhZSvRaUHiTXn31gJJxkUPoClBKKFizM+inhVA2cYIdM4HJouPvoe9s9H+KzDhyGK6KkmIqitBhww2C11rjQL2L4kgUwFxk8yPyzauUA3Pk/353XnA6zKbKCaQ2UlMvJF6W5uF5F8yHfZWZpC9HRmBziaEpm1bpY9XvhxuWJRldC7Mt03WlZwpjnkZUNa2DMG2EaPj9MGd2l2mofd0hQ7ZSopsXckHxVCUp32fXGdD0ZktrgFUmMqwhcWFjp87RArsD+9bn585IRaSHAKgBL3SZwOTRc8BKg7yYoskp5OJDiiPmF2Sj7ox0siYJ7lJA04EqvzZ9B1xSVt6PlW0IxZgUMJdZYAJuWngLQt9IRuZXmoTEkmci8ZtTXTViUKyasA9FRun5d8z6bfw0gYWm9mmCXxZatQgxfC7I2NVpRYQOxKWppLs4mcgn5NcibgL1K40xYp8CYY5TXEpjcb3LAJ0OZyyg3+2nySm6fjEtzkEz+7VBx3RTb+60z9dma7pkvwO2QQL5HzTtAdpKF7euw/HuzfrosBHy+ZsBimzbQshjWTVMDgez53B5MbjcGbr1ZjdUJOM5O0SLXzJ2R+uOA1dMAVoLsm5zb73JSId8t8Aa1LsAJdoTCrCaw6e3NC2DdFMUXWRg173mysJNOSUNskUJ1cOlXa2LhcbgmSszXYSn9hl3KSxTDjrZ2cbbfbWDyumsh9m3e7zCG7a3ETt+gtI7fx6lEOanZKDVvuA2cjYmt5xNOd2Louz3IQ12UZ2Zo3lkb9cDlvSs6m4Vk5Yqlabs0B97wT7PUuCXQz0Bnt9QxMPTW4iwBtmUlY8hFsHJPlzcQ1xuG75CVK1kXofCUGnU9fg1aVD7kfE9MoabtYkcAvIUYS2op3Hc3TTrDQzIAeojugTVLFolWDR6wFPtY0R66n6HltwjCIawnE2ymresk9NtN+pfUUi0mX6RJLfrh9zMRaRPOqubSA8W2MNzC0mHpK7j2ruuw5mYkxl5+2+HGQeg4yNYg7vNg+xMxFsuRMuiTsRJZG3cysAl4D9n4aC4un8L9qUyVvbCyYwFXX1nGUxFf1cCiEQqy75O+TpMwYKNKSPQUqhLyyWLsRbESLctx0YnixgfphRWA8pOPc+N4F9d+eV9V4OlCX/As5w5g+wtGhJGukp5go2R3D7EW9rSDcnGL56YgJHj+8GcFND/Vy41jj/H0jxc6HU/AA2QlR01UlH3D7CmITQnJq4lVWBi1yl8XYEh278c5H++F+Iui7r7bYR8tH/gbqoJN7fVODUhLYVVxzmYCEyOxFg7RUVa0egCHZZ55eRHnp/tKgMna6s/bbMdTxZgMzl9CCcmq7k690OzDfaeSN4QcsREjsQpgXHwyWyfg9K5WE7hc6JqTWjyihObfygOFOkv6i5K5TZx8LsL1sVS4NL8ItiB7sgAcEKcWHfUCVhK3kUVnBNbfXIs4l5xAv5sJs234eTUy93L0Au2otQOw5ORMyfQ6WwexFupVSHowG6uThXfebmlhWojMS3fazmMeGxEI6S2SUti6RAo2vKohVuH3qUG5FWm/PjH8kzutgSH5g58xrVwzIbZkxHf7OFjFC+wrMDXcpOqOKX/g01U/XPvVJyxdWsiJblqYmnZoWbDxAcR56X5WPuh4ewcL5PY9JBRUYjc7fzjG6Uc3mHBWbg23X1BLaFHOSnrw4bWiNAXSEWcWRntIignXTP/oDsfKZX66mMbZAPfhviU1AyYmJLYAMZa/QXjUSeIiixpj3UUFtd884KytjN7EjdGNNMbWwtlf3FvbQ4OQtIoYSzbxqVDLXMTxP8jnnbiyKcaJLvueGLD6kXW2sKZov1tpn7hwXf3ZUvq0K2FXOM7Op/Xgb6PhxsWIErYGVuK3WGXWkkwMMZVCVl5kWtax5A6usgemvnx4DelUcYcFC0eIbcbXKzggeyBjeXIhkftaKknJKLtnuSg7KmKQsrH+1nqbmLWY6w/tBGy/8xrruR5SM99LLIjfT/4ZbNZnQEPssIVb21rKTGRIPDagNoLdFMKgcuLc/TF6Bulk6c7ovg4TU+XvS6FNw1tDfVqH9MOPmBDui0hcK6wz744FlDjNe0m3aVldJYagtI6YbF+3ZGPsQHlN1vbeh8lJofqJ+uo9Zi4wXZxKFiXKGxbHT7pNq71oNg4Qi6MviE0FpRVqjGXILYoJ4tCjdYU1rWeMdPLc/ochj3B9pGNGL4NupGPRlUl35KMVxFLNO6ZnxYlBsUPqoMkbUqAb6VhMVKQ7MVT1dYdrL8hzEAcjpmvjHKphgaFb0ZVJZw7dwVD9q5fkgPTRbBxnzmGfgRLQsMCkG+moQdcp6GzzZsL2MGyllvBNGWM9RqMCk26kI7aBK526csVShZTfzid6FEzeiNAGP92jpCPQEbrW7EW5MbZxAz/fN9lg0IbQaaxrQ83/VoKPb/HqJx67Hw+43CDQBPsX0gm6ufXNvH4vP9rZapzx7+Nn+oxZAjfo2caZ3n350c5W6FSEdQ86sNarj3c/jRV+H42AXsdGRBfPPIlnb/mUtxzWXfALn/PmRze2Gud6E/xsXwYtnlsWN8Tc5/oyxjn/jvyJrlY82xLUfWuPr/TqxzuXQZkIP9M7CXiyuP4B4WmsTnNhzinjrD+WO9bRhmdZWLXe4EKRtV5tpN3Hx3s2G+d79/MJf4qff0LnE72kfFEs4ITQvWLMab8C131dP9n9Je1Yx000Nz2jAf+UJwCBchc3NvGR1Qx71XXY2Ww1Jvx7YalzAPkX9rp5E5Z+pv+ja8bE43uN491b9dHO9Xx4lUxziLn21Nai/wXWM6t9vkvtrwAAAABJRU5ErkJggg==";
1229
+ }
1230
+ // Return the Haneul chains that your wallet supports.
1231
+ get chains() {
1232
+ return import_wallet_standard2.HANEUL_CHAINS;
1233
+ }
1234
+ get accounts() {
1235
+ return [account];
1236
+ }
1237
+ get features() {
1238
+ return {
1239
+ "standard:connect": {
1240
+ version: "1.0.0",
1241
+ connect: __privateGet(this, _connect)
1242
+ },
1243
+ "standard:events": {
1244
+ version: "1.0.0",
1245
+ on: __privateGet(this, _on)
1246
+ },
1247
+ "sui:signPersonalMessage": {
1248
+ version: "1.1.0",
1249
+ signPersonalMessage: __privateGet(this, _signPersonalMessage)
1250
+ },
1251
+ "sui:signTransactionBlock": {
1252
+ version: "1.0.0",
1253
+ signTransactionBlock: __privateGet(this, _signTransactionBlock)
1254
+ },
1255
+ "sui:signAndExecuteTransactionBlock": {
1256
+ version: "1.0.0",
1257
+ signAndExecuteTransactionBlock: __privateGet(this, _signAndExecuteTransactionBlock)
1258
+ },
1259
+ "sui:signTransaction": {
1260
+ version: "2.0.0",
1261
+ signTransaction: __privateGet(this, _signTransaction)
1262
+ },
1263
+ "sui:signAndExecuteTransaction": {
1264
+ version: "2.0.0",
1265
+ signAndExecuteTransaction: __privateGet(this, _signAndExecuteTransaction)
1266
+ }
1267
+ };
1268
+ }
1269
+ }
1270
+ _on = new WeakMap();
1271
+ _connect = new WeakMap();
1272
+ _signPersonalMessage = new WeakMap();
1273
+ _signTransactionBlock = new WeakMap();
1274
+ _signTransaction = new WeakMap();
1275
+ _signAndExecuteTransactionBlock = new WeakMap();
1276
+ _signAndExecuteTransaction = new WeakMap();
1277
+ return walletsApi.register(new UnsafeBurnerWallet());
1278
+ }
1279
+
1280
+ // src/hooks/wallet/useWalletPropertiesChanged.ts
1281
+ var import_react15 = require("react");
1282
+ function useWalletPropertiesChanged() {
1283
+ const { currentWallet } = useCurrentWallet();
1284
+ const updateWalletAccounts = useWalletStore((state) => state.updateWalletAccounts);
1285
+ (0, import_react15.useEffect)(() => {
1286
+ const unsubscribeFromEvents = currentWallet?.features["standard:events"].on(
1287
+ "change",
1288
+ ({ accounts }) => {
1289
+ if (accounts) {
1290
+ updateWalletAccounts(accounts);
1291
+ }
1292
+ }
1293
+ );
1294
+ return unsubscribeFromEvents;
1295
+ }, [currentWallet?.features, updateWalletAccounts]);
1296
+ }
1297
+
1298
+ // src/hooks/wallet/useWalletsChanged.ts
1299
+ var import_wallet_standard3 = require("@haneullabs/wallet-standard");
1300
+ var import_react16 = require("react");
1301
+ function useWalletsChanged(preferredWallets, walletFilter) {
1302
+ const setWalletRegistered = useWalletStore((state) => state.setWalletRegistered);
1303
+ const setWalletUnregistered = useWalletStore((state) => state.setWalletUnregistered);
1304
+ (0, import_react16.useEffect)(() => {
1305
+ const walletsApi = (0, import_wallet_standard3.getWallets)();
1306
+ setWalletRegistered(getRegisteredWallets(preferredWallets, walletFilter));
1307
+ const unsubscribeFromRegister = walletsApi.on("register", () => {
1308
+ setWalletRegistered(getRegisteredWallets(preferredWallets, walletFilter));
1309
+ });
1310
+ const unsubscribeFromUnregister = walletsApi.on("unregister", (unregisteredWallet) => {
1311
+ setWalletUnregistered(
1312
+ getRegisteredWallets(preferredWallets, walletFilter),
1313
+ unregisteredWallet
1314
+ );
1315
+ });
1316
+ return () => {
1317
+ unsubscribeFromRegister();
1318
+ unsubscribeFromUnregister();
1319
+ };
1320
+ }, [preferredWallets, walletFilter, setWalletRegistered, setWalletUnregistered]);
1321
+ }
1322
+
1323
+ // src/themes/lightTheme.ts
1324
+ var lightTheme = {
1325
+ blurs: {
1326
+ modalOverlay: "blur(0)"
1327
+ },
1328
+ backgroundColors: {
1329
+ primaryButton: "#F6F7F9",
1330
+ primaryButtonHover: "#F0F2F5",
1331
+ outlineButtonHover: "#F4F4F5",
1332
+ modalOverlay: "rgba(24 36 53 / 20%)",
1333
+ modalPrimary: "white",
1334
+ modalSecondary: "#F7F8F8",
1335
+ iconButton: "transparent",
1336
+ iconButtonHover: "#F0F1F2",
1337
+ dropdownMenu: "#FFFFFF",
1338
+ dropdownMenuSeparator: "#F3F6F8",
1339
+ walletItemSelected: "white",
1340
+ walletItemHover: "#3C424226"
1341
+ },
1342
+ borderColors: {
1343
+ outlineButton: "#E4E4E7"
1344
+ },
1345
+ colors: {
1346
+ primaryButton: "#373737",
1347
+ outlineButton: "#373737",
1348
+ iconButton: "#000000",
1349
+ body: "#182435",
1350
+ bodyMuted: "#767A81",
1351
+ bodyDanger: "#FF794B"
1352
+ },
1353
+ radii: {
1354
+ small: "6px",
1355
+ medium: "8px",
1356
+ large: "12px",
1357
+ xlarge: "16px"
1358
+ },
1359
+ shadows: {
1360
+ primaryButton: "0px 4px 12px rgba(0, 0, 0, 0.1)",
1361
+ walletItemSelected: "0px 2px 6px rgba(0, 0, 0, 0.05)"
1362
+ },
1363
+ fontWeights: {
1364
+ normal: "400",
1365
+ medium: "500",
1366
+ bold: "600"
1367
+ },
1368
+ fontSizes: {
1369
+ small: "14px",
1370
+ medium: "16px",
1371
+ large: "18px",
1372
+ xlarge: "20px"
1373
+ },
1374
+ typography: {
1375
+ fontFamily: 'ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"',
1376
+ fontStyle: "normal",
1377
+ lineHeight: "1.3",
1378
+ letterSpacing: "1"
1379
+ }
1380
+ };
1381
+
1382
+ // src/walletStore.ts
1383
+ var import_zustand2 = require("zustand");
1384
+ var import_middleware = require("zustand/middleware");
1385
+ function createWalletStore({
1386
+ wallets,
1387
+ storage,
1388
+ storageKey,
1389
+ autoConnectEnabled
1390
+ }) {
1391
+ return (0, import_zustand2.createStore)()(
1392
+ (0, import_middleware.persist)(
1393
+ (set, get) => ({
1394
+ autoConnectEnabled,
1395
+ wallets,
1396
+ accounts: [],
1397
+ currentWallet: null,
1398
+ currentAccount: null,
1399
+ lastConnectedAccountAddress: null,
1400
+ lastConnectedWalletName: null,
1401
+ connectionStatus: "disconnected",
1402
+ supportedIntents: [],
1403
+ setConnectionStatus(connectionStatus2) {
1404
+ set(() => ({
1405
+ connectionStatus: connectionStatus2
1406
+ }));
1407
+ },
1408
+ setWalletConnected(wallet, connectedAccounts, selectedAccount, supportedIntents = []) {
1409
+ set(() => ({
1410
+ accounts: connectedAccounts,
1411
+ currentWallet: wallet,
1412
+ currentAccount: selectedAccount,
1413
+ lastConnectedWalletName: getWalletUniqueIdentifier(wallet),
1414
+ lastConnectedAccountAddress: selectedAccount?.address,
1415
+ connectionStatus: "connected",
1416
+ supportedIntents
1417
+ }));
1418
+ },
1419
+ setWalletDisconnected() {
1420
+ set(() => ({
1421
+ accounts: [],
1422
+ currentWallet: null,
1423
+ currentAccount: null,
1424
+ lastConnectedWalletName: null,
1425
+ lastConnectedAccountAddress: null,
1426
+ connectionStatus: "disconnected",
1427
+ supportedIntents: []
1428
+ }));
1429
+ },
1430
+ setAccountSwitched(selectedAccount) {
1431
+ set(() => ({
1432
+ currentAccount: selectedAccount,
1433
+ lastConnectedAccountAddress: selectedAccount.address
1434
+ }));
1435
+ },
1436
+ setWalletRegistered(updatedWallets) {
1437
+ set(() => ({ wallets: updatedWallets }));
1438
+ },
1439
+ setWalletUnregistered(updatedWallets, unregisteredWallet) {
1440
+ if (unregisteredWallet === get().currentWallet) {
1441
+ set(() => ({
1442
+ wallets: updatedWallets,
1443
+ accounts: [],
1444
+ currentWallet: null,
1445
+ currentAccount: null,
1446
+ lastConnectedWalletName: null,
1447
+ lastConnectedAccountAddress: null,
1448
+ connectionStatus: "disconnected",
1449
+ supportedIntents: []
1450
+ }));
1451
+ } else {
1452
+ set(() => ({ wallets: updatedWallets }));
1453
+ }
1454
+ },
1455
+ updateWalletAccounts(accounts) {
1456
+ const currentAccount = get().currentAccount;
1457
+ set(() => ({
1458
+ accounts,
1459
+ currentAccount: currentAccount && accounts.find(({ address }) => address === currentAccount.address) || accounts[0]
1460
+ }));
1461
+ }
1462
+ }),
1463
+ {
1464
+ name: storageKey,
1465
+ storage: (0, import_middleware.createJSONStorage)(() => storage),
1466
+ partialize: ({ lastConnectedWalletName, lastConnectedAccountAddress }) => ({
1467
+ lastConnectedWalletName,
1468
+ lastConnectedAccountAddress
1469
+ })
1470
+ }
1471
+ )
1472
+ );
1473
+ }
1474
+
1475
+ // src/components/styling/InjectedThemeStyles.tsx
1476
+ var import_dynamic = require("@vanilla-extract/dynamic");
1477
+
1478
+ // src/themes/themeContract.ts
1479
+ var import_css = require("@vanilla-extract/css");
1480
+ var themeContractValues = {
1481
+ blurs: {
1482
+ modalOverlay: ""
1483
+ },
1484
+ backgroundColors: {
1485
+ primaryButton: "",
1486
+ primaryButtonHover: "",
1487
+ outlineButtonHover: "",
1488
+ walletItemHover: "",
1489
+ walletItemSelected: "",
1490
+ modalOverlay: "",
1491
+ modalPrimary: "",
1492
+ modalSecondary: "",
1493
+ iconButton: "",
1494
+ iconButtonHover: "",
1495
+ dropdownMenu: "",
1496
+ dropdownMenuSeparator: ""
1497
+ },
1498
+ borderColors: {
1499
+ outlineButton: ""
1500
+ },
1501
+ colors: {
1502
+ primaryButton: "",
1503
+ outlineButton: "",
1504
+ body: "",
1505
+ bodyMuted: "",
1506
+ bodyDanger: "",
1507
+ iconButton: ""
1508
+ },
1509
+ radii: {
1510
+ small: "",
1511
+ medium: "",
1512
+ large: "",
1513
+ xlarge: ""
1514
+ },
1515
+ shadows: {
1516
+ primaryButton: "",
1517
+ walletItemSelected: ""
1518
+ },
1519
+ fontWeights: {
1520
+ normal: "",
1521
+ medium: "",
1522
+ bold: ""
1523
+ },
1524
+ fontSizes: {
1525
+ small: "",
1526
+ medium: "",
1527
+ large: "",
1528
+ xlarge: ""
1529
+ },
1530
+ typography: {
1531
+ fontFamily: "",
1532
+ fontStyle: "",
1533
+ lineHeight: "",
1534
+ letterSpacing: ""
1535
+ }
1536
+ };
1537
+ var themeVars = (0, import_css.createGlobalThemeContract)(
1538
+ themeContractValues,
1539
+ (_, path) => `dapp-kit-${path.join("-")}`
1540
+ );
1541
+
1542
+ // src/components/styling/InjectedThemeStyles.tsx
1543
+ var import_jsx_runtime20 = require("react/jsx-runtime");
1544
+ function InjectedThemeStyles({ theme }) {
1545
+ const themeStyles = Array.isArray(theme) ? getDynamicThemeStyles(theme) : getStaticThemeStyles(theme);
1546
+ return /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(
1547
+ "style",
1548
+ {
1549
+ precedence: "default",
1550
+ href: "haneullabs-dapp-kit-theme",
1551
+ dangerouslySetInnerHTML: {
1552
+ __html: themeStyles
1553
+ }
1554
+ }
1555
+ );
1556
+ }
1557
+ function getDynamicThemeStyles(themes) {
1558
+ return themes.map(({ mediaQuery, selector, variables }) => {
1559
+ const themeStyles = getStaticThemeStyles(variables);
1560
+ const themeStylesWithSelectorPrefix = selector ? `${selector} ${themeStyles}` : themeStyles;
1561
+ return mediaQuery ? `@media ${mediaQuery}{${themeStylesWithSelectorPrefix}}` : themeStylesWithSelectorPrefix;
1562
+ }).join(" ");
1563
+ }
1564
+ function getStaticThemeStyles(theme) {
1565
+ return `${styleDataAttributeSelector} {${cssStringFromTheme(theme)}}`;
1566
+ }
1567
+ function cssStringFromTheme(theme) {
1568
+ return Object.entries((0, import_dynamic.assignInlineVars)(themeVars, theme)).map(([key, value]) => `${key}:${value};`).join("");
1569
+ }
1570
+
1571
+ // src/components/WalletProvider.tsx
1572
+ var import_jsx_runtime21 = require("react/jsx-runtime");
1573
+ function WalletProvider({
1574
+ preferredWallets = DEFAULT_PREFERRED_WALLETS,
1575
+ walletFilter = DEFAULT_WALLET_FILTER,
1576
+ storage = DEFAULT_STORAGE,
1577
+ storageKey = DEFAULT_STORAGE_KEY,
1578
+ enableUnsafeBurner = false,
1579
+ autoConnect = false,
1580
+ slushWallet,
1581
+ theme = lightTheme,
1582
+ children
1583
+ }) {
1584
+ const storeRef = (0, import_react17.useRef)(
1585
+ createWalletStore({
1586
+ autoConnectEnabled: autoConnect,
1587
+ wallets: getRegisteredWallets(preferredWallets, walletFilter),
1588
+ storage: storage || createInMemoryStore(),
1589
+ storageKey
1590
+ })
1591
+ );
1592
+ return /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(WalletContext.Provider, { value: storeRef.current, children: /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(
1593
+ WalletConnectionManager,
1594
+ {
1595
+ preferredWallets,
1596
+ walletFilter,
1597
+ enableUnsafeBurner,
1598
+ slushWallet,
1599
+ children: [
1600
+ theme ? /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(InjectedThemeStyles, { theme }) : null,
1601
+ children
1602
+ ]
1603
+ }
1604
+ ) });
1605
+ }
1606
+ function WalletConnectionManager({
1607
+ preferredWallets = DEFAULT_PREFERRED_WALLETS,
1608
+ walletFilter = DEFAULT_WALLET_FILTER,
1609
+ enableUnsafeBurner = false,
1610
+ slushWallet,
1611
+ children
1612
+ }) {
1613
+ useWalletsChanged(preferredWallets, walletFilter);
1614
+ useWalletPropertiesChanged();
1615
+ useSlushWallet(slushWallet);
1616
+ useUnsafeBurnerWallet(enableUnsafeBurner);
1617
+ useAutoConnectWallet();
1618
+ return children;
1619
+ }
1620
+
1621
+ // src/hooks/networkConfig.ts
1622
+ function createNetworkConfig(networkConfig) {
1623
+ function useNetworkConfig() {
1624
+ const { config } = useHaneulClientContext();
1625
+ if (!config) {
1626
+ throw new Error("No network config found");
1627
+ }
1628
+ return config;
1629
+ }
1630
+ function useNetworkVariables() {
1631
+ const { variables } = useNetworkConfig();
1632
+ return variables ?? {};
1633
+ }
1634
+ function useNetworkVariable(name) {
1635
+ const variables = useNetworkVariables();
1636
+ return variables[name];
1637
+ }
1638
+ return {
1639
+ networkConfig,
1640
+ useNetworkConfig,
1641
+ useNetworkVariables,
1642
+ useNetworkVariable
1643
+ };
1644
+ }
1645
+
1646
+ // src/hooks/useHaneulClientInfiniteQuery.ts
1647
+ var import_react_query6 = require("@tanstack/react-query");
1648
+ function useHaneulClientInfiniteQuery(method, params, {
1649
+ queryKey = [],
1650
+ enabled = !!params,
1651
+ ...options
1652
+ } = {}) {
1653
+ const suiContext = useHaneulClientContext();
1654
+ return (0, import_react_query6.useInfiniteQuery)({
1655
+ ...options,
1656
+ initialPageParam: null,
1657
+ queryKey: [suiContext.network, method, params, ...queryKey],
1658
+ enabled,
1659
+ queryFn: ({ pageParam }) => suiContext.client[method]({
1660
+ // oxlint-disable-next-line no-useless-fallback-in-spread
1661
+ ...params ?? {},
1662
+ cursor: pageParam
1663
+ }),
1664
+ getNextPageParam: (lastPage) => lastPage.hasNextPage ? lastPage.nextCursor ?? null : null
1665
+ });
1666
+ }
1667
+
1668
+ // src/hooks/useHaneulClientMutation.ts
1669
+ var import_react_query7 = require("@tanstack/react-query");
1670
+ function useHaneulClientMutation(method, options = {}) {
1671
+ const suiContext = useHaneulClientContext();
1672
+ return (0, import_react_query7.useMutation)({
1673
+ ...options,
1674
+ mutationFn: async (params) => {
1675
+ return await suiContext.client[method](params);
1676
+ }
1677
+ });
1678
+ }
1679
+
1680
+ // src/hooks/useHaneulClientQueries.ts
1681
+ var import_react_query8 = require("@tanstack/react-query");
1682
+ function useHaneulClientQueries({
1683
+ queries,
1684
+ combine
1685
+ }) {
1686
+ const suiContext = useHaneulClientContext();
1687
+ return (0, import_react_query8.useQueries)({
1688
+ combine,
1689
+ queries: queries.map((query) => {
1690
+ const { method, params, options: { queryKey = [], ...restOptions } = {} } = query;
1691
+ return {
1692
+ ...restOptions,
1693
+ queryKey: [suiContext.network, method, params, ...queryKey],
1694
+ queryFn: async () => {
1695
+ return await suiContext.client[method](params);
1696
+ }
1697
+ };
1698
+ })
1699
+ });
1700
+ }
1701
+
1702
+ // src/hooks/wallet/useSignAndExecuteTransaction.ts
1703
+ var import_utils4 = require("@haneullabs/haneul/utils");
1704
+ var import_wallet_standard4 = require("@haneullabs/wallet-standard");
1705
+ var import_react_query10 = require("@tanstack/react-query");
1706
+
1707
+ // src/hooks/wallet/useReportTransactionEffects.ts
1708
+ var import_utils3 = require("@haneullabs/haneul/utils");
1709
+ var import_react_query9 = require("@tanstack/react-query");
1710
+ function useReportTransactionEffects({
1711
+ mutationKey,
1712
+ ...mutationOptions
1713
+ } = {}) {
1714
+ const { currentWallet } = useCurrentWallet();
1715
+ const currentAccount = useCurrentAccount();
1716
+ return (0, import_react_query9.useMutation)({
1717
+ mutationKey: walletMutationKeys.reportTransactionEffects(mutationKey),
1718
+ mutationFn: async ({ effects, chain = currentWallet?.chains[0], account = currentAccount }) => {
1719
+ if (!currentWallet) {
1720
+ throw new WalletNotConnectedError("No wallet is connected.");
1721
+ }
1722
+ if (!account) {
1723
+ throw new WalletNoAccountSelectedError(
1724
+ "No wallet account is selected to report transaction effects for"
1725
+ );
1726
+ }
1727
+ const reportTransactionEffectsFeature = currentWallet.features["sui:reportTransactionEffects"];
1728
+ if (reportTransactionEffectsFeature) {
1729
+ return await reportTransactionEffectsFeature.reportTransactionEffects({
1730
+ effects: Array.isArray(effects) ? (0, import_utils3.toBase64)(new Uint8Array(effects)) : effects,
1731
+ account,
1732
+ chain: chain ?? currentWallet?.chains[0]
1733
+ });
1734
+ }
1735
+ },
1736
+ ...mutationOptions
1737
+ });
1738
+ }
1739
+
1740
+ // src/hooks/wallet/useSignAndExecuteTransaction.ts
1741
+ function useSignAndExecuteTransaction({
1742
+ mutationKey,
1743
+ execute,
1744
+ ...mutationOptions
1745
+ } = {}) {
1746
+ const { currentWallet, supportedIntents } = useCurrentWallet();
1747
+ const currentAccount = useCurrentAccount();
1748
+ const { client, network } = useHaneulClientContext();
1749
+ const { mutate: reportTransactionEffects } = useReportTransactionEffects();
1750
+ const executeTransaction = execute ?? (async ({ bytes, signature }) => {
1751
+ const { digest, rawEffects } = await client.executeTransactionBlock({
1752
+ transactionBlock: bytes,
1753
+ signature,
1754
+ options: {
1755
+ showRawEffects: true
1756
+ }
1757
+ });
1758
+ return {
1759
+ digest,
1760
+ rawEffects,
1761
+ effects: (0, import_utils4.toBase64)(new Uint8Array(rawEffects)),
1762
+ bytes,
1763
+ signature
1764
+ };
1765
+ });
1766
+ return (0, import_react_query10.useMutation)({
1767
+ mutationKey: walletMutationKeys.signAndExecuteTransaction(mutationKey),
1768
+ mutationFn: async ({ transaction, ...signTransactionArgs }) => {
1769
+ if (!currentWallet) {
1770
+ throw new WalletNotConnectedError("No wallet is connected.");
1771
+ }
1772
+ const signerAccount = signTransactionArgs.account ?? currentAccount;
1773
+ if (!signerAccount) {
1774
+ throw new WalletNoAccountSelectedError(
1775
+ "No wallet account is selected to sign the transaction with."
1776
+ );
1777
+ }
1778
+ if (!currentWallet.features["sui:signTransaction"] && !currentWallet.features["sui:signTransactionBlock"]) {
1779
+ throw new WalletFeatureNotSupportedError(
1780
+ "This wallet doesn't support the `signTransaction` feature."
1781
+ );
1782
+ }
1783
+ if (typeof transaction !== "string" && "setSenderIfNotSet" in transaction) {
1784
+ transaction.setSenderIfNotSet(signerAccount.address);
1785
+ }
1786
+ const chain = signTransactionArgs.chain ?? `sui:${network}`;
1787
+ const { signature, bytes } = await (0, import_wallet_standard4.signTransaction)(currentWallet, {
1788
+ ...signTransactionArgs,
1789
+ transaction: {
1790
+ async toJSON() {
1791
+ return typeof transaction === "string" ? transaction : await transaction.toJSON({
1792
+ supportedIntents,
1793
+ client
1794
+ });
1795
+ }
1796
+ },
1797
+ account: signerAccount,
1798
+ chain
1799
+ });
1800
+ const result = await executeTransaction({ bytes, signature });
1801
+ let effects;
1802
+ if ("effects" in result && result.effects?.bcs) {
1803
+ effects = result.effects.bcs;
1804
+ } else if ("rawEffects" in result) {
1805
+ effects = (0, import_utils4.toBase64)(new Uint8Array(result.rawEffects));
1806
+ } else {
1807
+ throw new Error("Could not parse effects from transaction result.");
1808
+ }
1809
+ reportTransactionEffects({ effects, account: signerAccount, chain });
1810
+ return result;
1811
+ },
1812
+ ...mutationOptions
1813
+ });
1814
+ }
1815
+
1816
+ // src/hooks/wallet/useSignPersonalMessage.ts
1817
+ var import_react_query11 = require("@tanstack/react-query");
1818
+ function useSignPersonalMessage({
1819
+ mutationKey,
1820
+ ...mutationOptions
1821
+ } = {}) {
1822
+ const { currentWallet } = useCurrentWallet();
1823
+ const currentAccount = useCurrentAccount();
1824
+ const { network } = useHaneulClientContext();
1825
+ return (0, import_react_query11.useMutation)({
1826
+ mutationKey: walletMutationKeys.signPersonalMessage(mutationKey),
1827
+ mutationFn: async (signPersonalMessageArgs) => {
1828
+ if (!currentWallet) {
1829
+ throw new WalletNotConnectedError("No wallet is connected.");
1830
+ }
1831
+ const signerAccount = signPersonalMessageArgs.account ?? currentAccount;
1832
+ if (!signerAccount) {
1833
+ throw new WalletNoAccountSelectedError(
1834
+ "No wallet account is selected to sign the personal message with."
1835
+ );
1836
+ }
1837
+ const signPersonalMessageFeature = currentWallet.features["sui:signPersonalMessage"];
1838
+ if (signPersonalMessageFeature) {
1839
+ return await signPersonalMessageFeature.signPersonalMessage({
1840
+ ...signPersonalMessageArgs,
1841
+ account: signerAccount,
1842
+ chain: signPersonalMessageArgs.chain ?? `sui:${network}`
1843
+ });
1844
+ }
1845
+ const signMessageFeature = currentWallet.features["sui:signMessage"];
1846
+ if (signMessageFeature) {
1847
+ console.warn(
1848
+ "This wallet doesn't support the `signPersonalMessage` feature... falling back to `signMessage`."
1849
+ );
1850
+ const { messageBytes, signature } = await signMessageFeature.signMessage({
1851
+ ...signPersonalMessageArgs,
1852
+ account: signerAccount
1853
+ });
1854
+ return { bytes: messageBytes, signature };
1855
+ }
1856
+ throw new WalletFeatureNotSupportedError(
1857
+ "This wallet doesn't support the `signPersonalMessage` feature."
1858
+ );
1859
+ },
1860
+ ...mutationOptions
1861
+ });
1862
+ }
1863
+
1864
+ // src/hooks/wallet/useSignTransaction.ts
1865
+ var import_wallet_standard5 = require("@haneullabs/wallet-standard");
1866
+ var import_react_query12 = require("@tanstack/react-query");
1867
+ function useSignTransaction({
1868
+ mutationKey,
1869
+ ...mutationOptions
1870
+ } = {}) {
1871
+ const { currentWallet } = useCurrentWallet();
1872
+ const currentAccount = useCurrentAccount();
1873
+ const { client, network } = useHaneulClientContext();
1874
+ const { mutate: reportTransactionEffects } = useReportTransactionEffects();
1875
+ return (0, import_react_query12.useMutation)({
1876
+ mutationKey: walletMutationKeys.signTransaction(mutationKey),
1877
+ mutationFn: async ({ transaction, ...signTransactionArgs }) => {
1878
+ if (!currentWallet) {
1879
+ throw new WalletNotConnectedError("No wallet is connected.");
1880
+ }
1881
+ const signerAccount = signTransactionArgs.account ?? currentAccount;
1882
+ if (!signerAccount) {
1883
+ throw new WalletNoAccountSelectedError(
1884
+ "No wallet account is selected to sign the transaction with."
1885
+ );
1886
+ }
1887
+ if (!currentWallet.features["sui:signTransaction"] && !currentWallet.features["sui:signTransactionBlock"]) {
1888
+ throw new WalletFeatureNotSupportedError(
1889
+ "This wallet doesn't support the `signTransaction` feature."
1890
+ );
1891
+ }
1892
+ if (typeof transaction !== "string" && "setSenderIfNotSet" in transaction) {
1893
+ transaction.setSenderIfNotSet(signerAccount.address);
1894
+ }
1895
+ const chain = signTransactionArgs.chain ?? `sui:${network}`;
1896
+ const { bytes, signature } = await (0, import_wallet_standard5.signTransaction)(currentWallet, {
1897
+ ...signTransactionArgs,
1898
+ transaction: {
1899
+ toJSON: async () => {
1900
+ return typeof transaction === "string" ? transaction : await transaction.toJSON({
1901
+ supportedIntents: [],
1902
+ client
1903
+ });
1904
+ }
1905
+ },
1906
+ account: signerAccount,
1907
+ chain
1908
+ });
1909
+ return {
1910
+ bytes,
1911
+ signature,
1912
+ reportTransactionEffects: (effects) => {
1913
+ reportTransactionEffects({
1914
+ effects,
1915
+ account: signerAccount,
1916
+ chain
1917
+ });
1918
+ }
1919
+ };
1920
+ },
1921
+ ...mutationOptions
1922
+ });
1923
+ }
1924
+ //# sourceMappingURL=index.js.map