thirdweb 5.31.1-nightly-a1d6a3c93e9a7b0433076a3e321183b09cfc0054-20240702000343 → 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 (518) 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/wallets/coinbase/coinbaseWebSDK.js +9 -1
  127. package/dist/cjs/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  128. package/dist/cjs/wallets/in-app/native/native-connector.js +3 -4
  129. package/dist/cjs/wallets/in-app/native/native-connector.js.map +1 -1
  130. package/dist/cjs/wallets/manager/index.js +3 -2
  131. package/dist/cjs/wallets/manager/index.js.map +1 -1
  132. package/dist/esm/exports/react.js +4 -3
  133. package/dist/esm/exports/react.js.map +1 -1
  134. package/dist/esm/exports/react.native.js +6 -2
  135. package/dist/esm/exports/react.native.js.map +1 -1
  136. package/dist/esm/exports/wallets/in-app.js +1 -1
  137. package/dist/esm/exports/wallets/in-app.js.map +1 -1
  138. package/dist/esm/pay/utils/definitions.js +15 -9
  139. package/dist/esm/pay/utils/definitions.js.map +1 -1
  140. package/dist/esm/react/core/hooks/connection/ConnectButtonProps.js.map +1 -0
  141. package/dist/esm/react/core/hooks/connection/ConnectEmbedProps.js +2 -0
  142. package/dist/esm/react/core/hooks/connection/ConnectEmbedProps.js.map +1 -0
  143. package/dist/esm/react/core/hooks/transaction/useSendTransaction.js.map +1 -1
  144. package/dist/esm/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
  145. package/dist/esm/react/core/hooks/wallets/useSendToken.js +78 -0
  146. package/dist/esm/react/core/hooks/wallets/useSendToken.js.map +1 -0
  147. package/dist/esm/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.js +10 -15
  148. package/dist/esm/react/core/utils/defaultTokens.js.map +1 -0
  149. package/dist/esm/react/core/utils/isSmartWallet.js.map +1 -0
  150. package/dist/esm/react/{web/ui/ConnectWallet/icons/dataUris.js → core/utils/socialIcons.js} +18 -1
  151. package/dist/esm/react/core/utils/socialIcons.js.map +1 -0
  152. package/dist/esm/react/core/utils/storage.js.map +1 -0
  153. package/dist/esm/react/core/utils/wallet.js +80 -0
  154. package/dist/esm/react/core/utils/wallet.js.map +1 -0
  155. package/dist/esm/react/native/design-system/index.js +30 -0
  156. package/dist/esm/react/native/design-system/index.js.map +1 -0
  157. package/dist/esm/react/native/hooks/wallets/useAutoConnect.js +5 -1
  158. package/dist/esm/react/native/hooks/wallets/useAutoConnect.js.map +1 -1
  159. package/dist/esm/react/native/hooks/wallets/useSendToken.js +28 -0
  160. package/dist/esm/react/native/hooks/wallets/useSendToken.js.map +1 -0
  161. package/dist/esm/react/native/ui/components/Address.js +27 -0
  162. package/dist/esm/react/native/ui/components/Address.js.map +1 -0
  163. package/dist/esm/react/native/ui/components/ChainIcon.js +26 -0
  164. package/dist/esm/react/native/ui/components/ChainIcon.js.map +1 -0
  165. package/dist/esm/react/native/ui/components/Header.js +27 -0
  166. package/dist/esm/react/native/ui/components/Header.js.map +1 -0
  167. package/dist/esm/react/native/ui/components/RNImage.js +39 -0
  168. package/dist/esm/react/native/ui/components/RNImage.js.map +1 -0
  169. package/dist/esm/react/native/ui/components/Skeleton.js +58 -0
  170. package/dist/esm/react/native/ui/components/Skeleton.js.map +1 -0
  171. package/dist/esm/react/native/ui/components/TokenIcon.js +13 -0
  172. package/dist/esm/react/native/ui/components/TokenIcon.js.map +1 -0
  173. package/dist/esm/react/native/ui/components/WalletImage.js +65 -0
  174. package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -0
  175. package/dist/esm/react/native/ui/components/button.js +24 -10
  176. package/dist/esm/react/native/ui/components/button.js.map +1 -1
  177. package/dist/esm/react/native/ui/components/input.js +60 -0
  178. package/dist/esm/react/native/ui/components/input.js.map +1 -0
  179. package/dist/esm/react/native/ui/components/spacer.js +7 -0
  180. package/dist/esm/react/native/ui/components/spacer.js.map +1 -0
  181. package/dist/esm/react/native/ui/components/text.js +10 -7
  182. package/dist/esm/react/native/ui/components/text.js.map +1 -1
  183. package/dist/esm/react/native/ui/connect/ConnectButton.js +103 -0
  184. package/dist/esm/react/native/ui/connect/ConnectButton.js.map +1 -0
  185. package/dist/esm/react/native/ui/connect/ConnectModal.js +126 -0
  186. package/dist/esm/react/native/ui/connect/ConnectModal.js.map +1 -0
  187. package/dist/esm/react/native/ui/connect/ConnectedButton.js +39 -0
  188. package/dist/esm/react/native/ui/connect/ConnectedButton.js.map +1 -0
  189. package/dist/esm/react/native/ui/connect/ConnectedModal.js +172 -0
  190. package/dist/esm/react/native/ui/connect/ConnectedModal.js.map +1 -0
  191. package/dist/esm/react/native/ui/connect/ErrorView.js +21 -0
  192. package/dist/esm/react/native/ui/connect/ErrorView.js.map +1 -0
  193. package/dist/esm/react/native/ui/connect/ExternalWalletsList.js +64 -0
  194. package/dist/esm/react/native/ui/connect/ExternalWalletsList.js.map +1 -0
  195. package/dist/esm/react/native/ui/connect/InAppWalletUI.js +163 -0
  196. package/dist/esm/react/native/ui/connect/InAppWalletUI.js.map +1 -0
  197. package/dist/esm/react/native/ui/connect/ReceiveScreen.js +38 -0
  198. package/dist/esm/react/native/ui/connect/ReceiveScreen.js.map +1 -0
  199. package/dist/esm/react/native/ui/connect/SendScreen.js +78 -0
  200. package/dist/esm/react/native/ui/connect/SendScreen.js.map +1 -0
  201. package/dist/esm/react/native/ui/connect/SuccessView.js +21 -0
  202. package/dist/esm/react/native/ui/connect/SuccessView.js.map +1 -0
  203. package/dist/esm/react/native/ui/connect/TokenListScreen.js +54 -0
  204. package/dist/esm/react/native/ui/connect/TokenListScreen.js.map +1 -0
  205. package/dist/esm/react/native/ui/icons/svgs.js +233 -0
  206. package/dist/esm/react/native/ui/icons/svgs.js.map +1 -0
  207. package/dist/esm/react/native/ui/{TransactionButton/TrabsactionButton.js → transaction/TransactionButton.js} +1 -1
  208. package/dist/esm/react/native/ui/transaction/TransactionButton.js.map +1 -0
  209. package/dist/esm/react/native/wallets/defaultWallets.js +19 -0
  210. package/dist/esm/react/native/wallets/defaultWallets.js.map +1 -0
  211. package/dist/esm/react/web/hooks/transaction/useSendTransaction.js.map +1 -1
  212. package/dist/esm/react/web/hooks/wallets/useAutoConnect.js +7 -2
  213. package/dist/esm/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
  214. package/dist/esm/react/web/hooks/wallets/useSendToken.js +28 -0
  215. package/dist/esm/react/web/hooks/wallets/useSendToken.js.map +1 -0
  216. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js +1 -1
  217. package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
  218. package/dist/esm/react/web/ui/ConnectWallet/Details.js +7 -51
  219. package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
  220. package/dist/esm/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.js +1 -1
  221. package/dist/esm/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.js.map +1 -1
  222. package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +1 -5
  223. package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
  224. package/dist/esm/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.js +1 -1
  225. package/dist/esm/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.js.map +1 -1
  226. package/dist/esm/react/web/ui/ConnectWallet/WalletEntryButton.js +1 -1
  227. package/dist/esm/react/web/ui/ConnectWallet/WalletEntryButton.js.map +1 -1
  228. package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js +1 -1
  229. package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
  230. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.js.map +1 -1
  231. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatSteps.js.map +1 -1
  232. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.js.map +1 -1
  233. package/dist/esm/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.js.map +1 -1
  234. package/dist/esm/react/web/ui/ConnectWallet/screens/SendFunds.js +5 -16
  235. package/dist/esm/react/web/ui/ConnectWallet/screens/SendFunds.js.map +1 -1
  236. package/dist/esm/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
  237. package/dist/esm/react/web/ui/ConnectWallet/screens/TokenSelector.js.map +1 -1
  238. package/dist/esm/react/web/ui/ConnectWallet/screens/ViewFunds.js +1 -1
  239. package/dist/esm/react/web/ui/ConnectWallet/screens/ViewFunds.js.map +1 -1
  240. package/dist/esm/react/web/ui/PayEmbed.js.map +1 -1
  241. package/dist/esm/react/web/ui/components/ChainIcon.js.map +1 -1
  242. package/dist/esm/react/web/ui/components/TokenIcon.js +1 -1
  243. package/dist/esm/react/web/ui/components/WalletImage.js +3 -4
  244. package/dist/esm/react/web/ui/components/WalletImage.js.map +1 -1
  245. package/dist/esm/react/web/wallets/ecosystem/EcosystemWalletHeader.js +1 -1
  246. package/dist/esm/react/web/wallets/ecosystem/EcosystemWalletHeader.js.map +1 -1
  247. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +2 -3
  248. package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
  249. package/dist/esm/react/web/wallets/shared/OTPLoginUI.js +1 -1
  250. package/dist/esm/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
  251. package/dist/esm/react/web/wallets/shared/PassKeyLogin.js +1 -1
  252. package/dist/esm/react/web/wallets/shared/PassKeyLogin.js.map +1 -1
  253. package/dist/esm/react/web/wallets/shared/SocialLogin.js +1 -1
  254. package/dist/esm/react/web/wallets/shared/SocialLogin.js.map +1 -1
  255. package/dist/esm/version.js +1 -1
  256. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js +9 -1
  257. package/dist/esm/wallets/coinbase/coinbaseWebSDK.js.map +1 -1
  258. package/dist/esm/wallets/in-app/native/native-connector.js +3 -4
  259. package/dist/esm/wallets/in-app/native/native-connector.js.map +1 -1
  260. package/dist/esm/wallets/manager/index.js +3 -2
  261. package/dist/esm/wallets/manager/index.js.map +1 -1
  262. package/dist/types/exports/react.d.ts +7 -6
  263. package/dist/types/exports/react.d.ts.map +1 -1
  264. package/dist/types/exports/react.native.d.ts +7 -2
  265. package/dist/types/exports/react.native.d.ts.map +1 -1
  266. package/dist/types/exports/wallets/in-app.d.ts +1 -1
  267. package/dist/types/exports/wallets/in-app.d.ts.map +1 -1
  268. package/dist/types/pay/utils/definitions.d.ts +1 -0
  269. package/dist/types/pay/utils/definitions.d.ts.map +1 -1
  270. package/dist/types/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.d.ts +6 -6
  271. package/dist/types/react/core/hooks/connection/ConnectButtonProps.d.ts.map +1 -0
  272. package/dist/types/react/core/hooks/connection/ConnectEmbedProps.d.ts +264 -0
  273. package/dist/types/react/core/hooks/connection/ConnectEmbedProps.d.ts.map +1 -0
  274. package/dist/types/react/core/hooks/connection/types.d.ts +1 -1
  275. package/dist/types/react/core/hooks/connection/types.d.ts.map +1 -1
  276. package/dist/types/react/core/hooks/transaction/useSendTransaction.d.ts +1 -1
  277. package/dist/types/react/core/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  278. package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts +3 -1
  279. package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  280. package/dist/types/react/core/hooks/wallets/useSendToken.d.ts +12 -0
  281. package/dist/types/react/core/hooks/wallets/useSendToken.d.ts.map +1 -0
  282. package/dist/types/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.d.ts +1 -0
  283. package/dist/types/react/core/utils/defaultTokens.d.ts.map +1 -0
  284. package/dist/types/react/core/utils/isSmartWallet.d.ts.map +1 -0
  285. package/dist/types/react/{web/ui/ConnectWallet/icons/dataUris.d.ts → core/utils/socialIcons.d.ts} +17 -1
  286. package/dist/types/react/core/utils/socialIcons.d.ts.map +1 -0
  287. package/dist/types/react/core/utils/storage.d.ts +5 -0
  288. package/dist/types/react/core/utils/storage.d.ts.map +1 -0
  289. package/dist/types/react/core/utils/wallet.d.ts +26 -0
  290. package/dist/types/react/core/utils/wallet.d.ts.map +1 -0
  291. package/dist/types/react/native/design-system/index.d.ts +30 -0
  292. package/dist/types/react/native/design-system/index.d.ts.map +1 -0
  293. package/dist/types/react/native/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  294. package/dist/types/react/{web/ui/hooks → native/hooks/wallets}/useSendToken.d.ts +18 -1
  295. package/dist/types/react/native/hooks/wallets/useSendToken.d.ts.map +1 -0
  296. package/dist/types/react/native/ui/components/Address.d.ts +9 -0
  297. package/dist/types/react/native/ui/components/Address.d.ts.map +1 -0
  298. package/dist/types/react/native/ui/components/ChainIcon.d.ts +11 -0
  299. package/dist/types/react/native/ui/components/ChainIcon.d.ts.map +1 -0
  300. package/dist/types/react/native/ui/components/Header.d.ts +10 -0
  301. package/dist/types/react/native/ui/components/Header.d.ts.map +1 -0
  302. package/dist/types/react/native/ui/components/RNImage.d.ts +10 -0
  303. package/dist/types/react/native/ui/components/RNImage.d.ts.map +1 -0
  304. package/dist/types/react/native/ui/components/Skeleton.d.ts +11 -0
  305. package/dist/types/react/native/ui/components/Skeleton.d.ts.map +1 -0
  306. package/dist/types/react/native/ui/components/TokenIcon.d.ts +15 -0
  307. package/dist/types/react/native/ui/components/TokenIcon.d.ts.map +1 -0
  308. package/dist/types/react/native/ui/components/WalletImage.d.ts +9 -0
  309. package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -0
  310. package/dist/types/react/native/ui/components/button.d.ts +5 -1
  311. package/dist/types/react/native/ui/components/button.d.ts.map +1 -1
  312. package/dist/types/react/native/ui/components/input.d.ts +12 -0
  313. package/dist/types/react/native/ui/components/input.d.ts.map +1 -0
  314. package/dist/types/react/native/ui/components/spacer.d.ts +5 -0
  315. package/dist/types/react/native/ui/components/spacer.d.ts.map +1 -0
  316. package/dist/types/react/native/ui/components/text.d.ts +1 -1
  317. package/dist/types/react/native/ui/components/text.d.ts.map +1 -1
  318. package/dist/types/react/native/ui/connect/ConnectButton.d.ts +18 -0
  319. package/dist/types/react/native/ui/connect/ConnectButton.d.ts.map +1 -0
  320. package/dist/types/react/native/ui/connect/ConnectModal.d.ts +40 -0
  321. package/dist/types/react/native/ui/connect/ConnectModal.d.ts.map +1 -0
  322. package/dist/types/react/native/ui/connect/ConnectedButton.d.ts +9 -0
  323. package/dist/types/react/native/ui/connect/ConnectedButton.d.ts.map +1 -0
  324. package/dist/types/react/native/ui/connect/ConnectedModal.d.ts +14 -0
  325. package/dist/types/react/native/ui/connect/ConnectedModal.d.ts.map +1 -0
  326. package/dist/types/react/native/ui/connect/ErrorView.d.ts +7 -0
  327. package/dist/types/react/native/ui/connect/ErrorView.d.ts.map +1 -0
  328. package/dist/types/react/native/ui/connect/ExternalWalletsList.d.ts +15 -0
  329. package/dist/types/react/native/ui/connect/ExternalWalletsList.d.ts.map +1 -0
  330. package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts +19 -0
  331. package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts.map +1 -0
  332. package/dist/types/react/native/ui/connect/ReceiveScreen.d.ts +13 -0
  333. package/dist/types/react/native/ui/connect/ReceiveScreen.d.ts.map +1 -0
  334. package/dist/types/react/native/ui/connect/SendScreen.d.ts +14 -0
  335. package/dist/types/react/native/ui/connect/SendScreen.d.ts.map +1 -0
  336. package/dist/types/react/native/ui/connect/SuccessView.d.ts +7 -0
  337. package/dist/types/react/native/ui/connect/SuccessView.d.ts.map +1 -0
  338. package/dist/types/react/native/ui/connect/TokenListScreen.d.ts +20 -0
  339. package/dist/types/react/native/ui/connect/TokenListScreen.d.ts.map +1 -0
  340. package/dist/types/react/native/ui/icons/svgs.d.ts +22 -0
  341. package/dist/types/react/native/ui/icons/svgs.d.ts.map +1 -0
  342. package/dist/types/react/native/ui/{TransactionButton/TrabsactionButton.d.ts → transaction/TransactionButton.d.ts} +1 -1
  343. package/dist/types/react/native/ui/transaction/TransactionButton.d.ts.map +1 -0
  344. package/dist/types/react/native/wallets/defaultWallets.d.ts +11 -0
  345. package/dist/types/react/native/wallets/defaultWallets.d.ts.map +1 -0
  346. package/dist/types/react/web/hooks/transaction/useSendTransaction.d.ts.map +1 -1
  347. package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts.map +1 -1
  348. package/dist/types/react/web/hooks/wallets/useSendToken.d.ts +28 -0
  349. package/dist/types/react/web/hooks/wallets/useSendToken.d.ts.map +1 -0
  350. package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts +1 -1
  351. package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts.map +1 -1
  352. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts +2 -2
  353. package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
  354. package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts +1 -267
  355. package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts.map +1 -1
  356. package/dist/types/react/web/ui/ConnectWallet/WalletEntryButton.d.ts.map +1 -1
  357. package/dist/types/react/web/ui/ConnectWallet/WalletSelector.d.ts.map +1 -1
  358. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.d.ts +2 -2
  359. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.d.ts.map +1 -1
  360. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useEnabledPaymentMethods.d.ts +1 -1
  361. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useEnabledPaymentMethods.d.ts.map +1 -1
  362. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.d.ts +1 -1
  363. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.d.ts.map +1 -1
  364. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.d.ts +1 -1
  365. package/dist/types/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.d.ts.map +1 -1
  366. package/dist/types/react/web/ui/ConnectWallet/screens/SendFunds.d.ts +1 -1
  367. package/dist/types/react/web/ui/ConnectWallet/screens/SendFunds.d.ts.map +1 -1
  368. package/dist/types/react/web/ui/ConnectWallet/screens/SignatureScreen.d.ts +1 -1
  369. package/dist/types/react/web/ui/ConnectWallet/screens/SignatureScreen.d.ts.map +1 -1
  370. package/dist/types/react/web/ui/ConnectWallet/screens/TokenSelector.d.ts +1 -1
  371. package/dist/types/react/web/ui/ConnectWallet/screens/TokenSelector.d.ts.map +1 -1
  372. package/dist/types/react/web/ui/ConnectWallet/screens/ViewFunds.d.ts +1 -1
  373. package/dist/types/react/web/ui/ConnectWallet/screens/ViewFunds.d.ts.map +1 -1
  374. package/dist/types/react/web/ui/ConnectWallet/screens/nativeToken.d.ts +1 -1
  375. package/dist/types/react/web/ui/ConnectWallet/screens/nativeToken.d.ts.map +1 -1
  376. package/dist/types/react/web/ui/PayEmbed.d.ts +2 -2
  377. package/dist/types/react/web/ui/PayEmbed.d.ts.map +1 -1
  378. package/dist/types/react/web/ui/components/ChainIcon.d.ts.map +1 -1
  379. package/dist/types/react/web/ui/components/WalletImage.d.ts.map +1 -1
  380. package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
  381. package/dist/types/react/web/wallets/shared/OTPLoginUI.d.ts.map +1 -1
  382. package/dist/types/react/web/wallets/shared/SocialLogin.d.ts.map +1 -1
  383. package/dist/types/version.d.ts +1 -1
  384. package/dist/types/wallets/coinbase/coinbaseWebSDK.d.ts.map +1 -1
  385. package/dist/types/wallets/in-app/native/native-connector.d.ts.map +1 -1
  386. package/dist/types/wallets/manager/index.d.ts +1 -0
  387. package/dist/types/wallets/manager/index.d.ts.map +1 -1
  388. package/package.json +19 -3
  389. package/src/exports/react.native.ts +19 -5
  390. package/src/exports/react.ts +7 -12
  391. package/src/exports/wallets/in-app.ts +1 -1
  392. package/src/pay/utils/definitions.ts +16 -9
  393. package/src/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.ts +7 -10
  394. package/src/react/core/hooks/connection/ConnectEmbedProps.ts +285 -0
  395. package/src/react/core/hooks/connection/types.ts +1 -1
  396. package/src/react/core/hooks/transaction/useSendTransaction.ts +1 -1
  397. package/src/react/core/hooks/wallets/useAutoConnect.ts +1 -1
  398. package/src/react/core/hooks/wallets/useSendToken.ts +94 -0
  399. package/src/react/{web/ui/ConnectWallet → core/utils}/defaultTokens.ts +10 -15
  400. package/src/react/{web/ui/ConnectWallet/icons/dataUris.ts → core/utils/socialIcons.ts} +30 -0
  401. package/src/react/{web/wallets/shared → core/utils}/storage.ts +2 -2
  402. package/src/react/core/utils/wallet.ts +101 -0
  403. package/src/react/native/design-system/index.ts +31 -0
  404. package/src/react/native/hooks/wallets/useAutoConnect.ts +5 -1
  405. package/src/react/native/hooks/wallets/useSendToken.ts +29 -0
  406. package/src/react/native/ui/components/Address.tsx +52 -0
  407. package/src/react/native/ui/components/ChainIcon.tsx +42 -0
  408. package/src/react/native/ui/components/Header.tsx +84 -0
  409. package/src/react/native/ui/components/RNImage.tsx +71 -0
  410. package/src/react/native/ui/components/Skeleton.tsx +93 -0
  411. package/src/react/native/ui/components/TokenIcon.tsx +31 -0
  412. package/src/react/native/ui/components/WalletImage.tsx +81 -0
  413. package/src/react/native/ui/components/button.tsx +41 -9
  414. package/src/react/native/ui/components/input.tsx +128 -0
  415. package/src/react/native/ui/components/spacer.tsx +6 -0
  416. package/src/react/native/ui/components/text.tsx +17 -8
  417. package/src/react/native/ui/connect/ConnectButton.tsx +188 -0
  418. package/src/react/native/ui/connect/ConnectModal.tsx +298 -0
  419. package/src/react/native/ui/connect/ConnectedButton.tsx +94 -0
  420. package/src/react/native/ui/connect/ConnectedModal.tsx +434 -0
  421. package/src/react/native/ui/connect/ErrorView.tsx +44 -0
  422. package/src/react/native/ui/connect/ExternalWalletsList.tsx +162 -0
  423. package/src/react/native/ui/connect/InAppWalletUI.tsx +320 -0
  424. package/src/react/native/ui/connect/ReceiveScreen.tsx +81 -0
  425. package/src/react/native/ui/connect/SendScreen.tsx +238 -0
  426. package/src/react/native/ui/connect/SuccessView.tsx +44 -0
  427. package/src/react/native/ui/connect/TokenListScreen.tsx +147 -0
  428. package/src/react/native/ui/icons/svgs.ts +252 -0
  429. package/src/react/native/wallets/defaultWallets.ts +30 -0
  430. package/src/react/web/hooks/transaction/useSendTransaction.tsx +2 -2
  431. package/src/react/web/hooks/wallets/useAutoConnect.ts +18 -8
  432. package/src/react/web/hooks/wallets/useSendToken.ts +29 -0
  433. package/src/react/web/ui/ConnectWallet/ConnectButton.tsx +2 -2
  434. package/src/react/web/ui/ConnectWallet/Details.tsx +26 -78
  435. package/src/react/web/ui/ConnectWallet/Modal/AnyWalletConnectUI.tsx +1 -1
  436. package/src/react/web/ui/ConnectWallet/Modal/ConnectEmbed.tsx +6 -285
  437. package/src/react/web/ui/ConnectWallet/Modal/SmartWalletConnectUI.tsx +1 -1
  438. package/src/react/web/ui/ConnectWallet/WalletEntryButton.tsx +1 -1
  439. package/src/react/web/ui/ConnectWallet/WalletSelector.tsx +1 -1
  440. package/src/react/web/ui/ConnectWallet/screens/Buy/BuyScreen.tsx +2 -2
  441. package/src/react/web/ui/ConnectWallet/screens/Buy/fiat/FiatSteps.tsx +1 -1
  442. package/src/react/web/ui/ConnectWallet/screens/Buy/main/useEnabledPaymentMethods.ts +1 -1
  443. package/src/react/web/ui/ConnectWallet/screens/Buy/main/useUISelectionStates.ts +1 -1
  444. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/PayWithCrypto.tsx +1 -1
  445. package/src/react/web/ui/ConnectWallet/screens/Buy/swap/SwapFlow.tsx +1 -1
  446. package/src/react/web/ui/ConnectWallet/screens/SendFunds.tsx +8 -21
  447. package/src/react/web/ui/ConnectWallet/screens/SignatureScreen.tsx +1 -1
  448. package/src/react/web/ui/ConnectWallet/screens/TokenSelector.tsx +1 -1
  449. package/src/react/web/ui/ConnectWallet/screens/ViewFunds.tsx +4 -1
  450. package/src/react/web/ui/ConnectWallet/screens/nativeToken.ts +1 -1
  451. package/src/react/web/ui/PayEmbed.tsx +3 -3
  452. package/src/react/web/ui/components/ChainIcon.tsx +0 -1
  453. package/src/react/web/ui/components/TokenIcon.tsx +1 -1
  454. package/src/react/web/ui/components/WalletImage.tsx +7 -9
  455. package/src/react/web/wallets/ecosystem/EcosystemWalletHeader.tsx +1 -1
  456. package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +6 -6
  457. package/src/react/web/wallets/shared/OTPLoginUI.tsx +1 -1
  458. package/src/react/web/wallets/shared/PassKeyLogin.tsx +1 -1
  459. package/src/react/web/wallets/shared/SocialLogin.tsx +1 -1
  460. package/src/version.ts +1 -1
  461. package/src/wallets/coinbase/coinbaseWebSDK.ts +14 -1
  462. package/src/wallets/in-app/native/native-connector.ts +4 -6
  463. package/src/wallets/manager/index.ts +4 -2
  464. package/dist/cjs/react/native/ui/TransactionButton/TrabsactionButton.js.map +0 -1
  465. package/dist/cjs/react/web/ui/ConnectWallet/ConnectButtonProps.js.map +0 -1
  466. package/dist/cjs/react/web/ui/ConnectWallet/defaultTokens.js.map +0 -1
  467. package/dist/cjs/react/web/ui/ConnectWallet/icons/dataUris.js.map +0 -1
  468. package/dist/cjs/react/web/ui/ConnectWallet/icons/socialLogins.js +0 -15
  469. package/dist/cjs/react/web/ui/ConnectWallet/icons/socialLogins.js.map +0 -1
  470. package/dist/cjs/react/web/ui/hooks/useSendToken.js +0 -57
  471. package/dist/cjs/react/web/ui/hooks/useSendToken.js.map +0 -1
  472. package/dist/cjs/react/web/ui/hooks/useWalletInfo.js +0 -37
  473. package/dist/cjs/react/web/ui/hooks/useWalletInfo.js.map +0 -1
  474. package/dist/cjs/react/web/utils/isSmartWallet.js.map +0 -1
  475. package/dist/cjs/react/web/wallets/in-app/socialIcons.js +0 -10
  476. package/dist/cjs/react/web/wallets/in-app/socialIcons.js.map +0 -1
  477. package/dist/cjs/react/web/wallets/shared/storage.js.map +0 -1
  478. package/dist/esm/react/native/ui/TransactionButton/TrabsactionButton.js.map +0 -1
  479. package/dist/esm/react/web/ui/ConnectWallet/ConnectButtonProps.js.map +0 -1
  480. package/dist/esm/react/web/ui/ConnectWallet/defaultTokens.js.map +0 -1
  481. package/dist/esm/react/web/ui/ConnectWallet/icons/dataUris.js.map +0 -1
  482. package/dist/esm/react/web/ui/ConnectWallet/icons/socialLogins.js +0 -12
  483. package/dist/esm/react/web/ui/ConnectWallet/icons/socialLogins.js.map +0 -1
  484. package/dist/esm/react/web/ui/hooks/useSendToken.js +0 -54
  485. package/dist/esm/react/web/ui/hooks/useSendToken.js.map +0 -1
  486. package/dist/esm/react/web/ui/hooks/useWalletInfo.js +0 -33
  487. package/dist/esm/react/web/ui/hooks/useWalletInfo.js.map +0 -1
  488. package/dist/esm/react/web/utils/isSmartWallet.js.map +0 -1
  489. package/dist/esm/react/web/wallets/in-app/socialIcons.js +0 -7
  490. package/dist/esm/react/web/wallets/in-app/socialIcons.js.map +0 -1
  491. package/dist/esm/react/web/wallets/shared/storage.js.map +0 -1
  492. package/dist/types/react/native/ui/TransactionButton/TrabsactionButton.d.ts.map +0 -1
  493. package/dist/types/react/web/ui/ConnectWallet/ConnectButtonProps.d.ts.map +0 -1
  494. package/dist/types/react/web/ui/ConnectWallet/defaultTokens.d.ts.map +0 -1
  495. package/dist/types/react/web/ui/ConnectWallet/icons/dataUris.d.ts.map +0 -1
  496. package/dist/types/react/web/ui/ConnectWallet/icons/socialLogins.d.ts +0 -12
  497. package/dist/types/react/web/ui/ConnectWallet/icons/socialLogins.d.ts.map +0 -1
  498. package/dist/types/react/web/ui/hooks/useSendToken.d.ts.map +0 -1
  499. package/dist/types/react/web/ui/hooks/useWalletInfo.d.ts +0 -13
  500. package/dist/types/react/web/ui/hooks/useWalletInfo.d.ts.map +0 -1
  501. package/dist/types/react/web/utils/isSmartWallet.d.ts.map +0 -1
  502. package/dist/types/react/web/wallets/in-app/socialIcons.d.ts +0 -6
  503. package/dist/types/react/web/wallets/in-app/socialIcons.d.ts.map +0 -1
  504. package/dist/types/react/web/wallets/shared/storage.d.ts +0 -5
  505. package/dist/types/react/web/wallets/shared/storage.d.ts.map +0 -1
  506. package/src/react/web/ui/ConnectWallet/icons/socialLogins.ts +0 -22
  507. package/src/react/web/ui/hooks/useSendToken.ts +0 -66
  508. package/src/react/web/ui/hooks/useWalletInfo.ts +0 -37
  509. package/src/react/web/wallets/in-app/socialIcons.ts +0 -11
  510. /package/dist/cjs/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.js +0 -0
  511. /package/dist/cjs/react/{web → core}/utils/isSmartWallet.js +0 -0
  512. /package/dist/cjs/react/{web/wallets/shared → core/utils}/storage.js +0 -0
  513. /package/dist/esm/react/{web/ui/ConnectWallet → core/hooks/connection}/ConnectButtonProps.js +0 -0
  514. /package/dist/esm/react/{web → core}/utils/isSmartWallet.js +0 -0
  515. /package/dist/esm/react/{web/wallets/shared → core/utils}/storage.js +0 -0
  516. /package/dist/types/react/{web → core}/utils/isSmartWallet.d.ts +0 -0
  517. /package/src/react/{web → core}/utils/isSmartWallet.ts +0 -0
  518. /package/src/react/native/ui/{TransactionButton/TrabsactionButton.tsx → transaction/TransactionButton.tsx} +0 -0
