thirdweb 5.31.1 → 5.32.0-nightly-931cca3a7e8f3946bdb7e40880333790387d4cef-20240702071901

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 (515) hide show
  1. package/dist/cjs/exports/react.js +4 -4
  2. package/dist/cjs/exports/react.js.map +1 -1
  3. package/dist/cjs/exports/react.native.js +14 -6
  4. package/dist/cjs/exports/react.native.js.map +1 -1
  5. package/dist/cjs/exports/wallets/in-app.js +1 -1
  6. package/dist/cjs/exports/wallets/in-app.js.map +1 -1
  7. package/dist/cjs/pay/utils/definitions.js +17 -10
  8. package/dist/cjs/pay/utils/definitions.js.map +1 -1
  9. package/dist/cjs/react/core/hooks/connection/ConnectButtonProps.js.map +1 -0
  10. package/dist/cjs/react/core/hooks/connection/ConnectEmbedProps.js +3 -0
  11. package/dist/cjs/react/core/hooks/connection/ConnectEmbedProps.js.map +1 -0
  12. package/dist/cjs/react/core/hooks/transaction/useSendTransaction.js.map +1 -1
  13. package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
  14. package/dist/cjs/react/core/hooks/wallets/useSendToken.js +81 -0
  15. package/dist/cjs/react/core/hooks/wallets/useSendToken.js.map +1 -0
  16. package/dist/cjs/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.js +20 -25
  17. package/dist/cjs/react/core/utils/defaultTokens.js.map +1 -0
  18. package/dist/cjs/react/core/utils/isSmartWallet.js.map +1 -0
  19. package/dist/cjs/react/{web/ui/ConnectWallet/icons/dataUris.js → core/utils/socialIcons.js} +19 -2
  20. package/dist/cjs/react/core/utils/socialIcons.js.map +1 -0
  21. package/dist/cjs/react/core/utils/storage.js.map +1 -0
  22. package/dist/cjs/react/core/utils/wallet.js +85 -0
  23. package/dist/cjs/react/core/utils/wallet.js.map +1 -0
  24. package/dist/cjs/react/native/design-system/index.js +33 -0
  25. package/dist/cjs/react/native/design-system/index.js.map +1 -0
  26. package/dist/cjs/react/native/hooks/wallets/useAutoConnect.js +5 -1
  27. package/dist/cjs/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
  28. package/dist/cjs/react/native/hooks/wallets/useSendToken.js +31 -0
  29. package/dist/cjs/react/native/hooks/wallets/useSendToken.js.map +1 -0
  30. package/dist/cjs/react/native/ui/components/Address.js +31 -0
  31. package/dist/cjs/react/native/ui/components/Address.js.map +1 -0
  32. package/dist/cjs/react/native/ui/components/ChainIcon.js +30 -0
  33. package/dist/cjs/react/native/ui/components/ChainIcon.js.map +1 -0
  34. package/dist/cjs/react/native/ui/components/Header.js +30 -0
  35. package/dist/cjs/react/native/ui/components/Header.js.map +1 -0
  36. package/dist/cjs/react/native/ui/components/RNImage.js +43 -0
  37. package/dist/cjs/react/native/ui/components/RNImage.js.map +1 -0
  38. package/dist/cjs/react/native/ui/components/Skeleton.js +62 -0
  39. package/dist/cjs/react/native/ui/components/Skeleton.js.map +1 -0
  40. package/dist/cjs/react/native/ui/components/TokenIcon.js +16 -0
  41. package/dist/cjs/react/native/ui/components/TokenIcon.js.map +1 -0
  42. package/dist/cjs/react/native/ui/components/WalletImage.js +69 -0
  43. package/dist/cjs/react/native/ui/components/WalletImage.js.map +1 -0
  44. package/dist/cjs/react/native/ui/components/button.js +23 -8
  45. package/dist/cjs/react/native/ui/components/button.js.map +1 -1
  46. package/dist/cjs/react/native/ui/components/input.js +64 -0
  47. package/dist/cjs/react/native/ui/components/input.js.map +1 -0
  48. package/dist/cjs/react/native/ui/components/spacer.js +10 -0
  49. package/dist/cjs/react/native/ui/components/spacer.js.map +1 -0
  50. package/dist/cjs/react/native/ui/components/text.js +10 -7
  51. package/dist/cjs/react/native/ui/components/text.js.map +1 -1
  52. package/dist/cjs/react/native/ui/connect/ConnectButton.js +106 -0
  53. package/dist/cjs/react/native/ui/connect/ConnectButton.js.map +1 -0
  54. package/dist/cjs/react/native/ui/connect/ConnectModal.js +130 -0
  55. package/dist/cjs/react/native/ui/connect/ConnectModal.js.map +1 -0
  56. package/dist/cjs/react/native/ui/connect/ConnectedButton.js +42 -0
  57. package/dist/cjs/react/native/ui/connect/ConnectedButton.js.map +1 -0
  58. package/dist/cjs/react/native/ui/connect/ConnectedModal.js +175 -0
  59. package/dist/cjs/react/native/ui/connect/ConnectedModal.js.map +1 -0
  60. package/dist/cjs/react/native/ui/connect/ErrorView.js +25 -0
  61. package/dist/cjs/react/native/ui/connect/ErrorView.js.map +1 -0
  62. package/dist/cjs/react/native/ui/connect/ExternalWalletsList.js +67 -0
  63. package/dist/cjs/react/native/ui/connect/ExternalWalletsList.js.map +1 -0
  64. package/dist/cjs/react/native/ui/connect/InAppWalletUI.js +167 -0
  65. package/dist/cjs/react/native/ui/connect/InAppWalletUI.js.map +1 -0
  66. package/dist/cjs/react/native/ui/connect/ReceiveScreen.js +42 -0
  67. package/dist/cjs/react/native/ui/connect/ReceiveScreen.js.map +1 -0
  68. package/dist/cjs/react/native/ui/connect/SendScreen.js +82 -0
  69. package/dist/cjs/react/native/ui/connect/SendScreen.js.map +1 -0
  70. package/dist/cjs/react/native/ui/connect/SuccessView.js +25 -0
  71. package/dist/cjs/react/native/ui/connect/SuccessView.js.map +1 -0
  72. package/dist/cjs/react/native/ui/connect/TokenListScreen.js +59 -0
  73. package/dist/cjs/react/native/ui/connect/TokenListScreen.js.map +1 -0
  74. package/dist/cjs/react/native/ui/icons/svgs.js +236 -0
  75. package/dist/cjs/react/native/ui/icons/svgs.js.map +1 -0
  76. package/dist/cjs/react/native/ui/{TransactionButton/TrabsactionButton.js → transaction/TransactionButton.js} +1 -1
  77. package/dist/cjs/react/native/ui/transaction/TransactionButton.js.map +1 -0
  78. package/dist/cjs/react/native/wallets/defaultWallets.js +22 -0
  79. package/dist/cjs/react/native/wallets/defaultWallets.js.map +1 -0
  80. package/dist/cjs/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  81. package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js +7 -2
  82. package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
  83. package/dist/cjs/react/web/hooks/wallets/useSendToken.js +31 -0
  84. package/dist/cjs/react/web/hooks/wallets/useSendToken.js.map +1 -0
  85. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js +1 -1
  86. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  87. package/dist/cjs/react/web/ui/ConnectWallet/Details.js +7 -51
  88. package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
  89. package/dist/cjs/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.js +2 -2
  90. package/dist/cjs/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.js.map +1 -1
  91. package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +0 -4
  92. package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
  93. package/dist/cjs/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.js +2 -2
  94. package/dist/cjs/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.js.map +1 -1
  95. package/dist/cjs/react/web/ui/ConnectWallet/WalletEntryButton.js +2 -2
  96. package/dist/cjs/react/web/ui/ConnectWallet/WalletEntryButton.js.map +1 -1
  97. package/dist/cjs/react/web/ui/ConnectWallet/WalletSelector.js +2 -2
  98. package/dist/cjs/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
  99. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  100. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatSteps.js.map +1 -1
  101. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.js.map +1 -1
  102. package/dist/cjs/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.js.map +1 -1
  103. package/dist/cjs/react/web/ui/ConnectWallet/screens/SendFunds.js +4 -15
  104. package/dist/cjs/react/web/ui/ConnectWallet/screens/SendFunds.js.map +1 -1
  105. package/dist/cjs/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
  106. package/dist/cjs/react/web/ui/ConnectWallet/screens/TokenSelector.js.map +1 -1
  107. package/dist/cjs/react/web/ui/ConnectWallet/screens/ViewFunds.js +1 -1
  108. package/dist/cjs/react/web/ui/ConnectWallet/screens/ViewFunds.js.map +1 -1
  109. package/dist/cjs/react/web/ui/PayEmbed.js.map +1 -1
  110. package/dist/cjs/react/web/ui/components/ChainIcon.js.map +1 -1
  111. package/dist/cjs/react/web/ui/components/TokenIcon.js +2 -2
  112. package/dist/cjs/react/web/ui/components/TokenIcon.js.map +1 -1
  113. package/dist/cjs/react/web/ui/components/WalletImage.js +12 -13
  114. package/dist/cjs/react/web/ui/components/WalletImage.js.map +1 -1
  115. package/dist/cjs/react/web/wallets/ecosystem/EcosystemWalletHeader.js +2 -2
  116. package/dist/cjs/react/web/wallets/ecosystem/EcosystemWalletHeader.js.map +1 -1
  117. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +5 -6
  118. package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  119. package/dist/cjs/react/web/wallets/shared/OTPLoginUI.js +1 -1
  120. package/dist/cjs/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
  121. package/dist/cjs/react/web/wallets/shared/PassKeyLogin.js +1 -1
  122. package/dist/cjs/react/web/wallets/shared/PassKeyLogin.js.map +1 -1
  123. package/dist/cjs/react/web/wallets/shared/SocialLogin.js +1 -1
  124. package/dist/cjs/react/web/wallets/shared/SocialLogin.js.map +1 -1
  125. package/dist/cjs/version.js +1 -1
  126. package/dist/cjs/version.js.map +1 -1
  127. package/dist/cjs/wallets/in-app/native/native-connector.js +3 -4
  128. package/dist/cjs/wallets/in-app/native/native-connector.js.map +1 -1
  129. package/dist/cjs/wallets/manager/index.js +3 -2
  130. package/dist/cjs/wallets/manager/index.js.map +1 -1
  131. package/dist/esm/exports/react.js +4 -3
  132. package/dist/esm/exports/react.js.map +1 -1
  133. package/dist/esm/exports/react.native.js +6 -2
  134. package/dist/esm/exports/react.native.js.map +1 -1
  135. package/dist/esm/exports/wallets/in-app.js +1 -1
  136. package/dist/esm/exports/wallets/in-app.js.map +1 -1
  137. package/dist/esm/pay/utils/definitions.js +15 -9
  138. package/dist/esm/pay/utils/definitions.js.map +1 -1
  139. package/dist/esm/react/core/hooks/connection/ConnectButtonProps.js.map +1 -0
  140. package/dist/esm/react/core/hooks/connection/ConnectEmbedProps.js +2 -0
  141. package/dist/esm/react/core/hooks/connection/ConnectEmbedProps.js.map +1 -0
  142. package/dist/esm/react/core/hooks/transaction/useSendTransaction.js.map +1 -1
  143. package/dist/esm/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
  144. package/dist/esm/react/core/hooks/wallets/useSendToken.js +78 -0
  145. package/dist/esm/react/core/hooks/wallets/useSendToken.js.map +1 -0
  146. package/dist/esm/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.js +10 -15
  147. package/dist/esm/react/core/utils/defaultTokens.js.map +1 -0
  148. package/dist/esm/react/core/utils/isSmartWallet.js.map +1 -0
  149. package/dist/esm/react/{web/ui/ConnectWallet/icons/dataUris.js → core/utils/socialIcons.js} +18 -1
  150. package/dist/esm/react/core/utils/socialIcons.js.map +1 -0
  151. package/dist/esm/react/core/utils/storage.js.map +1 -0
  152. package/dist/esm/react/core/utils/wallet.js +80 -0
  153. package/dist/esm/react/core/utils/wallet.js.map +1 -0
  154. package/dist/esm/react/native/design-system/index.js +30 -0
  155. package/dist/esm/react/native/design-system/index.js.map +1 -0
  156. package/dist/esm/react/native/hooks/wallets/useAutoConnect.js +5 -1
  157. package/dist/esm/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
  158. package/dist/esm/react/native/hooks/wallets/useSendToken.js +28 -0
  159. package/dist/esm/react/native/hooks/wallets/useSendToken.js.map +1 -0
  160. package/dist/esm/react/native/ui/components/Address.js +27 -0
  161. package/dist/esm/react/native/ui/components/Address.js.map +1 -0
  162. package/dist/esm/react/native/ui/components/ChainIcon.js +26 -0
  163. package/dist/esm/react/native/ui/components/ChainIcon.js.map +1 -0
  164. package/dist/esm/react/native/ui/components/Header.js +27 -0
  165. package/dist/esm/react/native/ui/components/Header.js.map +1 -0
  166. package/dist/esm/react/native/ui/components/RNImage.js +39 -0
  167. package/dist/esm/react/native/ui/components/RNImage.js.map +1 -0
  168. package/dist/esm/react/native/ui/components/Skeleton.js +58 -0
  169. package/dist/esm/react/native/ui/components/Skeleton.js.map +1 -0
  170. package/dist/esm/react/native/ui/components/TokenIcon.js +13 -0
  171. package/dist/esm/react/native/ui/components/TokenIcon.js.map +1 -0
  172. package/dist/esm/react/native/ui/components/WalletImage.js +65 -0
  173. package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -0
  174. package/dist/esm/react/native/ui/components/button.js +24 -10
  175. package/dist/esm/react/native/ui/components/button.js.map +1 -1
  176. package/dist/esm/react/native/ui/components/input.js +60 -0
  177. package/dist/esm/react/native/ui/components/input.js.map +1 -0
  178. package/dist/esm/react/native/ui/components/spacer.js +7 -0
  179. package/dist/esm/react/native/ui/components/spacer.js.map +1 -0
  180. package/dist/esm/react/native/ui/components/text.js +10 -7
  181. package/dist/esm/react/native/ui/components/text.js.map +1 -1
  182. package/dist/esm/react/native/ui/connect/ConnectButton.js +103 -0
  183. package/dist/esm/react/native/ui/connect/ConnectButton.js.map +1 -0
  184. package/dist/esm/react/native/ui/connect/ConnectModal.js +126 -0
  185. package/dist/esm/react/native/ui/connect/ConnectModal.js.map +1 -0
  186. package/dist/esm/react/native/ui/connect/ConnectedButton.js +39 -0
  187. package/dist/esm/react/native/ui/connect/ConnectedButton.js.map +1 -0
  188. package/dist/esm/react/native/ui/connect/ConnectedModal.js +172 -0
  189. package/dist/esm/react/native/ui/connect/ConnectedModal.js.map +1 -0
  190. package/dist/esm/react/native/ui/connect/ErrorView.js +21 -0
  191. package/dist/esm/react/native/ui/connect/ErrorView.js.map +1 -0
  192. package/dist/esm/react/native/ui/connect/ExternalWalletsList.js +64 -0
  193. package/dist/esm/react/native/ui/connect/ExternalWalletsList.js.map +1 -0
  194. package/dist/esm/react/native/ui/connect/InAppWalletUI.js +163 -0
  195. package/dist/esm/react/native/ui/connect/InAppWalletUI.js.map +1 -0
  196. package/dist/esm/react/native/ui/connect/ReceiveScreen.js +38 -0
  197. package/dist/esm/react/native/ui/connect/ReceiveScreen.js.map +1 -0
  198. package/dist/esm/react/native/ui/connect/SendScreen.js +78 -0
  199. package/dist/esm/react/native/ui/connect/SendScreen.js.map +1 -0
  200. package/dist/esm/react/native/ui/connect/SuccessView.js +21 -0
  201. package/dist/esm/react/native/ui/connect/SuccessView.js.map +1 -0
  202. package/dist/esm/react/native/ui/connect/TokenListScreen.js +54 -0
  203. package/dist/esm/react/native/ui/connect/TokenListScreen.js.map +1 -0
  204. package/dist/esm/react/native/ui/icons/svgs.js +233 -0
  205. package/dist/esm/react/native/ui/icons/svgs.js.map +1 -0
  206. package/dist/esm/react/native/ui/{TransactionButton/TrabsactionButton.js → transaction/TransactionButton.js} +1 -1
  207. package/dist/esm/react/native/ui/transaction/TransactionButton.js.map +1 -0
  208. package/dist/esm/react/native/wallets/defaultWallets.js +19 -0
  209. package/dist/esm/react/native/wallets/defaultWallets.js.map +1 -0
  210. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  211. package/dist/esm/react/web/hooks/wallets/useAutoConnect.js +7 -2
  212. package/dist/esm/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
  213. package/dist/esm/react/web/hooks/wallets/useSendToken.js +28 -0
  214. package/dist/esm/react/web/hooks/wallets/useSendToken.js.map +1 -0
  215. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js +1 -1
  216. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  217. package/dist/esm/react/web/ui/ConnectWallet/Details.js +7 -51
  218. package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
  219. package/dist/esm/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.js +1 -1
  220. package/dist/esm/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.js.map +1 -1
  221. package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +1 -5
  222. package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
  223. package/dist/esm/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.js +1 -1
  224. package/dist/esm/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.js.map +1 -1
  225. package/dist/esm/react/web/ui/ConnectWallet/WalletEntryButton.js +1 -1
  226. package/dist/esm/react/web/ui/ConnectWallet/WalletEntryButton.js.map +1 -1
  227. package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js +1 -1
  228. package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
  229. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  230. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatSteps.js.map +1 -1
  231. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.js.map +1 -1
  232. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.js.map +1 -1
  233. package/dist/esm/react/web/ui/ConnectWallet/screens/SendFunds.js +5 -16
  234. package/dist/esm/react/web/ui/ConnectWallet/screens/SendFunds.js.map +1 -1
  235. package/dist/esm/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
  236. package/dist/esm/react/web/ui/ConnectWallet/screens/TokenSelector.js.map +1 -1
  237. package/dist/esm/react/web/ui/ConnectWallet/screens/ViewFunds.js +1 -1
  238. package/dist/esm/react/web/ui/ConnectWallet/screens/ViewFunds.js.map +1 -1
  239. package/dist/esm/react/web/ui/PayEmbed.js.map +1 -1
  240. package/dist/esm/react/web/ui/components/ChainIcon.js.map +1 -1
  241. package/dist/esm/react/web/ui/components/TokenIcon.js +1 -1
  242. package/dist/esm/react/web/ui/components/WalletImage.js +3 -4
  243. package/dist/esm/react/web/ui/components/WalletImage.js.map +1 -1
  244. package/dist/esm/react/web/wallets/ecosystem/EcosystemWalletHeader.js +1 -1
  245. package/dist/esm/react/web/wallets/ecosystem/EcosystemWalletHeader.js.map +1 -1
  246. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +2 -3
  247. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  248. package/dist/esm/react/web/wallets/shared/OTPLoginUI.js +1 -1
  249. package/dist/esm/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
  250. package/dist/esm/react/web/wallets/shared/PassKeyLogin.js +1 -1
  251. package/dist/esm/react/web/wallets/shared/PassKeyLogin.js.map +1 -1
  252. package/dist/esm/react/web/wallets/shared/SocialLogin.js +1 -1
  253. package/dist/esm/react/web/wallets/shared/SocialLogin.js.map +1 -1
  254. package/dist/esm/version.js +1 -1
  255. package/dist/esm/version.js.map +1 -1
  256. package/dist/esm/wallets/in-app/native/native-connector.js +3 -4
  257. package/dist/esm/wallets/in-app/native/native-connector.js.map +1 -1
  258. package/dist/esm/wallets/manager/index.js +3 -2
  259. package/dist/esm/wallets/manager/index.js.map +1 -1
  260. package/dist/types/exports/react.d.ts +7 -6
  261. package/dist/types/exports/react.d.ts.map +1 -1
  262. package/dist/types/exports/react.native.d.ts +7 -2
  263. package/dist/types/exports/react.native.d.ts.map +1 -1
  264. package/dist/types/exports/wallets/in-app.d.ts +1 -1
  265. package/dist/types/exports/wallets/in-app.d.ts.map +1 -1
  266. package/dist/types/pay/utils/definitions.d.ts +1 -0
  267. package/dist/types/pay/utils/definitions.d.ts.map +1 -1
  268. package/dist/types/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.d.ts +6 -6
  269. package/dist/types/react/core/hooks/connection/ConnectButtonProps.d.ts.map +1 -0
  270. package/dist/types/react/core/hooks/connection/ConnectEmbedProps.d.ts +264 -0
  271. package/dist/types/react/core/hooks/connection/ConnectEmbedProps.d.ts.map +1 -0
  272. package/dist/types/react/core/hooks/connection/types.d.ts +1 -1
  273. package/dist/types/react/core/hooks/connection/types.d.ts.map +1 -1
  274. package/dist/types/react/core/hooks/transaction/useSendTransaction.d.ts +1 -1
  275. package/dist/types/react/core/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  276. package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts +3 -1
  277. package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  278. package/dist/types/react/core/hooks/wallets/useSendToken.d.ts +12 -0
  279. package/dist/types/react/core/hooks/wallets/useSendToken.d.ts.map +1 -0
  280. package/dist/types/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.d.ts +1 -0
  281. package/dist/types/react/core/utils/defaultTokens.d.ts.map +1 -0
  282. package/dist/types/react/core/utils/isSmartWallet.d.ts.map +1 -0
  283. package/dist/types/react/{web/ui/ConnectWallet/icons/dataUris.d.ts → core/utils/socialIcons.d.ts} +17 -1
  284. package/dist/types/react/core/utils/socialIcons.d.ts.map +1 -0
  285. package/dist/types/react/core/utils/storage.d.ts +5 -0
  286. package/dist/types/react/core/utils/storage.d.ts.map +1 -0
  287. package/dist/types/react/core/utils/wallet.d.ts +26 -0
  288. package/dist/types/react/core/utils/wallet.d.ts.map +1 -0
  289. package/dist/types/react/native/design-system/index.d.ts +30 -0
  290. package/dist/types/react/native/design-system/index.d.ts.map +1 -0
  291. package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  292. package/dist/types/react/{web/ui/hooks → native/hooks/wallets}/useSendToken.d.ts +18 -1
  293. package/dist/types/react/native/hooks/wallets/useSendToken.d.ts.map +1 -0
  294. package/dist/types/react/native/ui/components/Address.d.ts +9 -0
  295. package/dist/types/react/native/ui/components/Address.d.ts.map +1 -0
  296. package/dist/types/react/native/ui/components/ChainIcon.d.ts +11 -0
  297. package/dist/types/react/native/ui/components/ChainIcon.d.ts.map +1 -0
  298. package/dist/types/react/native/ui/components/Header.d.ts +10 -0
  299. package/dist/types/react/native/ui/components/Header.d.ts.map +1 -0
  300. package/dist/types/react/native/ui/components/RNImage.d.ts +10 -0
  301. package/dist/types/react/native/ui/components/RNImage.d.ts.map +1 -0
  302. package/dist/types/react/native/ui/components/Skeleton.d.ts +11 -0
  303. package/dist/types/react/native/ui/components/Skeleton.d.ts.map +1 -0
  304. package/dist/types/react/native/ui/components/TokenIcon.d.ts +15 -0
  305. package/dist/types/react/native/ui/components/TokenIcon.d.ts.map +1 -0
  306. package/dist/types/react/native/ui/components/WalletImage.d.ts +9 -0
  307. package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -0
  308. package/dist/types/react/native/ui/components/button.d.ts +5 -1
  309. package/dist/types/react/native/ui/components/button.d.ts.map +1 -1
  310. package/dist/types/react/native/ui/components/input.d.ts +12 -0
  311. package/dist/types/react/native/ui/components/input.d.ts.map +1 -0
  312. package/dist/types/react/native/ui/components/spacer.d.ts +5 -0
  313. package/dist/types/react/native/ui/components/spacer.d.ts.map +1 -0
  314. package/dist/types/react/native/ui/components/text.d.ts +1 -1
  315. package/dist/types/react/native/ui/components/text.d.ts.map +1 -1
  316. package/dist/types/react/native/ui/connect/ConnectButton.d.ts +18 -0
  317. package/dist/types/react/native/ui/connect/ConnectButton.d.ts.map +1 -0
  318. package/dist/types/react/native/ui/connect/ConnectModal.d.ts +40 -0
  319. package/dist/types/react/native/ui/connect/ConnectModal.d.ts.map +1 -0
  320. package/dist/types/react/native/ui/connect/ConnectedButton.d.ts +9 -0
  321. package/dist/types/react/native/ui/connect/ConnectedButton.d.ts.map +1 -0
  322. package/dist/types/react/native/ui/connect/ConnectedModal.d.ts +14 -0
  323. package/dist/types/react/native/ui/connect/ConnectedModal.d.ts.map +1 -0
  324. package/dist/types/react/native/ui/connect/ErrorView.d.ts +7 -0
  325. package/dist/types/react/native/ui/connect/ErrorView.d.ts.map +1 -0
  326. package/dist/types/react/native/ui/connect/ExternalWalletsList.d.ts +15 -0
  327. package/dist/types/react/native/ui/connect/ExternalWalletsList.d.ts.map +1 -0
  328. package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts +19 -0
  329. package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts.map +1 -0
  330. package/dist/types/react/native/ui/connect/ReceiveScreen.d.ts +13 -0
  331. package/dist/types/react/native/ui/connect/ReceiveScreen.d.ts.map +1 -0
  332. package/dist/types/react/native/ui/connect/SendScreen.d.ts +14 -0
  333. package/dist/types/react/native/ui/connect/SendScreen.d.ts.map +1 -0
  334. package/dist/types/react/native/ui/connect/SuccessView.d.ts +7 -0
  335. package/dist/types/react/native/ui/connect/SuccessView.d.ts.map +1 -0
  336. package/dist/types/react/native/ui/connect/TokenListScreen.d.ts +20 -0
  337. package/dist/types/react/native/ui/connect/TokenListScreen.d.ts.map +1 -0
  338. package/dist/types/react/native/ui/icons/svgs.d.ts +22 -0
  339. package/dist/types/react/native/ui/icons/svgs.d.ts.map +1 -0
  340. package/dist/types/react/native/ui/{TransactionButton/TrabsactionButton.d.ts → transaction/TransactionButton.d.ts} +1 -1
  341. package/dist/types/react/native/ui/transaction/TransactionButton.d.ts.map +1 -0
  342. package/dist/types/react/native/wallets/defaultWallets.d.ts +11 -0
  343. package/dist/types/react/native/wallets/defaultWallets.d.ts.map +1 -0
  344. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  345. package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  346. package/dist/types/react/web/hooks/wallets/useSendToken.d.ts +28 -0
  347. package/dist/types/react/web/hooks/wallets/useSendToken.d.ts.map +1 -0
  348. package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts +1 -1
  349. package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts.map +1 -1
  350. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts +2 -2
  351. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
  352. package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts +1 -267
  353. package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts.map +1 -1
  354. package/dist/types/react/web/ui/ConnectWallet/WalletEntryButton.d.ts.map +1 -1
  355. package/dist/types/react/web/ui/ConnectWallet/WalletSelector.d.ts.map +1 -1
  356. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.d.ts +2 -2
  357. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.d.ts.map +1 -1
  358. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useEnabledPaymentMethods.d.ts +1 -1
  359. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useEnabledPaymentMethods.d.ts.map +1 -1
  360. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.d.ts +1 -1
  361. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.d.ts.map +1 -1
  362. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.d.ts +1 -1
  363. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.d.ts.map +1 -1
  364. package/dist/types/react/web/ui/ConnectWallet/screens/SendFunds.d.ts +1 -1
  365. package/dist/types/react/web/ui/ConnectWallet/screens/SendFunds.d.ts.map +1 -1
  366. package/dist/types/react/web/ui/ConnectWallet/screens/SignatureScreen.d.ts +1 -1
  367. package/dist/types/react/web/ui/ConnectWallet/screens/SignatureScreen.d.ts.map +1 -1
  368. package/dist/types/react/web/ui/ConnectWallet/screens/TokenSelector.d.ts +1 -1
  369. package/dist/types/react/web/ui/ConnectWallet/screens/TokenSelector.d.ts.map +1 -1
  370. package/dist/types/react/web/ui/ConnectWallet/screens/ViewFunds.d.ts +1 -1
  371. package/dist/types/react/web/ui/ConnectWallet/screens/ViewFunds.d.ts.map +1 -1
  372. package/dist/types/react/web/ui/ConnectWallet/screens/nativeToken.d.ts +1 -1
  373. package/dist/types/react/web/ui/ConnectWallet/screens/nativeToken.d.ts.map +1 -1
  374. package/dist/types/react/web/ui/PayEmbed.d.ts +2 -2
  375. package/dist/types/react/web/ui/PayEmbed.d.ts.map +1 -1
  376. package/dist/types/react/web/ui/components/ChainIcon.d.ts.map +1 -1
  377. package/dist/types/react/web/ui/components/WalletImage.d.ts.map +1 -1
  378. package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
  379. package/dist/types/react/web/wallets/shared/OTPLoginUI.d.ts.map +1 -1
  380. package/dist/types/react/web/wallets/shared/SocialLogin.d.ts.map +1 -1
  381. package/dist/types/version.d.ts +1 -1
  382. package/dist/types/version.d.ts.map +1 -1
  383. package/dist/types/wallets/in-app/native/native-connector.d.ts.map +1 -1
  384. package/dist/types/wallets/manager/index.d.ts +1 -0
  385. package/dist/types/wallets/manager/index.d.ts.map +1 -1
  386. package/package.json +19 -3
  387. package/src/exports/react.native.ts +19 -5
  388. package/src/exports/react.ts +7 -12
  389. package/src/exports/wallets/in-app.ts +1 -1
  390. package/src/pay/utils/definitions.ts +16 -9
  391. package/src/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.ts +7 -10
  392. package/src/react/core/hooks/connection/ConnectEmbedProps.ts +285 -0
  393. package/src/react/core/hooks/connection/types.ts +1 -1
  394. package/src/react/core/hooks/transaction/useSendTransaction.ts +1 -1
  395. package/src/react/core/hooks/wallets/useAutoConnect.ts +1 -1
  396. package/src/react/core/hooks/wallets/useSendToken.ts +94 -0
  397. package/src/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.ts +10 -15
  398. package/src/react/{web/ui/ConnectWallet/icons/dataUris.ts → core/utils/socialIcons.ts} +30 -0
  399. package/src/react/{web/wallets/shared → core/utils}/storage.ts +2 -2
  400. package/src/react/core/utils/wallet.ts +101 -0
  401. package/src/react/native/design-system/index.ts +31 -0
  402. package/src/react/native/hooks/wallets/useAutoConnect.ts +5 -1
  403. package/src/react/native/hooks/wallets/useSendToken.ts +29 -0
  404. package/src/react/native/ui/components/Address.tsx +52 -0
  405. package/src/react/native/ui/components/ChainIcon.tsx +42 -0
  406. package/src/react/native/ui/components/Header.tsx +84 -0
  407. package/src/react/native/ui/components/RNImage.tsx +71 -0
  408. package/src/react/native/ui/components/Skeleton.tsx +93 -0
  409. package/src/react/native/ui/components/TokenIcon.tsx +31 -0
  410. package/src/react/native/ui/components/WalletImage.tsx +81 -0
  411. package/src/react/native/ui/components/button.tsx +41 -9
  412. package/src/react/native/ui/components/input.tsx +128 -0
  413. package/src/react/native/ui/components/spacer.tsx +6 -0
  414. package/src/react/native/ui/components/text.tsx +17 -8
  415. package/src/react/native/ui/connect/ConnectButton.tsx +188 -0
  416. package/src/react/native/ui/connect/ConnectModal.tsx +298 -0
  417. package/src/react/native/ui/connect/ConnectedButton.tsx +94 -0
  418. package/src/react/native/ui/connect/ConnectedModal.tsx +434 -0
  419. package/src/react/native/ui/connect/ErrorView.tsx +44 -0
  420. package/src/react/native/ui/connect/ExternalWalletsList.tsx +162 -0
  421. package/src/react/native/ui/connect/InAppWalletUI.tsx +320 -0
  422. package/src/react/native/ui/connect/ReceiveScreen.tsx +81 -0
  423. package/src/react/native/ui/connect/SendScreen.tsx +238 -0
  424. package/src/react/native/ui/connect/SuccessView.tsx +44 -0
  425. package/src/react/native/ui/connect/TokenListScreen.tsx +147 -0
  426. package/src/react/native/ui/icons/svgs.ts +252 -0
  427. package/src/react/native/wallets/defaultWallets.ts +30 -0
  428. package/src/react/web/hooks/transaction/useSendTransaction.tsx +2 -2
  429. package/src/react/web/hooks/wallets/useAutoConnect.ts +18 -8
  430. package/src/react/web/hooks/wallets/useSendToken.ts +29 -0
  431. package/src/react/web/ui/ConnectWallet/ConnectButton.tsx +2 -2
  432. package/src/react/web/ui/ConnectWallet/Details.tsx +26 -78
  433. package/src/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.tsx +1 -1
  434. package/src/react/web/ui/ConnectWallet/Modal/ConnectEmbed.tsx +6 -285
  435. package/src/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.tsx +1 -1
  436. package/src/react/web/ui/ConnectWallet/WalletEntryButton.tsx +1 -1
  437. package/src/react/web/ui/ConnectWallet/WalletSelector.tsx +1 -1
  438. package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +2 -2
  439. package/src/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatSteps.tsx +1 -1
  440. package/src/react/web/ui/ConnectWallet/screens/Buy/main/useEnabledPaymentMethods.ts +1 -1
  441. package/src/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.ts +1 -1
  442. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.tsx +1 -1
  443. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/SwapFlow.tsx +1 -1
  444. package/src/react/web/ui/ConnectWallet/screens/SendFunds.tsx +8 -21
  445. package/src/react/web/ui/ConnectWallet/screens/SignatureScreen.tsx +1 -1
  446. package/src/react/web/ui/ConnectWallet/screens/TokenSelector.tsx +1 -1
  447. package/src/react/web/ui/ConnectWallet/screens/ViewFunds.tsx +4 -1
  448. package/src/react/web/ui/ConnectWallet/screens/nativeToken.ts +1 -1
  449. package/src/react/web/ui/PayEmbed.tsx +3 -3
  450. package/src/react/web/ui/components/ChainIcon.tsx +0 -1
  451. package/src/react/web/ui/components/TokenIcon.tsx +1 -1
  452. package/src/react/web/ui/components/WalletImage.tsx +7 -9
  453. package/src/react/web/wallets/ecosystem/EcosystemWalletHeader.tsx +1 -1
  454. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +6 -6
  455. package/src/react/web/wallets/shared/OTPLoginUI.tsx +1 -1
  456. package/src/react/web/wallets/shared/PassKeyLogin.tsx +1 -1
  457. package/src/react/web/wallets/shared/SocialLogin.tsx +1 -1
  458. package/src/version.ts +1 -1
  459. package/src/wallets/in-app/native/native-connector.ts +4 -6
  460. package/src/wallets/manager/index.ts +4 -2
  461. package/dist/cjs/react/native/ui/TransactionButton/TrabsactionButton.js.map +0 -1
  462. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButtonProps.js.map +0 -1
  463. package/dist/cjs/react/web/ui/ConnectWallet/defaultTokens.js.map +0 -1
  464. package/dist/cjs/react/web/ui/ConnectWallet/icons/dataUris.js.map +0 -1
  465. package/dist/cjs/react/web/ui/ConnectWallet/icons/socialLogins.js +0 -15
  466. package/dist/cjs/react/web/ui/ConnectWallet/icons/socialLogins.js.map +0 -1
  467. package/dist/cjs/react/web/ui/hooks/useSendToken.js +0 -57
  468. package/dist/cjs/react/web/ui/hooks/useSendToken.js.map +0 -1
  469. package/dist/cjs/react/web/ui/hooks/useWalletInfo.js +0 -37
  470. package/dist/cjs/react/web/ui/hooks/useWalletInfo.js.map +0 -1
  471. package/dist/cjs/react/web/utils/isSmartWallet.js.map +0 -1
  472. package/dist/cjs/react/web/wallets/in-app/socialIcons.js +0 -10
  473. package/dist/cjs/react/web/wallets/in-app/socialIcons.js.map +0 -1
  474. package/dist/cjs/react/web/wallets/shared/storage.js.map +0 -1
  475. package/dist/esm/react/native/ui/TransactionButton/TrabsactionButton.js.map +0 -1
  476. package/dist/esm/react/web/ui/ConnectWallet/ConnectButtonProps.js.map +0 -1
  477. package/dist/esm/react/web/ui/ConnectWallet/defaultTokens.js.map +0 -1
  478. package/dist/esm/react/web/ui/ConnectWallet/icons/dataUris.js.map +0 -1
  479. package/dist/esm/react/web/ui/ConnectWallet/icons/socialLogins.js +0 -12
  480. package/dist/esm/react/web/ui/ConnectWallet/icons/socialLogins.js.map +0 -1
  481. package/dist/esm/react/web/ui/hooks/useSendToken.js +0 -54
  482. package/dist/esm/react/web/ui/hooks/useSendToken.js.map +0 -1
  483. package/dist/esm/react/web/ui/hooks/useWalletInfo.js +0 -33
  484. package/dist/esm/react/web/ui/hooks/useWalletInfo.js.map +0 -1
  485. package/dist/esm/react/web/utils/isSmartWallet.js.map +0 -1
  486. package/dist/esm/react/web/wallets/in-app/socialIcons.js +0 -7
  487. package/dist/esm/react/web/wallets/in-app/socialIcons.js.map +0 -1
  488. package/dist/esm/react/web/wallets/shared/storage.js.map +0 -1
  489. package/dist/types/react/native/ui/TransactionButton/TrabsactionButton.d.ts.map +0 -1
  490. package/dist/types/react/web/ui/ConnectWallet/ConnectButtonProps.d.ts.map +0 -1
  491. package/dist/types/react/web/ui/ConnectWallet/defaultTokens.d.ts.map +0 -1
  492. package/dist/types/react/web/ui/ConnectWallet/icons/dataUris.d.ts.map +0 -1
  493. package/dist/types/react/web/ui/ConnectWallet/icons/socialLogins.d.ts +0 -12
  494. package/dist/types/react/web/ui/ConnectWallet/icons/socialLogins.d.ts.map +0 -1
  495. package/dist/types/react/web/ui/hooks/useSendToken.d.ts.map +0 -1
  496. package/dist/types/react/web/ui/hooks/useWalletInfo.d.ts +0 -13
  497. package/dist/types/react/web/ui/hooks/useWalletInfo.d.ts.map +0 -1
  498. package/dist/types/react/web/utils/isSmartWallet.d.ts.map +0 -1
  499. package/dist/types/react/web/wallets/in-app/socialIcons.d.ts +0 -6
  500. package/dist/types/react/web/wallets/in-app/socialIcons.d.ts.map +0 -1
  501. package/dist/types/react/web/wallets/shared/storage.d.ts +0 -5
  502. package/dist/types/react/web/wallets/shared/storage.d.ts.map +0 -1
  503. package/src/react/web/ui/ConnectWallet/icons/socialLogins.ts +0 -22
  504. package/src/react/web/ui/hooks/useSendToken.ts +0 -66
  505. package/src/react/web/ui/hooks/useWalletInfo.ts +0 -37
  506. package/src/react/web/wallets/in-app/socialIcons.ts +0 -11
  507. /package/dist/cjs/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.js +0 -0
  508. /package/dist/cjs/react/{web → core}/utils/isSmartWallet.js +0 -0
  509. /package/dist/cjs/react/{web/wallets/shared → core/utils}/storage.js +0 -0
  510. /package/dist/esm/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.js +0 -0
  511. /package/dist/esm/react/{web → core}/utils/isSmartWallet.js +0 -0
  512. /package/dist/esm/react/{web/wallets/shared → core/utils}/storage.js +0 -0
  513. /package/dist/types/react/{web → core}/utils/isSmartWallet.d.ts +0 -0
  514. /package/src/react/{web → core}/utils/isSmartWallet.ts +0 -0
  515. /package/src/react/native/ui/{TransactionButton/TrabsactionButton.tsx → transaction/TransactionButton.tsx} +0 -0
