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
@@ -0,0 +1,128 @@
1
+ import { useState } from "react";
2
+ import {
3
+ StyleSheet,
4
+ TextInput,
5
+ type TextInputProps,
6
+ TouchableOpacity,
7
+ View,
8
+ } from "react-native";
9
+ import { SvgXml } from "react-native-svg";
10
+ import type { Theme } from "../../../core/design-system/index.js";
11
+ import { radius, spacing } from "../../design-system/index.js";
12
+ import { RIGHT_ARROW } from "../icons/svgs.js";
13
+ import { ThemedSpinner } from "./spinner.js";
14
+
15
+ export type ThemedInputProps = {
16
+ theme: Theme;
17
+ rightView?: React.ReactNode;
18
+ } & TextInputProps;
19
+
20
+ export function ThemedInput(props: ThemedInputProps) {
21
+ const { theme, rightView } = props;
22
+ const [isFocused, setIsFocused] = useState(false);
23
+ return (
24
+ <View
25
+ style={[
26
+ styles.container,
27
+ {
28
+ borderColor: isFocused
29
+ ? theme.colors.accentButtonBg
30
+ : theme.colors.borderColor,
31
+ },
32
+ ]}
33
+ >
34
+ <TextInput
35
+ placeholderTextColor={theme.colors.secondaryText}
36
+ style={[styles.input, { color: theme.colors.primaryText }]}
37
+ onFocus={() => setIsFocused(true)}
38
+ onBlur={() => setIsFocused(false)}
39
+ {...props}
40
+ />
41
+ {rightView && (
42
+ <>
43
+ <View style={{ flex: 1 }} />
44
+ {rightView}
45
+ </>
46
+ )}
47
+ </View>
48
+ );
49
+ }
50
+
51
+ export function ThemedInputWithSubmit(
52
+ props: ThemedInputProps & {
53
+ onSubmit?: (value: string) => void;
54
+ isSubmitting?: boolean;
55
+ },
56
+ ) {
57
+ const { theme, onSubmit } = props;
58
+ const [isFocused, setIsFocused] = useState(false);
59
+ const [val, setVal] = useState("");
60
+ return (
61
+ <View
62
+ style={[
63
+ styles.container,
64
+ {
65
+ borderColor: isFocused
66
+ ? theme.colors.accentButtonBg
67
+ : theme.colors.borderColor,
68
+ },
69
+ ]}
70
+ >
71
+ <TextInput
72
+ placeholderTextColor={theme.colors.secondaryText}
73
+ style={[
74
+ styles.input,
75
+ {
76
+ color: theme.colors.primaryText,
77
+ },
78
+ ]}
79
+ value={val}
80
+ onChangeText={setVal}
81
+ onFocus={() => setIsFocused(true)}
82
+ onBlur={() => setIsFocused(false)}
83
+ {...props}
84
+ />
85
+ {onSubmit && (
86
+ <TouchableOpacity
87
+ onPress={() => onSubmit(val)}
88
+ disabled={props.isSubmitting}
89
+ style={{
90
+ paddingHorizontal: spacing.lg,
91
+ }}
92
+ >
93
+ {props.isSubmitting ? (
94
+ <ThemedSpinner size={24} color={theme.colors.secondaryIconColor} />
95
+ ) : (
96
+ <SvgXml
97
+ width={24}
98
+ height={24}
99
+ xml={RIGHT_ARROW}
100
+ color={theme.colors.secondaryIconColor}
101
+ />
102
+ )}
103
+ </TouchableOpacity>
104
+ )}
105
+ </View>
106
+ );
107
+ }
108
+
109
+ const styles = StyleSheet.create({
110
+ container: {
111
+ flexDirection: "row",
112
+ alignItems: "center",
113
+ borderRadius: radius.lg,
114
+ borderWidth: 1,
115
+ borderStyle: "solid",
116
+ },
117
+ input: {
118
+ flex: 1,
119
+ flexDirection: "row",
120
+ fontSize: 16,
121
+ height: 56,
122
+ gap: spacing.md,
123
+ paddingLeft: spacing.lg,
124
+ paddingVertical: spacing.md,
125
+ justifyContent: "center",
126
+ alignItems: "center",
127
+ },
128
+ });
@@ -0,0 +1,6 @@
1
+ import { View } from "react-native";
2
+ import { spacing } from "../../design-system/index.js";
3
+
4
+ export function Spacer({ size }: { size: keyof typeof spacing }) {
5
+ return <View style={{ height: spacing[size] }} />;
6
+ }
@@ -3,7 +3,13 @@ import type { Theme } from "../../../core/design-system/index.js";
3
3
 