@@ -0,0 +1,238 @@
1
+ import { useState } from "react";
2
+ import { StyleSheet, View } from "react-native";
3
+ import type { ThirdwebClient } from "../../../../client/client.js";
4
+ import type { Theme } from "../../../core/design-system/index.js";
5
+ import { useChainQuery } from "../../../core/hooks/others/useChainQuery.js";
6
+ import type {
7
+ SupportedTokens,
8
+ TokenInfo,
9
+ } from "../../../core/utils/defaultTokens.js";
10
+ import { radius, spacing } from "../../design-system/index.js";
11
+ import { useActiveAccount } from "../../hooks/wallets/useActiveAccount.js";
12
+ import { useActiveWalletChain } from "../../hooks/wallets/useActiveWalletChain.js";
13
+ import { useSendToken } from "../../hooks/wallets/useSendToken.js";
14
+ import { type ContainerType, Header } from "../components/Header.js";
15
+ import { ThemedButton } from "../components/button.js";
16
+ import { ThemedInput } from "../components/input.js";
17
+ import { Spacer } from "../components/spacer.js";
18
+ import { ThemedSpinner } from "../components/spinner.js";
19
+ import { ThemedText } from "../components/text.js";
20
+ import { ErrorView } from "./ErrorView.js";
21
+ import { SuccessView } from "./SuccessView.js";
22
+ import { TokenListScreen, TokenRow } from "./TokenListScreen.js";
23
+
24
+ export type SendScreenProps = {
25
+ theme: Theme;
26
+ client: ThirdwebClient;
27
+ onClose?: () => void;
28
+ onBack?: () => void;
29
+ containerType: ContainerType;
30
+ supportedTokens?: SupportedTokens;
31
+ };
32
+
33
+ export const SendScreen = (props: SendScreenProps) => {
34
+ const { theme, client, onClose, onBack, containerType, supportedTokens } =
35
+ props;
36
+ const [receiverAddress, setReceiverAddress] = useState("");
37
+ const [amount, setAmount] = useState("0");
38
+ const [selectedToken, setSelectedToken] = useState<TokenInfo>();
39
+ const account = useActiveAccount();
40
+ const chain = useActiveWalletChain();
41
+ const chainIfo = useChainQuery(chain);
42
+ const sendMutation = useSendToken(client);
43
+ const [screen, setScreen] = useState<
44
+ "base" | "tokenList" | "success" | "error"
45
+ >("base");
46
+
47
+ const handleTokenClicked = () => {
48
+ setScreen("tokenList");
49
+ };
50
+
51
+ const handleSend = async () => {
52
+ sendMutation.mutate(
53
+ {
54
+ amount,
55
+ receiverAddress,
56
+ tokenAddress: selectedToken?.address,
57
+ },
58
+ {
59
+ onSuccess() {
60
+ setScreen("success");
61
+ },
62
+ onError() {
63
+ setScreen("error");
64
+ },
65
+ },
66
+ );
67
+ };
68
+
69
+ if (screen === "success") {
70
+ return (
71
+ <>
72
+ <Header
73
+ theme={theme}
74
+ onClose={onClose}
75
+ onBack={() => setScreen("base")}
76
+ containerType={containerType}
77
+ title="Funds Sent"
78
+ />
79
+ <Spacer size="xl" />
80
+ <View style={{ flex: 1 }}>
81
+ <SuccessView theme={theme} title="Transaction Successful" />
82
+ </View>
83
+ </>
84
+ );
85
+ }
86
+
87
+ if (screen === "error") {
88
+ return (
89
+ <>
90
+ <Header
91
+ theme={theme}
92
+ onClose={onClose}
93
+ onBack={() => setScreen("base")}
94
+ containerType={containerType}
95
+ title="Error Sending Funds"
96
+ />
97
+ <Spacer size="xl" />
98
+ <View style={{ flex: 1 }}>
99
+ <ErrorView
100
+ theme={theme}
101
+ title={sendMutation.error?.message || "Unknown error"}
102
+ />
103
+ </View>
104
+ </>
105
+ );
106
+ }
107
+
108
+ if (screen === "tokenList") {
109
+ return (
110
+ <>
111
+ <Header
112
+ theme={theme}
113
+ onClose={onClose}
114
+ onBack={() => setScreen("base")}
115
+ containerType={containerType}
116
+ title="Token to Send"
117
+ />
118
+ <Spacer size="xl" />
119
+ <View style={{ flex: 1 }}>
120
+ <TokenListScreen
121
+ theme={theme}
122
+ client={client}
123
+ supportedTokens={supportedTokens}
124
+ onTokenSelected={(t) => {
125
+ setSelectedToken(t);
126
+ setScreen("base");
127
+ }}
128
+ />
129
+ </View>
130
+ </>
131
+ );
132
+ }
133
+
134
+ return (
135
+ <>
136
+ <Header
137
+ theme={theme}
138
+ onClose={onClose}
139
+ onBack={onBack}
140
+ containerType={containerType}
141
+ title="Send Funds"
142
+ />
143
+ <View style={styles.container}>
144
+ <View style={styles.inputContainer}>
145
+ <ThemedText theme={theme} type="subtext">
146
+ Token
147
+ </ThemedText>
148
+ <View
149
+ style={{
150
+ borderColor: theme.colors.borderColor,
151
+ borderWidth: 1,
152
+ paddingHorizontal: spacing.md,
153
+ paddingVertical: spacing.smd,
154
+ borderRadius: radius.lg,
155
+ }}
156
+ >
157
+ <TokenRow
158
+ theme={theme}
159
+ client={client}
160
+ address={account?.address}
161
+ chain={chain}
162
+ token={selectedToken}
163
+ onTokenSelected={handleTokenClicked}
164
+ />
165
+ </View>
166
+ </View>
167
+ <View style={styles.inputContainer}>
168
+ <ThemedText theme={theme} type="subtext">
169
+ Send to
170
+ </ThemedText>
171
+ <ThemedInput
172
+ theme={theme}
173
+ onChangeText={setReceiverAddress}
174
+ value={receiverAddress}
175
+ placeholder="0x... / ENS name"
176
+ textContentType="URL"
177
+ keyboardType="url"
178
+ autoCapitalize="none"
179
+ />
180
+ </View>
181
+ <View style={styles.inputContainer}>
182
+ <ThemedText theme={theme} type="subtext">
183
+ Amount
184
+ </ThemedText>
185
+ <ThemedInput
186
+ theme={theme}
187
+ onChangeText={setAmount}
188
+ value={amount}
189
+ inputMode="numeric"
190
+ rightView={
191
+ <ThemedText
192
+ theme={theme}
193
+ type="subtext"
194
+ style={{ marginRight: spacing.md }}
195
+ >
196
+ {selectedToken?.symbol || chainIfo.data?.nativeCurrency?.symbol}
197
+ </ThemedText>
198
+ }
199
+ />
200
+ </View>
201
+ <View style={styles.inputContainer}>
202
+ <ThemedButton
203
+ theme={theme}
204
+ variant="accent"
205
+ onPress={handleSend}
206
+ disabled={sendMutation.isPending}
207
+ >
208
+ {sendMutation.isPending ? (
209
+ <ThemedSpinner color={theme.colors.accentButtonText} />
210
+ ) : (
211
+ <ThemedText
212
+ theme={theme}
213
+ type="defaultSemiBold"
214
+ style={{
215
+ color: theme.colors.accentButtonText,
216
+ }}
217
+ >
218
+ Send
219
+ </ThemedText>
220
+ )}
221
+ </ThemedButton>
222
+ </View>
223
+ </View>
224
+ </>
225
+ );
226
+ };
227
+
228
+ const styles = StyleSheet.create({
229
+ container: {
230
+ paddingHorizontal: spacing.lg,
231
+ paddingVertical: spacing.lg,
232
+ flexDirection: "column",
233
+ gap: spacing.md,
234
+ },
235
+ inputContainer: {
236
+ gap: spacing.sm,
237
+ },
238
+ });
@@ -0,0 +1,44 @@
1
+ import { StyleSheet, View } from "react-native";
2
+ import type { Theme } from "../../../core/design-system/index.js";
3
+ import { spacing } from "../../design-system/index.js";
4
+ import { RNImage } from "../components/RNImage.js";
5
+ import { ThemedText } from "../components/text.js";
6
+ import { CHECK_CIRCLE } from "../icons/svgs.js";
7
+
8
+ export type SuccessViewProps = {
9
+ theme: Theme;
10
+ title: string;
11
+ };
12
+
13
+ export const SuccessView = (props: SuccessViewProps) => {
14
+ const { theme, title } = props;
15
+
16
+ return (
17
+ <View style={styles.container}>
18
+ <RNImage
19
+ theme={theme}
20
+ data={CHECK_CIRCLE}
21
+ size={64}
22
+ color={theme.colors.success}
23
+ />
24
+ <ThemedText
25
+ type="defaultSemiBold"
26
+ theme={theme}
27
+ style={{ color: theme.colors.success, textAlign: "center" }}
28
+ >
29
+ {title}
30
+ </ThemedText>
31
+ </View>
32
+ );
33
+ };
34
+
35
+ const styles = StyleSheet.create({
36
+ container: {
37
+ paddingHorizontal: spacing.lg,
38
+ paddingVertical: spacing.xxl,
39
+ flexDirection: "column",
40
+ justifyContent: "center",
41
+ alignItems: "center",
42
+ gap: spacing.lg,
43
+ },
44
+ });
@@ -0,0 +1,147 @@
1
+ import { ScrollView, StyleSheet, TouchableOpacity, View } from "react-native";
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 { useWalletBalance } from "../../../core/hooks/others/useWalletBalance.js";
6
+ import {
7
+ type SupportedTokens,
8
+ type TokenInfo,
9
+ defaultTokens,
10
+ } from "../../../core/utils/defaultTokens.js";
11
+ import { spacing } from "../../design-system/index.js";
12
+ import { useActiveAccount } from "../../hooks/wallets/useActiveAccount.js";
13
+ import { useActiveWalletChain } from "../../hooks/wallets/useActiveWalletChain.js";
14
+ import { RNImage } from "../components/RNImage.js";
15
+ import { Skeleton } from "../components/Skeleton.js";
16
+ import { TokenIcon } from "../components/TokenIcon.js";
17
+ import { ThemedText } from "../components/text.js";
18
+ import { RIGHT_CHEVRON } from "../icons/svgs.js";
19
+
20
+ export type TokenListScreenProps = {
21
+ theme: Theme;
22
+ client: ThirdwebClient;
23
+ supportedTokens?: SupportedTokens;
24
+ onTokenSelected?: (token?: TokenInfo) => void;
25
+ };
26
+
27
+ export const TokenListScreen = (props: TokenListScreenProps) => {
28
+ const supportedTokens = props.supportedTokens || defaultTokens;
29
+ const chain = useActiveWalletChain();
30
+ const account = useActiveAccount();
31
+ const tokens = chain ? supportedTokens[chain.id] || [] : [];
32
+
33
+ return (
34
+ <ScrollView style={{ flex: 1 }}>
35
+ <View style={styles.listContainer}>
36
+ <TokenRow
37
+ chain={chain}
38
+ address={account?.address}
39
+ client={props.client}
40
+ theme={props.theme}
41
+ onTokenSelected={props.onTokenSelected}
42
+ />
43
+ {tokens.map((t) => {
44
+ return (
45
+ <TokenRow
46
+ chain={chain}
47
+ client={props.client}
48
+ address={account?.address}
49
+ theme={props.theme}
50
+ token={t}
51
+ onTokenSelected={props.onTokenSelected}
52
+ key={t.address}
53
+ />
54
+ );
55
+ })}
56
+ </View>
57
+ </ScrollView>
58
+ );
59
+ };
60
+
61
+ export const TokenRow = (props: {
62
+ token?: TokenInfo;
63
+ theme: Theme;
64
+ client: ThirdwebClient;
65
+ chain?: Chain;
66
+ address?: string;
67
+ onTokenSelected?: (token?: TokenInfo) => void;
68
+ }) => {
69
+ const { token, theme, address, chain, client, onTokenSelected } = props;
70
+ const balanceQuery = useWalletBalance({
71
+ address,
72
+ chain,
73
+ client,
74
+ tokenAddress: token?.address,
75
+ });
76
+ const tokenName = props.token ? props.token.name : balanceQuery.data?.name;
77
+ const inner = (
78
+ <>
79
+ <TokenIcon
80
+ token={token}
81
+ size={40}
82
+ chain={chain}
83
+ client={client}
84
+ theme={theme}
85
+ />
86
+ <View style={{ flexDirection: "column", gap: spacing.xxs }}>
87
+ <ThemedText theme={theme} type="defaultSemiBold">
88
+ {tokenName}
89
+ </ThemedText>
90
+ {address && (
91
+ <>
92
+ {balanceQuery.data ? (
93
+ <ThemedText theme={theme} type="subtext">
94
+ {Number(balanceQuery.data.displayValue).toFixed(3)}{" "}
95
+ {balanceQuery.data?.symbol}
96
+ </ThemedText>
97
+ ) : (
98
+ <Skeleton theme={theme} style={{ width: 80, height: 14 }} />
99
+ )}
100
+ </>
101
+ )}
102
+ </View>
103
+ {props.onTokenSelected && (
104
+ <>
105
+ <View style={{ flex: 1 }} />
106
+ <RNImage
107
+ theme={theme}
108
+ size={24}
109
+ data={RIGHT_CHEVRON}
110
+ color={theme.colors.secondaryIconColor}
111
+ />
112
+ </>
113
+ )}
114
+ </>
115
+ );
116
+ return onTokenSelected ? (
117
+ <TouchableOpacity
118
+ style={styles.tokenRowContainer}
119
+ onPress={() => onTokenSelected(token)}
120
+ >
121
+ {inner}
122
+ </TouchableOpacity>
123
+ ) : (
124
+ <View style={styles.tokenRowContainer}>{inner}</View>
125
+ );
126
+ };
127
+
128
+ const styles = StyleSheet.create({
129
+ listContainer: {
130
+ flexDirection: "column",
131
+ flex: 1,
132
+ paddingHorizontal: spacing.lg,
133
+ gap: spacing.md,
134
+ },
135
+ tokenRowContainer: {
136
+ flexDirection: "row",
137
+ gap: spacing.md,
138
+ alignItems: "center",
139
+ },
140
+ emptyContainer: {
141
+ flexDirection: "column",
142
+ flex: 1,
143
+ justifyContent: "center",
144
+ alignItems: "center",
145
+ padding: spacing.lg,
146
+ },
147
+ });