@daimo/pay 0.3.21 → 1.0.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 (302) hide show
  1. package/build/index.d.ts +132 -301
  2. package/build/package.json.js +103 -0
  3. package/build/package.json.js.map +1 -0
  4. package/build/src/assets/ScanIconWithLogos.js +34 -0
  5. package/build/src/assets/ScanIconWithLogos.js.map +1 -0
  6. package/build/src/assets/browsers.js +13 -0
  7. package/build/src/assets/browsers.js.map +1 -0
  8. package/build/src/assets/chains.js +152 -0
  9. package/build/src/assets/chains.js.map +1 -0
  10. package/build/src/assets/coins.js +6 -0
  11. package/build/src/assets/coins.js.map +1 -0
  12. package/build/src/assets/crepe.js +8 -0
  13. package/build/src/assets/crepe.js.map +1 -0
  14. package/build/src/assets/icons.js +28 -0
  15. package/build/src/assets/icons.js.map +1 -0
  16. package/build/src/assets/logos.js +131 -0
  17. package/build/src/assets/logos.js.map +1 -0
  18. package/build/src/assets/wallet.js +8 -0
  19. package/build/src/assets/wallet.js.map +1 -0
  20. package/build/src/assets/wave.js +6 -0
  21. package/build/src/assets/wave.js.map +1 -0
  22. package/build/src/components/Common/Alert/index.js +10 -0
  23. package/build/src/components/Common/Alert/index.js.map +1 -0
  24. package/build/src/components/Common/Alert/styles.js +55 -0
  25. package/build/src/components/Common/Alert/styles.js.map +1 -0
  26. package/build/src/components/Common/Avatar/index.js +66 -0
  27. package/build/src/components/Common/Avatar/index.js.map +1 -0
  28. package/build/src/components/Common/Avatar/styles.js +59 -0
  29. package/build/src/components/Common/Avatar/styles.js.map +1 -0
  30. package/build/src/components/Common/BrowserIcon/index.js +28 -0
  31. package/build/src/components/Common/BrowserIcon/index.js.map +1 -0
  32. package/build/src/components/Common/BrowserIcon/styles.js +20 -0
  33. package/build/src/components/Common/BrowserIcon/styles.js.map +1 -0
  34. package/build/src/components/Common/Button/index.js +38 -0
  35. package/build/src/components/Common/Button/index.js.map +1 -0
  36. package/build/src/components/Common/Button/styles.js +291 -0
  37. package/build/src/components/Common/Button/styles.js.map +1 -0
  38. package/build/src/components/Common/Chain/index.js +25 -0
  39. package/build/src/components/Common/Chain/index.js.map +1 -0
  40. package/build/src/components/Common/Chain/styles.js +94 -0
  41. package/build/src/components/Common/Chain/styles.js.map +1 -0
  42. package/build/src/components/Common/ChainSelectList/index.js +107 -0
  43. package/build/src/components/Common/ChainSelectList/index.js.map +1 -0
  44. package/build/src/components/Common/ChainSelectList/styles.js +228 -0
  45. package/build/src/components/Common/ChainSelectList/styles.js.map +1 -0
  46. package/build/src/components/Common/ConnectorList/index.js +70 -0
  47. package/build/src/components/Common/ConnectorList/index.js.map +1 -0
  48. package/build/src/components/Common/ConnectorList/styles.js +314 -0
  49. package/build/src/components/Common/ConnectorList/styles.js.map +1 -0
  50. package/build/src/components/Common/CopyToClipboard/CopyToClipboardIcon.js +71 -0
  51. package/build/src/components/Common/CopyToClipboard/CopyToClipboardIcon.js.map +1 -0
  52. package/build/src/components/Common/CopyToClipboard/index.js +51 -0
  53. package/build/src/components/Common/CopyToClipboard/index.js.map +1 -0
  54. package/build/src/components/Common/CustomQRCode/QRCode.js +69 -0
  55. package/build/src/components/Common/CustomQRCode/QRCode.js.map +1 -0
  56. package/build/src/components/Common/CustomQRCode/index.js +22 -0
  57. package/build/src/components/Common/CustomQRCode/index.js.map +1 -0
  58. package/build/src/components/Common/CustomQRCode/styles.js +155 -0
  59. package/build/src/components/Common/CustomQRCode/styles.js.map +1 -0
  60. package/build/src/components/Common/FitText/index.js +27 -0
  61. package/build/src/components/Common/FitText/index.js.map +1 -0
  62. package/build/src/components/Common/Modal/index.js +297 -0
  63. package/build/src/components/Common/Modal/index.js.map +1 -0
  64. package/build/src/components/Common/Modal/styles.js +660 -0
  65. package/build/src/components/Common/Modal/styles.js.map +1 -0
  66. package/build/src/components/Common/OptionsList/index.js +106 -0
  67. package/build/src/components/Common/OptionsList/index.js.map +1 -0
  68. package/build/src/components/Common/OptionsList/styles.js +165 -0
  69. package/build/src/components/Common/OptionsList/styles.js.map +1 -0
  70. package/build/src/components/Common/OrderHeader/index.js +215 -0
  71. package/build/src/components/Common/OrderHeader/index.js.map +1 -0
  72. package/build/src/components/Common/Portal/index.js +31 -0
  73. package/build/src/components/Common/Portal/index.js.map +1 -0
  74. package/build/src/components/Common/PoweredByFooter/index.js +44 -0
  75. package/build/src/components/Common/PoweredByFooter/index.js.map +1 -0
  76. package/build/src/components/Common/ScrollArea/index.js +62 -0
  77. package/build/src/components/Common/ScrollArea/index.js.map +1 -0
  78. package/build/src/components/Common/ScrollArea/styles.js +168 -0
  79. package/build/src/components/Common/ScrollArea/styles.js.map +1 -0
  80. package/build/src/components/Common/Spinner/index.js +24 -0
  81. package/build/src/components/Common/Spinner/index.js.map +1 -0
  82. package/build/src/components/Common/Spinner/styles.js +22 -0
  83. package/build/src/components/Common/Spinner/styles.js.map +1 -0
  84. package/build/src/components/Common/ThemedButton/index.js +25 -0
  85. package/build/src/components/Common/ThemedButton/index.js.map +1 -0
  86. package/build/src/components/Common/ThemedButton/styles.js +152 -0
  87. package/build/src/components/Common/ThemedButton/styles.js.map +1 -0
  88. package/build/src/components/Common/Tooltip/index.js +97 -0
  89. package/build/src/components/Common/Tooltip/index.js.map +1 -0
  90. package/build/src/components/Common/Tooltip/styles.js +81 -0
  91. package/build/src/components/Common/Tooltip/styles.js.map +1 -0
  92. package/build/src/components/DaimoPay.js +232 -0
  93. package/build/src/components/DaimoPay.js.map +1 -0
  94. package/build/src/components/DaimoPayButton/index.js +129 -0
  95. package/build/src/components/DaimoPayButton/index.js.map +1 -0
  96. package/build/src/components/DaimoPayButton/styles.js +50 -0
  97. package/build/src/components/DaimoPayButton/styles.js.map +1 -0
  98. package/build/src/components/DaimoPayModal/ConnectUsing.js +45 -0
  99. package/build/src/components/DaimoPayModal/ConnectUsing.js.map +1 -0
  100. package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js +202 -0
  101. package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js.map +1 -0
  102. package/build/src/components/DaimoPayModal/ConnectWithInjector/styles.js +133 -0
  103. package/build/src/components/DaimoPayModal/ConnectWithInjector/styles.js.map +1 -0
  104. package/build/src/components/DaimoPayModal/ConnectWithQRCode.js +75 -0
  105. package/build/src/components/DaimoPayModal/ConnectWithQRCode.js.map +1 -0
  106. package/build/src/components/DaimoPayModal/index.js +140 -0
  107. package/build/src/components/DaimoPayModal/index.js.map +1 -0
  108. package/build/src/components/DaimoPayThemeProvider/DaimoPayThemeProvider.js +21 -0
  109. package/build/src/components/DaimoPayThemeProvider/DaimoPayThemeProvider.js.map +1 -0
  110. package/build/src/components/Pages/About/graphics.js +187 -0
  111. package/build/src/components/Pages/About/graphics.js.map +1 -0
  112. package/build/src/components/Pages/About/index.js +131 -0
  113. package/build/src/components/Pages/About/index.js.map +1 -0
  114. package/build/src/components/Pages/About/styles.js +144 -0
  115. package/build/src/components/Pages/About/styles.js.map +1 -0
  116. package/build/src/components/Pages/Confirmation/index.js +105 -0
  117. package/build/src/components/Pages/Confirmation/index.js.map +1 -0
  118. package/build/src/components/Pages/Connectors/index.js +20 -0
  119. package/build/src/components/Pages/Connectors/index.js.map +1 -0
  120. package/build/src/components/Pages/Connectors/styles.js +267 -0
  121. package/build/src/components/Pages/Connectors/styles.js.map +1 -0
  122. package/build/src/components/Pages/DownloadApp/index.js +30 -0
  123. package/build/src/components/Pages/DownloadApp/index.js.map +1 -0
  124. package/build/src/components/Pages/MobileConnectors/index.js +73 -0
  125. package/build/src/components/Pages/MobileConnectors/index.js.map +1 -0
  126. package/build/src/components/Pages/MobileConnectors/styles.js +65 -0
  127. package/build/src/components/Pages/MobileConnectors/styles.js.map +1 -0
  128. package/build/src/components/Pages/Onboarding/index.js +18 -0
  129. package/build/src/components/Pages/Onboarding/index.js.map +1 -0
  130. package/build/src/components/Pages/Onboarding/styles.js +229 -0
  131. package/build/src/components/Pages/Onboarding/styles.js.map +1 -0
  132. package/build/src/components/Pages/PayWithToken/index.js +204 -0
  133. package/build/src/components/Pages/PayWithToken/index.js.map +1 -0
  134. package/build/src/components/Pages/SelectDepositAddressChain/index.js +32 -0
  135. package/build/src/components/Pages/SelectDepositAddressChain/index.js.map +1 -0
  136. package/build/src/components/Pages/SelectMethod/index.js +113 -0
  137. package/build/src/components/Pages/SelectMethod/index.js.map +1 -0
  138. package/build/src/components/Pages/SelectToken/index.js +62 -0
  139. package/build/src/components/Pages/SelectToken/index.js.map +1 -0
  140. package/build/src/components/Pages/Solana/ConnectSolana/index.js +37 -0
  141. package/build/src/components/Pages/Solana/ConnectSolana/index.js.map +1 -0
  142. package/build/src/components/Pages/Solana/ConnectorSolana/index.js +45 -0
  143. package/build/src/components/Pages/Solana/ConnectorSolana/index.js.map +1 -0
  144. package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js +85 -0
  145. package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js.map +1 -0
  146. package/build/src/components/Pages/Solana/SelectSolanaToken/index.js +38 -0
  147. package/build/src/components/Pages/Solana/SelectSolanaToken/index.js.map +1 -0
  148. package/build/src/components/Pages/SwitchNetworks/index.js +26 -0
  149. package/build/src/components/Pages/SwitchNetworks/index.js.map +1 -0
  150. package/build/src/components/Pages/WaitingDepositAddress/index.js +51 -0
  151. package/build/src/components/Pages/WaitingDepositAddress/index.js.map +1 -0
  152. package/build/src/components/Pages/WaitingOther/index.js +91 -0
  153. package/build/src/components/Pages/WaitingOther/index.js.map +1 -0
  154. package/build/src/components/Spinners/CircleSpinner/index.js +15 -0
  155. package/build/src/components/Spinners/CircleSpinner/index.js.map +1 -0
  156. package/build/src/components/Spinners/CircleSpinner/styles.js +118 -0
  157. package/build/src/components/Spinners/CircleSpinner/styles.js.map +1 -0
  158. package/build/src/components/Spinners/SquircleSpinner/index.js +15 -0
  159. package/build/src/components/Spinners/SquircleSpinner/index.js.map +1 -0
  160. package/build/src/components/Spinners/SquircleSpinner/styles.js +66 -0
  161. package/build/src/components/Spinners/SquircleSpinner/styles.js.map +1 -0
  162. package/build/src/components/contexts/solana/index.js +11 -0
  163. package/build/src/components/contexts/solana/index.js.map +1 -0
  164. package/build/src/components/contexts/web3/index.js +46 -0
  165. package/build/src/components/contexts/web3/index.js.map +1 -0
  166. package/build/src/constants/chainConfigs.js +306 -0
  167. package/build/src/constants/chainConfigs.js.map +1 -0
  168. package/build/src/constants/defaultTheme.js +6 -0
  169. package/build/src/constants/defaultTheme.js.map +1 -0
  170. package/build/src/defaultConfig.js +59 -0
  171. package/build/src/defaultConfig.js.map +1 -0
  172. package/build/src/defaultConnectors.js +43 -0
  173. package/build/src/defaultConnectors.js.map +1 -0
  174. package/build/src/hooks/connectors/useWalletConnectUri.js +93 -0
  175. package/build/src/hooks/connectors/useWalletConnectUri.js.map +1 -0
  176. package/build/src/hooks/useChainIsSupported.js +12 -0
  177. package/build/src/hooks/useChainIsSupported.js.map +1 -0
  178. package/build/src/hooks/useChains.js +11 -0
  179. package/build/src/hooks/useChains.js.map +1 -0
  180. package/build/src/hooks/useConnect.js +45 -0
  181. package/build/src/hooks/useConnect.js.map +1 -0
  182. package/build/src/hooks/useConnectCallback.js +18 -0
  183. package/build/src/hooks/useConnectCallback.js.map +1 -0
  184. package/build/src/hooks/useConnectors.js +29 -0
  185. package/build/src/hooks/useConnectors.js.map +1 -0
  186. package/build/src/hooks/useDaimoPayStatus.js +37 -0
  187. package/build/src/hooks/useDaimoPayStatus.js.map +1 -0
  188. package/build/src/hooks/useDepositAddressOptions.js +28 -0
  189. package/build/src/hooks/useDepositAddressOptions.js.map +1 -0
  190. package/build/src/hooks/useEnsFallbackConfig.js +16 -0
  191. package/build/src/hooks/useEnsFallbackConfig.js.map +1 -0
  192. package/build/src/hooks/useExternalPaymentOptions.js +46 -0
  193. package/build/src/hooks/useExternalPaymentOptions.js.map +1 -0
  194. package/build/src/hooks/useFitText.js +148 -0
  195. package/build/src/hooks/useFitText.js.map +1 -0
  196. package/build/src/hooks/useFocusTrap.js +60 -0
  197. package/build/src/hooks/useFocusTrap.js.map +1 -0
  198. package/build/src/hooks/useGoogleFont.js +45 -0
  199. package/build/src/hooks/useGoogleFont.js.map +1 -0
  200. package/build/src/hooks/useIsMobile.js +17 -0
  201. package/build/src/hooks/useIsMobile.js.map +1 -0
  202. package/build/src/hooks/useIsMounted.js +12 -0
  203. package/build/src/hooks/useIsMounted.js.map +1 -0
  204. package/build/src/hooks/useLastConnector.js +24 -0
  205. package/build/src/hooks/useLastConnector.js.map +1 -0
  206. package/build/src/hooks/useLocales.js +67 -0
  207. package/build/src/hooks/useLocales.js.map +1 -0
  208. package/build/src/hooks/useLockBodyScroll.js +53 -0
  209. package/build/src/hooks/useLockBodyScroll.js.map +1 -0
  210. package/build/src/hooks/useModal.js +35 -0
  211. package/build/src/hooks/useModal.js.map +1 -0
  212. package/build/src/hooks/usePayWithSolanaToken.js +50 -0
  213. package/build/src/hooks/usePayWithSolanaToken.js.map +1 -0
  214. package/build/src/hooks/usePayWithToken.js +57 -0
  215. package/build/src/hooks/usePayWithToken.js.map +1 -0
  216. package/build/src/hooks/usePaymentState.js +243 -0
  217. package/build/src/hooks/usePaymentState.js.map +1 -0
  218. package/build/src/hooks/usePrevious.js +14 -0
  219. package/build/src/hooks/usePrevious.js.map +1 -0
  220. package/build/src/hooks/useSolanaPaymentOptions.js +37 -0
  221. package/build/src/hooks/useSolanaPaymentOptions.js.map +1 -0
  222. package/build/src/hooks/useWalletConnectModal.js +52 -0
  223. package/build/src/hooks/useWalletConnectModal.js.map +1 -0
  224. package/build/src/hooks/useWalletPaymentOptions.js +40 -0
  225. package/build/src/hooks/useWalletPaymentOptions.js.map +1 -0
  226. package/build/src/hooks/useWindowSize.js +23 -0
  227. package/build/src/hooks/useWindowSize.js.map +1 -0
  228. package/build/src/index.js +10 -0
  229. package/build/src/index.js.map +1 -0
  230. package/build/src/localizations/index.js +57 -0
  231. package/build/src/localizations/index.js.map +1 -0
  232. package/build/src/localizations/locales/ar-AE.js +97 -0
  233. package/build/src/localizations/locales/ar-AE.js.map +1 -0
  234. package/build/src/localizations/locales/ca-AD.js +95 -0
  235. package/build/src/localizations/locales/ca-AD.js.map +1 -0
  236. package/build/src/localizations/locales/ee-EE.js +95 -0
  237. package/build/src/localizations/locales/ee-EE.js.map +1 -0
  238. package/build/src/localizations/locales/en-US.js +95 -0
  239. package/build/src/localizations/locales/en-US.js.map +1 -0
  240. package/build/src/localizations/locales/es-ES.js +95 -0
  241. package/build/src/localizations/locales/es-ES.js.map +1 -0
  242. package/build/src/localizations/locales/fa-IR.js +95 -0
  243. package/build/src/localizations/locales/fa-IR.js.map +1 -0
  244. package/build/src/localizations/locales/fr-FR.js +95 -0
  245. package/build/src/localizations/locales/fr-FR.js.map +1 -0
  246. package/build/src/localizations/locales/ja-JP.js +95 -0
  247. package/build/src/localizations/locales/ja-JP.js.map +1 -0
  248. package/build/src/localizations/locales/pt-BR.js +95 -0
  249. package/build/src/localizations/locales/pt-BR.js.map +1 -0
  250. package/build/src/localizations/locales/ru-RU.js +95 -0
  251. package/build/src/localizations/locales/ru-RU.js.map +1 -0
  252. package/build/src/localizations/locales/tr-TR.js +95 -0
  253. package/build/src/localizations/locales/tr-TR.js.map +1 -0
  254. package/build/src/localizations/locales/vi-VN.js +95 -0
  255. package/build/src/localizations/locales/vi-VN.js.map +1 -0
  256. package/build/src/localizations/locales/zh-CN.js +95 -0
  257. package/build/src/localizations/locales/zh-CN.js.map +1 -0
  258. package/build/src/styles/defaultTheme.js +89 -0
  259. package/build/src/styles/defaultTheme.js.map +1 -0
  260. package/build/src/styles/index.js +329 -0
  261. package/build/src/styles/index.js.map +1 -0
  262. package/build/src/styles/styled/index.js +16 -0
  263. package/build/src/styles/styled/index.js.map +1 -0
  264. package/build/src/styles/themes/base.js +141 -0
  265. package/build/src/styles/themes/base.js.map +1 -0
  266. package/build/src/styles/themes/index.js +13 -0
  267. package/build/src/styles/themes/index.js.map +1 -0
  268. package/build/src/styles/themes/midnight.js +76 -0
  269. package/build/src/styles/themes/midnight.js.map +1 -0
  270. package/build/src/styles/themes/minimal.js +96 -0
  271. package/build/src/styles/themes/minimal.js.map +1 -0
  272. package/build/src/styles/themes/nouns.js +81 -0
  273. package/build/src/styles/themes/nouns.js.map +1 -0
  274. package/build/src/styles/themes/retro.js +106 -0
  275. package/build/src/styles/themes/retro.js.map +1 -0
  276. package/build/src/styles/themes/rounded.js +106 -0
  277. package/build/src/styles/themes/rounded.js.map +1 -0
  278. package/build/src/styles/themes/soft.js +71 -0
  279. package/build/src/styles/themes/soft.js.map +1 -0
  280. package/build/src/styles/themes/web95.js +132 -0
  281. package/build/src/styles/themes/web95.js.map +1 -0
  282. package/build/src/utils/exports.js +12 -0
  283. package/build/src/utils/exports.js.map +1 -0
  284. package/build/src/utils/index.js +39 -0
  285. package/build/src/utils/index.js.map +1 -0
  286. package/build/src/utils/p3.js +16 -0
  287. package/build/src/utils/p3.js.map +1 -0
  288. package/build/src/utils/platform.js +13 -0
  289. package/build/src/utils/platform.js.map +1 -0
  290. package/build/src/utils/trpc.js +14 -0
  291. package/build/src/utils/trpc.js.map +1 -0
  292. package/build/src/utils/wallets.js +14 -0
  293. package/build/src/utils/wallets.js.map +1 -0
  294. package/build/src/wallets/index.js +32 -0
  295. package/build/src/wallets/index.js.map +1 -0
  296. package/build/src/wallets/useWallets.js +86 -0
  297. package/build/src/wallets/useWallets.js.map +1 -0
  298. package/build/src/wallets/walletConfigs.js +362 -0
  299. package/build/src/wallets/walletConfigs.js.map +1 -0
  300. package/package.json +5 -5
  301. package/build/index.es.js +0 -11565
  302. package/build/index.es.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,204 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useState, useEffect } from 'react';
