@daimo/pay 1.15.0 → 1.16.1

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 (375) hide show
  1. package/build/components/DaimoPayButton/index.d.ts +13 -0
  2. package/build/hooks/useConnect.d.ts +8 -8
  3. package/build/hooks/useLocales.d.ts +2 -1
  4. package/build/hooks/useWalletPaymentOptions.d.ts +12 -1
  5. package/build/index.d.ts +626 -15
  6. package/build/localizations/locales/en-US.d.ts +2 -0
  7. package/build/localizations/locales/index.d.ts +1 -0
  8. package/build/package.json.js +6 -4
  9. package/build/package.json.js.map +1 -1
  10. package/build/payment/paymentFsm.d.ts +5 -0
  11. package/build/payment/paymentUtils.d.ts +6 -0
  12. package/build/src/assets/MobileWithLogos.js +320 -1
  13. package/build/src/assets/MobileWithLogos.js.map +1 -1
  14. package/build/src/assets/ScanIconWithLogos.js +216 -10
  15. package/build/src/assets/ScanIconWithLogos.js.map +1 -1
  16. package/build/src/assets/browsers.js +963 -7
  17. package/build/src/assets/browsers.js.map +1 -1
  18. package/build/src/assets/chains.js +633 -103
  19. package/build/src/assets/chains.js.map +1 -1
  20. package/build/src/assets/coins.js +38 -1
  21. package/build/src/assets/coins.js.map +1 -1
  22. package/build/src/assets/crepe.js +35 -1
  23. package/build/src/assets/crepe.js.map +1 -1
  24. package/build/src/assets/icons.js +258 -15
  25. package/build/src/assets/icons.js.map +1 -1
  26. package/build/src/assets/logos.js +1510 -140
  27. package/build/src/assets/logos.js.map +1 -1
  28. package/build/src/assets/wallet.js +32 -1
  29. package/build/src/assets/wallet.js.map +1 -1
  30. package/build/src/assets/wave.js +41 -1
  31. package/build/src/assets/wave.js.map +1 -1
  32. package/build/src/components/Common/Alert/index.js +4 -1
  33. package/build/src/components/Common/Alert/index.js.map +1 -1
  34. package/build/src/components/Common/Alert/styles.js +4 -4
  35. package/build/src/components/Common/Alert/styles.js.map +1 -1
  36. package/build/src/components/Common/AmountInput/AmountInputField.js +29 -18
  37. package/build/src/components/Common/AmountInput/AmountInputField.js.map +1 -1
  38. package/build/src/components/Common/AmountInput/index.js +112 -99
  39. package/build/src/components/Common/AmountInput/index.js.map +1 -1
  40. package/build/src/components/Common/Avatar/index.js +63 -51
  41. package/build/src/components/Common/Avatar/index.js.map +1 -1
  42. package/build/src/components/Common/Avatar/styles.js +9 -14
  43. package/build/src/components/Common/Avatar/styles.js.map +1 -1
  44. package/build/src/components/Common/BrowserIcon/index.js +15 -14
  45. package/build/src/components/Common/BrowserIcon/index.js.map +1 -1
  46. package/build/src/components/Common/BrowserIcon/styles.js +1 -1
  47. package/build/src/components/Common/BrowserIcon/styles.js.map +1 -1
  48. package/build/src/components/Common/Button/index.js +131 -25
  49. package/build/src/components/Common/Button/index.js.map +1 -1
  50. package/build/src/components/Common/Button/styles.js +20 -24
  51. package/build/src/components/Common/Button/styles.js.map +1 -1
  52. package/build/src/components/Common/Chain/index.js +130 -14
  53. package/build/src/components/Common/Chain/index.js.map +1 -1
  54. package/build/src/components/Common/Chain/styles.js +9 -13
  55. package/build/src/components/Common/Chain/styles.js.map +1 -1
  56. package/build/src/components/Common/ChainSelectList/index.js +232 -89
  57. package/build/src/components/Common/ChainSelectList/index.js.map +1 -1
  58. package/build/src/components/Common/ChainSelectList/styles.js +11 -13
  59. package/build/src/components/Common/ChainSelectList/styles.js.map +1 -1
  60. package/build/src/components/Common/CircleTimer.js +85 -41
  61. package/build/src/components/Common/CircleTimer.js.map +1 -1
  62. package/build/src/components/Common/ConnectorList/index.js +106 -80
  63. package/build/src/components/Common/ConnectorList/index.js.map +1 -1
  64. package/build/src/components/Common/ConnectorList/styles.js +28 -36
  65. package/build/src/components/Common/ConnectorList/styles.js.map +1 -1
  66. package/build/src/components/Common/CopyToClipboard/CopyToClipboardIcon.js +16 -9
  67. package/build/src/components/Common/CopyToClipboard/CopyToClipboardIcon.js.map +1 -1
  68. package/build/src/components/Common/CopyToClipboard/index.js +3 -5
  69. package/build/src/components/Common/CopyToClipboard/index.js.map +1 -1
  70. package/build/src/components/Common/CustomQRCode/QRCode.js +120 -57
  71. package/build/src/components/Common/CustomQRCode/QRCode.js.map +1 -1
  72. package/build/src/components/Common/CustomQRCode/index.js +60 -10
  73. package/build/src/components/Common/CustomQRCode/index.js.map +1 -1
  74. package/build/src/components/Common/CustomQRCode/styles.js +6 -6
  75. package/build/src/components/Common/CustomQRCode/styles.js.map +1 -1
  76. package/build/src/components/Common/FitText/index.js +24 -17
  77. package/build/src/components/Common/FitText/index.js.map +1 -1
  78. package/build/src/components/Common/Modal/index.js +481 -267
  79. package/build/src/components/Common/Modal/index.js.map +1 -1
  80. package/build/src/components/Common/Modal/styles.js +44 -48
  81. package/build/src/components/Common/Modal/styles.js.map +1 -1
  82. package/build/src/components/Common/OptionsList/index.js +75 -33
  83. package/build/src/components/Common/OptionsList/index.js.map +1 -1
  84. package/build/src/components/Common/OptionsList/styles.js +7 -8
  85. package/build/src/components/Common/OptionsList/styles.js.map +1 -1
  86. package/build/src/components/Common/OrderHeader/index.js +109 -65
  87. package/build/src/components/Common/OrderHeader/index.js.map +1 -1
  88. package/build/src/components/Common/PaymentBreakdown/index.js +29 -7
  89. package/build/src/components/Common/PaymentBreakdown/index.js.map +1 -1
  90. package/build/src/components/Common/Portal/index.js +21 -22
  91. package/build/src/components/Common/Portal/index.js.map +1 -1
  92. package/build/src/components/Common/PoweredByFooter/index.js +39 -21
  93. package/build/src/components/Common/PoweredByFooter/index.js.map +1 -1
  94. package/build/src/components/Common/ScrollArea/index.js +107 -52
  95. package/build/src/components/Common/ScrollArea/index.js.map +1 -1
  96. package/build/src/components/Common/ScrollArea/styles.js +7 -11
  97. package/build/src/components/Common/ScrollArea/styles.js.map +1 -1
  98. package/build/src/components/Common/SelectAnotherMethodButton/index.js +67 -55
  99. package/build/src/components/Common/SelectAnotherMethodButton/index.js.map +1 -1
  100. package/build/src/components/Common/Spinner/index.js +56 -16
  101. package/build/src/components/Common/Spinner/index.js.map +1 -1
  102. package/build/src/components/Common/Spinner/styles.js +2 -2
  103. package/build/src/components/Common/Spinner/styles.js.map +1 -1
  104. package/build/src/components/Common/SwitchButton/index.js +18 -15
  105. package/build/src/components/Common/SwitchButton/index.js.map +1 -1
  106. package/build/src/components/Common/ThemedButton/index.js +37 -16
  107. package/build/src/components/Common/ThemedButton/index.js.map +1 -1
  108. package/build/src/components/Common/ThemedButton/styles.js +2 -2
  109. package/build/src/components/Common/ThemedButton/styles.js.map +1 -1
  110. package/build/src/components/Common/TokenChainLogo/index.js +14 -8
  111. package/build/src/components/Common/TokenChainLogo/index.js.map +1 -1
  112. package/build/src/components/Common/Tooltip/index.js +115 -83
  113. package/build/src/components/Common/Tooltip/index.js.map +1 -1
  114. package/build/src/components/Common/Tooltip/styles.js +8 -8
  115. package/build/src/components/Common/Tooltip/styles.js.map +1 -1
  116. package/build/src/components/Common/WalletChainLogo/index.js +13 -6
  117. package/build/src/components/Common/WalletChainLogo/index.js.map +1 -1
  118. package/build/src/components/DaimoPayButton/index.js +170 -176
  119. package/build/src/components/DaimoPayButton/index.js.map +1 -1
  120. package/build/src/components/DaimoPayButton/styles.js +4 -4
  121. package/build/src/components/DaimoPayButton/styles.js.map +1 -1
  122. package/build/src/components/DaimoPayModal/ConnectUsing.js +50 -24
  123. package/build/src/components/DaimoPayModal/ConnectUsing.js.map +1 -1
  124. package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js +303 -163
  125. package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js.map +1 -1
  126. package/build/src/components/DaimoPayModal/ConnectWithInjector/styles.js +10 -12
  127. package/build/src/components/DaimoPayModal/ConnectWithInjector/styles.js.map +1 -1
  128. package/build/src/components/DaimoPayModal/ConnectWithQRCode.js +69 -39
  129. package/build/src/components/DaimoPayModal/ConnectWithQRCode.js.map +1 -1
  130. package/build/src/components/DaimoPayModal/index.js +409 -416
  131. package/build/src/components/DaimoPayModal/index.js.map +1 -1
  132. package/build/src/components/DaimoPayThemeProvider/DaimoPayThemeProvider.js +15 -11
  133. package/build/src/components/DaimoPayThemeProvider/DaimoPayThemeProvider.js.map +1 -1
  134. package/build/src/components/Pages/About/graphics.js +796 -130
  135. package/build/src/components/Pages/About/graphics.js.map +1 -1
  136. package/build/src/components/Pages/About/index.js +203 -110
  137. package/build/src/components/Pages/About/index.js.map +1 -1
  138. package/build/src/components/Pages/About/styles.js +11 -15
  139. package/build/src/components/Pages/About/styles.js.map +1 -1
  140. package/build/src/components/Pages/Confirmation/index.js +72 -41
  141. package/build/src/components/Pages/Confirmation/index.js.map +1 -1
  142. package/build/src/components/Pages/Connectors/index.js +50 -16
  143. package/build/src/components/Pages/Connectors/index.js.map +1 -1
  144. package/build/src/components/Pages/Connectors/styles.js +10 -10
  145. package/build/src/components/Pages/Connectors/styles.js.map +1 -1
  146. package/build/src/components/Pages/DownloadApp/index.js +23 -18
  147. package/build/src/components/Pages/DownloadApp/index.js.map +1 -1
  148. package/build/src/components/Pages/Error/index.js +27 -15
  149. package/build/src/components/Pages/Error/index.js.map +1 -1
  150. package/build/src/components/Pages/MobileConnectors/index.js +50 -44
  151. package/build/src/components/Pages/MobileConnectors/index.js.map +1 -1
  152. package/build/src/components/Pages/MobileConnectors/styles.js +9 -11
  153. package/build/src/components/Pages/MobileConnectors/styles.js.map +1 -1
  154. package/build/src/components/Pages/Onboarding/index.js +20 -4
  155. package/build/src/components/Pages/Onboarding/index.js.map +1 -1
  156. package/build/src/components/Pages/Onboarding/styles.js +13 -13
  157. package/build/src/components/Pages/Onboarding/styles.js.map +1 -1
  158. package/build/src/components/Pages/PayWithToken/index.js +133 -122
  159. package/build/src/components/Pages/PayWithToken/index.js.map +1 -1
  160. package/build/src/components/Pages/SelectAmount/index.js +12 -5
  161. package/build/src/components/Pages/SelectAmount/index.js.map +1 -1
  162. package/build/src/components/Pages/SelectDepositAddressAmount/index.js +56 -38
  163. package/build/src/components/Pages/SelectDepositAddressAmount/index.js.map +1 -1
  164. package/build/src/components/Pages/SelectDepositAddressChain/index.js +57 -40
  165. package/build/src/components/Pages/SelectDepositAddressChain/index.js.map +1 -1
  166. package/build/src/components/Pages/SelectExchange/index.js +29 -24
  167. package/build/src/components/Pages/SelectExchange/index.js.map +1 -1
  168. package/build/src/components/Pages/SelectExternalAmount/index.js +57 -41
  169. package/build/src/components/Pages/SelectExternalAmount/index.js.map +1 -1
  170. package/build/src/components/Pages/SelectMethod/index.js +201 -183
  171. package/build/src/components/Pages/SelectMethod/index.js.map +1 -1
  172. package/build/src/components/Pages/SelectToken/index.js +72 -46
  173. package/build/src/components/Pages/SelectToken/index.js.map +1 -1
  174. package/build/src/components/Pages/SelectWalletAmount/index.js +40 -32
  175. package/build/src/components/Pages/SelectWalletAmount/index.js.map +1 -1
  176. package/build/src/components/Pages/SelectWalletChain/index.js +40 -36
  177. package/build/src/components/Pages/SelectWalletChain/index.js.map +1 -1
  178. package/build/src/components/Pages/SelectZKP/index.js +29 -24
  179. package/build/src/components/Pages/SelectZKP/index.js.map +1 -1
  180. package/build/src/components/Pages/Solana/ConnectorSolana/index.js +60 -45
  181. package/build/src/components/Pages/Solana/ConnectorSolana/index.js.map +1 -1
  182. package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js +73 -61
  183. package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js.map +1 -1
  184. package/build/src/components/Pages/Solana/SelectSolanaAmount/index.js +12 -5
  185. package/build/src/components/Pages/Solana/SelectSolanaAmount/index.js.map +1 -1
  186. package/build/src/components/Pages/SwitchNetworks/index.js +29 -10
  187. package/build/src/components/Pages/SwitchNetworks/index.js.map +1 -1
  188. package/build/src/components/Pages/WaitingDepositAddress/index.js +339 -178
  189. package/build/src/components/Pages/WaitingDepositAddress/index.js.map +1 -1
  190. package/build/src/components/Pages/WaitingExternal/index.js +69 -46
  191. package/build/src/components/Pages/WaitingExternal/index.js.map +1 -1
  192. package/build/src/components/Pages/WaitingWallet/index.js +37 -16
  193. package/build/src/components/Pages/WaitingWallet/index.js.map +1 -1
  194. package/build/src/components/Spinners/CircleSpinner/index.js +96 -7
  195. package/build/src/components/Spinners/CircleSpinner/index.js.map +1 -1
  196. package/build/src/components/Spinners/CircleSpinner/styles.js +6 -7
  197. package/build/src/components/Spinners/CircleSpinner/styles.js.map +1 -1
  198. package/build/src/components/Spinners/ExternalPaymentSpinner/index.js +18 -9
  199. package/build/src/components/Spinners/ExternalPaymentSpinner/index.js.map +1 -1
  200. package/build/src/components/Spinners/SquircleSpinner/index.js +60 -7
  201. package/build/src/components/Spinners/SquircleSpinner/index.js.map +1 -1
  202. package/build/src/components/Spinners/SquircleSpinner/styles.js +4 -4
  203. package/build/src/components/Spinners/SquircleSpinner/styles.js.map +1 -1
  204. package/build/src/components/Spinners/TokenLogoSpinner/index.js +12 -1
  205. package/build/src/components/Spinners/TokenLogoSpinner/index.js.map +1 -1
  206. package/build/src/components/Spinners/TokenLogoSpinner/styles.js +1 -1
  207. package/build/src/components/Spinners/TokenLogoSpinner/styles.js.map +1 -1
  208. package/build/src/components/Spinners/WalletPaymentSpinner/index.js +27 -20
  209. package/build/src/components/Spinners/WalletPaymentSpinner/index.js.map +1 -1
  210. package/build/src/components/Spinners/styles.js +3 -4
  211. package/build/src/components/Spinners/styles.js.map +1 -1
  212. package/build/src/constants/defaultTheme.js +1 -1
  213. package/build/src/constants/defaultTheme.js.map +1 -1
  214. package/build/src/constants/routes.js +29 -30
  215. package/build/src/constants/routes.js.map +1 -1
  216. package/build/src/defaultConfig.js +49 -46
  217. package/build/src/defaultConfig.js.map +1 -1
  218. package/build/src/defaultConnectors.js +32 -19
  219. package/build/src/defaultConnectors.js.map +1 -1
  220. package/build/src/hooks/useChainIsSupported.js +3 -5
  221. package/build/src/hooks/useChainIsSupported.js.map +1 -1
  222. package/build/src/hooks/useChains.js +3 -4
  223. package/build/src/hooks/useChains.js.map +1 -1
  224. package/build/src/hooks/useConnect.js +51 -39
  225. package/build/src/hooks/useConnect.js.map +1 -1
  226. package/build/src/hooks/useConnectCallback.js +15 -12
  227. package/build/src/hooks/useConnectCallback.js.map +1 -1
  228. package/build/src/hooks/useConnectors.js +2 -2
  229. package/build/src/hooks/useConnectors.js.map +1 -1
  230. package/build/src/hooks/useDaimoPay.js +98 -82
  231. package/build/src/hooks/useDaimoPay.js.map +1 -1
  232. package/build/src/hooks/useDaimoPayStatus.js +4 -15
  233. package/build/src/hooks/useDaimoPayStatus.js.map +1 -1
  234. package/build/src/hooks/useDaimoPayUI.js +7 -7
  235. package/build/src/hooks/useDaimoPayUI.js.map +1 -1
  236. package/build/src/hooks/useDepositAddressOptions.js +29 -25
  237. package/build/src/hooks/useDepositAddressOptions.js.map +1 -1
  238. package/build/src/hooks/useEnsFallbackConfig.js +5 -5
  239. package/build/src/hooks/useEnsFallbackConfig.js.map +1 -1
  240. package/build/src/hooks/useExternalPaymentOptions.js +57 -52
  241. package/build/src/hooks/useExternalPaymentOptions.js.map +1 -1
  242. package/build/src/hooks/useFitText.js +120 -135
  243. package/build/src/hooks/useFitText.js.map +1 -1
  244. package/build/src/hooks/useFocusTrap.js +33 -37
  245. package/build/src/hooks/useFocusTrap.js.map +1 -1
  246. package/build/src/hooks/useIsMobile.js +3 -3
  247. package/build/src/hooks/useIsMobile.js.map +1 -1
  248. package/build/src/hooks/useIsMounted.js +3 -5
  249. package/build/src/hooks/useIsMounted.js.map +1 -1
  250. package/build/src/hooks/useLastConnector.js +15 -15
  251. package/build/src/hooks/useLastConnector.js.map +1 -1
  252. package/build/src/hooks/useLocales.js +44 -42
  253. package/build/src/hooks/useLocales.js.map +1 -1
  254. package/build/src/hooks/useLockBodyScroll.js +38 -44
  255. package/build/src/hooks/useLockBodyScroll.js.map +1 -1
  256. package/build/src/hooks/useOrderUsdLimits.js +17 -19
  257. package/build/src/hooks/useOrderUsdLimits.js.map +1 -1
  258. package/build/src/hooks/usePayContext.js +3 -5
  259. package/build/src/hooks/usePayContext.js.map +1 -1
  260. package/build/src/hooks/usePaymentState.js +351 -321
  261. package/build/src/hooks/usePaymentState.js.map +1 -1
  262. package/build/src/hooks/usePrevious.js +6 -7
  263. package/build/src/hooks/usePrevious.js.map +1 -1
  264. package/build/src/hooks/useSolanaPaymentOptions.js +33 -33
  265. package/build/src/hooks/useSolanaPaymentOptions.js.map +1 -1
  266. package/build/src/hooks/useTokenOptions.js +131 -95
  267. package/build/src/hooks/useTokenOptions.js.map +1 -1
  268. package/build/src/hooks/useUntronAvailability.js +26 -34
  269. package/build/src/hooks/useUntronAvailability.js.map +1 -1
  270. package/build/src/hooks/useWalletPaymentOptions.js +86 -61
  271. package/build/src/hooks/useWalletPaymentOptions.js.map +1 -1
  272. package/build/src/hooks/useWindowSize.js +16 -16
  273. package/build/src/hooks/useWindowSize.js.map +1 -1
  274. package/build/src/localizations/index.js +28 -31
  275. package/build/src/localizations/index.js.map +1 -1
  276. package/build/src/localizations/locales/ar-AE.js +88 -88
  277. package/build/src/localizations/locales/ar-AE.js.map +1 -1
  278. package/build/src/localizations/locales/ca-AD.js +88 -88
  279. package/build/src/localizations/locales/ca-AD.js.map +1 -1
  280. package/build/src/localizations/locales/ee-EE.js +96 -88
  281. package/build/src/localizations/locales/ee-EE.js.map +1 -1
  282. package/build/src/localizations/locales/en-US.js +134 -124
  283. package/build/src/localizations/locales/en-US.js.map +1 -1
  284. package/build/src/localizations/locales/es-ES.js +126 -124
  285. package/build/src/localizations/locales/es-ES.js.map +1 -1
  286. package/build/src/localizations/locales/fa-IR.js +88 -88
  287. package/build/src/localizations/locales/fa-IR.js.map +1 -1
  288. package/build/src/localizations/locales/fr-FR.js +88 -88
  289. package/build/src/localizations/locales/fr-FR.js.map +1 -1
  290. package/build/src/localizations/locales/ja-JP.js +88 -88
  291. package/build/src/localizations/locales/ja-JP.js.map +1 -1
  292. package/build/src/localizations/locales/pt-BR.js +96 -88
  293. package/build/src/localizations/locales/pt-BR.js.map +1 -1
  294. package/build/src/localizations/locales/ru-RU.js +92 -88
  295. package/build/src/localizations/locales/ru-RU.js.map +1 -1
  296. package/build/src/localizations/locales/tr-TR.js +96 -88
  297. package/build/src/localizations/locales/tr-TR.js.map +1 -1
  298. package/build/src/localizations/locales/vi-VN.js +96 -88
  299. package/build/src/localizations/locales/vi-VN.js.map +1 -1
  300. package/build/src/localizations/locales/zh-CN.js +88 -88
  301. package/build/src/localizations/locales/zh-CN.js.map +1 -1
  302. package/build/src/payment/paymentEffects.js +237 -264
  303. package/build/src/payment/paymentEffects.js.map +1 -1
  304. package/build/src/payment/paymentFsm.js +167 -187
  305. package/build/src/payment/paymentFsm.js.map +1 -1
  306. package/build/src/payment/paymentStore.js +8 -10
  307. package/build/src/payment/paymentStore.js.map +1 -1
  308. package/build/src/payment/paymentUtils.js +10 -0
  309. package/build/src/payment/paymentUtils.js.map +1 -0
  310. package/build/src/provider/DaimoPayProvider.js +258 -245
  311. package/build/src/provider/DaimoPayProvider.js.map +1 -1
  312. package/build/src/provider/PayContext.js +0 -1
  313. package/build/src/provider/PayContext.js.map +1 -1
  314. package/build/src/provider/PaymentProvider.js +18 -17
  315. package/build/src/provider/PaymentProvider.js.map +1 -1
  316. package/build/src/provider/SolanaContextProvider.js +6 -3
  317. package/build/src/provider/SolanaContextProvider.js.map +1 -1
  318. package/build/src/provider/Web3ContextProvider.js +23 -23
  319. package/build/src/provider/Web3ContextProvider.js.map +1 -1
  320. package/build/src/stateStore.js +28 -74
  321. package/build/src/stateStore.js.map +1 -1
  322. package/build/src/styles/defaultTheme.js +64 -73
  323. package/build/src/styles/defaultTheme.js.map +1 -1
  324. package/build/src/styles/index.js +202 -217
  325. package/build/src/styles/index.js.map +1 -1
  326. package/build/src/styles/styled/index.js +0 -10
  327. package/build/src/styles/styled/index.js.map +1 -1
  328. package/build/src/styles/themes/base.js +136 -136
  329. package/build/src/styles/themes/base.js.map +1 -1
  330. package/build/src/styles/themes/index.js.map +1 -1
  331. package/build/src/styles/themes/midnight.js +71 -71
  332. package/build/src/styles/themes/midnight.js.map +1 -1
  333. package/build/src/styles/themes/minimal.js +75 -75
  334. package/build/src/styles/themes/minimal.js.map +1 -1
  335. package/build/src/styles/themes/nouns.js +76 -76
  336. package/build/src/styles/themes/nouns.js.map +1 -1
  337. package/build/src/styles/themes/retro.js +88 -88
  338. package/build/src/styles/themes/retro.js.map +1 -1
  339. package/build/src/styles/themes/rounded.js +84 -84
  340. package/build/src/styles/themes/rounded.js.map +1 -1
  341. package/build/src/styles/themes/soft.js +66 -66
  342. package/build/src/styles/themes/soft.js.map +1 -1
  343. package/build/src/styles/themes/web95.js +95 -95
  344. package/build/src/styles/themes/web95.js.map +1 -1
  345. package/build/src/utils/exports.js +0 -1
  346. package/build/src/utils/exports.js.map +1 -1
  347. package/build/src/utils/format.js +25 -63
  348. package/build/src/utils/format.js.map +1 -1
  349. package/build/src/utils/index.js +23 -20
  350. package/build/src/utils/index.js.map +1 -1
  351. package/build/src/utils/p3.js +8 -9
  352. package/build/src/utils/p3.js.map +1 -1
  353. package/build/src/utils/platform.js +6 -8
  354. package/build/src/utils/platform.js.map +1 -1
  355. package/build/src/utils/polling.js +31 -31
  356. package/build/src/utils/polling.js.map +1 -1
  357. package/build/src/utils/supportUrl.js +9 -9
  358. package/build/src/utils/supportUrl.js.map +1 -1
  359. package/build/src/utils/trpc.js +11 -11
  360. package/build/src/utils/trpc.js.map +1 -1
  361. package/build/src/utils/validateInput.js +9 -29
  362. package/build/src/utils/validateInput.js.map +1 -1
  363. package/build/src/wallets/index.js +13 -22
  364. package/build/src/wallets/index.js.map +1 -1
  365. package/build/src/wallets/useWallets.js +183 -181
  366. package/build/src/wallets/useWallets.js.map +1 -1
  367. package/build/src/wallets/walletConfigs.js +230 -235
  368. package/build/src/wallets/walletConfigs.js.map +1 -1
  369. package/build/src/world-mini-app/WorldPayButton.js +113 -118
  370. package/build/src/world-mini-app/WorldPayButton.js.map +1 -1
  371. package/build/src/world-mini-app/promptWorldPayment.js +49 -47
  372. package/build/src/world-mini-app/promptWorldPayment.js.map +1 -1
  373. package/build/types-7ed033b6.d.ts +66 -0
  374. package/build/world.d.ts +89 -1
  375. package/package.json +6 -4