@@ -2,6 +2,7 @@ import { nativeLocalStorage } from "../../../../utils/storage/nativeStorage.js";
2
2
  import type { AutoConnectProps } from "../../../core/hooks/connection/types.js";
3
3
  import { useAutoConnectCore } from "../../../core/hooks/wallets/useAutoConnect.js";
4
4
  import { connectionManager } from "../../index.js";
5
+ import { getDefaultWallets } from "../../wallets/defaultWallets.js";
5
6
 
6
7
  /**
7
8
  * Autoconnect the last previously connected wallet.
@@ -23,5 +24,8 @@ import { connectionManager } from "../../index.js";
23
24
  * @returns whether the auto connect was successful.
24
25
  */
25
26
  export function useAutoConnect(props: AutoConnectProps) {
26
- return useAutoConnectCore(connectionManager, nativeLocalStorage, props);
27
+ return useAutoConnectCore(connectionManager, nativeLocalStorage, {
28
+ ...props,
29
+ wallets: props.wallets || getDefaultWallets(props),
30
+ });
27
31
  }
@@ -0,0 +1,29 @@
1
+ import type { ThirdwebClient } from "../../../../client/client.js";
2
+ import { useSendTokenCore } from "../../../core/hooks/wallets/useSendToken.js";
3
+ import { useActiveWallet } from "./useActiveWallet.js";
4
+
5
+ /**
6
+ * Send Native or ERC20 tokens from active wallet to given address.
7
+ * @example
8
+ * ```tsx
9
+ * const { mutate: sendToken } = useSendToken(client);
10
+ *
11
+ * // send native currency
12
+ * sendToken({
13
+ * receiverAddress: "0x...",
14
+ * amount: "0.1",
15
+ * });
16
+ *
17
+ * // send ERC20
18
+ * sendToken({
19
+ * tokenAddress,
20
+ * receiverAddress: "0x...",
21
+ * amount: "0.5",
22
+ * });
23
+ * ```
24
+ * @wallet
25
+ */
26
+ export function useSendToken(client: ThirdwebClient) {
27
+ const wallet = useActiveWallet();
28
+ return useSendTokenCore(client, wallet);
29
+ }
@@ -0,0 +1,52 @@
1
+ import Clipboard from "@react-native-clipboard/clipboard";
2
+ import { useState } from "react";
3
+ import { StyleSheet, TouchableOpacity } from "react-native";
4
+ import type { Account } from "../../../../wallets/interfaces/wallet.js";
5
+ import type { Theme } from "../../../core/design-system/index.js";
6
+ import { spacing } from "../../design-system/index.js";
7
+ import { CHECK, COPY_ICON } from "../icons/svgs.js";
8
+ import { RNImage } from "./RNImage.js";
9
+ import { ThemedText } from "./text.js";
10
+
11
+ export type AddressProps = {
12
+ account: Account;
13
+ theme: Theme;
14
+ addressOrENS: string;
15
+ };
16
+
17
+ export const Address = ({ account, theme, addressOrENS }: AddressProps) => {
18
+ const [copySuccess, setCopySuccess] = useState(false);
19
+ return (
20
+ <TouchableOpacity
21
+ style={styles.addressContainer}
22
+ onPress={() => {
23
+ // @ts-ignore - missing native types
24
+ Clipboard.setString(account.address);
25
+ setCopySuccess(true);
26
+ setTimeout(() => {
27
+ setCopySuccess(false);
28
+ }, 2500);
29
+ }}
30
+ >
31
+ <ThemedText theme={theme} type="defaultSemiBold">
32
+ {addressOrENS}
33
+ </ThemedText>
34
+ <RNImage
35
+ theme={theme}
36
+ data={copySuccess ? CHECK : COPY_ICON}
37
+ size={15}
38
+ color={
39
+ copySuccess ? theme.colors.success : theme.colors.secondaryIconColor
40
+ }
41
+ />
42
+ </TouchableOpacity>
43
+ );
44
+ };
45
+
46
+ const styles = StyleSheet.create({
47
+ addressContainer: {
48
+ flexDirection: "row",
49
+ gap: spacing.sm,
50
+ alignItems: "center",
51
+ },
52
+ });
@@ -0,0 +1,42 @@
1
+ import { useMemo } from "react";
2
+ import type { Chain } from "../../../../chains/types.js";
3
+ import type { ThirdwebClient } from "../../../../client/client.js";
4
+ import { resolveScheme } from "../../../../utils/ipfs.js";
5
+ import type { Theme } from "../../../core/design-system/index.js";
6
+ import { useChainQuery } from "../../../core/hooks/others/useChainQuery.js";
7
+ import { CHAIN_ICON } from "../icons/svgs.js";
8
+ import { RNImage } from "./RNImage.js";
9
+
10
+ export type ChainIconProps = {
11
+ theme: Theme;
12
+ size: number;
13
+ client: ThirdwebClient;
14
+ chain?: Chain;
15
+ };
16
+
17
+ export const ChainIcon = (props: ChainIconProps) => {
18
+ const chainQuery = useChainQuery(props.chain);
19
+ const data = useMemo(() => {
20
+ const url = chainQuery?.data?.icon?.url;
21
+ if (!url) {
22
+ return CHAIN_ICON;
23
+ }
24
+ try {
25
+ return resolveScheme({
26
+ uri: url,
27
+ client: props.client,
28
+ });
29
+ } catch {
30
+ return CHAIN_ICON;
31
+ }
32
+ }, [props, chainQuery?.data?.icon?.url]);
33
+ return (
34
+ <RNImage
35
+ theme={props.theme}
36
+ size={props.size}
37
+ data={data}
38
+ placeholder={CHAIN_ICON}
39
+ color={props.theme.colors.secondaryIconColor}
40
+ />
41
+ );
42
+ };
@@ -0,0 +1,84 @@
1
+ import { StyleSheet, TouchableOpacity, View } from "react-native";
2
+ import type { Theme } from "../../../core/design-system/index.js";
3
+ import { spacing } from "../../design-system/index.js";
4
+ import { BACK_ICON, CLOSE_ICON } from "../icons/svgs.js";
5
+ import { RNImage } from "./RNImage.js";
6
+ import { ThemedText } from "./text.js";
7
+
8
+ export type ContainerType = "modal" | "embed";
9
+
10
+ export function Header({
11
+ theme,
12
+ title,
13
+ onClose,
14
+ onBack,
15
+ containerType,
16
+ }: {
17
+ theme: Theme;
18
+ title?: string;
19
+ onClose?: () => void;
20
+ onBack?: () => void;
21
+ containerType: ContainerType;
22
+ }) {
23
+ if (containerType === "embed") {
24
+ return onBack ? (
25
+ <TouchableOpacity
26
+ onPress={onBack}
27
+ style={{
28
+ flexDirection: "row",
29
+ gap: spacing.sm,
30
+ alignItems: "center",
31
+ paddingTop: spacing.lg,
32
+ }}
33
+ >
34
+ <RNImage
35
+ theme={theme}
36
+ data={BACK_ICON}
37
+ size={14}
38
+ color={theme.colors.secondaryIconColor}
39
+ />
40
+ <ThemedText theme={theme} type="subtext">
41
+ Back
42
+ </ThemedText>
43
+ </TouchableOpacity>
44
+ ) : null;
45
+ }
46
+
47
+ return (
48
+ <View style={styles.headerModal}>
49
+ {onBack && (
50
+ <TouchableOpacity onPress={onBack}>
51
+ <RNImage
52
+ theme={theme}
53
+ data={BACK_ICON}
54
+ size={24}
55
+ color={theme.colors.secondaryIconColor}
56
+ />
57
+ </TouchableOpacity>
58
+ )}
59
+ <ThemedText theme={theme} type="title">
60
+ {title ? title : "Sign in"}
61
+ </ThemedText>
62
+ {onClose && (
63
+ <TouchableOpacity onPress={onClose}>
64
+ <RNImage
65
+ theme={theme}
66
+ data={CLOSE_ICON}
67
+ size={24}
68
+ color={theme.colors.secondaryIconColor}
69
+ />
70
+ </TouchableOpacity>
71
+ )}
72
+ </View>
73
+ );
74
+ }
75
+
76
+ const styles = StyleSheet.create({
77
+ headerModal: {
78
+ flexDirection: "row",
79
+ alignItems: "center",
80
+ justifyContent: "space-between",
81
+ paddingHorizontal: spacing.lg,
82
+ paddingTop: spacing.lg,
83
+ },
84
+ });
@@ -0,0 +1,71 @@
1
+ import { useMemo, useState } from "react";
2
+ import { Image } from "react-native";
3
+ import { SvgXml } from "react-native-svg";
4
+ import type { Theme } from "../../../core/design-system/index.js";
5
+ import { radius } from "../../design-system/index.js";
6
+ import { Skeleton } from "./Skeleton.js";
7
+
8
+ export type ImageInfo = {
9
+ size: number;
10
+ theme: Theme;
11
+ data?: string | null;
12
+ placeholder?: string;
13
+ color?: string;
14
+ };
15
+
16
+ function getImage(data: string): {
17
+ image: string;
18
+ type: "xml" | "image" | "url";
19
+ } {
20
+ if (data.startsWith("data:image/svg+xml;base64,")) {
21
+ const image = globalThis.atob(
22
+ data.replace("data:image/svg+xml;base64,", ""),
23
+ );
24
+ return { image, type: "xml" };
25
+ }
26
+ if (data.startsWith("data:image/")) {
27
+ return { image: data, type: "image" };
28
+ }
29
+ if (data.startsWith("<svg")) {
30
+ return { image: data, type: "xml" };
31
+ }
32
+ return { image: data, type: "url" };
33
+ }
34
+
35
+ export const RNImage = (props: ImageInfo) => {
36
+ const { data, size, color, placeholder } = props;
37
+ const [loading, setLoading] = useState(true);
38
+ if (!data) {
39
+ return null;
40
+ }
41
+ const { image, type } = useMemo(() => getImage(data), [data]);
42
+ switch (type) {
43
+ case "url":
44
+ case "image":
45
+ return (
46
+ <>
47
+ {loading && (
48
+ <Skeleton
49
+ theme={props.theme}
50
+ style={{ width: size, height: size }}
51
+ />
52
+ )}
53
+ <Image
54
+ source={{ uri: image }}
55
+ loadingIndicatorSource={{ uri: placeholder }}
56
+ width={size}
57
+ height={size}
58
+ onLoadStart={() => setLoading(true)}
59
+ onLoadEnd={() => setLoading(false)}
60
+ style={[
61
+ { borderRadius: radius.md, display: loading ? "none" : "flex" },
62
+ ]}
63
+ />
64
+ </>
65
+ );
66
+ case "xml":
67
+ return <SvgXml xml={image} width={size} height={size} color={color} />;
68
+ default:
69
+ return null;
70
+ }
71
+ };
@@ -0,0 +1,93 @@
1
+ import type React from "react";
2
+ import { useEffect, useRef } from "react";
3
+ import {
4
+ Animated,
5
+ Dimensions,
6
+ StyleSheet,
7
+ View,
8
+ type ViewStyle,
9
+ } from "react-native";
10
+ import type { Theme } from "../../../core/design-system/index.js";
11
+ import { radius } from "../../design-system/index.js";
12
+
13
+ const { width } = Dimensions.get("window");
14
+
15
+ interface SkeletonLoaderProps {
16
+ theme: Theme;
17
+ color?: string;
18
+ style?: ViewStyle;
19
+ }
20
+
21
+ export const Skeleton: React.FC<SkeletonLoaderProps> = ({
22
+ style,
23
+ color,
24
+ theme,
25
+ }) => {
26
+ const translateX = useRef(new Animated.Value(-width));
27
+
28
+ useEffect(() => {
29
+ const animation = Animated.loop(
30
+ Animated.sequence([
31
+ Animated.timing(translateX.current, {
32
+ toValue: width,
33
+ duration: 2500,
34
+ useNativeDriver: true,
35
+ }),
36
+ Animated.timing(translateX.current, {
37
+ toValue: -width,
38
+ duration: 0,
39
+ useNativeDriver: true,
40
+ }),
41
+ ]),
42
+ );
43
+ animation.start();
44
+
45
+ return () => animation.stop();
46
+ }, []);
47
+
48
+ return (
49
+ <View
50
+ style={[
51
+ styles.container,
52
+ { backgroundColor: color || theme.colors.borderColor },
53
+ style,
54
+ ]}
55
+ >
56
+ <View style={styles.skeleton} />
57
+ <Animated.View
58
+ style={[
59
+ styles.gradient,
60
+ {
61
+ transform: [{ translateX: translateX.current }],
62
+ },
63
+ ]}
64
+ >
65
+ <View style={styles.innerGradient} />
66
+ </Animated.View>
67
+ </View>
68
+ );
69
+ };
70
+
71
+ const styles = StyleSheet.create({
72
+ container: {
73
+ overflow: "hidden",
74
+ borderRadius: radius.lg,
75
+ },
76
+ skeleton: {
77
+ height: "100%",
78
+ width: "100%",
79
+ },
80
+ gradient: {
81
+ position: "absolute",
82
+ top: 0,
83
+ bottom: 0,
84
+ width: "100%",
85
+ },
86
+ innerGradient: {
87
+ width: "100%",
88
+ height: "100%",
89
+ backgroundColor: "rgba(255,255,255,0.5)",
90
+ opacity: 0.3,
91
+ transform: [{ skewX: "-20deg" }],
92
+ },
93
+ });
@@ -0,0 +1,31 @@
1
+ "use client";
2
+ import type { Chain } from "../../../../chains/types.js";
3
+ import type { ThirdwebClient } from "../../../../client/client.js";
4
+ import type { Theme } from "../../../core/design-system/index.js";
5
+ import type { TokenInfo } from "../../../core/utils/defaultTokens.js";
6
+ import { genericTokenIcon } from "../../../core/utils/socialIcons.js";
7
+ import { ChainIcon } from "./ChainIcon.js";
8
+ import { RNImage } from "./RNImage.js";
9
+
10
+ // Note: Must not use useConnectUI here
11
+
12
+ /**
13
+ * @internal
14
+ */
15
+ export function TokenIcon(props: {
16
+ theme: Theme;
17
+ size: number;
18
+ token?: TokenInfo;
19
+ chain?: Chain;
20
+ client: ThirdwebClient;
21
+ }) {
22
+ return props.token ? (
23
+ <RNImage
24
+ theme={props.theme}
25
+ data={props.token?.icon || genericTokenIcon}
26
+ size={props.size}
27
+ />
28
+ ) : (
29
+ <ChainIcon {...props} />
30
+ );
31
+ }
@@ -0,0 +1,81 @@
1
+ import { useQuery } from "@tanstack/react-query";
2
+ import { nativeLocalStorage } from "../../../../utils/storage/nativeStorage.js";
3
+ import { getWalletInfo } from "../../../../wallets/__generated__/getWalletInfo.js";
4
+ import type { Wallet } from "../../../../wallets/interfaces/wallet.js";
5
+ import { getStoredActiveWalletId } from "../../../../wallets/manager/index.js";
6
+ import type { Theme } from "../../../core/design-system/index.js";
7
+ import { getLastAuthProvider } from "../../../core/utils/storage.js";
8
+ import {
9
+ APPLE_ICON,
10
+ EMAIL_ICON,
11
+ FACEBOOK_ICON,
12
+ GOOGLE_ICON,
13
+ PHONE_ICON,
14
+ WALLET_ICON,
15
+ } from "../icons/svgs.js";
16
+ import { RNImage } from "./RNImage.js";
17
+
18
+ export const WalletImage = (props: {
19
+ theme: Theme;
20
+ wallet: Wallet;
21
+ size: number;
22
+ ensAvatar?: string | null;
23
+ }) => {
24
+ const { wallet, ensAvatar, size } = props;
25
+
26
+ const { data: imageData } = useQuery({
27
+ queryKey: ["wallet-image", wallet.id, wallet.getAccount()?.address],
28
+ queryFn: async (): Promise<string> => {
29
+ let activeEOAId = wallet.id;
30
+ if (wallet.id === "smart") {
31
+ // TODO (rn) investigate why the first render this returns null from storage
32
+ const storedId = await getStoredActiveWalletId(nativeLocalStorage);
33
+ if (storedId) {
34
+ activeEOAId = storedId;
35
+ } else {
36
+ throw new Error("No active EOA wallet");
37
+ }
38
+ }
39
+ let imageData: string;
40
+ if (
41
+ activeEOAId === "inApp" &&
42
+ (wallet.id === "inApp" || wallet.id === "smart")
43
+ ) {
44
+ const lastAuthProvider = await getLastAuthProvider(nativeLocalStorage);
45
+ switch (lastAuthProvider) {
46
+ case "phone":
47
+ imageData = PHONE_ICON;
48
+ break;
49
+ case "email":
50
+ imageData = EMAIL_ICON;
51
+ break;
52
+ case "google":
53
+ imageData = GOOGLE_ICON;
54
+ break;
55
+ case "apple":
56
+ imageData = APPLE_ICON;
57
+ break;
58
+ case "facebook":
59
+ imageData = FACEBOOK_ICON;
60
+ break;
61
+ default:
62
+ imageData = WALLET_ICON;
63
+ break;
64
+ }
65
+ return imageData;
66
+ }
67
+ try {
68
+ const externalWalletImage = await getWalletInfo(activeEOAId, true);
69
+ if (externalWalletImage) {
70
+ return externalWalletImage;
71
+ }
72
+ } catch {}
73
+
74
+ return WALLET_ICON;
75
+ },
76
+ enabled: !ensAvatar,
77
+ });
78
+
79
+ const data = ensAvatar || imageData || WALLET_ICON;
80
+ return <RNImage theme={props.theme} data={data} size={size} />;
81
+ };
@@ -2,27 +2,36 @@ import {
2
2
  StyleSheet,
3
3
  TouchableOpacity,
4
4
  type TouchableOpacityProps,
5
+ View,
5
6
  } from "react-native";