3
+ import { usePayContext, ROUTES } from '../../DaimoPay.js';
4
+ import { ModalBody, PageContent, ModalContent, ModalH1 } from '../../Common/Modal/styles.js';
5
+ import { motion, AnimatePresence } from 'framer-motion';
6
+ import { css } from 'styled-components';
7
+ import { useChainId, useSwitchChain } from 'wagmi';
8
+ import { chainToLogo } from '../../../assets/chains.js';
9
+ import defaultTheme from '../../../constants/defaultTheme.js';
10
+ import styled from '../../../styles/styled/index.js';
11
+ import Button from '../../Common/Button/index.js';
12
+ import CircleSpinner from '../../Spinners/CircleSpinner/index.js';
13
+
14
+ var PayState;
15
+ (function (PayState) {
16
+ PayState["RequestingPayment"] = "Requesting Payment";
17
+ PayState["SwitchingChain"] = "Switching Chain";
18
+ PayState["RequestCancelled"] = "Payment Cancelled";
19
+ PayState["RequestSuccessful"] = "Payment Successful";
20
+ })(PayState || (PayState = {}));
21
+ const PayWithToken = () => {
22
+ const { triggerResize, paymentState, setRoute, log } = usePayContext();
23
+ const { selectedTokenOption, payWithToken } = paymentState;
24
+ const [payState, setPayState] = useState(PayState.RequestingPayment);
25
+ const walletChainId = useChainId();
26
+ const { switchChainAsync } = useSwitchChain();
27
+ const trySwitchingChain = async (option, forceSwitch = false) => {
28
+ if (walletChainId !== option.required.token.chainId || forceSwitch) {
29
+ const resultChain = await (async () => {
30
+ try {
31
+ return await switchChainAsync({
32
+ chainId: option.required.token.chainId,
33
+ });
34
+ }
35
+ catch (e) {
36
+ console.error("Failed to switch chain", e);
37
+ return null;
38
+ }
39
+ })();
40
+ if (resultChain?.id !== option.required.token.chainId) {
41
+ return false;
42
+ }
43
+ }
44
+ return true;
45
+ };
46
+ const handleTransfer = async (option) => {
47
+ // Switch chain if necessary
48
+ setPayState(PayState.SwitchingChain);
49
+ const switchChain = await trySwitchingChain(option);
50
+ if (!switchChain) {
51
+ console.error("Switching chain failed");
52
+ setPayState(PayState.RequestCancelled);
53
+ return;
54
+ }
55
+ setPayState(PayState.RequestingPayment);
56
+ try {
57
+ await payWithToken(option.required);
58
+ setPayState(PayState.RequestSuccessful);
59
+ setTimeout(() => {
60
+ setRoute(ROUTES.CONFIRMATION);
61
+ }, 200);
62
+ }
63
+ catch (e) {
64
+ if (e?.name === "ConnectorChainMismatchError") {
65
+ // Workaround for Rainbow wallet bug -- user is able to switch chain without
66
+ // the wallet updating the chain ID for wagmi.
67
+ log("Chain mismatch detected, attempting to switch and retry");
68
+ const switchSuccessful = await trySwitchingChain(option, true);
69
+ if (switchSuccessful) {
70
+ try {
71
+ await payWithToken(option.required);
72
+ return; // Payment successful after switching chain
73
+ }
74
+ catch (retryError) {
75
+ console.error("Failed to pay with token after switching chain", retryError);
76
+ throw retryError;
77
+ }
78
+ }
79
+ }
80
+ setPayState(PayState.RequestCancelled);
81
+ console.error("Failed to pay with token", e);
82
+ }
83
+ };
84
+ let transferTimeout; // Prevent double-triggering in React dev strict mode.
85
+ useEffect(() => {
86
+ if (!selectedTokenOption)
87
+ return;
88
+ // Give user time to see the UI before opening
89
+ transferTimeout = setTimeout(() => {
90
+ handleTransfer(selectedTokenOption);
91
+ }, 100);
92
+ return () => {
93
+ clearTimeout(transferTimeout);
94
+ };
95
+ }, []);
96
+ useEffect(() => {
97
+ triggerResize();
98
+ }, [payState]);
99
+ return (jsxs(PageContent, { children: [jsx(LoadingContainer, { children: jsx(AnimationContainer, { "$circle": true, children: jsxs(AnimatePresence, { children: [jsx(ChainLogoContainer, { children: selectedTokenOption &&
100
+ chainToLogo[selectedTokenOption.required.token.chainId] }, "ChainLogoContainer"), jsx(CircleSpinner, { logo: jsx("img", { src: selectedTokenOption?.required.token.logoURI, alt: selectedTokenOption?.required.token.symbol }, selectedTokenOption?.required.token.logoURI), loading: true, unavailable: false }, "CircleSpinner")] }) }) }), jsxs(ModalContent, { style: { paddingBottom: 0 }, children: [jsx(ModalH1, { children: payState }), selectedTokenOption && (jsx(PaymentDetails, { selectedTokenOption: selectedTokenOption })), payState === PayState.RequestCancelled && (jsx(Button, { onClick: () => selectedTokenOption ? handleTransfer(selectedTokenOption) : null, children: "Retry Payment" }))] })] }));
101
+ };
102
+ const PaymentDetails = ({ selectedTokenOption, }) => {
103
+ const totalUsd = selectedTokenOption.required.usd;
104
+ const feesUsd = selectedTokenOption.fees.usd;
105
+ const subtotalUsd = totalUsd - feesUsd;
106
+ return (jsxs(FeesContainer, { children: [feesUsd > 0 && (jsxs(FeeRow, { children: [jsx(ModalBody, { children: "Subtotal" }), jsxs(ModalBody, { children: ["$", subtotalUsd.toFixed(2)] })] })), jsxs(FeeRow, { children: [jsx(ModalBody, { children: "Fees" }), feesUsd === 0 ? (jsx(Badge, { children: "Free" })) : (jsxs(ModalBody, { children: ["$", feesUsd.toFixed(2)] }))] }), jsxs(FeeRow, { style: { marginTop: 8 }, children: [jsx(ModalBody, { style: { fontWeight: 600 }, children: "Total" }), jsxs(ModalBody, { style: { fontWeight: 600 }, children: ["$", totalUsd.toFixed(2)] })] })] }));
107
+ };
108
+ const LoadingContainer = styled(motion.div) `
109
+ display: flex;
110
+ align-items: center;
111
+ justify-content: center;
112
+ margin: 10px auto 16px;
113
+ height: 120px;
114
+ `;
115
+ const AnimationContainer = styled(motion.div) `
116
+ user-select: none;
117
+ position: relative;
118
+ --spinner-error-opacity: 0;
119
+ &:before {
120
+ content: "";
121
+ position: absolute;
122
+ inset: 1px;
123
+ opacity: 0;
124
+ background: var(--ck-body-color-danger);
125
+ ${(props) => props.$circle &&
126
+ css `
127
+ inset: -5px;
128
+ border-radius: 50%;
129
+ background: none;
130
+ box-shadow: inset 0 0 0 3.5px var(--ck-body-color-danger);
131
+ `}
132
+ }
133
+ `;
134
+ const ChainLogoContainer = styled(motion.div) `
135
+ z-index: 10;
136
+ position: absolute;
137
+ right: 2px;
138
+ bottom: 2px;
139
+ padding: 0;
140
+ display: flex;
141
+ align-items: center;
142
+ justify-content: center;
143
+ width: 32px;
144
+ height: 32px;
145
+ border-radius: 16px;
146
+ overflow: hidden;
147
+
148
+ color: var(--ck-body-background);
149
+ transition: color 200ms ease;
150
+
151
+ &:before {
152
+ z-index: 5;
153
+ content: "";
154
+ position: absolute;
155
+ inset: 0;
156
+ opacity: 0;
157
+ transition: opacity 200ms ease;
158
+ background: var(--ck-body-color);
159
+ }
160
+
161
+ svg {
162
+ display: block;
163
+ position: relative;
164
+ width: 100%;
165
+ height: 100%;
166
+ }
167
+ `;
168
+ const FeesContainer = styled.div `
169
+ display: flex;
170
+ flex-direction: column;
171
+ align-items: center;
172
+ width: 100%;
173
+ gap: 4px;
174
+ margin: 16px 0;
175
+
176
+ @media only screen and (max-width: ${defaultTheme.mobileWidth}px) {
177
+ & ${ModalBody} {
178
+ margin: 0 !important;
179
+ max-width: 100% !important;
180
+ text-align: left !important;
181
+ }
182
+ }
183
+ `;
184
+ const FeeRow = styled.div `
185
+ display: flex;
186
+ justify-content: space-between;
187
+ align-items: center;
188
+ width: 50%;
189
+ `;
190
+ const Badge = styled.span `
191
+ display: inline-block;
192
+ padding: 3px 8px;
193
+ border-radius: var(--ck-primary-button-border-radius);
194
+ font-size: 14px;
195
+ font-weight: 400;
196
+ background: var(
197
+ --ck-secondary-button-background,
198
+ var(--ck-body-background-secondary)
199
+ );
200
+ color: var(--ck-body-color-muted);
201
+ `;
202
+
203
+ export { PayWithToken as default };
204
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,32 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { usePayContext, ROUTES } from '../../DaimoPay.js';
3
+ import { PageContent, ModalContent, ModalH1 } from '../../Common/Modal/styles.js';
4
+ import Button from '../../Common/Button/index.js';
5
+ import OptionsList from '../../Common/OptionsList/index.js';
6
+ import { OrderHeader } from '../../Common/OrderHeader/index.js';
7
+
8
+ const SelectDepositAddressChain = () => {
9
+ const { setRoute, paymentState } = usePayContext();
10
+ const { setSelectedDepositAddressOption, depositAddressOptions } = paymentState;
11
+ return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true }), !depositAddressOptions.loading &&
12
+ depositAddressOptions.options?.length === 0 && (jsxs(ModalContent, { style: {
13
+ display: "flex",
14
+ alignItems: "center",
15
+ justifyContent: "center",
16
+ paddingTop: 16,
17
+ paddingBottom: 16,
18
+ }, children: [jsx(ModalH1, { children: "Chains unavailable." }), jsx(Button, { onClick: () => setRoute(ROUTES.SELECT_METHOD), children: "Select Another Method" })] })), jsx(OptionsList, { requiredSkeletons: 4, isLoading: depositAddressOptions.loading, options: depositAddressOptions.options?.map((option) => {
19
+ return {
20
+ id: option.id,
21
+ title: option.id,
22
+ icons: [option.logoURI],
23
+ onClick: () => {
24
+ setSelectedDepositAddressOption(option);
25
+ setRoute(ROUTES.WAITING_DEPOSIT_ADDRESS);
26
+ },
27
+ };
28
+ }) ?? [] })] }));
29
+ };
30
+
31
+ export { SelectDepositAddressChain as default };
32
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,113 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { usePayContext, ROUTES } from '../../DaimoPay.js';
3
+ import { PageContent } from '../../Common/Modal/styles.js';
4
+ import { getAddressContraction } from '@daimo/common';
5
+ import { useWallet } from '@solana/wallet-adapter-react';
6
+ import { useAccount, useDisconnect } from 'wagmi';
7
+ import { Solana, Bitcoin, Tron, Zcash } from '../../../assets/chains.js';
8
+ import { MetaMask, Rainbow, Coinbase, Rabby } from '../../../assets/logos.js';
9
+ import useIsMobile from '../../../hooks/useIsMobile.js';
10
+ import OptionsList from '../../Common/OptionsList/index.js';
11
+ import { OrderHeader } from '../../Common/OrderHeader/index.js';
12
+ import PoweredByFooter from '../../Common/PoweredByFooter/index.js';
13
+
14
+ // Get 3 icons, skipping the one that is already connected
15
+ function getBestUnconnectedWalletIcons(connector) {
16
+ const icons = [];
17
+ const strippedId = connector?.id.toLowerCase(); // some connector ids can have weird casing and or suffixes and prefixes
18
+ const [isMetaMask, isRainbow, isCoinbase] = [
19
+ strippedId?.includes("metamask"),
20
+ strippedId?.includes("rainbow"),
21
+ strippedId?.includes("coinbase"),
22
+ ];
23
+ if (!isMetaMask)
24
+ icons.push(jsx(MetaMask, {}));
25
+ if (!isRainbow)
26
+ icons.push(jsx(Rainbow, {}));
27
+ if (!isCoinbase)
28
+ icons.push(jsx(Coinbase, {}));
29
+ if (icons.length < 3)
30
+ icons.push(jsx(Rabby, {}));
31
+ return icons;
32
+ }
33
+ function getSolanaOption() {
34
+ const { wallets } = useWallet();
35
+ const { setRoute } = usePayContext();
36
+ if (wallets.length === 0)
37
+ return null;
38
+ return {
39
+ id: "solana",
40
+ title: "Pay on Solana",
41
+ icons: [jsx(Solana, {})],
42
+ onClick: () => {
43
+ setRoute(ROUTES.SOLANA_CONNECT);
44
+ },
45
+ };
46
+ }
47
+ function getDepositAddressOption(depositAddressOptions) {
48
+ const { setRoute } = usePayContext();
49
+ if (!depositAddressOptions.loading &&
50
+ depositAddressOptions.options.length === 0) {
51
+ return null;
52
+ }
53
+ return {
54
+ id: "depositAddress",
55
+ title: "Pay on another chain",
56
+ subtitle: "Bitcoin, Tron, Zcash...",
57
+ icons: [jsx(Bitcoin, {}), jsx(Tron, {}), jsx(Zcash, {})],
58
+ onClick: () => {
59
+ setRoute(ROUTES.SELECT_DEPOSIT_ADDRESS_CHAIN);
60
+ },
61
+ };
62
+ }
63
+ const SelectMethod = () => {
64
+ const isMobile = useIsMobile();
65
+ const { address, isConnected, connector } = useAccount();
66
+ const { disconnectAsync } = useDisconnect();
67
+ const { setRoute, paymentState, log } = usePayContext();
68
+ const { setSelectedExternalOption, externalPaymentOptions, depositAddressOptions, senderEnsName, } = paymentState;
69
+ const displayName = senderEnsName ?? (address ? getAddressContraction(address) : "wallet");
70
+ const connectedWalletOption = isConnected
71
+ ? {
72
+ id: "connectedWallet",
73
+ title: `Pay with ${displayName}`,
74
+ icons: connector && connector.icon ? [connector.icon] : [jsx(MetaMask, {})],
75
+ onClick: () => {
76
+ setRoute(ROUTES.SELECT_TOKEN);
77
+ },
78
+ }
79
+ : null;
80
+ const unconnectedWalletOption = {
81
+ id: "unconnectedWallet",
82
+ title: isConnected ? `Pay with another wallet` : `Pay with wallet`,
83
+ icons: getBestUnconnectedWalletIcons(connector),
84
+ onClick: async () => {
85
+ await disconnectAsync();
86
+ setRoute(ROUTES.CONNECTORS);
87
+ },
88
+ };
89
+ const walletOptions = connectedWalletOption
90
+ ? [connectedWalletOption, unconnectedWalletOption]
91
+ : [unconnectedWalletOption];
92
+ log(`[SELECT_METHOD] loading: ${externalPaymentOptions.loading}, options: ${JSON.stringify(externalPaymentOptions.options)}`);
93
+ const solanaOption = getSolanaOption();
94
+ const depositAddressOption = getDepositAddressOption(depositAddressOptions);
95
+ const options = [
96
+ ...walletOptions,
97
+ ...(solanaOption ? [solanaOption] : []),
98
+ ...(externalPaymentOptions.options ?? []).map((option) => ({
99
+ id: option.id,
100
+ title: option.cta,
101
+ icons: [option.logoURI],
102
+ onClick: () => {
103
+ setSelectedExternalOption(option);
104
+ setRoute(ROUTES.WAITING_OTHER);
105
+ },
106
+ })),
107
+ ...(depositAddressOption ? [depositAddressOption] : []),
108
+ ];
109
+ return (jsxs(PageContent, { children: [jsx(OrderHeader, {}), jsx(OptionsList, { requiredSkeletons: isMobile ? 4 : 3, isLoading: externalPaymentOptions.loading, options: externalPaymentOptions.loading ? [] : options }), jsx(PoweredByFooter, {})] }));
110
+ };
111
+
112
+ export { SelectMethod as default };
113
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,62 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { usePayContext, ROUTES } from '../../DaimoPay.js';
3
+ import { PageContent, ModalContent, ModalH1 } from '../../Common/Modal/styles.js';
4
+ import { capitalize, getDisplayPrice } from '@daimo/common';
5
+ import { getChainName } from '@daimo/contract';
6
+ import { motion } from 'framer-motion';
7
+ import { chainToLogo } from '../../../assets/chains.js';
8
+ import styled from '../../../styles/styled/index.js';
9
+ import Button from '../../Common/Button/index.js';
10
+ import OptionsList from '../../Common/OptionsList/index.js';
11
+ import { OrderHeader } from '../../Common/OrderHeader/index.js';
12
+
13
+ function getDaimoTokenKey(token) {
14
+ return `${token.chainId}-${token.token}`;
15
+ }
16
+ const TokenChainLogo = ({ token }) => {
17
+ return (jsxs(TokenChainContainer, { children: [jsx("img", { src: token.logoURI, alt: token.symbol, style: { borderRadius: 9999 } }), jsx(ChainContainer, { children: chainToLogo[token.chainId] })] }));
18
+ };
19
+ const TokenChainContainer = styled(motion.div) `
20
+ width: 100%;
21
+ height: 100%;
22
+ `;
23
+ const ChainContainer = styled(motion.div) `
24
+ position: absolute;
25
+ width: 16px;
26
+ height: 16px;
27
+ border-radius: 9999px;
28
+ overflow: hidden;
29
+ bottom: 0px;
30
+ right: 0px;
31
+ `;
32
+ const SelectToken = () => {
33
+ const { setRoute, paymentState } = usePayContext();
34
+ const { setSelectedTokenOption, walletPaymentOptions } = paymentState;
35
+ return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true }), !walletPaymentOptions.isLoading &&
36
+ walletPaymentOptions.options?.length === 0 && (jsxs(ModalContent, { style: {
37
+ display: "flex",
38
+ alignItems: "center",
39
+ justifyContent: "center",
40
+ paddingTop: 16,
41
+ paddingBottom: 16,
42
+ }, children: [jsx(ModalH1, { children: "Insufficient balance." }), jsx(Button, { onClick: () => setRoute(ROUTES.SELECT_METHOD), children: "Select Another Method" })] })), jsx(OptionsList, { requiredSkeletons: 4, isLoading: walletPaymentOptions.isLoading, options: walletPaymentOptions.options?.map((option) => {
43
+ const capitalizedChainName = capitalize(getChainName(option.required.token.chainId));
44
+ const title = `${getDisplayPrice(option.required)} ${option.required.token.symbol} on ${capitalizedChainName}`;
45
+ const subtitle = `Balance: ${getDisplayPrice(option.balance)} ${option.balance.token.symbol}`;
46
+ return {
47
+ id: getDaimoTokenKey(option.required.token),
48
+ title,
49
+ subtitle,
50
+ icons: [
51
+ jsx(TokenChainLogo, { token: option.required.token }, getDaimoTokenKey(option.required.token)),
52
+ ],
53
+ onClick: () => {
54
+ setSelectedTokenOption(option);
55
+ setRoute(ROUTES.PAY_WITH_TOKEN);
56
+ },
57
+ };
58
+ }) ?? [] })] }));
59
+ };
60
+
61
+ export { SelectToken as default };
62
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,37 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { PageContent, ModalContent, ModalH1 } from '../../../Common/Modal/styles.js';
3
+ import { useWallet } from '@solana/wallet-adapter-react';
4
+ import Button from '../../../Common/Button/index.js';
5
+ import OptionsList from '../../../Common/OptionsList/index.js';
6
+ import { OrderHeader } from '../../../Common/OrderHeader/index.js';
7
+ import { usePayContext, ROUTES } from '../../../DaimoPay.js';
8
+
9
+ const ConnectSolana = () => {
10
+ const { setSolanaConnector, setRoute } = usePayContext();
11
+ const solanaWallets = useWallet();
12
+ const options = solanaWallets.wallets.map((wallet) => ({
13
+ id: wallet.adapter.name,
14
+ title: `${wallet.adapter.name}`,
15
+ icons: [
16
+ jsx(SquircleIcon, { icon: wallet.adapter.icon, alt: wallet.adapter.name }),
17
+ ],
18
+ onClick: async () => {
19
+ setSolanaConnector(wallet.adapter.name);
20
+ if (solanaWallets.connected) {
21
+ await solanaWallets.disconnect();
22
+ }
23
+ setRoute(ROUTES.SOLANA_CONNECTOR);
24
+ },
25
+ }));
26
+ return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true }), solanaWallets.wallets.length === 0 && (jsxs(ModalContent, { style: {
27
+ display: "flex",
28
+ alignItems: "center",
29
+ justifyContent: "center",
30
+ paddingTop: 16,
31
+ paddingBottom: 16,
32
+ }, children: [jsx(ModalH1, { children: "No Solana wallets detected." }), jsx(Button, { onClick: () => setRoute(ROUTES.SELECT_METHOD), children: "Select Another Method" })] })), jsx(OptionsList, { options: options })] }));
33
+ };
34
+ const SquircleIcon = ({ icon, alt }) => (jsx("div", { style: { borderRadius: "22.5%", overflow: "hidden" }, children: jsx("img", { src: icon, alt: alt }) }));
35
+
36
+ export { ConnectSolana as default };
37
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,45 @@
1
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
2
+ import { useEffect } from 'react';
3
+ import { PageContent, ModalContent, ModalH1, ModalBody } from '../../../Common/Modal/styles.js';
4
+ import { useWallet } from '@solana/wallet-adapter-react';
5
+ import { motion, AnimatePresence } from 'framer-motion';
6
+ import styled from '../../../../styles/styled/index.js';
7
+ import { usePayContext, ROUTES } from '../../../DaimoPay.js';
8
+ import SquircleSpinner from '../../../Spinners/SquircleSpinner/index.js';
9
+ import { LoadingContainer } from '../../WaitingOther/index.js';
10
+
11
+ const ConnectSolana = () => {
12
+ const solanaWallets = useWallet();
13
+ const isConnected = solanaWallets.connected;
14
+ const { solanaConnector, setRoute } = usePayContext();
15
+ const selectedWallet = solanaWallets.wallets.find((wallet) => wallet.adapter.name === solanaConnector);
16
+ useEffect(() => {
17
+ if (!solanaConnector)
18
+ return;
19
+ solanaWallets.select(solanaConnector);
20
+ }, [solanaConnector]);
21
+ useEffect(() => {
22
+ if (isConnected) {
23
+ // Wait so user can see it's connected
24
+ setTimeout(() => setRoute(ROUTES.SOLANA_SELECT_TOKEN), 500);
25
+ }
26
+ }, [isConnected]);
27
+ if (!solanaConnector)
28
+ return null;
29
+ return (jsxs(PageContent, { children: [jsx(LoadingContainer, { children: jsx(AnimationContainer, { children: jsx(AnimatePresence, { children: jsx(SquircleSpinner, { logo: jsx("div", { style: { borderRadius: "22.5%", overflow: "hidden" }, children: jsx("img", { src: selectedWallet?.adapter.icon, alt: selectedWallet?.adapter.name }) }), loading: true }) }) }) }), jsx(ModalContent, { style: { paddingBottom: 0 }, children: isConnected ? (jsx(ModalH1, { children: "Connected" })) : (jsxs(Fragment, { children: [jsx(ModalH1, { children: "Requesting Connection" }), jsxs(ModalBody, { children: ["Open ", selectedWallet?.adapter.name, " to continue."] })] })) })] }));
30
+ };
31
+ const AnimationContainer = styled(motion.div) `
32
+ user-select: none;
33
+ position: relative;
34
+ --spinner-error-opacity: 0;
35
+ &:before {
36
+ content: "";
37
+ position: absolute;
38
+ inset: 1px;
39
+ opacity: 0;
40
+ background: var(--ck-body-color-danger);
41
+ }
42
+ `;
43
+
44
+ export { ConnectSolana as default };
45
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,85 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useState, useEffect } from 'react';
3
+ import { usePayContext, ROUTES } from '../../../DaimoPay.js';
4
+ import { WalletSignTransactionError } from '@solana/wallet-adapter-base';
5
+ import { PageContent, ModalContent, ModalH1 } from '../../../Common/Modal/styles.js';
6
+ import { assert } from '@daimo/common';
7
+ import { motion, AnimatePresence } from 'framer-motion';
8
+ import { css } from 'styled-components';
9
+ import styled from '../../../../styles/styled/index.js';
10
+ import Button from '../../../Common/Button/index.js';
11
+ import CircleSpinner from '../../../Spinners/CircleSpinner/index.js';
12
+
13
+ var PayState;
14
+ (function (PayState) {
15
+ PayState["RequestingPayment"] = "Requesting Payment";
16
+ PayState["RequestCancelled"] = "Payment Cancelled";
17
+ PayState["RequestFailed"] = "Payment Failed";
18
+ PayState["RequestSuccessful"] = "Payment Successful";
19
+ })(PayState || (PayState = {}));
20
+ const PayWithSolanaToken = () => {
21
+ const { triggerResize, paymentState, setRoute } = usePayContext();
22
+ const { selectedSolanaTokenOption, payWithSolanaToken } = paymentState;
23
+ const [payState, setPayState] = useState(PayState.RequestingPayment);
24
+ const handleTransfer = async () => {
25
+ try {
26
+ setPayState(PayState.RequestingPayment);
27
+ assert(!!selectedSolanaTokenOption, "No token option selected");
28
+ await payWithSolanaToken(selectedSolanaTokenOption.required.token.token);
29
+ setPayState(PayState.RequestSuccessful);
30
+ setTimeout(() => {
31
+ setRoute(ROUTES.CONFIRMATION);
32
+ }, 200);
33
+ }
34
+ catch (error) {
35
+ console.error(error);
36
+ if (error instanceof WalletSignTransactionError) {
37
+ setPayState(PayState.RequestCancelled);
38
+ }
39
+ else {
40
+ setPayState(PayState.RequestFailed);
41
+ }
42
+ }
43
+ };
44
+ let transferTimeout; // Prevent double-triggering in React dev strict mode.
45
+ useEffect(() => {
46
+ if (!selectedSolanaTokenOption)
47
+ return;
48
+ // Give user time to see the UI before opening
49
+ transferTimeout = setTimeout(handleTransfer, 100);
50
+ return () => clearTimeout(transferTimeout);
51
+ }, []);
52
+ useEffect(() => {
53
+ triggerResize();
54
+ }, [payState]);
55
+ return (jsxs(PageContent, { children: [jsx(LoadingContainer, { children: jsx(AnimationContainer, { "$circle": true, children: jsx(AnimatePresence, { children: jsx(CircleSpinner, { logo: jsx("img", { src: selectedSolanaTokenOption?.required.token.logoURI, alt: selectedSolanaTokenOption?.required.token.symbol }, selectedSolanaTokenOption?.required.token.logoURI), loading: true, unavailable: false }, "CircleSpinner") }) }) }), jsxs(ModalContent, { style: { paddingBottom: 0 }, children: [jsx(ModalH1, { children: payState }), payState === PayState.RequestCancelled && (jsx(Button, { onClick: handleTransfer, children: "Retry Payment" })), payState === PayState.RequestFailed && (jsx(Button, { onClick: () => setRoute(ROUTES.SELECT_METHOD), children: "Select Another Method" }))] })] }));
56
+ };
57
+ const LoadingContainer = styled(motion.div) `
58
+ display: flex;
59
+ align-items: center;
60
+ justify-content: center;
61
+ margin: 10px auto 16px;
62
+ height: 120px;
63
+ `;
64
+ const AnimationContainer = styled(motion.div) `
65
+ user-select: none;
66
+ position: relative;
67
+ --spinner-error-opacity: 0;
68
+ &:before {
69
+ content: "";
70
+ position: absolute;
71
+ inset: 1px;
72
+ opacity: 0;
73
+ background: var(--ck-body-color-danger);
74
+ ${(props) => props.$circle &&
75
+ css `
76
+ inset: -5px;
77
+ border-radius: 50%;
78
+ background: none;
79
+ box-shadow: inset 0 0 0 3.5px var(--ck-body-color-danger);
80
+ `}
81
+ }
82
+ `;
83
+
84
+ export { PayWithSolanaToken as default };
85
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,38 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { usePayContext, ROUTES } from '../../../DaimoPay.js';
3
+ import { PageContent, ModalContent, ModalH1 } from '../../../Common/Modal/styles.js';
4
+ import { getDisplayPrice } from '@daimo/common';
5
+ import Button from '../../../Common/Button/index.js';
6
+ import OptionsList from '../../../Common/OptionsList/index.js';
7
+ import { OrderHeader } from '../../../Common/OrderHeader/index.js';
8
+
9
+ const SelectSolanaToken = () => {
10
+ const { paymentState, setRoute } = usePayContext();
11
+ const { solanaPaymentOptions, setSelectedSolanaTokenOption } = paymentState;
12
+ return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true }), !solanaPaymentOptions.isLoading &&
13
+ solanaPaymentOptions.options?.length === 0 && (jsxs(ModalContent, { style: {
14
+ display: "flex",
15
+ alignItems: "center",
16
+ justifyContent: "center",
17
+ paddingTop: 16,
18
+ paddingBottom: 16,
19
+ }, children: [jsx(ModalH1, { children: "Insufficient balance." }), jsx(Button, { onClick: () => setRoute(ROUTES.SELECT_METHOD), children: "Select Another Method" })] })), jsx(OptionsList, { requiredSkeletons: 4, isLoading: solanaPaymentOptions.isLoading, options: solanaPaymentOptions.options?.map((option) => {
20
+ const title = `${getDisplayPrice(option.required)} ${option.required.token.symbol}`;
21
+ const subtitle = `Balance: ${getDisplayPrice(option.balance)} ${option.balance.token.symbol}`;
22
+ return {
23
+ id: `${option.required.token.token}-${option.required.token.symbol}`,
24
+ title,
25
+ subtitle,
26
+ icons: [
27
+ jsx("img", { src: option.required.token.logoURI, alt: option.required.token.symbol, style: { borderRadius: 9999 } }),
28
+ ],
29
+ onClick: () => {
30
+ setSelectedSolanaTokenOption(option);
31
+ setRoute(ROUTES.SOLANA_PAY_WITH_TOKEN);
32
+ },
33
+ };
34
+ }) ?? [] })] }));
35
+ };
36
+
37
+ export { SelectSolanaToken as default };
38
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}