@@ -15,330 +15,360 @@ import { useSolanaPaymentOptions } from './useSolanaPaymentOptions.js';
15
15
  import { useUntronAvailability } from './useUntronAvailability.js';
16
16
  import { useWalletPaymentOptions } from './useWalletPaymentOptions.js';
17
17
 
18
- function usePaymentState({ trpc, lockPayParams, setRoute, log, redirectReturnUrl, }) {
19
- const pay = useDaimoPay();
20
- // Browser state.
21
- const [platform, setPlatform] = useState();
22
- useEffect(() => {
23
- setPlatform(detectPlatform(window.navigator.userAgent));
24
- }, []);
25
- // Wallet state.
26
- const { address: ethWalletAddress } = useAccount();
27
- const { data: senderEnsName } = useEnsName({
28
- chainId: ethereum.chainId,
29
- address: ethWalletAddress,
30
- });
31
- const { sendTransactionAsync } = useSendTransaction();
32
- const { writeContractAsync } = useWriteContract();
33
- // Solana wallet state.
34
- const solanaWallet = useWallet();
35
- const { connection } = useConnection();
36
- const solanaPubKey = solanaWallet.publicKey?.toBase58();
37
- // Solana bridging is only supported on CCTPv1 chains.
38
- const destChainId = pay.order == null ? null : getOrderDestChainId(pay.order);
39
- const showSolanaPaymentMethod = destChainId != null && isCCTPV1Chain(destChainId);
40
- // From DaimoPayButton props
41
- const [buttonProps, setButtonProps] = useState();
42
- const [currPayParams, setCurrPayParams] = useState();
43
- const [paymentWaitingMessage, setPaymentWaitingMessage] = useState();
44
- const [isDepositFlow, setIsDepositFlow] = useState(false);
45
- // UI state. Selection for external payment (Binance, etc) vs wallet payment.
46
- const externalPaymentOptions = useExternalPaymentOptions({
47
- trpc,
48
- // allow <DaimoPayButton payId={...} paymentOptions={override} />
49
- filterIds: buttonProps?.paymentOptions ?? pay.order?.metadata.payer?.paymentOptions,
50
- platform,
51
- usdRequired: pay.order?.destFinalCallTokenAmount.usd,
52
- mode: pay.order?.mode,
53
- });
54
- const walletPaymentOptions = useWalletPaymentOptions({
55
- trpc,
56
- address: ethWalletAddress,
57
- usdRequired: pay.order?.destFinalCallTokenAmount.usd,
58
- destChainId: pay.order?.destFinalCallTokenAmount.token.chainId,
59
- preferredChains: pay.order?.metadata.payer?.preferredChains,
60
- preferredTokens: pay.order?.metadata.payer?.preferredTokens,
61
- evmChains: pay.order?.metadata.payer?.evmChains,
62
- isDepositFlow,
63
- log,
18
+ function usePaymentState({
19
+ trpc,
20
+ lockPayParams,
21
+ setRoute,
22
+ log,
23
+ redirectReturnUrl
24
+ }) {
25
+ const pay = useDaimoPay();
26
+ const [platform, setPlatform] = useState();
27
+ useEffect(() => {
28
+ setPlatform(detectPlatform(window.navigator.userAgent));
29
+ }, []);
30
+ const { address: ethWalletAddress } = useAccount();
31
+ const { data: senderEnsName } = useEnsName({
32
+ chainId: ethereum.chainId,
33
+ address: ethWalletAddress
34
+ });
35
+ const { sendTransactionAsync } = useSendTransaction();
36
+ const { writeContractAsync } = useWriteContract();
37
+ const solanaWallet = useWallet();
38
+ const { connection } = useConnection();
39
+ const solanaPubKey = solanaWallet.publicKey?.toBase58();
40
+ const destChainId = pay.order == null ? null : getOrderDestChainId(pay.order);
41
+ const showSolanaPaymentMethod = destChainId != null && isCCTPV1Chain(destChainId);
42
+ const [buttonProps, setButtonProps] = useState();
43
+ const [currPayParams, setCurrPayParams] = useState();
44
+ const [paymentWaitingMessage, setPaymentWaitingMessage] = useState();
45
+ const [isDepositFlow, setIsDepositFlow] = useState(false);
46
+ const externalPaymentOptions = useExternalPaymentOptions({
47
+ trpc,
48
+ // allow <DaimoPayButton payId={...} paymentOptions={override} />
49
+ filterIds: buttonProps?.paymentOptions ?? pay.order?.metadata.payer?.paymentOptions,
50
+ platform,
51
+ usdRequired: pay.order?.destFinalCallTokenAmount.usd,
52
+ mode: pay.order?.mode
53
+ });
54
+ const walletPaymentOptions = useWalletPaymentOptions({
55
+ trpc,
56
+ address: ethWalletAddress,
57
+ usdRequired: pay.order?.destFinalCallTokenAmount.usd,
58
+ destChainId: pay.order?.destFinalCallTokenAmount.token.chainId,
59
+ destAddress: pay.order?.destFinalCall.to,
60
+ preferredChains: pay.order?.metadata.payer?.preferredChains,
61
+ preferredTokens: pay.order?.metadata.payer?.preferredTokens,
62
+ evmChains: pay.order?.metadata.payer?.evmChains,
63
+ passthroughTokens: pay.order?.metadata.payer?.passthroughTokens,
64
+ isDepositFlow,
65
+ log
66
+ });
67
+ const solanaPaymentOptions = useSolanaPaymentOptions({
68
+ trpc,
69
+ address: solanaPubKey,
70
+ usdRequired: pay.order?.destFinalCallTokenAmount.usd,
71
+ isDepositFlow,
72
+ showSolanaPaymentMethod
73
+ });
74
+ const depositAddressOptions = useDepositAddressOptions({
75
+ trpc,
76
+ usdRequired: pay.order?.destFinalCallTokenAmount.usd,
77
+ mode: pay.order?.mode
78
+ });
79
+ const { available: untronAvailable } = useUntronAvailability({ trpc });
80
+ const chainOrderUsdLimits = useOrderUsdLimits({ trpc });
81
+ const [selectedExternalOption, setSelectedExternalOption] = useState();
82
+ const [selectedTokenOption, setSelectedTokenOption] = useState();
83
+ const [selectedSolanaTokenOption, setSelectedSolanaTokenOption] = useState();
84
+ const [selectedDepositAddressOption, setSelectedDepositAddressOption] = useState();
85
+ const [selectedWallet, setSelectedWallet] = useState();
86
+ const [selectedWalletDeepLink, setSelectedWalletDeepLink] = useState();
87
+ const getOrderUsdLimit = () => {
88
+ const DEFAULT_USD_LIMIT = 2e4;
89
+ if (pay.order == null || chainOrderUsdLimits.loading) {
90
+ return DEFAULT_USD_LIMIT;
91
+ }
92
+ const destChainId2 = pay.order.destFinalCallTokenAmount.token.chainId;
93
+ return destChainId2 in chainOrderUsdLimits.limits ? chainOrderUsdLimits.limits[destChainId2] : DEFAULT_USD_LIMIT;
94
+ };
95
+ const payWithToken = async (walletOption) => {
96
+ assert(
97
+ ethWalletAddress != null,
98
+ `[PAY TOKEN] null ethWalletAddress when paying on ethereum`
99
+ );
100
+ assert(
101
+ pay.paymentState === "preview" || pay.paymentState === "unhydrated" || pay.paymentState === "payment_unpaid",
102
+ `[PAY TOKEN] paymentState is ${pay.paymentState}, must be preview or unhydrated or payment_unpaid`
103
+ );
104
+ let hydratedOrder;
105
+ const { required, fees } = walletOption;
106
+ const paymentAmount = BigInt(required.amount) + BigInt(fees.amount);
107
+ if (pay.paymentState !== "payment_unpaid") {
108
+ assert(
109
+ required.token.token === fees.token.token,
110
+ `[PAY TOKEN] required token ${debugJson(required)} does not match fees token ${debugJson(fees)}`
111
+ );
112
+ const res = await pay.hydrateOrder(ethWalletAddress);
113
+ hydratedOrder = res.order;
114
+ log(
115
+ `[PAY TOKEN] hydrated order: ${debugJson(
116
+ hydratedOrder
117
+ )}, paying ${paymentAmount} of token ${required.token.token}`
118
+ );
119
+ } else {
120
+ hydratedOrder = pay.order;
121
+ }
122
+ const paymentTxHash = await (async () => {
123
+ const dest = walletOption.passthroughAddress ?? hydratedOrder.intentAddr;
124
+ try {
125
+ if (required.token.token === zeroAddress) {
126
+ return await sendTransactionAsync({
127
+ to: dest,
128
+ value: paymentAmount
129
+ });
130
+ } else {
131
+ return await writeContractAsync({
132
+ abi: erc20Abi,
133
+ address: getAddress(required.token.token),
134
+ functionName: "transfer",
135
+ args: [dest, paymentAmount]
136
+ });
137
+ }
138
+ } catch (e) {
139
+ console.error(`[PAY TOKEN] error sending token: ${e}`);
140
+ throw e;
141
+ }
142
+ })();
143
+ if (!isHex(paymentTxHash) || paymentTxHash.length !== 66) {
144
+ log(
145
+ `[PAY TOKEN] wallet bug detected. ignoring invalid payment txHash: ${paymentTxHash}`
146
+ );
147
+ return { success: true };
148
+ }
149
+ try {
150
+ await pay.payEthSource({
151
+ paymentTxHash,
152
+ sourceChainId: required.token.chainId,
153
+ payerAddress: ethWalletAddress,
154
+ sourceToken: getAddress(required.token.token),
155
+ sourceAmount: paymentAmount
156
+ });
157
+ return { txHash: paymentTxHash, success: true };
158
+ } catch {
159
+ console.error(
160
+ `[PAY TOKEN] could not verify payment tx on chain: ${paymentTxHash}`
161
+ );
162
+ return { txHash: paymentTxHash, success: false };
163
+ }
164
+ };
165
+ const payWithSolanaToken = async (inputToken) => {
166
+ const payerPublicKey = solanaWallet.publicKey;
167
+ assert(
168
+ payerPublicKey != null,
169
+ "[PAY SOLANA] null payerPublicKey when paying on solana"
170
+ );
171
+ assert(
172
+ pay.order?.id != null,
173
+ "[PAY SOLANA] null orderId when paying on solana"
174
+ );
175
+ assert(
176
+ pay.paymentState === "preview" || pay.paymentState === "unhydrated" || pay.paymentState === "payment_unpaid",
177
+ `[PAY SOLANA] paymentState is ${pay.paymentState}, must be preview or unhydrated or payment_unpaid`
178
+ );
179
+ let hydratedOrder;
180
+ if (pay.paymentState !== "payment_unpaid") {
181
+ const res = await pay.hydrateOrder();
182
+ hydratedOrder = res.order;
183
+ log(
184
+ `[PAY SOLANA] Hydrated order: ${JSON.stringify(
185
+ hydratedOrder
186
+ )}, checking out with Solana ${inputToken}`
187
+ );
188
+ } else {
189
+ hydratedOrder = pay.order;
190
+ }
191
+ const paymentTxHash = await (async () => {
192
+ try {
193
+ const serializedTx = await trpc.getSolanaSwapAndBurnTx.query({
194
+ orderId: pay.order.id.toString(),
195
+ userPublicKey: assertNotNull(
196
+ payerPublicKey,
197
+ "[PAY SOLANA] wallet.publicKey cannot be null"
198
+ ).toString(),
199
+ inputTokenMint: inputToken
200
+ });
201
+ const tx = VersionedTransaction.deserialize(hexToBytes(serializedTx));
202
+ const txHash = await solanaWallet.sendTransaction(tx, connection);
203
+ return txHash;
204
+ } catch (e) {
205
+ console.error(e);
206
+ throw e;
207
+ }
208
+ })();
209
+ try {
210
+ await pay.paySolanaSource({
211
+ paymentTxHash,
212
+ sourceToken: inputToken
213
+ });
214
+ return { txHash: paymentTxHash, success: true };
215
+ } catch {
216
+ console.error(
217
+ `[PAY SOLANA] could not verify payment tx on chain: ${paymentTxHash}`
218
+ );
219
+ return { txHash: paymentTxHash, success: false };
220
+ }
221
+ };
222
+ const payWithExternal = async (option) => {
223
+ assert(pay.order != null, "[PAY EXTERNAL] order cannot be null");
224
+ assert(platform != null, "[PAY EXTERNAL] platform cannot be null");
225
+ const { order } = await pay.hydrateOrder();
226
+ const externalPaymentOptionData = await trpc.getExternalPaymentOptionData.query({
227
+ id: order.id.toString(),
228
+ externalPaymentOption: option,
229
+ platform,
230
+ redirectReturnUrl
64
231
  });
65
- const solanaPaymentOptions = useSolanaPaymentOptions({
66
- trpc,
67
- address: solanaPubKey,
68
- usdRequired: pay.order?.destFinalCallTokenAmount.usd,
69
- isDepositFlow,
70
- showSolanaPaymentMethod,
232
+ assert(
233
+ externalPaymentOptionData != null,
234
+ "[PAY EXTERNAL] missing externalPaymentOptionData"
235
+ );
236
+ log(
237
+ `[PAY EXTERNAL] hydrated order: ${debugJson(
238
+ order
239
+ )}, checking out with external payment: ${option}`
240
+ );
241
+ setPaymentWaitingMessage(externalPaymentOptionData.waitingMessage);
242
+ return externalPaymentOptionData.url;
243
+ };
244
+ const payWithDepositAddress = async (option) => {
245
+ const { order } = await pay.hydrateOrder();
246
+ log(
247
+ `[PAY DEPOSIT ADDRESS] hydrated order ${order.id} for ${order.usdValue} USD, checking out with deposit address: ${option}`
248
+ );
249
+ const result = await trpc.getDepositAddressForOrder.query({
250
+ orderId: order.id.toString(),
251
+ option
71
252
  });
72
- const depositAddressOptions = useDepositAddressOptions({
73
- trpc,
74
- usdRequired: pay.order?.destFinalCallTokenAmount.usd,
75
- mode: pay.order?.mode,
253
+ return "error" in result ? null : result;
254
+ };
255
+ const { isIOS } = useIsMobile();
256
+ const openInWalletBrowser = (wallet, amountUsd) => {
257
+ const paymentState = pay.paymentState;
258
+ assert(
259
+ paymentState === "payment_unpaid",
260
+ `[OPEN IN WALLET BROWSER] paymentState is ${paymentState}, must be payment_unpaid`
261
+ );
262
+ assert(
263
+ wallet.getDaimoPayDeeplink != null,
264
+ `openInWalletBrowser: missing deeplink for ${wallet.name}`
265
+ );
266
+ const payId = writeDaimoPayOrderID(pay.order.id);
267
+ const deeplink = wallet.getDaimoPayDeeplink(payId);
268
+ if (!isIOS) {
269
+ window.open(deeplink, "_blank");
270
+ }
271
+ setSelectedWallet(wallet);
272
+ setSelectedWalletDeepLink(deeplink);
273
+ setRoute(ROUTES.WAITING_WALLET, {
274
+ amountUsd,
275
+ payId,
276
+ wallet_name: wallet.name
76
277
  });
77
- // Poll for Untron receiver availability so components can disable unsupported chains promptly.
78
- const { available: untronAvailable } = useUntronAvailability({ trpc });
79
- const chainOrderUsdLimits = useOrderUsdLimits({ trpc });
80
- const [selectedExternalOption, setSelectedExternalOption] = useState();
81
- const [selectedTokenOption, setSelectedTokenOption] = useState();
82
- const [selectedSolanaTokenOption, setSelectedSolanaTokenOption] = useState();
83
- const [selectedDepositAddressOption, setSelectedDepositAddressOption] = useState();
84
- const [selectedWallet, setSelectedWallet] = useState();
85
- const [selectedWalletDeepLink, setSelectedWalletDeepLink] = useState();
86
- const getOrderUsdLimit = () => {
87
- const DEFAULT_USD_LIMIT = 20000;
88
- if (pay.order == null || chainOrderUsdLimits.loading) {
89
- return DEFAULT_USD_LIMIT;
90
- }
91
- const destChainId = pay.order.destFinalCallTokenAmount.token.chainId;
92
- return destChainId in chainOrderUsdLimits.limits
93
- ? chainOrderUsdLimits.limits[destChainId]
94
- : DEFAULT_USD_LIMIT;
95
- };
96
- /** Commit to a token + amount = initiate payment. */
97
- const payWithToken = async (walletOption) => {
98
- assert(ethWalletAddress != null, `[PAY TOKEN] null ethWalletAddress when paying on ethereum`);
99
- assert(pay.paymentState === "preview" ||
100
- pay.paymentState === "unhydrated" ||
101
- pay.paymentState === "payment_unpaid", `[PAY TOKEN] paymentState is ${pay.paymentState}, must be preview or unhydrated or payment_unpaid`);
102
- let hydratedOrder;
103
- const { required, fees } = walletOption;
104
- const paymentAmount = BigInt(required.amount) + BigInt(fees.amount);
105
- if (pay.paymentState !== "payment_unpaid") {
106
- assert(required.token.token === fees.token.token, `[PAY TOKEN] required token ${debugJson(required)} does not match fees token ${debugJson(fees)}`);
107
- // Will refund to ethWalletAddress if refundAddress was not set in payParams
108
- const res = await pay.hydrateOrder(ethWalletAddress);
109
- hydratedOrder = res.order;
110
- log(`[PAY TOKEN] hydrated order: ${debugJson(hydratedOrder)}, paying ${paymentAmount} of token ${required.token.token}`);
111
- }
112
- else {
113
- hydratedOrder = pay.order;
114
- }
115
- const paymentTxHash = await (async () => {
116
- try {
117
- if (required.token.token === zeroAddress) {
118
- return await sendTransactionAsync({
119
- to: hydratedOrder.intentAddr,
120
- value: paymentAmount,
121
- });
122
- }
123
- else {
124
- return await writeContractAsync({
125
- abi: erc20Abi,
126
- address: getAddress(required.token.token),
127
- functionName: "transfer",
128
- args: [hydratedOrder.intentAddr, paymentAmount],
129
- });
130
- }
131
- }
132
- catch (e) {
133
- console.error(`[PAY TOKEN] error sending token: ${e}`);
134
- throw e;
135
- }
136
- })();
137
- // Special case. Handle Rabby bug, where it returns the *Safe signature*
138
- // instead of a txHash for a queued, unsubmitted Safe transaction.
139
- if (!isHex(paymentTxHash) || paymentTxHash.length !== 66) {
140
- log(`[PAY TOKEN] wallet bug detected. ignoring invalid payment txHash: ${paymentTxHash}`);
141
- return { success: true };
142
- }
143
- try {
144
- await pay.payEthSource({
145
- paymentTxHash,
146
- sourceChainId: required.token.chainId,
147
- payerAddress: ethWalletAddress,
148
- sourceToken: getAddress(required.token.token),
149
- sourceAmount: paymentAmount,
150
- });
151
- return { txHash: paymentTxHash, success: true };
152
- }
153
- catch {
154
- console.error(`[PAY TOKEN] could not verify payment tx on chain: ${paymentTxHash}`);
155
- return { txHash: paymentTxHash, success: false };
156
- }
157
- };
158
- const payWithSolanaToken = async (inputToken) => {
159
- const payerPublicKey = solanaWallet.publicKey;
160
- assert(payerPublicKey != null, "[PAY SOLANA] null payerPublicKey when paying on solana");
161
- assert(pay.order?.id != null, "[PAY SOLANA] null orderId when paying on solana");
162
- assert(pay.paymentState === "preview" ||
163
- pay.paymentState === "unhydrated" ||
164
- pay.paymentState === "payment_unpaid", `[PAY SOLANA] paymentState is ${pay.paymentState}, must be preview or unhydrated or payment_unpaid`);
165
- let hydratedOrder;
166
- if (pay.paymentState !== "payment_unpaid") {
167
- const res = await pay.hydrateOrder();
168
- hydratedOrder = res.order;
169
- log(`[PAY SOLANA] Hydrated order: ${JSON.stringify(hydratedOrder)}, checking out with Solana ${inputToken}`);
170
- }
171
- else {
172
- hydratedOrder = pay.order;
173
- }
174
- const paymentTxHash = await (async () => {
175
- try {
176
- const serializedTx = await trpc.getSolanaSwapAndBurnTx.query({
177
- orderId: pay.order.id.toString(),
178
- userPublicKey: assertNotNull(payerPublicKey, "[PAY SOLANA] wallet.publicKey cannot be null").toString(),
179
- inputTokenMint: inputToken,
180
- });
181
- const tx = VersionedTransaction.deserialize(hexToBytes(serializedTx));
182
- const txHash = await solanaWallet.sendTransaction(tx, connection);
183
- return txHash;
184
- }
185
- catch (e) {
186
- console.error(e);
187
- throw e;
188
- }
189
- })();
190
- try {
191
- await pay.paySolanaSource({
192
- paymentTxHash: paymentTxHash,
193
- sourceToken: inputToken,
194
- });
195
- return { txHash: paymentTxHash, success: true };
196
- }
197
- catch {
198
- console.error(`[PAY SOLANA] could not verify payment tx on chain: ${paymentTxHash}`);
199
- return { txHash: paymentTxHash, success: false };
200
- }
201
- };
202
- const payWithExternal = async (option) => {
203
- assert(pay.order != null, "[PAY EXTERNAL] order cannot be null");
204
- assert(platform != null, "[PAY EXTERNAL] platform cannot be null");
205
- const { order } = await pay.hydrateOrder();
206
- const externalPaymentOptionData = await trpc.getExternalPaymentOptionData.query({
207
- id: order.id.toString(),
208
- externalPaymentOption: option,
209
- platform,
210
- redirectReturnUrl,
211
- });
212
- assert(externalPaymentOptionData != null, "[PAY EXTERNAL] missing externalPaymentOptionData");
213
- log(`[PAY EXTERNAL] hydrated order: ${debugJson(order)}, checking out with external payment: ${option}`);
214
- setPaymentWaitingMessage(externalPaymentOptionData.waitingMessage);
215
- return externalPaymentOptionData.url;
216
- };
217
- const payWithDepositAddress = async (option) => {
218
- const { order } = await pay.hydrateOrder();
219
- log(`[PAY DEPOSIT ADDRESS] hydrated order ${order.id} for ${order.usdValue} USD, checking out with deposit address: ${option}`);
220
- const result = await trpc.getDepositAddressForOrder.query({
221
- orderId: order.id.toString(),
222
- option,
223
- });
224
- return "error" in result ? null : result;
225
- };
226
- const { isIOS } = useIsMobile();
227
- const openInWalletBrowser = (wallet, amountUsd) => {
228
- const paymentState = pay.paymentState;
229
- assert(paymentState === "payment_unpaid", `[OPEN IN WALLET BROWSER] paymentState is ${paymentState}, must be payment_unpaid`);
230
- assert(wallet.getDaimoPayDeeplink != null, `openInWalletBrowser: missing deeplink for ${wallet.name}`);
231
- const payId = writeDaimoPayOrderID(pay.order.id);
232
- const deeplink = wallet.getDaimoPayDeeplink(payId);
233
- // If we are in IOS, we don't open the deeplink in a new window, because it
234
- // will not work, the link will be opened in the page WAITING_WALLET
235
- if (!isIOS) {
236
- window.open(deeplink, "_blank");
237
- }
238
- setSelectedWallet(wallet);
239
- setSelectedWalletDeepLink(deeplink);
240
- setRoute(ROUTES.WAITING_WALLET, {
241
- amountUsd,
242
- payId,
243
- wallet_name: wallet.name,
244
- });
245
- };
246
- /** User picked a different deposit amount. */
247
- const setChosenUsd = (usd) => {
248
- assert(pay.paymentState === "preview", "[SET CHOSEN USD] paymentState is not preview");
249
- // Too expensive to make an API call to regenerate preview order each time
250
- // the user changes the amount. Instead, we modify the order in memory.
251
- pay.setChosenUsd(usd);
252
- };
253
- const setPayId = useCallback(async (payId) => {
254
- if (lockPayParams || payId == null)
255
- return;
256
- const id = readDaimoPayOrderID(payId).toString();
257
- if (pay.order?.id && BigInt(id) == pay.order.id) {
258
- // Already loaded, ignore.
259
- return;
260
- }
261
- pay.reset();
262
- pay.setPayId(payId);
263
- }, [lockPayParams, pay]);
264
- /** Called whenever params change. */
265
- const setPayParams = async (payParams) => {
266
- if (lockPayParams)
267
- return;
268
- assert(payParams != null, "[SET PAY PARAMS] payParams cannot be null");
269
- log("[SET PAY PARAMS] setting payParams", payParams);
270
- pay.reset();
271
- await pay.createPreviewOrder(payParams);
272
- setCurrPayParams(payParams);
273
- setIsDepositFlow(payParams.toUnits == null);
274
- };
275
- const generatePreviewOrder = async () => {
276
- pay.reset();
277
- if (currPayParams == null)
278
- return;
279
- await pay.createPreviewOrder(currPayParams);
280
- };
281
- const resetOrder = useCallback(async (payParams) => {
282
- const mergedPayParams = payParams != null && currPayParams != null
283
- ? { ...currPayParams, ...payParams }
284
- : currPayParams;
285
- // Clear the old order & state
286
- pay.reset();
287
- setSelectedExternalOption(undefined);
288
- setSelectedTokenOption(undefined);
289
- setSelectedSolanaTokenOption(undefined);
290
- setSelectedDepositAddressOption(undefined);
291
- setSelectedWallet(undefined);
292
- setSelectedWalletDeepLink(undefined);
293
- setPaymentWaitingMessage(undefined);
294
- // Set the new payParams
295
- if (mergedPayParams) {
296
- await pay.createPreviewOrder(mergedPayParams);
297
- setCurrPayParams(mergedPayParams);
298
- setIsDepositFlow(mergedPayParams.toUnits == null);
299
- }
300
- setRoute(ROUTES.SELECT_METHOD);
301
- }, [setRoute, pay, currPayParams]);
302
- const [tokenMode, setTokenMode] = useState("evm");
303
- return {
304
- buttonProps,
305
- setButtonProps,
306
- setPayId,
307
- setPayParams,
308
- tokenMode,
309
- setTokenMode,
310
- generatePreviewOrder,
311
- isDepositFlow,
312
- paymentWaitingMessage,
313
- selectedExternalOption,
314
- selectedTokenOption,
315
- selectedSolanaTokenOption,
316
- externalPaymentOptions,
317
- showSolanaPaymentMethod,
318
- selectedWallet,
319
- selectedWalletDeepLink,
320
- walletPaymentOptions,
321
- solanaPaymentOptions,
322
- depositAddressOptions,
323
- selectedDepositAddressOption,
324
- getOrderUsdLimit,
325
- resetOrder,
326
- setSelectedWallet,
327
- setSelectedWalletDeepLink,
328
- setPaymentWaitingMessage,
329
- setSelectedExternalOption,
330
- setSelectedTokenOption,
331
- setSelectedSolanaTokenOption,
332
- setSelectedDepositAddressOption,
333
- setChosenUsd,
334
- payWithToken,
335
- payWithExternal,
336
- payWithDepositAddress,
337
- payWithSolanaToken,
338
- openInWalletBrowser,
339
- senderEnsName: senderEnsName ?? undefined,
340
- untronAvailable,
341
- };
278
+ };
279
+ const setChosenUsd = (usd) => {
280
+ assert(
281
+ pay.paymentState === "preview",
282
+ "[SET CHOSEN USD] paymentState is not preview"
283
+ );
284
+ pay.setChosenUsd(usd);
285
+ };
286
+ const setPayId = useCallback(
287
+ async (payId) => {
288
+ if (lockPayParams || payId == null) return;
289
+ const id = readDaimoPayOrderID(payId).toString();
290
+ if (pay.order?.id && BigInt(id) == pay.order.id) {
291
+ return;
292
+ }
293
+ pay.reset();
294
+ pay.setPayId(payId);
295
+ },
296
+ [lockPayParams, pay]
297
+ );
298
+ const setPayParams = async (payParams) => {
299
+ if (lockPayParams) return;
300
+ assert(payParams != null, "[SET PAY PARAMS] payParams cannot be null");
301
+ log("[SET PAY PARAMS] setting payParams", payParams);
302
+ pay.reset();
303
+ await pay.createPreviewOrder(payParams);
304
+ setCurrPayParams(payParams);
305
+ setIsDepositFlow(payParams.toUnits == null);
306
+ };
307
+ const generatePreviewOrder = async () => {
308
+ pay.reset();
309
+ if (currPayParams == null) return;
310
+ await pay.createPreviewOrder(currPayParams);
311
+ };
312
+ const resetOrder = useCallback(
313
+ async (payParams) => {
314
+ const mergedPayParams = payParams != null && currPayParams != null ? { ...currPayParams, ...payParams } : currPayParams;
315
+ pay.reset();
316
+ setSelectedExternalOption(void 0);
317
+ setSelectedTokenOption(void 0);
318
+ setSelectedSolanaTokenOption(void 0);
319
+ setSelectedDepositAddressOption(void 0);
320
+ setSelectedWallet(void 0);
321
+ setSelectedWalletDeepLink(void 0);
322
+ setPaymentWaitingMessage(void 0);
323
+ if (mergedPayParams) {
324
+ await pay.createPreviewOrder(mergedPayParams);
325
+ setCurrPayParams(mergedPayParams);
326
+ setIsDepositFlow(mergedPayParams.toUnits == null);
327
+ }
328
+ setRoute(ROUTES.SELECT_METHOD);
329
+ },
330
+ [setRoute, pay, currPayParams]
331
+ );
332
+ const [tokenMode, setTokenMode] = useState("evm");
333
+ return {
334
+ buttonProps,
335
+ setButtonProps,
336
+ setPayId,
337
+ setPayParams,
338
+ tokenMode,
339
+ setTokenMode,
340
+ generatePreviewOrder,
341
+ isDepositFlow,
342
+ paymentWaitingMessage,
343
+ selectedExternalOption,
344
+ selectedTokenOption,
345
+ selectedSolanaTokenOption,
346
+ externalPaymentOptions,
347
+ showSolanaPaymentMethod,
348
+ selectedWallet,
349
+ selectedWalletDeepLink,
350
+ walletPaymentOptions,
351
+ solanaPaymentOptions,
352
+ depositAddressOptions,
353
+ selectedDepositAddressOption,
354
+ getOrderUsdLimit,
355
+ resetOrder,
356
+ setSelectedWallet,
357
+ setSelectedWalletDeepLink,
358
+ setPaymentWaitingMessage,
359
+ setSelectedExternalOption,
360
+ setSelectedTokenOption,
361
+ setSelectedSolanaTokenOption,
362
+ setSelectedDepositAddressOption,
363
+ setChosenUsd,
364
+ payWithToken,
365
+ payWithExternal,
366
+ payWithDepositAddress,
367
+ payWithSolanaToken,
368
+ openInWalletBrowser,
369
+ senderEnsName: senderEnsName ?? void 0,
370
+ untronAvailable
371
+ };
342
372
  }
343
373
 
344
374
  export { usePaymentState };