6
7
  import type { Theme } from "../../../core/design-system/index.js";
8
+ import { radius, spacing } from "../../design-system/index.js";
9
+ import { RNImage } from "./RNImage.js";
10
+ import { ThemedText } from "./text.js";
7
11
 
8
12
  export type ThemedButtonProps = TouchableOpacityProps & {
9
13
  theme: Theme;
10
- variant?: "primary" | "secondary";
14
+ variant?: "primary" | "secondary" | "accent";
11
15
  };
12
16
 
13
17
  export function ThemedButton(props: ThemedButtonProps) {
14
18
  const variant = props.variant ?? "primary";
15
- const bg = props.theme.colors.primaryButtonBg;
16
- const { style: styleOverride, ...restProps } = props;
19
+ const { style: styleOverride, theme, ...restProps } = props;
17
20
  return (
18
21
  <TouchableOpacity
19
22
  activeOpacity={0.5}
20
23
  style={[
21
24
  styles.button,
22
25
  {
23
- borderColor: variant === "secondary" ? bg : "transparent",
26
+ borderColor:
27
+ variant === "secondary" ? theme.colors.borderColor : "transparent",
24
28
  borderWidth: variant === "secondary" ? 1 : 0,
25
- backgroundColor: variant === "secondary" ? "transparent" : bg,
29
+ backgroundColor:
30
+ variant === "secondary"
31
+ ? "transparent"
32
+ : variant === "accent"
33
+ ? props.theme.colors.accentButtonBg
34
+ : props.theme.colors.primaryButtonBg,
26
35
  },
27
36
  styleOverride,
28
37
  ]}
@@ -33,13 +42,36 @@ export function ThemedButton(props: ThemedButtonProps) {
33
42
  );
34
43
  }
35
44
 
45
+ export function ThemedButtonWithIcon(
46
+ props: ThemedButtonProps & {
47
+ title: string;
48
+ icon: string;
49
+ },
50
+ ) {
51
+ const { theme, title, icon, onPress } = props;
52
+ return (
53
+ <ThemedButton theme={theme} variant="secondary" onPress={onPress}>
54
+ <View
55
+ style={{
56
+ flexDirection: "row",
57
+ gap: spacing.md,
58
+ paddingLeft: spacing.sm,
59
+ alignContent: "center",
60
+ width: "100%",
61
+ }}
62
+ >
63
+ <RNImage theme={theme} size={24} data={icon} />
64
+ <ThemedText theme={theme}>{title}</ThemedText>
65
+ </View>
66
+ </ThemedButton>
67
+ );
68
+ }
69
+
36
70
  const styles = StyleSheet.create({
37
71
  button: {
38
- flex: 1,
39
72
  flexDirection: "row",
40
- gap: 8,
41
- padding: 12,
42
- borderRadius: 6,
73
+ padding: spacing.md,
74
+ borderRadius: radius.lg,
43
75
  justifyContent: "center",
44
76
  alignItems: "center",
45
77
  },