4
4
  export type ThemedTextProps = TextProps & {
5
5
  theme: Theme;
6
- type?: "default" | "title" | "defaultSemiBold" | "subtitle" | "link";
6
+ type?:
7
+ | "default"
8
+ | "title"
9
+ | "defaultSemiBold"
10
+ | "subtitle"
11
+ | "link"
12
+ | "subtext";
7
13
  };
8
14
 
9
15
  export function ThemedText({
@@ -21,6 +27,9 @@ export function ThemedText({
21
27
  type === "defaultSemiBold" ? styles.defaultSemiBold : undefined,
22
28
  type === "subtitle" ? styles.subtitle : undefined,
23
29
  type === "link" ? styles.link : undefined,
30
+ type === "subtext"
31
+ ? { ...styles.subtext, color: theme.colors.secondaryText }
32
+ : undefined,
24
33
  style,
25
34
  ]}
26
35
  {...rest}
@@ -31,24 +40,24 @@ export function ThemedText({
31
40
  const styles = StyleSheet.create({
32
41
  default: {
33
42
  fontSize: 16,
34
- lineHeight: 24,
35
43
  },
36
44
  defaultSemiBold: {
37
45
  fontSize: 16,
38
- lineHeight: 24,
39
46
  fontWeight: "600",
40
47
  },
48
+ subtext: {
49
+ fontSize: 14,
50
+ },
41
51
  title: {
42
- fontSize: 32,
52
+ fontSize: 24,
43
53
  fontWeight: "bold",
44
- lineHeight: 32,
54
+ lineHeight: 28,
45
55
  },
46
56
  subtitle: {
47
- fontSize: 20,
48
- fontWeight: "bold",
57
+ fontSize: 18,
58
+ fontWeight: "600",
49
59
  },
50
60
  link: {
51
- lineHeight: 30,
52
61
  fontSize: 16,
53
62
  },
54
63
  });
@@ -0,0 +1,188 @@
1
+ import { useCallback, useRef, useState } from "react";
2
+ import {
3
+ Animated,
4
+ Dimensions,
5
+ Easing,
6
+ KeyboardAvoidingView,
7
+ Modal,
8
+ Pressable,
9
+ StyleSheet,
10
+ View,
11
+ } from "react-native";
12
+ import { parseTheme } from "../../../core/design-system/CustomThemeProvider.js";
13
+ import type { ConnectButtonProps } from "../../../core/hooks/connection/ConnectButtonProps.js";
14
+ import { useActiveAccount } from "../../hooks/wallets/useActiveAccount.js";
15
+ import { useActiveWallet } from "../../hooks/wallets/useActiveWallet.js";
16
+ import { useActiveWalletConnectionStatus } from "../../hooks/wallets/useActiveWalletConnectionStatus.js";
17
+ import { useAutoConnect } from "../../hooks/wallets/useAutoConnect.js";
18
+ import { ThemedButton } from "../components/button.js";
19
+ import { ThemedSpinner } from "../components/spinner.js";
20
+ import { ThemedText } from "../components/text.js";
21
+ import { ConnectModal } from "./ConnectModal.js";
22
+ import { ConnectedButton } from "./ConnectedButton.js";
23
+ import { ConnectedModal } from "./ConnectedModal.js";
24
+
25
+ /**
26
+ * A component that allows the user to connect their wallet.
27
+ * It renders a button which when clicked opens a modal to allow users to connect to wallets specified in `wallets` prop.
28
+ * @example
29
+ * ```tsx
30
+ * <ConnectButton
31
+ * client={client}
32
+ * />
33
+ * ```
34
+ * @param props
35
+ * Props for the `ConnectButton` component
36
+ *
37
+ * Refer to [ConnectButtonProps](https://portal.thirdweb.com/references/typescript/v5/ConnectButtonProps) to see the available props.
38
+ * @component
39
+ */
40
+ export function ConnectButton(props: ConnectButtonProps) {
41
+ const theme = parseTheme(props.theme);
42
+ const [visible, setVisible] = useState(false);
43
+ const wallet = useActiveWallet();
44
+ const account = useActiveAccount();
45
+ const status = useActiveWalletConnectionStatus();
46
+ useAutoConnect(props);
47
+
48
+ const fadeAnim = useRef(new Animated.Value(0)); // For background opacity
49
+ const slideAnim = useRef(new Animated.Value(screenHeight)); // For bottom sheet position
50
+
51
+ const openModal = useCallback(() => {
52
+ setVisible(true);
53
+ Animated.parallel([
54
+ Animated.timing(fadeAnim.current, {
55
+ toValue: 1,
56
+ duration: 300,
57
+ useNativeDriver: true,
58
+ }),
59
+ Animated.timing(slideAnim.current, {
60
+ toValue: 0,
61
+ duration: 300,
62
+ useNativeDriver: true,
63
+ easing: Easing.out(Easing.exp),
64
+ }),
65
+ ]).start();
66
+ }, []);
67
+
68
+ const closeModal = useCallback(() => {
69
+ Animated.parallel([
70
+ Animated.timing(fadeAnim.current, {
71
+ toValue: 0,
72
+ duration: 300,
73
+ useNativeDriver: true,
74
+ }),
75
+ Animated.timing(slideAnim.current, {
76
+ toValue: screenHeight,
77
+ duration: 300,
78
+ useNativeDriver: true,
79
+ easing: Easing.in(Easing.exp),
80
+ }),
81
+ ]).start(() => {
82
+ setVisible(false);
83
+ fadeAnim.current.setValue(0);
84
+ slideAnim.current.setValue(screenHeight);
85
+ });
86
+ }, []);
87
+
88
+ return (
89
+ <View>
90
+ {wallet && account ? (
91
+ <ConnectedButton
92
+ openModal={() => openModal()}
93
+ onClose={closeModal}
94
+ wallet={wallet}
95
+ account={account}
96
+ {...props}
97
+ />
98
+ ) : (
99
+ <ThemedButton theme={theme} onPress={() => openModal()}>
100
+ {status === "connecting" ? (
101
+ <>
102
+ <ThemedSpinner color={theme.colors.primaryButtonText} />
103
+ </>
104
+ ) : (
105
+ <ThemedText
106
+ theme={theme}
107
+ type="defaultSemiBold"
108
+ style={{ color: theme.colors.primaryButtonText }}
109
+ >
110
+ Connect Wallet
111
+ </ThemedText>
112
+ )}
113
+ </ThemedButton>
114
+ )}
115
+ <Modal
116
+ visible={visible}
117
+ animationType="none"
118
+ transparent={true}
119
+ onRequestClose={closeModal}
120
+ >
121
+ <KeyboardAvoidingView behavior={"padding"} style={{ flex: 1 }}>
122
+ <Animated.View
123
+ style={[styles.modalOverlay, { opacity: fadeAnim.current }]}
124
+ />
125
+ <Animated.View
126
+ style={[
127
+ { flex: 1, transform: [{ translateY: slideAnim.current }] },
128
+ ]}
129
+ >
130
+ <Pressable style={styles.dismissArea} onPress={closeModal} />
131
+ <View style={styles.bottomSheetContainer}>
132
+ {wallet && account ? (
133
+ <ConnectedModal
134
+ {...props}
135
+ theme={theme}
136
+ onClose={closeModal}
137
+ containerType="modal"
138
+ wallet={wallet}
139
+ account={account}
140
+ />
141
+ ) : status === "connecting" ? (
142
+ <View
143
+ style={{
144
+ flexDirection: "column",
145
+ flex: 1,
146
+ alignItems: "center",
147
+ justifyContent: "center",
148
+ }}
149
+ >
150
+ <ThemedSpinner color={theme.colors.primaryText} size={32} />
151
+ </View>
152
+ ) : (
153
+ <ConnectModal
154
+ {...props}
155
+ theme={theme}
156
+ onClose={closeModal}
157
+ containerType="modal"
158
+ />
159
+ )}
160
+ </View>
161
+ </Animated.View>
162
+ </KeyboardAvoidingView>
163
+ </Modal>
164
+ </View>
165
+ );
166
+ }
167
+
168
+ const screenHeight = Dimensions.get("window").height;
169
+ const modalHeight = 480;
170
+ const screenWidth = Dimensions.get("window").width;
171
+
172
+ const styles = StyleSheet.create({
173
+ modalOverlay: {
174
+ position: "absolute",
175
+ width: screenWidth,
176
+ height: screenHeight,
177
+ backgroundColor: "rgba(0,0,0,0.8)",
178
+ },
179
+ dismissArea: {
180
+ width: "100%",
181
+ flex: 1,
182
+ },
183
+ bottomSheetContainer: {
184
+ height: modalHeight,
185
+ width: screenWidth,
186
+ flexDirection: "column",
187
+ },
188
+ });
@@ -0,0 +1,298 @@
1
+ import { useState } from "react";
2
+ import { Platform, StyleSheet, View } from "react-native";
3
+ import { SvgXml } from "react-native-svg";
4
+ import type { MultiStepAuthProviderType } from "../../../../wallets/in-app/core/authentication/type.js";
5
+ import type { Wallet } from "../../../../wallets/interfaces/wallet.js";
6
+ import { parseTheme } from "../../../core/design-system/CustomThemeProvider.js";
7
+ import type { Theme } from "../../../core/design-system/index.js";
8
+ import type { ConnectButtonProps } from "../../../core/hooks/connection/ConnectButtonProps.js";
9
+ import type { ConnectEmbedProps } from "../../../core/hooks/connection/ConnectEmbedProps.js";
10
+ import { genericWalletIcon } from "../../../core/utils/socialIcons.js";
11
+ import { radius, spacing } from "../../design-system/index.js";
12
+ import { useActiveWallet } from "../../hooks/wallets/useActiveWallet.js";
13
+ import { useConnect } from "../../hooks/wallets/useConnect.js";
14
+ import { getDefaultWallets } from "../../wallets/defaultWallets.js";
15
+ import { type ContainerType, Header } from "../components/Header.js";
16
+ import { ThemedButtonWithIcon } from "../components/button.js";
17
+ import { Spacer } from "../components/spacer.js";
18
+ import { ThemedText } from "../components/text.js";
19
+ import { ThemedView } from "../components/view.js";
20
+ import { TW_ICON } from "../icons/svgs.js";
21
+ import { ExternalWalletsList } from "./ExternalWalletsList.js";
22
+ import { InAppWalletUI, OtpLogin } from "./InAppWalletUI.js";
23
+
24
+ export type ModalState =
25
+ | { screen: "base" }
26
+ | { screen: "otp"; auth: MultiStepAuthProviderType; wallet: Wallet<"inApp"> }
27
+ | { screen: "external_wallets" };
28
+
29
+ /**
30
+ * A component that allows the user to connect their wallet.
31
+ *
32
+ * it renders the same UI as the [`ConnectButton`](https://portal.thirdweb.com/react/v4/components/ConnectButton) component's modal - but directly on the page instead of being in a modal.
33
+ *
34
+ * It only renders UI if wallet is not connected
35
+ * @example
36
+ * ```tsx
37
+ * <ConnectEmbed
38
+ * client={client}
39
+ * />
40
+ * ```
41
+ * @param props -
42
+ * The props for the `ConnectEmbed` component.
43
+ *
44
+ * Refer to the [`ConnectEmbedProps`](https://portal.thirdweb.com/references/typescript/v5/ConnectEmbedProps) type for more details
45
+ * @component
46
+ */
47
+ export function ConnectEmbed(props: ConnectEmbedProps) {
48
+ const theme = parseTheme(props.theme);
49
+ const wallet = useActiveWallet();
50
+ const adaptedProps = {
51
+ ...props,
52
+ connectModal: { ...props },
53
+ } as ConnectButtonProps;
54
+ return wallet ? null : (
55
+ <ConnectModal {...adaptedProps} theme={theme} containerType="embed" />
56
+ );
57
+ }
58
+
59
+ export function ConnectModal(
60
+ props: ConnectButtonProps & {
61
+ theme: Theme;
62
+ onClose?: () => void;
63
+ containerType: ContainerType;
64
+ },
65
+ ) {
66
+ const { theme, client, containerType, accountAbstraction, onConnect } = props;
67
+ const connectMutation = useConnect({
68
+ client,
69
+ accountAbstraction,
70
+ onConnect,
71
+ });
72
+ const wallets = props.wallets || getDefaultWallets(props);
73
+ const [modalState, setModalState] = useState<ModalState>({ screen: "base" });
74
+ const inAppWallet = wallets.find((wallet) => wallet.id === "inApp") as
75
+ | Wallet<"inApp">
76
+ | undefined;
77
+ const externalWallets = wallets.filter((wallet) => wallet.id !== "inApp");
78
+ const showBranding = props.connectModal?.showThirdwebBranding !== false;
79
+ let content: JSX.Element;
80
+
81
+ switch (modalState.screen) {
82
+ case "otp": {
83
+ content = (
84
+ <>
85
+ <Header
86
+ theme={theme}
87
+ onClose={props.onClose}
88
+ containerType={containerType}
89
+ onBack={() => setModalState({ screen: "base" })}
90
+ />
91
+ <Spacer size="xl" />
92
+ <View
93
+ style={{
94
+ flexDirection: "column",
95
+ gap: spacing.md,
96
+ paddingHorizontal: containerType === "modal" ? spacing.lg : 0,
97
+ }}
98
+ >
99
+ <OtpLogin
100
+ auth={modalState.auth}
101
+ wallet={modalState.wallet}
102
+ client={client}
103
+ setScreen={setModalState}
104
+ theme={theme}
105
+ connectMutation={connectMutation}
106
+ />
107
+ </View>
108
+ {containerType === "modal" ? (
109
+ <View style={{ flex: 1 }} />
110
+ ) : (
111
+ <Spacer size="md" />
112
+ )}
113
+ </>
114
+ );
115
+ break;
116
+ }
117
+ case "external_wallets": {
118
+ content = (
119
+ <>
120
+ <Header
121
+ theme={theme}
122
+ onClose={props.onClose}
123
+ containerType={containerType}
124
+ onBack={() => setModalState({ screen: "base" })}
125
+ />
126
+ <Spacer size="lg" />
127
+ <ExternalWalletsList
128
+ theme={theme}
129
+ externalWallets={externalWallets}
130
+ client={client}
131
+ connectMutation={connectMutation}
132
+ containerType={containerType}
133
+ />
134
+ </>
135
+ );
136
+ break;
137
+ }
138
+ default: {
139
+ content = (
140
+ <>
141
+ <Header
142
+ theme={theme}
143
+ onClose={props.onClose}
144
+ containerType={containerType}
145
+ />
146
+ {inAppWallet ? (
147
+ <>
148
+ {containerType === "modal" ? (
149
+ <View style={{ flex: 1 }} />
150
+ ) : (
151
+ <Spacer size="lg" />
152
+ )}
153
+ <View
154
+ style={{
155
+ flexDirection: "column",
156
+ gap: spacing.md,
157
+ paddingHorizontal: containerType === "modal" ? spacing.lg : 0,
158
+ }}
159
+ >
160
+ <InAppWalletUI
161
+ wallet={inAppWallet}
162
+ setScreen={setModalState}
163
+ client={client}
164
+ theme={theme}
165
+ connectMutation={connectMutation}
166
+ />
167
+ {externalWallets.length > 0 ? (
168
+ <>
169
+ <OrDivider theme={theme} />
170
+ <ThemedButtonWithIcon
171
+ theme={theme}
172
+ icon={genericWalletIcon}
173
+ title="Connect a wallet"
174
+ onPress={() =>
175
+ setModalState({ screen: "external_wallets" })
176
+ }
177
+ />
178
+ </>
179
+ ) : null}
180
+ </View>
181
+ {containerType === "modal" ? (
182
+ <View style={{ flex: 1 }} />
183
+ ) : (
184
+ <Spacer size="md" />
185
+ )}
186
+ </>
187
+ ) : externalWallets.length > 0 ? (
188
+ <>
189
+ <Spacer size="lg" />
190
+ <View
191
+ style={{
192
+ flex: 1,
193
+ }}
194
+ >
195
+ <ExternalWalletsList
196
+ theme={theme}
197
+ externalWallets={externalWallets}
198
+ client={client}
199
+ connectMutation={connectMutation}
200
+ containerType={containerType}
201
+ />
202
+ </View>
203
+ </>
204
+ ) : null}
205
+ </>
206
+ );
207
+ }
208
+ }
209
+
210
+ return (
211
+ <ThemedView
212
+ theme={theme}
213
+ style={
214
+ containerType === "modal"
215
+ ? styles.modalContainer
216
+ : styles.embedContainer
217
+ }
218
+ >
219
+ {content}
220
+ {showBranding && <PoweredByThirdweb theme={theme} />}
221
+ </ThemedView>
222
+ );
223
+ }
224
+
225
+ function OrDivider({ theme }: { theme: Theme }) {
226
+ return (
227
+ <View
228
+ style={{
229
+ flexDirection: "row",
230
+ alignItems: "center",
231
+ justifyContent: "center",
232
+ gap: spacing.lg,
233
+ }}
234
+ >
235
+ <View
236
+ style={{
237
+ flex: 1,
238
+ height: 1,
239
+ backgroundColor: theme.colors.borderColor,
240
+ }}
241
+ />
242
+ <ThemedText theme={theme} style={{ color: theme.colors.secondaryText }}>
243
+ OR
244
+ </ThemedText>
245
+ <View
246
+ style={{
247
+ flex: 1,
248
+ height: 1,
249
+ backgroundColor: theme.colors.borderColor,
250
+ }}
251
+ />
252
+ </View>
253
+ );
254
+ }
255
+
256
+ function PoweredByThirdweb({ theme }: { theme: Theme }) {
257
+ return (
258
+ <View
259
+ style={{
260
+ flexDirection: "row",
261
+ justifyContent: "center",
262
+ alignItems: "center",
263
+ gap: spacing.xs,
264
+ paddingBottom: Platform.OS === "android" ? spacing.md : spacing.lg,
265
+ }}
266
+ >
267
+ <ThemedText theme={theme} type="subtext">
268
+ Powered by
269
+ </ThemedText>
270
+ <SvgXml
271
+ xml={TW_ICON}
272
+ width={22}
273
+ height={22}
274
+ style={{ marginBottom: -2 }}
275
+ color={theme.colors.secondaryText}
276
+ />
277
+ <ThemedText theme={theme} type="subtext" style={{ fontWeight: "600" }}>
278
+ thirdweb
279
+ </ThemedText>
280
+ </View>
281
+ );
282
+ }
283
+
284
+ const styles = StyleSheet.create({
285
+ modalContainer: {
286
+ flex: 1,
287
+ width: "100%",
288
+ flexDirection: "column",
289
+ borderTopLeftRadius: radius.lg,
290
+ borderTopRightRadius: radius.lg,
291
+ },
292
+ embedContainer: {
293
+ flex: 1,
294
+ width: "100%",
295
+ flexDirection: "column",
296
+ backgroundColor: "transparent",
297
+ },
298
+ });