@rozoai/intent-pay 0.0.7 → 0.0.9
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/README.md +36 -44
- package/build/assets/MobileWithLogos.d.ts +2 -0
- package/build/assets/ScanIconWithLogos.d.ts +6 -0
- package/build/assets/browsers.d.ts +10 -0
- package/build/assets/chains.d.ts +28 -0
- package/build/assets/coins.d.ts +2 -0
- package/build/assets/crepe.d.ts +3 -0
- package/build/assets/icons.d.ts +35 -0
- package/build/assets/logos.d.ts +211 -0
- package/build/assets/wallet.d.ts +3 -0
- package/build/assets/wave.d.ts +2 -0
- package/build/components/Common/Alert/index.d.ts +6 -0
- package/build/components/Common/Alert/styles.d.ts +2 -0
- package/build/components/Common/Alert/types.d.ts +5 -0
- package/build/components/Common/AmountInput/AmountInputField.d.ts +8 -0
- package/build/components/Common/AmountInput/index.d.ts +9 -0
- package/build/components/Common/Avatar/index.d.ts +17 -0
- package/build/components/Common/Avatar/styles.d.ts +2 -0
- package/build/components/Common/BrowserIcon/index.d.ts +4 -0
- package/build/components/Common/BrowserIcon/styles.d.ts +1 -0
- package/build/components/Common/BrowserIcon/types.d.ts +3 -0
- package/build/components/Common/Button/index.d.ts +4 -0
- package/build/components/Common/Button/styles.d.ts +10 -0
- package/build/components/Common/Button/types.d.ts +15 -0
- package/build/components/Common/Chain/index.d.ts +9 -0
- package/build/components/Common/Chain/styles.d.ts +4 -0
- package/build/components/Common/ChainSelectList/index.d.ts +4 -0
- package/build/components/Common/ChainSelectList/styles.d.ts +9 -0
- package/build/components/Common/CircleTimer.d.ts +17 -0
- package/build/components/Common/ConnectorList/index.d.ts +2 -0
- package/build/components/Common/ConnectorList/styles.d.ts +8 -0
- package/build/components/Common/CopyToClipboard/CopyToClipboardIcon.d.ts +6 -0
- package/build/components/Common/CopyToClipboard/index.d.ts +7 -0
- package/build/components/Common/CustomQRCode/QRCode.d.ts +12 -0
- package/build/components/Common/CustomQRCode/index.d.ts +6 -0
- package/build/components/Common/CustomQRCode/styles.d.ts +6 -0
- package/build/components/Common/CustomQRCode/types.d.ts +11 -0
- package/build/components/Common/DynamicContainer/index.d.ts +7 -0
- package/build/components/Common/FitText/index.d.ts +8 -0
- package/build/components/Common/LazyImage/index.d.ts +8 -0
- package/build/components/Common/Logo/index.d.ts +8 -0
- package/build/components/Common/Logo/styles.d.ts +3 -0
- package/build/components/Common/Modal/index.d.ts +25 -0
- package/build/components/Common/Modal/styles.d.ts +25 -0
- package/build/components/Common/OptionsList/index.d.ts +17 -0
- package/build/components/Common/OptionsList/styles.d.ts +5 -0
- package/build/components/Common/OrderHeader/index.d.ts +7 -0
- package/build/components/Common/PaymentBreakdown/index.d.ts +6 -0
- package/build/components/Common/Portal/index.d.ts +2 -0
- package/build/components/Common/PoweredByFooter/index.d.ts +4 -0
- package/build/components/Common/ScrollArea/index.d.ts +9 -0
- package/build/components/Common/ScrollArea/styles.d.ts +3 -0
- package/build/components/Common/SelectAnotherMethodButton/index.d.ts +1 -0
- package/build/components/Common/Spinner/index.d.ts +1 -0
- package/build/components/Common/Spinner/styles.d.ts +1 -0
- package/build/components/Common/SquareTimer.d.ts +19 -0
- package/build/components/Common/SwitchButton/index.d.ts +6 -0
- package/build/components/Common/ThemedButton/index.d.ts +15 -0
- package/build/components/Common/ThemedButton/styles.d.ts +2 -0
- package/build/components/Common/TokenChainLogo/index.d.ts +7 -0
- package/build/components/Common/Tooltip/index.d.ts +4 -0
- package/build/components/Common/Tooltip/styles.d.ts +3 -0
- package/build/components/Common/Tooltip/types.d.ts +9 -0
- package/build/components/Common/WalletChainLogo/index.d.ts +6 -0
- package/build/components/Pages/About/graphics.d.ts +11 -0
- package/build/components/Pages/About/index.d.ts +3 -0
- package/build/components/Pages/About/styles.d.ts +8 -0
- package/build/components/Pages/Confirmation/index.d.ts +3 -0
- package/build/components/Pages/Connectors/index.d.ts +3 -0
- package/build/components/Pages/Connectors/styles.d.ts +9 -0
- package/build/components/Pages/DownloadApp/index.d.ts +2 -0
- package/build/components/Pages/MobileConnectors/index.d.ts +3 -0
- package/build/components/Pages/MobileConnectors/styles.d.ts +5 -0
- package/build/components/Pages/Onboarding/index.d.ts +3 -0
- package/build/components/Pages/Onboarding/styles.d.ts +9 -0
- package/build/components/Pages/PayWithToken/index.d.ts +3 -0
- package/build/components/Pages/SelectAmount/index.d.ts +3 -0
- package/build/components/Pages/SelectDepositAddressAmount/index.d.ts +3 -0
- package/build/components/Pages/SelectDepositAddressChain/index.d.ts +3 -0
- package/build/components/Pages/SelectExternalAmount/index.d.ts +3 -0
- package/build/components/Pages/SelectMethod/index.d.ts +1 -0
- package/build/components/Pages/SelectMethod/styles.d.ts +9 -0
- package/build/components/Pages/SelectToken/index.d.ts +1 -0
- package/build/components/Pages/SelectWalletAmount/index.d.ts +3 -0
- package/build/components/Pages/SelectZKP/index.d.ts +3 -0
- package/build/components/Pages/Solana/ConnectSolana/index.d.ts +3 -0
- package/build/components/Pages/Solana/ConnectorSolana/index.d.ts +4 -0
- package/build/components/Pages/Solana/PayWithSolanaToken/index.d.ts +3 -0
- package/build/components/Pages/Solana/SelectSolanaAmount/index.d.ts +3 -0
- package/build/components/Pages/SwitchNetworks/index.d.ts +3 -0
- package/build/components/Pages/WaitingDepositAddress/index.d.ts +1 -0
- package/build/components/Pages/WaitingExternal/index.d.ts +3 -0
- package/build/components/Pages/WaitingWallet/index.d.ts +3 -0
- package/build/components/RozoPayButton/index.d.ts +132 -0
- package/build/components/RozoPayButton/styles.d.ts +4 -0
- package/build/components/RozoPayModal/ConnectUsing.d.ts +2 -0
- package/build/components/RozoPayModal/ConnectWithInjector/index.d.ts +15 -0
- package/build/components/RozoPayModal/ConnectWithInjector/styles.d.ts +6 -0
- package/build/components/RozoPayModal/ConnectWithQRCode.d.ts +3 -0
- package/build/components/RozoPayModal/index.d.ts +7 -0
- package/build/components/RozoPayThemeProvider/RozoPayThemeProvider.d.ts +16 -0
- package/build/components/Spinners/CircleSpinner/index.d.ts +9 -0
- package/build/components/Spinners/CircleSpinner/styles.d.ts +5 -0
- package/build/components/Spinners/ExternalPaymentSpinner/index.d.ts +5 -0
- package/build/components/Spinners/SquircleSpinner/index.d.ts +5 -0
- package/build/components/Spinners/SquircleSpinner/styles.d.ts +4 -0
- package/build/components/Spinners/TokenLogoSpinner/index.d.ts +5 -0
- package/build/components/Spinners/TokenLogoSpinner/styles.d.ts +1 -0
- package/build/components/Spinners/WalletPaymentSpinner/index.d.ts +5 -0
- package/build/components/Spinners/styles.d.ts +2 -0
- package/build/constants/defaultTheme.d.ts +4 -0
- package/build/constants/routes.d.ts +26 -0
- package/build/defaultConfig.d.ts +17 -0
- package/build/defaultConnectors.d.ts +14 -0
- package/build/hooks/useChainIsSupported.d.ts +2 -0
- package/build/hooks/useChains.d.ts +3 -0
- package/build/hooks/useConnectCallback.d.ts +8 -0
- package/build/hooks/useConnectors.d.ts +3 -0
- package/build/hooks/useDepositAddressOptions.d.ts +10 -0
- package/build/hooks/useEnsFallbackConfig.d.ts +2 -0
- package/build/hooks/useExternalPaymentOptions.d.ts +12 -0
- package/build/hooks/useFitText.d.ts +14 -0
- package/build/hooks/useFocusTrap.d.ts +1 -0
- package/build/hooks/useGoogleFont.d.ts +3 -0
- package/build/hooks/useIsMobile.d.ts +5 -0
- package/build/hooks/useIsMounted.d.ts +3 -0
- package/build/hooks/useLastConnector.d.ts +4 -0
- package/build/hooks/useLocalStorage.d.ts +7 -0
- package/build/hooks/useLocales.d.ts +1 -0
- package/build/hooks/useLockBodyScroll.d.ts +1 -0
- package/build/hooks/useModal.d.ts +8 -0
- package/build/hooks/useOrderUsdLimits.d.ts +7 -0
- package/build/hooks/usePayContext.d.ts +2 -0
- package/build/hooks/usePaymentState.d.ts +65 -0
- package/build/hooks/usePrevious.d.ts +1 -0
- package/build/hooks/useRozoPay.d.ts +91 -0
- package/build/hooks/useRozoPayStatus.d.ts +15 -0
- package/build/hooks/useRozoPayUI.d.ts +6 -0
- package/build/hooks/useSolanaPaymentOptions.d.ts +11 -0
- package/build/hooks/useTokenOptions.d.ts +5 -0
- package/build/hooks/useWalletPaymentOptions.d.ts +19 -0
- package/build/hooks/useWindowSize.d.ts +4 -0
- package/build/index.d.ts +15 -649
- package/build/localizations/index.d.ts +91 -0
- package/build/localizations/locales/ar-AE.d.ts +3 -0
- package/build/localizations/locales/ca-AD.d.ts +3 -0
- package/build/localizations/locales/ee-EE.d.ts +3 -0
- package/build/localizations/locales/en-US.d.ts +91 -0
- package/build/localizations/locales/es-ES.d.ts +3 -0
- package/build/localizations/locales/fa-IR.d.ts +3 -0
- package/build/localizations/locales/fr-FR.d.ts +3 -0
- package/build/localizations/locales/index.d.ts +2 -0
- package/build/localizations/locales/ja-JP.d.ts +91 -0
- package/build/localizations/locales/pt-BR.d.ts +3 -0
- package/build/localizations/locales/ru-RU.d.ts +3 -0
- package/build/localizations/locales/tr-TR.d.ts +3 -0
- package/build/localizations/locales/vi-VN.d.ts +3 -0
- package/build/localizations/locales/zh-CN.d.ts +3 -0
- package/build/package.json.js +125 -0
- package/build/package.json.js.map +1 -0
- package/build/payment/paymentEffects.d.ts +12 -0
- package/build/payment/paymentFsm.d.ts +126 -0
- package/build/payment/paymentStore.d.ts +14 -0
- package/build/provider/PayContext.d.ts +56 -0
- package/build/provider/PaymentProvider.d.ts +8 -0
- package/build/provider/RozoPayProvider.d.ts +24 -0
- package/build/provider/SolanaContextProvider.d.ts +6 -0
- package/build/provider/Web3ContextProvider.d.ts +24 -0
- package/build/src/assets/MobileWithLogos.js +10 -0
- package/build/src/assets/MobileWithLogos.js.map +1 -0
- package/build/src/assets/ScanIconWithLogos.js +37 -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 +97 -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 +30 -0
- package/build/src/assets/icons.js.map +1 -0
- package/build/src/assets/logos.js +177 -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/AmountInput/AmountInputField.js +60 -0
- package/build/src/components/Common/AmountInput/AmountInputField.js.map +1 -0
- package/build/src/components/Common/AmountInput/index.js +146 -0
- package/build/src/components/Common/AmountInput/index.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/CircleTimer.js +48 -0
- package/build/src/components/Common/CircleTimer.js.map +1 -0
- package/build/src/components/Common/ConnectorList/index.js +85 -0
- package/build/src/components/Common/ConnectorList/index.js.map +1 -0
- package/build/src/components/Common/ConnectorList/styles.js +352 -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 +35 -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 +139 -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/Logo/styles.js +29 -0
- package/build/src/components/Common/Logo/styles.js.map +1 -0
- package/build/src/components/Common/Modal/index.js +300 -0
- package/build/src/components/Common/Modal/index.js.map +1 -0
- package/build/src/components/Common/Modal/styles.js +669 -0
- package/build/src/components/Common/Modal/styles.js.map +1 -0
- package/build/src/components/Common/OptionsList/index.js +103 -0
- package/build/src/components/Common/OptionsList/index.js.map +1 -0
- package/build/src/components/Common/OptionsList/styles.js +139 -0
- package/build/src/components/Common/OptionsList/styles.js.map +1 -0
- package/build/src/components/Common/OrderHeader/index.js +152 -0
- package/build/src/components/Common/OrderHeader/index.js.map +1 -0
- package/build/src/components/Common/PaymentBreakdown/index.js +48 -0
- package/build/src/components/Common/PaymentBreakdown/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 +77 -0
- package/build/src/components/Common/PoweredByFooter/index.js.map +1 -0
- package/build/src/components/Common/ScrollArea/index.js +63 -0
- package/build/src/components/Common/ScrollArea/index.js.map +1 -0
- package/build/src/components/Common/ScrollArea/styles.js +173 -0
- package/build/src/components/Common/ScrollArea/styles.js.map +1 -0
- package/build/src/components/Common/SelectAnotherMethodButton/index.js +85 -0
- package/build/src/components/Common/SelectAnotherMethodButton/index.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/SwitchButton/index.js +40 -0
- package/build/src/components/Common/SwitchButton/index.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/TokenChainLogo/index.js +56 -0
- package/build/src/components/Common/TokenChainLogo/index.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/Common/WalletChainLogo/index.js +24 -0
- package/build/src/components/Common/WalletChainLogo/index.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 +129 -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 +89 -0
- package/build/src/components/Pages/Confirmation/index.js.map +1 -0
- package/build/src/components/Pages/Connectors/index.js +37 -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 +57 -0
- package/build/src/components/Pages/MobileConnectors/index.js.map +1 -0
- package/build/src/components/Pages/MobileConnectors/styles.js +66 -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 +127 -0
- package/build/src/components/Pages/PayWithToken/index.js.map +1 -0
- package/build/src/components/Pages/SelectAmount/index.js +17 -0
- package/build/src/components/Pages/SelectAmount/index.js.map +1 -0
- package/build/src/components/Pages/SelectDepositAddressAmount/index.js +61 -0
- package/build/src/components/Pages/SelectDepositAddressAmount/index.js.map +1 -0
- package/build/src/components/Pages/SelectDepositAddressChain/index.js +46 -0
- package/build/src/components/Pages/SelectDepositAddressChain/index.js.map +1 -0
- package/build/src/components/Pages/SelectExternalAmount/index.js +64 -0
- package/build/src/components/Pages/SelectExternalAmount/index.js.map +1 -0
- package/build/src/components/Pages/SelectMethod/index.js +198 -0
- package/build/src/components/Pages/SelectMethod/index.js.map +1 -0
- package/build/src/components/Pages/SelectToken/index.js +28 -0
- package/build/src/components/Pages/SelectToken/index.js.map +1 -0
- package/build/src/components/Pages/SelectWalletAmount/index.js +55 -0
- package/build/src/components/Pages/SelectWalletAmount/index.js.map +1 -0
- package/build/src/components/Pages/SelectZKP/index.js +36 -0
- package/build/src/components/Pages/SelectZKP/index.js.map +1 -0
- package/build/src/components/Pages/Solana/ConnectSolana/index.js +81 -0
- package/build/src/components/Pages/Solana/ConnectSolana/index.js.map +1 -0
- package/build/src/components/Pages/Solana/ConnectorSolana/index.js +62 -0
- package/build/src/components/Pages/Solana/ConnectorSolana/index.js.map +1 -0
- package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js +72 -0
- package/build/src/components/Pages/Solana/PayWithSolanaToken/index.js.map +1 -0
- package/build/src/components/Pages/Solana/SelectSolanaAmount/index.js +17 -0
- package/build/src/components/Pages/Solana/SelectSolanaAmount/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 +305 -0
- package/build/src/components/Pages/WaitingDepositAddress/index.js.map +1 -0
- package/build/src/components/Pages/WaitingExternal/index.js +68 -0
- package/build/src/components/Pages/WaitingExternal/index.js.map +1 -0
- package/build/src/components/Pages/WaitingWallet/index.js +28 -0
- package/build/src/components/Pages/WaitingWallet/index.js.map +1 -0
- package/build/src/components/RozoPayButton/index.js +201 -0
- package/build/src/components/RozoPayButton/index.js.map +1 -0
- package/build/src/components/RozoPayButton/styles.js +50 -0
- package/build/src/components/RozoPayButton/styles.js.map +1 -0
- package/build/src/components/RozoPayModal/ConnectUsing.js +42 -0
- package/build/src/components/RozoPayModal/ConnectUsing.js.map +1 -0
- package/build/src/components/RozoPayModal/ConnectWithInjector/index.js +195 -0
- package/build/src/components/RozoPayModal/ConnectWithInjector/index.js.map +1 -0
- package/build/src/components/RozoPayModal/ConnectWithInjector/styles.js +133 -0
- package/build/src/components/RozoPayModal/ConnectWithInjector/styles.js.map +1 -0
- package/build/src/components/RozoPayModal/ConnectWithQRCode.js +47 -0
- package/build/src/components/RozoPayModal/ConnectWithQRCode.js.map +1 -0
- package/build/src/components/RozoPayModal/index.js +254 -0
- package/build/src/components/RozoPayModal/index.js.map +1 -0
- package/build/src/components/RozoPayThemeProvider/RozoPayThemeProvider.js +21 -0
- package/build/src/components/RozoPayThemeProvider/RozoPayThemeProvider.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/ExternalPaymentSpinner/index.js +20 -0
- package/build/src/components/Spinners/ExternalPaymentSpinner/index.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/Spinners/TokenLogoSpinner/index.js +13 -0
- package/build/src/components/Spinners/TokenLogoSpinner/index.js.map +1 -0
- package/build/src/components/Spinners/TokenLogoSpinner/styles.js +40 -0
- package/build/src/components/Spinners/TokenLogoSpinner/styles.js.map +1 -0
- package/build/src/components/Spinners/WalletPaymentSpinner/index.js +30 -0
- package/build/src/components/Spinners/WalletPaymentSpinner/index.js.map +1 -0
- package/build/src/components/Spinners/styles.js +33 -0
- package/build/src/components/Spinners/styles.js.map +1 -0
- package/build/src/constants/defaultTheme.js +6 -0
- package/build/src/constants/defaultTheme.js.map +1 -0
- package/build/src/constants/routes.js +31 -0
- package/build/src/constants/routes.js.map +1 -0
- package/build/src/defaultConfig.js +62 -0
- package/build/src/defaultConfig.js.map +1 -0
- package/build/src/defaultConnectors.js +24 -0
- package/build/src/defaultConnectors.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 +49 -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 +9 -0
- package/build/src/hooks/useConnectors.js.map +1 -0
- package/build/src/hooks/useDepositAddressOptions.js +31 -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 +58 -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 +57 -0
- package/build/src/hooks/useFocusTrap.js.map +1 -0
- package/build/src/hooks/useIsMobile.js +11 -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 +58 -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/useOrderUsdLimits.js +26 -0
- package/build/src/hooks/useOrderUsdLimits.js.map +1 -0
- package/build/src/hooks/usePayContext.js +13 -0
- package/build/src/hooks/usePayContext.js.map +1 -0
- package/build/src/hooks/usePaymentState.js +339 -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/useRozoPay.js +89 -0
- package/build/src/hooks/useRozoPay.js.map +1 -0
- package/build/src/hooks/useRozoPayStatus.js +23 -0
- package/build/src/hooks/useRozoPayStatus.js.map +1 -0
- package/build/src/hooks/useRozoPayUI.js +15 -0
- package/build/src/hooks/useRozoPayUI.js.map +1 -0
- package/build/src/hooks/useSolanaPaymentOptions.js +39 -0
- package/build/src/hooks/useSolanaPaymentOptions.js.map +1 -0
- package/build/src/hooks/useTokenOptions.js +109 -0
- package/build/src/hooks/useTokenOptions.js.map +1 -0
- package/build/src/hooks/useWalletPaymentOptions.js +59 -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 +14 -0
- package/build/src/index.js.map +1 -0
- package/build/src/localizations/index.js +48 -0
- package/build/src/localizations/index.js.map +1 -0
- package/build/src/localizations/locales/ar-AE.js +95 -0
- package/build/src/localizations/locales/ar-AE.js.map +1 -0
- package/build/src/localizations/locales/ca-AD.js +93 -0
- package/build/src/localizations/locales/ca-AD.js.map +1 -0
- package/build/src/localizations/locales/ee-EE.js +93 -0
- package/build/src/localizations/locales/ee-EE.js.map +1 -0
- package/build/src/localizations/locales/en-US.js +93 -0
- package/build/src/localizations/locales/en-US.js.map +1 -0
- package/build/src/localizations/locales/es-ES.js +93 -0
- package/build/src/localizations/locales/es-ES.js.map +1 -0
- package/build/src/localizations/locales/fa-IR.js +93 -0
- package/build/src/localizations/locales/fa-IR.js.map +1 -0
- package/build/src/localizations/locales/fr-FR.js +93 -0
- package/build/src/localizations/locales/fr-FR.js.map +1 -0
- package/build/src/localizations/locales/ja-JP.js +93 -0
- package/build/src/localizations/locales/ja-JP.js.map +1 -0
- package/build/src/localizations/locales/pt-BR.js +93 -0
- package/build/src/localizations/locales/pt-BR.js.map +1 -0
- package/build/src/localizations/locales/ru-RU.js +93 -0
- package/build/src/localizations/locales/ru-RU.js.map +1 -0
- package/build/src/localizations/locales/tr-TR.js +93 -0
- package/build/src/localizations/locales/tr-TR.js.map +1 -0
- package/build/src/localizations/locales/vi-VN.js +93 -0
- package/build/src/localizations/locales/vi-VN.js.map +1 -0
- package/build/src/localizations/locales/zh-CN.js +93 -0
- package/build/src/localizations/locales/zh-CN.js.map +1 -0
- package/build/src/payment/paymentEffects.js +298 -0
- package/build/src/payment/paymentEffects.js.map +1 -0
- package/build/src/payment/paymentFsm.js +214 -0
- package/build/src/payment/paymentFsm.js.map +1 -0
- package/build/src/payment/paymentStore.js +20 -0
- package/build/src/payment/paymentStore.js.map +1 -0
- package/build/src/provider/PayContext.js +7 -0
- package/build/src/provider/PayContext.js.map +1 -0
- package/build/src/provider/PaymentProvider.js +28 -0
- package/build/src/provider/PaymentProvider.js.map +1 -0
- package/build/src/provider/RozoPayProvider.js +266 -0
- package/build/src/provider/RozoPayProvider.js.map +1 -0
- package/build/src/provider/SolanaContextProvider.js +11 -0
- package/build/src/provider/SolanaContextProvider.js.map +1 -0
- package/build/src/provider/Web3ContextProvider.js +36 -0
- package/build/src/provider/Web3ContextProvider.js.map +1 -0
- package/build/src/stateStore.js +82 -0
- package/build/src/stateStore.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 +328 -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 +5 -0
- package/build/src/utils/exports.js.map +1 -0
- package/build/src/utils/format.js +83 -0
- package/build/src/utils/format.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/polling.js +35 -0
- package/build/src/utils/polling.js.map +1 -0
- package/build/src/utils/supportUrl.js +16 -0
- package/build/src/utils/supportUrl.js.map +1 -0
- package/build/src/utils/trpc.js +19 -0
- package/build/src/utils/trpc.js.map +1 -0
- package/build/src/utils/validateInput.js +36 -0
- package/build/src/utils/validateInput.js.map +1 -0
- package/build/src/wallets/index.js +30 -0
- package/build/src/wallets/index.js.map +1 -0
- package/build/src/wallets/useWallets.js +143 -0
- package/build/src/wallets/useWallets.js.map +1 -0
- package/build/src/wallets/walletConfigs.js +259 -0
- package/build/src/wallets/walletConfigs.js.map +1 -0
- package/build/src/world-mini-app/WorldPayButton.js +75 -0
- package/build/src/world-mini-app/WorldPayButton.js.map +1 -0
- package/build/src/world-mini-app/promptWorldPayment.js +57 -0
- package/build/src/world-mini-app/promptWorldPayment.js.map +1 -0
- package/build/src/world.js +2 -0
- package/build/src/world.js.map +1 -0
- package/build/stateStore.d.ts +66 -0
- package/build/styles/defaultTheme.d.ts +3 -0
- package/build/styles/index.d.ts +1 -0
- package/build/styles/styled/index.d.ts +12 -0
- package/build/styles/themes/base.d.ts +129 -0
- package/build/styles/themes/index.d.ts +673 -0
- package/build/styles/themes/midnight.d.ts +74 -0
- package/build/styles/themes/minimal.d.ts +94 -0
- package/build/styles/themes/nouns.d.ts +79 -0
- package/build/styles/themes/retro.d.ts +89 -0
- package/build/styles/themes/rounded.d.ts +86 -0
- package/build/styles/themes/soft.d.ts +69 -0
- package/build/styles/themes/web95.d.ts +91 -0
- package/build/styles/types.d.ts +80 -0
- package/build/types.d.ts +44 -0
- package/build/utils/exports.d.ts +1 -0
- package/build/utils/format.d.ts +49 -0
- package/build/utils/index.d.ts +17 -0
- package/build/utils/localstorage.d.ts +9 -0
- package/build/utils/p3.d.ts +2 -0
- package/build/utils/platform.d.ts +2 -0
- package/build/utils/polling.d.ts +13 -0
- package/build/utils/supportUrl.d.ts +2 -0
- package/build/utils/trpc.d.ts +3 -0
- package/build/utils/validateInput.d.ts +16 -0
- package/build/utils/wallets.d.ts +24 -0
- package/build/wallets/index.d.ts +5 -0
- package/build/wallets/useWallets.d.ts +9 -0
- package/build/wallets/walletConfigs.d.ts +28 -0
- package/build/world-mini-app/WorldPayButton.d.ts +78 -0
- package/build/world-mini-app/promptWorldPayment.d.ts +9 -0
- package/build/world.d.ts +1 -0
- package/package.json +35 -16
- package/build/index.js +0 -13563
- package/build/index.js.map +0 -1
- package/src/index.ts +0 -38
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
import { ROUTES } from '../../../constants/routes.js';
|
|
4
|
+
import { usePayContext } from '../../../hooks/usePayContext.js';
|
|
5
|
+
import { PageContent, ModalContent, ModalBody } from '../../Common/Modal/styles.js';
|
|
6
|
+
import styled from '../../../styles/styled/index.js';
|
|
7
|
+
import { formatUsd, USD_DECIMALS } from '../../../utils/format.js';
|
|
8
|
+
import { isValidNumber, sanitizeNumber } from '../../../utils/validateInput.js';
|
|
9
|
+
import AmountInputField from '../../Common/AmountInput/AmountInputField.js';
|
|
10
|
+
import Button from '../../Common/Button/index.js';
|
|
11
|
+
import ExternalPaymentSpinner from '../../Spinners/ExternalPaymentSpinner/index.js';
|
|
12
|
+
|
|
13
|
+
const SelectExternalAmount = () => {
|
|
14
|
+
const { paymentState, setRoute, triggerResize } = usePayContext();
|
|
15
|
+
const { selectedExternalOption } = paymentState;
|
|
16
|
+
const maxUsdLimit = paymentState.getOrderUsdLimit();
|
|
17
|
+
const minimumMessage = (selectedExternalOption?.minimumUsd ?? 0) > 0
|
|
18
|
+
? `Minimum ${formatUsd(selectedExternalOption?.minimumUsd ?? 0, "up")}`
|
|
19
|
+
: null;
|
|
20
|
+
const [usdInput, setUsdInput] = useState("");
|
|
21
|
+
const [message, setMessage] = useState(minimumMessage);
|
|
22
|
+
const [continueDisabled, setContinueDisabled] = useState(true);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
triggerResize();
|
|
25
|
+
}, [message]); // eslint-disable-line react-hooks/exhaustive-deps
|
|
26
|
+
if (selectedExternalOption == null) {
|
|
27
|
+
return jsx(PageContent, {});
|
|
28
|
+
}
|
|
29
|
+
const handleAmountChange = (e) => {
|
|
30
|
+
const value = e.target.value;
|
|
31
|
+
if (value !== "" && !isValidNumber(value, USD_DECIMALS))
|
|
32
|
+
return;
|
|
33
|
+
setUsdInput(value);
|
|
34
|
+
if (Number(value) > maxUsdLimit) {
|
|
35
|
+
setMessage(`Maximum ${formatUsd(maxUsdLimit)}`);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
setMessage(minimumMessage);
|
|
39
|
+
}
|
|
40
|
+
const usd = Number(sanitizeNumber(value));
|
|
41
|
+
setContinueDisabled(usd <= 0 ||
|
|
42
|
+
usd < (selectedExternalOption.minimumUsd ?? 0) ||
|
|
43
|
+
usd > maxUsdLimit);
|
|
44
|
+
};
|
|
45
|
+
const handleKeyDown = (e) => {
|
|
46
|
+
if (e.key === "Enter" && !continueDisabled) {
|
|
47
|
+
handleContinue();
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
const handleContinue = () => {
|
|
51
|
+
const amountUsd = Number(sanitizeNumber(usdInput));
|
|
52
|
+
paymentState.setChosenUsd(amountUsd);
|
|
53
|
+
setRoute(ROUTES.WAITING_EXTERNAL, { amountUsd });
|
|
54
|
+
};
|
|
55
|
+
return (jsxs(PageContent, { children: [jsx(ExternalPaymentSpinner, { logoURI: selectedExternalOption.logoURI, logoShape: selectedExternalOption.logoShape }), jsxs(ModalContent, { "$preserveDisplay": true, children: [jsx(AmountInputContainer, { children: jsx(AmountInputField, { value: usdInput, onChange: handleAmountChange, onKeyDown: handleKeyDown }) }), message && jsx(ModalBody, { children: message }), jsx(Button, { onClick: handleContinue, disabled: continueDisabled, children: "Continue" })] })] }));
|
|
56
|
+
};
|
|
57
|
+
const AmountInputContainer = styled.div `
|
|
58
|
+
display: flex;
|
|
59
|
+
align-items: center;
|
|
60
|
+
justify-content: center;
|
|
61
|
+
`;
|
|
62
|
+
|
|
63
|
+
export { SelectExternalAmount as default };
|
|
64
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Pages/SelectExternalAmount/index.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":"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"}
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { ROUTES } from '../../../constants/routes.js';
|
|
3
|
+
import { usePayContext } from '../../../hooks/usePayContext.js';
|
|
4
|
+
import { PageContent } from '../../Common/Modal/styles.js';
|
|
5
|
+
import { getAddressContraction } from '@rozoai/intent-common';
|
|
6
|
+
import { useWallet } from '@solana/wallet-adapter-react';
|
|
7
|
+
import { useAccount, useDisconnect } from 'wagmi';
|
|
8
|
+
import { Ethereum, Solana, Tron, Base } from '../../../assets/chains.js';
|
|
9
|
+
import { WalletIcon, Trust, Rainbow, Phantom, Coinbase } from '../../../assets/logos.js';
|
|
10
|
+
import useIsMobile from '../../../hooks/useIsMobile.js';
|
|
11
|
+
import { OptionsList } from '../../Common/OptionsList/index.js';
|
|
12
|
+
import { OrderHeader } from '../../Common/OrderHeader/index.js';
|
|
13
|
+
import PoweredByFooter from '../../Common/PoweredByFooter/index.js';
|
|
14
|
+
import WalletChainLogo from '../../Common/WalletChainLogo/index.js';
|
|
15
|
+
|
|
16
|
+
function SelectMethod() {
|
|
17
|
+
const { isMobile, isIOS, isAndroid } = useIsMobile();
|
|
18
|
+
const { address, chain, isConnected: isEthConnected, connector, } = useAccount();
|
|
19
|
+
const { connected: isSolanaConnected, wallet: solanaWallet, wallets: solanaWallets, disconnect: disconnectSolana, publicKey, } = useWallet();
|
|
20
|
+
const { setRoute, paymentState, log } = usePayContext();
|
|
21
|
+
const { disconnectAsync } = useDisconnect();
|
|
22
|
+
const { setSelectedExternalOption, externalPaymentOptions, showSolanaPaymentMethod, senderEnsName, } = paymentState;
|
|
23
|
+
// Decide whether to show the connected eth account, solana account, or both.
|
|
24
|
+
const showConnectedEth = isEthConnected;
|
|
25
|
+
const showConnectedSolana = isSolanaConnected && showSolanaPaymentMethod;
|
|
26
|
+
const getConnectedWalletOptions = () => {
|
|
27
|
+
const showChainLogo = isEthConnected && isSolanaConnected;
|
|
28
|
+
const connectedOptions = [];
|
|
29
|
+
if (showConnectedEth) {
|
|
30
|
+
const ethWalletDisplayName = senderEnsName ?? (address ? getAddressContraction(address) : "wallet");
|
|
31
|
+
let walletIcon;
|
|
32
|
+
if (connector?.icon) {
|
|
33
|
+
walletIcon = (jsx("div", { style: { borderRadius: "22.5%", overflow: "hidden" }, children: jsx("img", { src: connector.icon, alt: connector.name }) }));
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
walletIcon = jsx(WalletIcon, {});
|
|
37
|
+
}
|
|
38
|
+
const connectedEthWalletOption = {
|
|
39
|
+
id: "connectedWallet",
|
|
40
|
+
title: `Pay with ${ethWalletDisplayName}`,
|
|
41
|
+
icons: [
|
|
42
|
+
jsx(WalletChainLogo, { walletIcon: walletIcon, walletName: connector?.name || "Wallet", chainLogo: showChainLogo ? jsx(Ethereum, {}) : null }, "eth"),
|
|
43
|
+
],
|
|
44
|
+
onClick: () => {
|
|
45
|
+
paymentState.setTokenMode("evm");
|
|
46
|
+
setRoute(ROUTES.SELECT_TOKEN, {
|
|
47
|
+
event: "click-wallet",
|
|
48
|
+
walletId: connector?.id,
|
|
49
|
+
chainId: chain?.id,
|
|
50
|
+
address: address,
|
|
51
|
+
});
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
connectedOptions.push(connectedEthWalletOption);
|
|
55
|
+
}
|
|
56
|
+
if (showConnectedSolana) {
|
|
57
|
+
const solWalletDisplayName = getAddressContraction(publicKey?.toBase58() ?? "");
|
|
58
|
+
const connectedSolWalletOption = {
|
|
59
|
+
id: "connectedSolanaWallet",
|
|
60
|
+
title: `Pay with ${solWalletDisplayName}`,
|
|
61
|
+
icons: solanaWallet?.adapter.icon
|
|
62
|
+
? [
|
|
63
|
+
jsx(WalletChainLogo, { walletIcon: solanaWallet.adapter.icon, walletName: solanaWallet.adapter.name, chainLogo: showChainLogo && jsx(Solana, {}) }, "sol-wallet"),
|
|
64
|
+
]
|
|
65
|
+
: [
|
|
66
|
+
jsx(WalletChainLogo, { walletIcon: jsx(Solana, {}), walletName: "Default wallet icon", chainLogo: null }, "sol-wallet"),
|
|
67
|
+
],
|
|
68
|
+
onClick: () => {
|
|
69
|
+
paymentState.setTokenMode("solana");
|
|
70
|
+
setRoute(ROUTES.SELECT_TOKEN, {
|
|
71
|
+
event: "click-wallet",
|
|
72
|
+
walletId: solanaWallet?.adapter.name,
|
|
73
|
+
chainId: "solana",
|
|
74
|
+
address: publicKey?.toBase58(),
|
|
75
|
+
});
|
|
76
|
+
},
|
|
77
|
+
};
|
|
78
|
+
connectedOptions.push(connectedSolWalletOption);
|
|
79
|
+
}
|
|
80
|
+
return connectedOptions;
|
|
81
|
+
};
|
|
82
|
+
const connectedWalletOptions = getConnectedWalletOptions();
|
|
83
|
+
const unconnectedWalletOption = {
|
|
84
|
+
id: "unconnectedWallet",
|
|
85
|
+
title: isEthConnected || isSolanaConnected
|
|
86
|
+
? `Pay with another wallet`
|
|
87
|
+
: `Pay with wallet`,
|
|
88
|
+
icons: getBestUnconnectedWalletIcons(connector, isMobile),
|
|
89
|
+
onClick: async () => {
|
|
90
|
+
await disconnectAsync();
|
|
91
|
+
setRoute(ROUTES.CONNECTORS);
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
const options = [];
|
|
95
|
+
options.push(...connectedWalletOptions);
|
|
96
|
+
options.push(unconnectedWalletOption);
|
|
97
|
+
log(`[SELECT_METHOD] loading: ${externalPaymentOptions.loading}, options: ${JSON.stringify(externalPaymentOptions.options)}`);
|
|
98
|
+
if (showSolanaPaymentMethod) {
|
|
99
|
+
const solanaOption = getSolanaOption(isIOS, isAndroid, solanaWallets, disconnectSolana, setRoute);
|
|
100
|
+
if (solanaOption) {
|
|
101
|
+
options.push(solanaOption);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
// External payment options, e.g. Binance, Coinbase, etc.
|
|
105
|
+
options.push(...(externalPaymentOptions.options.get("external") ?? []).map((option) => ({
|
|
106
|
+
id: option.id,
|
|
107
|
+
title: option.cta,
|
|
108
|
+
icons: [option.logoURI],
|
|
109
|
+
onClick: () => {
|
|
110
|
+
setSelectedExternalOption(option);
|
|
111
|
+
const meta = { event: "click-option", option: option.id };
|
|
112
|
+
if (paymentState.isDepositFlow) {
|
|
113
|
+
setRoute(ROUTES.SELECT_EXTERNAL_AMOUNT, meta);
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
setRoute(ROUTES.WAITING_EXTERNAL, meta);
|
|
117
|
+
}
|
|
118
|
+
},
|
|
119
|
+
disabled: option.disabled,
|
|
120
|
+
subtitle: option.message,
|
|
121
|
+
})));
|
|
122
|
+
const depositAddressOption = getDepositAddressOption(setRoute);
|
|
123
|
+
options.push(depositAddressOption);
|
|
124
|
+
// ZKP2P is currently only available on desktop. Check if the user is on
|
|
125
|
+
// desktop and if any ZKP2P options are available.
|
|
126
|
+
const zkp2pOptions = externalPaymentOptions.options.get("zkp2p") ?? [];
|
|
127
|
+
const showZkp2pPaymentMethod = !isMobile && zkp2pOptions.length > 0;
|
|
128
|
+
if (showZkp2pPaymentMethod) {
|
|
129
|
+
options.push({
|
|
130
|
+
id: "ZKP2P",
|
|
131
|
+
title: "Pay via payment app",
|
|
132
|
+
icons: zkp2pOptions.slice(0, 2).map((option) => option.logoURI),
|
|
133
|
+
onClick: () => {
|
|
134
|
+
setRoute(ROUTES.SELECT_ZKP2P);
|
|
135
|
+
},
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
// Order disabled to bottom
|
|
139
|
+
options.sort((a, b) => (a.disabled ? 1 : 0) - (b.disabled ? 1 : 0));
|
|
140
|
+
return (jsxs(PageContent, { children: [jsx(OrderHeader, {}), jsx(OptionsList, { requiredSkeletons: isMobile ? 4 : 3, isLoading: externalPaymentOptions.loading, options: externalPaymentOptions.loading ? [] : options }), jsx(PoweredByFooter, {})] }));
|
|
141
|
+
}
|
|
142
|
+
// Get 3 icons, skipping the one that is already connected
|
|
143
|
+
function getBestUnconnectedWalletIcons(connector, isMobile) {
|
|
144
|
+
const icons = [];
|
|
145
|
+
const strippedId = connector?.id.toLowerCase(); // some connector ids can have weird casing and or suffixes and prefixes
|
|
146
|
+
const [isRainbow, isTrust, isPhantom, isCoinbase] = [
|
|
147
|
+
strippedId?.includes("rainbow"),
|
|
148
|
+
strippedId?.includes("trust"),
|
|
149
|
+
strippedId?.includes("phantom"),
|
|
150
|
+
strippedId?.includes("coinbase"),
|
|
151
|
+
];
|
|
152
|
+
if (isMobile) {
|
|
153
|
+
if (!isTrust)
|
|
154
|
+
icons.push(jsx(Trust, { background: true }));
|
|
155
|
+
if (!isRainbow)
|
|
156
|
+
icons.push(jsx(Rainbow, {}));
|
|
157
|
+
if (!isPhantom)
|
|
158
|
+
icons.push(jsx(Phantom, {}));
|
|
159
|
+
if (!isCoinbase && icons.length < 3)
|
|
160
|
+
icons.push(jsx(Coinbase, {}));
|
|
161
|
+
}
|
|
162
|
+
else {
|
|
163
|
+
if (!isRainbow)
|
|
164
|
+
icons.push(jsx(Rainbow, {}));
|
|
165
|
+
if (!isPhantom)
|
|
166
|
+
icons.push(jsx(Phantom, {}));
|
|
167
|
+
}
|
|
168
|
+
return icons;
|
|
169
|
+
}
|
|
170
|
+
function getSolanaOption(isIOS, isAndroid, solanaWallets, disconnectSolana, setRoute) {
|
|
171
|
+
// If we're on iOS and there are no wallets, we don't need to show the Solana option
|
|
172
|
+
// If we're on Android and there are less than 2 wallets, we don't need to show the Solana option because there is always a default wallet called Mobile Wallet Adapter that is not useful
|
|
173
|
+
if ((isIOS && solanaWallets.length === 0) ||
|
|
174
|
+
(isAndroid && solanaWallets.length < 2))
|
|
175
|
+
return null;
|
|
176
|
+
return {
|
|
177
|
+
id: "solana",
|
|
178
|
+
title: "Pay on Solana",
|
|
179
|
+
icons: [jsx(Solana, {}, "solana")],
|
|
180
|
+
onClick: async () => {
|
|
181
|
+
await disconnectSolana();
|
|
182
|
+
setRoute(ROUTES.SOLANA_CONNECT);
|
|
183
|
+
},
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
function getDepositAddressOption(setRoute) {
|
|
187
|
+
return {
|
|
188
|
+
id: "depositAddress",
|
|
189
|
+
title: "Pay to address",
|
|
190
|
+
icons: [jsx(Ethereum, {}, "eth"), jsx(Tron, {}, "tron"), jsx(Base, {}, "base")],
|
|
191
|
+
onClick: () => {
|
|
192
|
+
setRoute(ROUTES.SELECT_DEPOSIT_ADDRESS_CHAIN);
|
|
193
|
+
},
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
export { SelectMethod as default };
|
|
198
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Pages/SelectMethod/index.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import defaultTheme from '../../../constants/defaultTheme.js';
|
|
3
|
+
import useIsMobile from '../../../hooks/useIsMobile.js';
|
|
4
|
+
import { usePayContext } from '../../../hooks/usePayContext.js';
|
|
5
|
+
import { useTokenOptions } from '../../../hooks/useTokenOptions.js';
|
|
6
|
+
import { PageContent, ModalContent, ModalH1 } from '../../Common/Modal/styles.js';
|
|
7
|
+
import { OptionsList } from '../../Common/OptionsList/index.js';
|
|
8
|
+
import { OrderHeader } from '../../Common/OrderHeader/index.js';
|
|
9
|
+
import SelectAnotherMethodButton from '../../Common/SelectAnotherMethodButton/index.js';
|
|
10
|
+
|
|
11
|
+
function SelectToken() {
|
|
12
|
+
const { isMobile } = useIsMobile();
|
|
13
|
+
const isMobileFormat = isMobile || window?.innerWidth < defaultTheme.mobileWidth;
|
|
14
|
+
const { paymentState } = usePayContext();
|
|
15
|
+
const { tokenMode } = paymentState;
|
|
16
|
+
const { optionsList, isLoading } = useTokenOptions(tokenMode);
|
|
17
|
+
const isAnotherMethodButtonVisible = optionsList.length > 0 && tokenMode !== "all";
|
|
18
|
+
return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true, showEth: true }), !isLoading && optionsList.length === 0 && (jsxs(ModalContent, { style: {
|
|
19
|
+
display: "flex",
|
|
20
|
+
alignItems: "center",
|
|
21
|
+
justifyContent: "center",
|
|
22
|
+
paddingTop: 16,
|
|
23
|
+
paddingBottom: 16,
|
|
24
|
+
}, children: [jsx(ModalH1, { children: "Insufficient balance." }), jsx(SelectAnotherMethodButton, {})] })), jsx(OptionsList, { requiredSkeletons: 4, isLoading: isLoading, options: optionsList, scrollHeight: isAnotherMethodButtonVisible && isMobileFormat ? 225 : 300, orDivider: isAnotherMethodButtonVisible, hideBottomLine: !isAnotherMethodButtonVisible }), isAnotherMethodButtonVisible && jsx(SelectAnotherMethodButton, {})] }));
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export { SelectToken as default };
|
|
28
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Pages/SelectToken/index.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;;;;;;AASc,SAAU,WAAW,GAAA;AACjC,IAAA,MAAM,EAAE,QAAQ,EAAE,GAAG,WAAW,EAAE,CAAC;IACnC,MAAM,cAAc,GAClB,QAAQ,IAAI,MAAM,EAAE,UAAU,GAAG,YAAY,CAAC,WAAW,CAAC;AAE5D,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,aAAa,EAAE,CAAC;AACzC,IAAA,MAAM,EAAE,SAAS,EAAE,GAAG,YAAY,CAAC;IACnC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;IAE9D,MAAM,4BAA4B,GAChC,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,SAAS,KAAK,KAAK,CAAC;AAEhD,IAAA,QACEA,IAAA,CAAC,WAAW,EAAA,EAAA,QAAA,EAAA,CACVC,GAAC,CAAA,WAAW,EAAC,EAAA,QAAQ,EAAC,IAAA,EAAA,OAAO,EAAE,IAAI,EAAI,CAAA,EAEtC,CAAC,SAAS,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,KACrCD,IAAC,CAAA,YAAY,EACX,EAAA,KAAK,EAAE;AACL,oBAAA,OAAO,EAAE,MAAM;AACf,oBAAA,UAAU,EAAE,QAAQ;AACpB,oBAAA,cAAc,EAAE,QAAQ;AACxB,oBAAA,UAAU,EAAE,EAAE;AACd,oBAAA,aAAa,EAAE,EAAE;iBAClB,EAED,QAAA,EAAA,CAAAC,GAAA,CAAC,OAAO,EAAA,EAAA,QAAA,EAAA,uBAAA,EAAA,CAAgC,EACxCA,GAAA,CAAC,yBAAyB,EAAA,EAAA,CAAG,CAChB,EAAA,CAAA,CAChB,EACDA,GAAA,CAAC,WAAW,EAAA,EACV,iBAAiB,EAAE,CAAC,EACpB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,WAAW,EACpB,YAAY,EACV,4BAA4B,IAAI,cAAc,GAAG,GAAG,GAAG,GAAG,EAE5D,SAAS,EAAE,4BAA4B,EACvC,cAAc,EAAE,CAAC,4BAA4B,EAAA,CAC7C,EACD,4BAA4B,IAAIA,GAAA,CAAC,yBAAyB,EAAA,EAAA,CAAG,CAClD,EAAA,CAAA,EACd;AACJ;;;;"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { ROUTES } from '../../../constants/routes.js';
|
|
4
|
+
import { usePayContext } from '../../../hooks/usePayContext.js';
|
|
5
|
+
import { PageContent, ModalContent } from '../../Common/Modal/styles.js';
|
|
6
|
+
import { useRozoPay } from '../../../hooks/useRozoPay.js';
|
|
7
|
+
import styled from '../../../styles/styled/index.js';
|
|
8
|
+
import { USD_DECIMALS } from '../../../utils/format.js';
|
|
9
|
+
import { isValidNumber, sanitizeNumber } from '../../../utils/validateInput.js';
|
|
10
|
+
import AmountInputField from '../../Common/AmountInput/AmountInputField.js';
|
|
11
|
+
import Button from '../../Common/Button/index.js';
|
|
12
|
+
import WalletPaymentSpinner from '../../Spinners/WalletPaymentSpinner/index.js';
|
|
13
|
+
|
|
14
|
+
const SelectWalletAmount = () => {
|
|
15
|
+
const { paymentState, setPendingConnectorId, setRoute } = usePayContext();
|
|
16
|
+
const { selectedWallet, openInWalletBrowser } = paymentState;
|
|
17
|
+
const { setChosenUsd, hydrateOrder } = useRozoPay();
|
|
18
|
+
const maxUsdLimit = paymentState.getOrderUsdLimit();
|
|
19
|
+
const [usdInput, setUsdInput] = useState("");
|
|
20
|
+
const [continueDisabled, setContinueDisabled] = useState(true);
|
|
21
|
+
if (selectedWallet == null) {
|
|
22
|
+
return jsx(PageContent, {});
|
|
23
|
+
}
|
|
24
|
+
const handleAmountChange = (e) => {
|
|
25
|
+
const value = e.target.value;
|
|
26
|
+
if (value !== "" && !isValidNumber(value, USD_DECIMALS))
|
|
27
|
+
return;
|
|
28
|
+
setUsdInput(value);
|
|
29
|
+
const usd = Number(sanitizeNumber(value));
|
|
30
|
+
setContinueDisabled(usd <= 0 || usd > maxUsdLimit);
|
|
31
|
+
};
|
|
32
|
+
const handleContinue = async () => {
|
|
33
|
+
const amountUsd = Number(sanitizeNumber(usdInput));
|
|
34
|
+
setChosenUsd(amountUsd);
|
|
35
|
+
await hydrateOrder();
|
|
36
|
+
if (selectedWallet.name === "Mobile Wallets") {
|
|
37
|
+
setPendingConnectorId("Mobile Wallets");
|
|
38
|
+
setRoute(ROUTES.CONNECT);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
openInWalletBrowser(selectedWallet, amountUsd);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
return (jsxs(PageContent, { children: [jsx(WalletPaymentSpinner, { logo: selectedWallet.icon, logoShape: selectedWallet.iconShape === "square"
|
|
45
|
+
? "squircle"
|
|
46
|
+
: selectedWallet.iconShape || "squircle" }), jsxs(ModalContent, { "$preserveDisplay": true, children: [jsx(AmountInputContainer, { children: jsx(AmountInputField, { value: usdInput, onChange: handleAmountChange }) }), jsx(Button, { onClick: handleContinue, disabled: continueDisabled, children: "Continue" })] })] }));
|
|
47
|
+
};
|
|
48
|
+
const AmountInputContainer = styled.div `
|
|
49
|
+
display: flex;
|
|
50
|
+
align-items: center;
|
|
51
|
+
justify-content: center;
|
|
52
|
+
`;
|
|
53
|
+
|
|
54
|
+
export { SelectWalletAmount as default };
|
|
55
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Pages/SelectWalletAmount/index.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":";;;;;;;;;;;;;AAcM,MAAA,kBAAkB,GAAa,MAAK;IACxC,MAAM,EAAE,YAAY,EAAE,qBAAqB,EAAE,QAAQ,EAAE,GAAG,aAAa,EAAE,CAAC;AAC1E,IAAA,MAAM,EAAE,cAAc,EAAE,mBAAmB,EAAE,GAAG,YAAY,CAAC;IAC7D,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,UAAU,EAAE,CAAC;AAEpD,IAAA,MAAM,WAAW,GAAG,YAAY,CAAC,gBAAgB,EAAE,CAAC;IAEpD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAC;IACrD,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;AAE/D,IAAA,IAAI,cAAc,IAAI,IAAI,EAAE;QAC1B,OAAOA,GAAA,CAAC,WAAW,EAAA,EAAA,CAAe,CAAC;KACpC;AAED,IAAA,MAAM,kBAAkB,GAAG,CAAC,CAAsC,KAAI;AACpE,QAAA,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAC7B,IAAI,KAAK,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,YAAY,CAAC;YAAE,OAAO;QAChE,WAAW,CAAC,KAAK,CAAC,CAAC;QAEnB,MAAM,GAAG,GAAG,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;QAC1C,mBAAmB,CAAC,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,WAAW,CAAC,CAAC;AACrD,KAAC,CAAC;AAEF,IAAA,MAAM,cAAc,GAAG,YAAW;QAChC,MAAM,SAAS,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;QACnD,YAAY,CAAC,SAAS,CAAC,CAAC;QACxB,MAAM,YAAY,EAAE,CAAC;AAErB,QAAA,IAAI,cAAc,CAAC,IAAI,KAAK,gBAAgB,EAAE;YAC5C,qBAAqB,CAAC,gBAAgB,CAAC,CAAC;AACxC,YAAA,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SAC1B;aAAM;AACL,YAAA,mBAAmB,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;SAChD;AACH,KAAC,CAAC;AAEF,IAAA,QACEC,IAAC,CAAA,WAAW,eACVD,GAAC,CAAA,oBAAoB,IACnB,IAAI,EAAE,cAAc,CAAC,IAAI,EACzB,SAAS,EACP,cAAc,CAAC,SAAS,KAAK,QAAQ;AACnC,sBAAE,UAAU;AACZ,sBAAE,cAAc,CAAC,SAAS,IAAI,UAAU,GAE5C,EACFC,IAAA,CAAC,YAAY,EAAmB,EAAA,kBAAA,EAAA,IAAI,aAClCD,GAAC,CAAA,oBAAoB,cACnBA,GAAC,CAAA,gBAAgB,IAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,kBAAkB,EAAA,CAAI,GAC9C,EACvBA,GAAA,CAAC,MAAM,EAAC,EAAA,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,gBAAgB,yBAElD,CACI,EAAA,CAAA,CAAA,EAAA,CACH,EACd;AACJ,EAAE;AAEF,MAAM,oBAAoB,GAAG,MAAM,CAAC,GAAG,CAAA,CAAA;;;;CAItC;;;;"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { PageContent, ModalH1 } from '../../Common/Modal/styles.js';
|
|
3
|
+
import { ROUTES } from '../../../constants/routes.js';
|
|
4
|
+
import { usePayContext } from '../../../hooks/usePayContext.js';
|
|
5
|
+
import { OptionsList } from '../../Common/OptionsList/index.js';
|
|
6
|
+
import { OrderHeader } from '../../Common/OrderHeader/index.js';
|
|
7
|
+
|
|
8
|
+
const SelectZKP = () => {
|
|
9
|
+
const { paymentState, setRoute } = usePayContext();
|
|
10
|
+
const { externalPaymentOptions, setSelectedExternalOption } = paymentState;
|
|
11
|
+
const zkp2pOptions = externalPaymentOptions.options.get("zkp2p");
|
|
12
|
+
if (!zkp2pOptions) {
|
|
13
|
+
return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true, showZKP2P: true }), jsx(ModalH1, { children: "No ZKP2P options available" })] }));
|
|
14
|
+
}
|
|
15
|
+
const options = zkp2pOptions.map((option) => ({
|
|
16
|
+
id: option.id,
|
|
17
|
+
title: option.cta,
|
|
18
|
+
icons: [option.logoURI],
|
|
19
|
+
onClick: () => {
|
|
20
|
+
setSelectedExternalOption(option);
|
|
21
|
+
const meta = { event: "click-option", option: option.id };
|
|
22
|
+
if (paymentState.isDepositFlow) {
|
|
23
|
+
setRoute(ROUTES.SELECT_EXTERNAL_AMOUNT, meta);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
setRoute(ROUTES.WAITING_EXTERNAL, meta);
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
disabled: option.disabled,
|
|
30
|
+
subtitle: option.message,
|
|
31
|
+
}));
|
|
32
|
+
return (jsxs(PageContent, { children: [jsx(OrderHeader, { minified: true, showZKP2P: true }), jsx(OptionsList, { options: options })] }));
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
export { SelectZKP as default };
|
|
36
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Pages/SelectZKP/index.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;;;AASM,MAAA,SAAS,GAAa,MAAK;IAC/B,MAAM,EAAE,YAAY,EAAE,QAAQ,EAAE,GAAG,aAAa,EAAE,CAAC;AACnD,IAAA,MAAM,EAAE,sBAAsB,EAAE,yBAAyB,EAAE,GAAG,YAAY,CAAC;IAC3E,MAAM,YAAY,GAAG,sBAAsB,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAEjE,IAAI,CAAC,YAAY,EAAE;AACjB,QAAA,QACEA,IAAC,CAAA,WAAW,EACV,EAAA,QAAA,EAAA,CAAAC,GAAA,CAAC,WAAW,EAAC,EAAA,QAAQ,EAAC,IAAA,EAAA,SAAS,SAAG,EAClCA,GAAA,CAAC,OAAO,EAAqC,EAAA,QAAA,EAAA,4BAAA,EAAA,CAAA,CAAA,EAAA,CACjC,EACd;KACH;IAED,MAAM,OAAO,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,MAAM,MAAM;QAC5C,EAAE,EAAE,MAAM,CAAC,EAAE;QACb,KAAK,EAAE,MAAM,CAAC,GAAG;AACjB,QAAA,KAAK,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;QACvB,OAAO,EAAE,MAAK;YACZ,yBAAyB,CAAC,MAAM,CAAC,CAAC;AAClC,YAAA,MAAM,IAAI,GAAG,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC;AAC1D,YAAA,IAAI,YAAY,CAAC,aAAa,EAAE;AAC9B,gBAAA,QAAQ,CAAC,MAAM,CAAC,sBAAsB,EAAE,IAAI,CAAC,CAAC;aAC/C;iBAAM;AACL,gBAAA,QAAQ,CAAC,MAAM,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;aACzC;SACF;QACD,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,QAAQ,EAAE,MAAM,CAAC,OAAO;AACzB,KAAA,CAAC,CAAC,CAAC;IAEJ,QACED,KAAC,WAAW,EAAA,EAAA,QAAA,EAAA,CACVC,IAAC,WAAW,EAAA,EAAC,QAAQ,EAAC,IAAA,EAAA,SAAS,SAAG,EAClCA,GAAA,CAAC,WAAW,EAAC,EAAA,OAAO,EAAE,OAAO,EAAA,CAAI,CACrB,EAAA,CAAA,EACd;AACJ;;;;"}
|
|
@@ -0,0 +1,81 @@
|
|
|
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 { SquircleIcon, Phantom, Solflare, Backpack } from '../../../../assets/logos.js';
|
|
5
|
+
import { ROUTES } from '../../../../constants/routes.js';
|
|
6
|
+
import { usePayContext } from '../../../../hooks/usePayContext.js';
|
|
7
|
+
import { isMobile } from '../../../../utils/index.js';
|
|
8
|
+
import { OptionsList } from '../../../Common/OptionsList/index.js';
|
|
9
|
+
import SelectAnotherMethodButton from '../../../Common/SelectAnotherMethodButton/index.js';
|
|
10
|
+
|
|
11
|
+
const ConnectSolana = () => {
|
|
12
|
+
const { setSolanaConnector, setRoute, log } = usePayContext();
|
|
13
|
+
const solanaWallets = useWallet();
|
|
14
|
+
const options = solanaWallets.wallets.map((wallet) => ({
|
|
15
|
+
id: wallet.adapter.name,
|
|
16
|
+
title: `${wallet.adapter.name}`,
|
|
17
|
+
icons: [
|
|
18
|
+
jsx(SquircleIcon, { icon: wallet.adapter.icon, alt: wallet.adapter.name }, wallet.adapter.name),
|
|
19
|
+
],
|
|
20
|
+
onClick: async () => {
|
|
21
|
+
log("wallet.adapter.name ", wallet.adapter.name);
|
|
22
|
+
setSolanaConnector(wallet.adapter.name);
|
|
23
|
+
if (solanaWallets.connected) {
|
|
24
|
+
await solanaWallets.disconnect();
|
|
25
|
+
}
|
|
26
|
+
setRoute(ROUTES.SOLANA_CONNECTOR, {
|
|
27
|
+
event: "click-solana-wallet",
|
|
28
|
+
walletName: wallet.adapter.name,
|
|
29
|
+
});
|
|
30
|
+
},
|
|
31
|
+
}));
|
|
32
|
+
const defaultOptions = [
|
|
33
|
+
{
|
|
34
|
+
id: "phantom",
|
|
35
|
+
title: "Open in Phantom",
|
|
36
|
+
icons: [
|
|
37
|
+
jsx(SquircleIcon, { icon: (props) => jsx(Phantom, { ...props, background: true }), alt: "Phantom" }, "phantom"),
|
|
38
|
+
],
|
|
39
|
+
onClick: () => window.open(`https://phantom.app/ul/browse/${encodeURIComponent(window.location.href)}?ref=${encodeURIComponent(window.location.origin)}`),
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
id: "solflare",
|
|
43
|
+
title: "Open in Solflare",
|
|
44
|
+
icons: [
|
|
45
|
+
jsx(SquircleIcon, { icon: (props) => jsx(Solflare, { ...props, background: true }), alt: "Solflare" }, "solflare"),
|
|
46
|
+
],
|
|
47
|
+
onClick: () => window.open(`https://solflare.com/ul/v1/browse/${encodeURIComponent(window.location.href)}?ref=${encodeURIComponent(window.location.origin)}`, "_blank"),
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
id: "backpack",
|
|
51
|
+
title: "Open in Backpack",
|
|
52
|
+
icons: [
|
|
53
|
+
jsx(SquircleIcon, { icon: (props) => jsx(Backpack, { ...props, background: true }), alt: "Backpack" }, "backpack"),
|
|
54
|
+
],
|
|
55
|
+
onClick: () => window.open(`https://backpack.app/ul/v1/browse/${encodeURIComponent(window.location.href)}?ref=${encodeURIComponent(window.location.origin)}`, "_blank"),
|
|
56
|
+
},
|
|
57
|
+
];
|
|
58
|
+
return (jsxs(PageContent, { style: {
|
|
59
|
+
height: "100%",
|
|
60
|
+
}, children: [solanaWallets.wallets.length === 0 && !isMobile() && (jsxs(ModalContent, { style: {
|
|
61
|
+
display: "flex",
|
|
62
|
+
flexDirection: "column",
|
|
63
|
+
alignItems: "center",
|
|
64
|
+
justifyContent: "center",
|
|
65
|
+
paddingTop: 16,
|
|
66
|
+
paddingBottom: 16,
|
|
67
|
+
gap: 16,
|
|
68
|
+
}, children: [jsx(ModalH1, { children: "No Solana wallets detected." }), jsx(SelectAnotherMethodButton, {})] })), isMobile() &&
|
|
69
|
+
(solanaWallets.wallets.length === 0 ||
|
|
70
|
+
(solanaWallets.wallets.length > 0 &&
|
|
71
|
+
solanaWallets.wallets[0].adapter.name ===
|
|
72
|
+
"Mobile Wallet Adapter")) && (jsx(ModalContent, { style: {
|
|
73
|
+
display: "flex",
|
|
74
|
+
flexDirection: "column",
|
|
75
|
+
gap: 16,
|
|
76
|
+
}, children: jsx(OptionsList, { options: defaultOptions }) })), solanaWallets.wallets.length > 0 &&
|
|
77
|
+
solanaWallets.wallets[0].adapter.name !== "Mobile Wallet Adapter" && (jsx(OptionsList, { options: options }))] }));
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export { ConnectSolana as default };
|
|
81
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../../src/components/Pages/Solana/ConnectSolana/index.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":"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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
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 { ROUTES } from '../../../../constants/routes.js';
|
|
7
|
+
import { usePayContext } from '../../../../hooks/usePayContext.js';
|
|
8
|
+
import styled from '../../../../styles/styled/index.js';
|
|
9
|
+
import SquircleSpinner from '../../../Spinners/SquircleSpinner/index.js';
|
|
10
|
+
|
|
11
|
+
const ConnectSolana = () => {
|
|
12
|
+
const solanaWallets = useWallet();
|
|
13
|
+
const isConnected = solanaWallets.connected;
|
|
14
|
+
const { solanaConnector, setRoute, paymentState } = usePayContext();
|
|
15
|
+
const { setTokenMode } = paymentState;
|
|
16
|
+
const selectedWallet = solanaWallets.wallets.find((wallet) => wallet.adapter.name === solanaConnector);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (!solanaConnector)
|
|
19
|
+
return;
|
|
20
|
+
solanaWallets.select(solanaConnector);
|
|
21
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
22
|
+
}, [solanaConnector]);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (!isConnected)
|
|
25
|
+
return;
|
|
26
|
+
// Wait so user can see it's connected
|
|
27
|
+
const meta = {
|
|
28
|
+
event: "wait-solana-connected",
|
|
29
|
+
walletName: solanaWallets.wallet?.adapter.name,
|
|
30
|
+
};
|
|
31
|
+
setTimeout(() => {
|
|
32
|
+
setTokenMode("solana");
|
|
33
|
+
setRoute(ROUTES.SELECT_TOKEN, meta);
|
|
34
|
+
}, 500);
|
|
35
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
36
|
+
}, [isConnected]);
|
|
37
|
+
if (!solanaConnector)
|
|
38
|
+
return null;
|
|
39
|
+
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."] })] })) })] }));
|
|
40
|
+
};
|
|
41
|
+
const LoadingContainer = styled(motion.div) `
|
|
42
|
+
display: flex;
|
|
43
|
+
align-items: center;
|
|
44
|
+
justify-content: center;
|
|
45
|
+
margin: 10px auto 16px;
|
|
46
|
+
height: 120px;
|
|
47
|
+
`;
|
|
48
|
+
const AnimationContainer = styled(motion.div) `
|
|
49
|
+
user-select: none;
|
|
50
|
+
position: relative;
|
|
51
|
+
--spinner-error-opacity: 0;
|
|
52
|
+
&:before {
|
|
53
|
+
content: "";
|
|
54
|
+
position: absolute;
|
|
55
|
+
inset: 1px;
|
|
56
|
+
opacity: 0;
|
|
57
|
+
background: var(--ck-body-color-danger);
|
|
58
|
+
}
|
|
59
|
+
`;
|
|
60
|
+
|
|
61
|
+
export { LoadingContainer, ConnectSolana as default };
|
|
62
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../../src/components/Pages/Solana/ConnectorSolana/index.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;;;;;;AAgBM,MAAA,aAAa,GAAa,MAAK;AACnC,IAAA,MAAM,aAAa,GAAG,SAAS,EAAE,CAAC;AAClC,IAAA,MAAM,WAAW,GAAG,aAAa,CAAC,SAAS,CAAC;IAE5C,MAAM,EAAE,eAAe,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,aAAa,EAAE,CAAC;AACpE,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,YAAY,CAAC;IAEtC,MAAM,cAAc,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAC/C,CAAC,MAAM,KAAK,MAAM,CAAC,OAAO,CAAC,IAAI,KAAK,eAAe,CACpD,CAAC;IAEF,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,CAAC,eAAe;YAAE,OAAO;AAC7B,QAAA,aAAa,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;;AAExC,KAAC,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;IAEtB,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,CAAC,WAAW;YAAE,OAAO;;AAEzB,QAAA,MAAM,IAAI,GAAG;AACX,YAAA,KAAK,EAAE,uBAAuB;AAC9B,YAAA,UAAU,EAAE,aAAa,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI;SAC/C,CAAC;QACF,UAAU,CAAC,MAAK;YACd,YAAY,CAAC,QAAQ,CAAC,CAAC;AACvB,YAAA,QAAQ,CAAC,MAAM,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;SACrC,EAAE,GAAG,CAAC,CAAC;;AAEV,KAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;AAElB,IAAA,IAAI,CAAC,eAAe;AAAE,QAAA,OAAO,IAAI,CAAC;IAElC,QACEA,KAAC,WAAW,EAAA,EAAA,QAAA,EAAA,CACVC,IAAC,gBAAgB,EAAA,EAAA,QAAA,EACfA,GAAC,CAAA,kBAAkB,EACjB,EAAA,QAAA,EAAAA,GAAA,CAAC,eAAe,EACd,EAAA,QAAA,EAAAA,GAAA,CAAC,eAAe,EACd,EAAA,IAAI,EACFA,GAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,YACvDA,GACE,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,cAAc,EAAE,OAAO,CAAC,IAAI,EACjC,GAAG,EAAE,cAAc,EAAE,OAAO,CAAC,IAAI,EAAA,CACjC,EACE,CAAA,EAER,OAAO,EAAE,IAAI,GACb,EACc,CAAA,EAAA,CACC,GACJ,EACnBA,GAAA,CAAC,YAAY,EAAA,EAAC,KAAK,EAAE,EAAE,aAAa,EAAE,CAAC,EAAE,EAAA,QAAA,EACtC,WAAW,IACVA,GAAC,CAAA,OAAO,4BAAoB,KAE5BD,4BACEC,GAAC,CAAA,OAAO,EAAgC,EAAA,QAAA,EAAA,uBAAA,EAAA,CAAA,EACxCD,IAAC,CAAA,SAAS,wBACF,cAAc,EAAE,OAAO,CAAC,IAAI,EAAA,eAAA,CAAA,EAAA,CACxB,IACX,CACJ,EAAA,CACY,CACH,EAAA,CAAA,EACd;AACJ,EAAE;AAEW,MAAA,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;EAMhD;AACF,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;;;;;;CAW5C;;;;"}
|