@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.
- package/build/index.d.ts +132 -301
- package/build/package.json.js +103 -0
- package/build/package.json.js.map +1 -0
- package/build/src/assets/ScanIconWithLogos.js +34 -0
- package/build/src/assets/ScanIconWithLogos.js.map +1 -0
- package/build/src/assets/browsers.js +13 -0
- package/build/src/assets/browsers.js.map +1 -0
- package/build/src/assets/chains.js +152 -0
- package/build/src/assets/chains.js.map +1 -0
- package/build/src/assets/coins.js +6 -0
- package/build/src/assets/coins.js.map +1 -0
- package/build/src/assets/crepe.js +8 -0
- package/build/src/assets/crepe.js.map +1 -0
- package/build/src/assets/icons.js +28 -0
- package/build/src/assets/icons.js.map +1 -0
- package/build/src/assets/logos.js +131 -0
- package/build/src/assets/logos.js.map +1 -0
- package/build/src/assets/wallet.js +8 -0
- package/build/src/assets/wallet.js.map +1 -0
- package/build/src/assets/wave.js +6 -0
- package/build/src/assets/wave.js.map +1 -0
- package/build/src/components/Common/Alert/index.js +10 -0
- package/build/src/components/Common/Alert/index.js.map +1 -0
- package/build/src/components/Common/Alert/styles.js +55 -0
- package/build/src/components/Common/Alert/styles.js.map +1 -0
- package/build/src/components/Common/Avatar/index.js +66 -0
- package/build/src/components/Common/Avatar/index.js.map +1 -0
- package/build/src/components/Common/Avatar/styles.js +59 -0
- package/build/src/components/Common/Avatar/styles.js.map +1 -0
- package/build/src/components/Common/BrowserIcon/index.js +28 -0
- package/build/src/components/Common/BrowserIcon/index.js.map +1 -0
- package/build/src/components/Common/BrowserIcon/styles.js +20 -0
- package/build/src/components/Common/BrowserIcon/styles.js.map +1 -0
- package/build/src/components/Common/Button/index.js +38 -0
- package/build/src/components/Common/Button/index.js.map +1 -0
- package/build/src/components/Common/Button/styles.js +291 -0
- package/build/src/components/Common/Button/styles.js.map +1 -0
- package/build/src/components/Common/Chain/index.js +25 -0
- package/build/src/components/Common/Chain/index.js.map +1 -0
- package/build/src/components/Common/Chain/styles.js +94 -0
- package/build/src/components/Common/Chain/styles.js.map +1 -0
- package/build/src/components/Common/ChainSelectList/index.js +107 -0
- package/build/src/components/Common/ChainSelectList/index.js.map +1 -0
- package/build/src/components/Common/ChainSelectList/styles.js +228 -0
- package/build/src/components/Common/ChainSelectList/styles.js.map +1 -0
- package/build/src/components/Common/ConnectorList/index.js +70 -0
- package/build/src/components/Common/ConnectorList/index.js.map +1 -0
- package/build/src/components/Common/ConnectorList/styles.js +314 -0
- package/build/src/components/Common/ConnectorList/styles.js.map +1 -0
- package/build/src/components/Common/CopyToClipboard/CopyToClipboardIcon.js +71 -0
- package/build/src/components/Common/CopyToClipboard/CopyToClipboardIcon.js.map +1 -0
- package/build/src/components/Common/CopyToClipboard/index.js +51 -0
- package/build/src/components/Common/CopyToClipboard/index.js.map +1 -0
- package/build/src/components/Common/CustomQRCode/QRCode.js +69 -0
- package/build/src/components/Common/CustomQRCode/QRCode.js.map +1 -0
- package/build/src/components/Common/CustomQRCode/index.js +22 -0
- package/build/src/components/Common/CustomQRCode/index.js.map +1 -0
- package/build/src/components/Common/CustomQRCode/styles.js +155 -0
- package/build/src/components/Common/CustomQRCode/styles.js.map +1 -0
- package/build/src/components/Common/FitText/index.js +27 -0
- package/build/src/components/Common/FitText/index.js.map +1 -0
- package/build/src/components/Common/Modal/index.js +297 -0
- package/build/src/components/Common/Modal/index.js.map +1 -0
- package/build/src/components/Common/Modal/styles.js +660 -0
- package/build/src/components/Common/Modal/styles.js.map +1 -0
- package/build/src/components/Common/OptionsList/index.js +106 -0
- package/build/src/components/Common/OptionsList/index.js.map +1 -0
- package/build/src/components/Common/OptionsList/styles.js +165 -0
- package/build/src/components/Common/OptionsList/styles.js.map +1 -0
- package/build/src/components/Common/OrderHeader/index.js +215 -0
- package/build/src/components/Common/OrderHeader/index.js.map +1 -0
- package/build/src/components/Common/Portal/index.js +31 -0
- package/build/src/components/Common/Portal/index.js.map +1 -0
- package/build/src/components/Common/PoweredByFooter/index.js +44 -0
- package/build/src/components/Common/PoweredByFooter/index.js.map +1 -0
- package/build/src/components/Common/ScrollArea/index.js +62 -0
- package/build/src/components/Common/ScrollArea/index.js.map +1 -0
- package/build/src/components/Common/ScrollArea/styles.js +168 -0
- package/build/src/components/Common/ScrollArea/styles.js.map +1 -0
- package/build/src/components/Common/Spinner/index.js +24 -0
- package/build/src/components/Common/Spinner/index.js.map +1 -0
- package/build/src/components/Common/Spinner/styles.js +22 -0
- package/build/src/components/Common/Spinner/styles.js.map +1 -0
- package/build/src/components/Common/ThemedButton/index.js +25 -0
- package/build/src/components/Common/ThemedButton/index.js.map +1 -0
- package/build/src/components/Common/ThemedButton/styles.js +152 -0
- package/build/src/components/Common/ThemedButton/styles.js.map +1 -0
- package/build/src/components/Common/Tooltip/index.js +97 -0
- package/build/src/components/Common/Tooltip/index.js.map +1 -0
- package/build/src/components/Common/Tooltip/styles.js +81 -0
- package/build/src/components/Common/Tooltip/styles.js.map +1 -0
- package/build/src/components/DaimoPay.js +232 -0
- package/build/src/components/DaimoPay.js.map +1 -0
- package/build/src/components/DaimoPayButton/index.js +129 -0
- package/build/src/components/DaimoPayButton/index.js.map +1 -0
- package/build/src/components/DaimoPayButton/styles.js +50 -0
- package/build/src/components/DaimoPayButton/styles.js.map +1 -0
- package/build/src/components/DaimoPayModal/ConnectUsing.js +45 -0
- package/build/src/components/DaimoPayModal/ConnectUsing.js.map +1 -0
- package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js +202 -0
- package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js.map +1 -0
- package/build/src/components/DaimoPayModal/ConnectWithInjector/styles.js +133 -0
- package/build/src/components/DaimoPayModal/ConnectWithInjector/styles.js.map +1 -0
- package/build/src/components/DaimoPayModal/ConnectWithQRCode.js +75 -0
- package/build/src/components/DaimoPayModal/ConnectWithQRCode.js.map +1 -0
- package/build/src/components/DaimoPayModal/index.js +140 -0
- package/build/src/components/DaimoPayModal/index.js.map +1 -0
- package/build/src/components/DaimoPayThemeProvider/DaimoPayThemeProvider.js +21 -0
- package/build/src/components/DaimoPayThemeProvider/DaimoPayThemeProvider.js.map +1 -0
- package/build/src/components/Pages/About/graphics.js +187 -0
- package/build/src/components/Pages/About/graphics.js.map +1 -0
- package/build/src/components/Pages/About/index.js +131 -0
- package/build/src/components/Pages/About/index.js.map +1 -0
- package/build/src/components/Pages/About/styles.js +144 -0
- package/build/src/components/Pages/About/styles.js.map +1 -0
- package/build/src/components/Pages/Confirmation/index.js +105 -0
- package/build/src/components/Pages/Confirmation/index.js.map +1 -0
- package/build/src/components/Pages/Connectors/index.js +20 -0
- package/build/src/components/Pages/Connectors/index.js.map +1 -0
- package/build/src/components/Pages/Connectors/styles.js +267 -0
- package/build/src/components/Pages/Connectors/styles.js.map +1 -0
- package/build/src/components/Pages/DownloadApp/index.js +30 -0
- package/build/src/components/Pages/DownloadApp/index.js.map +1 -0
- package/build/src/components/Pages/MobileConnectors/index.js +73 -0
- package/build/src/components/Pages/MobileConnectors/index.js.map +1 -0
- package/build/src/components/Pages/MobileConnectors/styles.js +65 -0
- package/build/src/components/Pages/MobileConnectors/styles.js.map +1 -0
- package/build/src/components/Pages/Onboarding/index.js +18 -0
- package/build/src/components/Pages/Onboarding/index.js.map +1 -0
- package/build/src/components/Pages/Onboarding/styles.js +229 -0
- package/build/src/components/Pages/Onboarding/styles.js.map +1 -0
- package/build/src/components/Pages/PayWithToken/index.js +204 -0
- package/build/src/components/Pages/PayWithToken/index.js.map +1 -0
- package/build/src/components/Pages/SelectDepositAddressChain/index.js +32 -0
- package/build/src/components/Pages/SelectDepositAddressChain/index.js.map +1 -0
- package/build/src/components/Pages/SelectMethod/index.js +113 -0
- package/build/src/components/Pages/SelectMethod/index.js.map +1 -0
- package/build/src/components/Pages/SelectToken/index.js +62 -0
- package/build/src/components/Pages/SelectToken/index.js.map +1 -0
- package/build/src/components/Pages/Solana/ConnectSolana/index.js +37 -0
- package/build/src/components/Pages/Solana/ConnectSolana/index.js.map +1 -0
- package/build/src/components/Pages/Solana/ConnectorSolana/index.js +45 -0
- package/build/src/components/Pages/Solana/ConnectorSolana/index.js.map +1 -0
- package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js +85 -0
- package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js.map +1 -0
- package/build/src/components/Pages/Solana/SelectSolanaToken/index.js +38 -0
- package/build/src/components/Pages/Solana/SelectSolanaToken/index.js.map +1 -0
- package/build/src/components/Pages/SwitchNetworks/index.js +26 -0
- package/build/src/components/Pages/SwitchNetworks/index.js.map +1 -0
- package/build/src/components/Pages/WaitingDepositAddress/index.js +51 -0
- package/build/src/components/Pages/WaitingDepositAddress/index.js.map +1 -0
- package/build/src/components/Pages/WaitingOther/index.js +91 -0
- package/build/src/components/Pages/WaitingOther/index.js.map +1 -0
- package/build/src/components/Spinners/CircleSpinner/index.js +15 -0
- package/build/src/components/Spinners/CircleSpinner/index.js.map +1 -0
- package/build/src/components/Spinners/CircleSpinner/styles.js +118 -0
- package/build/src/components/Spinners/CircleSpinner/styles.js.map +1 -0
- package/build/src/components/Spinners/SquircleSpinner/index.js +15 -0
- package/build/src/components/Spinners/SquircleSpinner/index.js.map +1 -0
- package/build/src/components/Spinners/SquircleSpinner/styles.js +66 -0
- package/build/src/components/Spinners/SquircleSpinner/styles.js.map +1 -0
- package/build/src/components/contexts/solana/index.js +11 -0
- package/build/src/components/contexts/solana/index.js.map +1 -0
- package/build/src/components/contexts/web3/index.js +46 -0
- package/build/src/components/contexts/web3/index.js.map +1 -0
- package/build/src/constants/chainConfigs.js +306 -0
- package/build/src/constants/chainConfigs.js.map +1 -0
- package/build/src/constants/defaultTheme.js +6 -0
- package/build/src/constants/defaultTheme.js.map +1 -0
- package/build/src/defaultConfig.js +59 -0
- package/build/src/defaultConfig.js.map +1 -0
- package/build/src/defaultConnectors.js +43 -0
- package/build/src/defaultConnectors.js.map +1 -0
- package/build/src/hooks/connectors/useWalletConnectUri.js +93 -0
- package/build/src/hooks/connectors/useWalletConnectUri.js.map +1 -0
- package/build/src/hooks/useChainIsSupported.js +12 -0
- package/build/src/hooks/useChainIsSupported.js.map +1 -0
- package/build/src/hooks/useChains.js +11 -0
- package/build/src/hooks/useChains.js.map +1 -0
- package/build/src/hooks/useConnect.js +45 -0
- package/build/src/hooks/useConnect.js.map +1 -0
- package/build/src/hooks/useConnectCallback.js +18 -0
- package/build/src/hooks/useConnectCallback.js.map +1 -0
- package/build/src/hooks/useConnectors.js +29 -0
- package/build/src/hooks/useConnectors.js.map +1 -0
- package/build/src/hooks/useDaimoPayStatus.js +37 -0
- package/build/src/hooks/useDaimoPayStatus.js.map +1 -0
- package/build/src/hooks/useDepositAddressOptions.js +28 -0
- package/build/src/hooks/useDepositAddressOptions.js.map +1 -0
- package/build/src/hooks/useEnsFallbackConfig.js +16 -0
- package/build/src/hooks/useEnsFallbackConfig.js.map +1 -0
- package/build/src/hooks/useExternalPaymentOptions.js +46 -0
- package/build/src/hooks/useExternalPaymentOptions.js.map +1 -0
- package/build/src/hooks/useFitText.js +148 -0
- package/build/src/hooks/useFitText.js.map +1 -0
- package/build/src/hooks/useFocusTrap.js +60 -0
- package/build/src/hooks/useFocusTrap.js.map +1 -0
- package/build/src/hooks/useGoogleFont.js +45 -0
- package/build/src/hooks/useGoogleFont.js.map +1 -0
- package/build/src/hooks/useIsMobile.js +17 -0
- package/build/src/hooks/useIsMobile.js.map +1 -0
- package/build/src/hooks/useIsMounted.js +12 -0
- package/build/src/hooks/useIsMounted.js.map +1 -0
- package/build/src/hooks/useLastConnector.js +24 -0
- package/build/src/hooks/useLastConnector.js.map +1 -0
- package/build/src/hooks/useLocales.js +67 -0
- package/build/src/hooks/useLocales.js.map +1 -0
- package/build/src/hooks/useLockBodyScroll.js +53 -0
- package/build/src/hooks/useLockBodyScroll.js.map +1 -0
- package/build/src/hooks/useModal.js +35 -0
- package/build/src/hooks/useModal.js.map +1 -0
- package/build/src/hooks/usePayWithSolanaToken.js +50 -0
- package/build/src/hooks/usePayWithSolanaToken.js.map +1 -0
- package/build/src/hooks/usePayWithToken.js +57 -0
- package/build/src/hooks/usePayWithToken.js.map +1 -0
- package/build/src/hooks/usePaymentState.js +243 -0
- package/build/src/hooks/usePaymentState.js.map +1 -0
- package/build/src/hooks/usePrevious.js +14 -0
- package/build/src/hooks/usePrevious.js.map +1 -0
- package/build/src/hooks/useSolanaPaymentOptions.js +37 -0
- package/build/src/hooks/useSolanaPaymentOptions.js.map +1 -0
- package/build/src/hooks/useWalletConnectModal.js +52 -0
- package/build/src/hooks/useWalletConnectModal.js.map +1 -0
- package/build/src/hooks/useWalletPaymentOptions.js +40 -0
- package/build/src/hooks/useWalletPaymentOptions.js.map +1 -0
- package/build/src/hooks/useWindowSize.js +23 -0
- package/build/src/hooks/useWindowSize.js.map +1 -0
- package/build/src/index.js +10 -0
- package/build/src/index.js.map +1 -0
- package/build/src/localizations/index.js +57 -0
- package/build/src/localizations/index.js.map +1 -0
- package/build/src/localizations/locales/ar-AE.js +97 -0
- package/build/src/localizations/locales/ar-AE.js.map +1 -0
- package/build/src/localizations/locales/ca-AD.js +95 -0
- package/build/src/localizations/locales/ca-AD.js.map +1 -0
- package/build/src/localizations/locales/ee-EE.js +95 -0
- package/build/src/localizations/locales/ee-EE.js.map +1 -0
- package/build/src/localizations/locales/en-US.js +95 -0
- package/build/src/localizations/locales/en-US.js.map +1 -0
- package/build/src/localizations/locales/es-ES.js +95 -0
- package/build/src/localizations/locales/es-ES.js.map +1 -0
- package/build/src/localizations/locales/fa-IR.js +95 -0
- package/build/src/localizations/locales/fa-IR.js.map +1 -0
- package/build/src/localizations/locales/fr-FR.js +95 -0
- package/build/src/localizations/locales/fr-FR.js.map +1 -0
- package/build/src/localizations/locales/ja-JP.js +95 -0
- package/build/src/localizations/locales/ja-JP.js.map +1 -0
- package/build/src/localizations/locales/pt-BR.js +95 -0
- package/build/src/localizations/locales/pt-BR.js.map +1 -0
- package/build/src/localizations/locales/ru-RU.js +95 -0
- package/build/src/localizations/locales/ru-RU.js.map +1 -0
- package/build/src/localizations/locales/tr-TR.js +95 -0
- package/build/src/localizations/locales/tr-TR.js.map +1 -0
- package/build/src/localizations/locales/vi-VN.js +95 -0
- package/build/src/localizations/locales/vi-VN.js.map +1 -0
- package/build/src/localizations/locales/zh-CN.js +95 -0
- package/build/src/localizations/locales/zh-CN.js.map +1 -0
- package/build/src/styles/defaultTheme.js +89 -0
- package/build/src/styles/defaultTheme.js.map +1 -0
- package/build/src/styles/index.js +329 -0
- package/build/src/styles/index.js.map +1 -0
- package/build/src/styles/styled/index.js +16 -0
- package/build/src/styles/styled/index.js.map +1 -0
- package/build/src/styles/themes/base.js +141 -0
- package/build/src/styles/themes/base.js.map +1 -0
- package/build/src/styles/themes/index.js +13 -0
- package/build/src/styles/themes/index.js.map +1 -0
- package/build/src/styles/themes/midnight.js +76 -0
- package/build/src/styles/themes/midnight.js.map +1 -0
- package/build/src/styles/themes/minimal.js +96 -0
- package/build/src/styles/themes/minimal.js.map +1 -0
- package/build/src/styles/themes/nouns.js +81 -0
- package/build/src/styles/themes/nouns.js.map +1 -0
- package/build/src/styles/themes/retro.js +106 -0
- package/build/src/styles/themes/retro.js.map +1 -0
- package/build/src/styles/themes/rounded.js +106 -0
- package/build/src/styles/themes/rounded.js.map +1 -0
- package/build/src/styles/themes/soft.js +71 -0
- package/build/src/styles/themes/soft.js.map +1 -0
- package/build/src/styles/themes/web95.js +132 -0
- package/build/src/styles/themes/web95.js.map +1 -0
- package/build/src/utils/exports.js +12 -0
- package/build/src/utils/exports.js.map +1 -0
- package/build/src/utils/index.js +39 -0
- package/build/src/utils/index.js.map +1 -0
- package/build/src/utils/p3.js +16 -0
- package/build/src/utils/p3.js.map +1 -0
- package/build/src/utils/platform.js +13 -0
- package/build/src/utils/platform.js.map +1 -0
- package/build/src/utils/trpc.js +14 -0
- package/build/src/utils/trpc.js.map +1 -0
- package/build/src/utils/wallets.js +14 -0
- package/build/src/utils/wallets.js.map +1 -0
- package/build/src/wallets/index.js +32 -0
- package/build/src/wallets/index.js.map +1 -0
- package/build/src/wallets/useWallets.js +86 -0
- package/build/src/wallets/useWallets.js.map +1 -0
- package/build/src/wallets/walletConfigs.js +362 -0
- package/build/src/wallets/walletConfigs.js.map +1 -0
- package/package.json +5 -5
- package/build/index.es.js +0 -11565
- 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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|