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