@daimo/pay 1.10.2 → 1.11.0
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 +4 -3
- 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 +24 -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/DaimoPayButton/index.d.ts +132 -0
- package/build/components/DaimoPayButton/styles.d.ts +4 -0
- package/build/components/DaimoPayModal/ConnectUsing.d.ts +2 -0
- package/build/components/DaimoPayModal/ConnectWithInjector/index.d.ts +15 -0
- package/build/components/DaimoPayModal/ConnectWithInjector/styles.d.ts +6 -0
- package/build/components/DaimoPayModal/ConnectWithQRCode.d.ts +3 -0
- package/build/components/DaimoPayModal/index.d.ts +7 -0
- package/build/components/DaimoPayThemeProvider/DaimoPayThemeProvider.d.ts +16 -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/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/useConnect.d.ts +110 -0
- package/build/hooks/useConnectCallback.d.ts +8 -0
- package/build/hooks/useConnectors.d.ts +3 -0
- package/build/hooks/useDaimoPay.d.ts +87 -0
- package/build/hooks/useDaimoPayStatus.d.ts +15 -0
- package/build/hooks/useDaimoPayUI.d.ts +6 -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 +58 -0
- package/build/hooks/usePrevious.d.ts +1 -0
- package/build/hooks/useSolanaPaymentOptions.d.ts +12 -0
- package/build/hooks/useTokenOptions.d.ts +5 -0
- package/build/hooks/useWalletPaymentOptions.d.ts +20 -0
- package/build/hooks/useWindowSize.d.ts +4 -0
- package/build/index.d.ts +15 -722
- 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 +116 -0
- package/build/package.json.js.map +1 -0
- package/build/payment/paymentEffects.d.ts +12 -0
- package/build/payment/paymentFsm.d.ts +123 -0
- package/build/payment/paymentStore.d.ts +12 -0
- package/build/provider/DaimoPayProvider.d.ts +24 -0
- package/build/provider/PayContext.d.ts +56 -0
- package/build/provider/PaymentProvider.d.ts +8 -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 +661 -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 +79 -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 +87 -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/DaimoPayButton/index.js +201 -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 +42 -0
- package/build/src/components/DaimoPayModal/ConnectUsing.js.map +1 -0
- package/build/src/components/DaimoPayModal/ConnectWithInjector/index.js +195 -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 +47 -0
- package/build/src/components/DaimoPayModal/ConnectWithQRCode.js.map +1 -0
- package/build/src/components/DaimoPayModal/index.js +251 -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 +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 +97 -0
- package/build/src/components/Pages/Confirmation/index.js.map +1 -0
- package/build/src/components/Pages/Connectors/index.js +39 -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 +103 -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 +58 -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/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/useDaimoPay.js +83 -0
- package/build/src/hooks/useDaimoPay.js.map +1 -0
- package/build/src/hooks/useDaimoPayStatus.js +23 -0
- package/build/src/hooks/useDaimoPayStatus.js.map +1 -0
- package/build/src/hooks/useDaimoPayUI.js +15 -0
- package/build/src/hooks/useDaimoPayUI.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 +331 -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 +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 +295 -0
- package/build/src/payment/paymentEffects.js.map +1 -0
- package/build/src/payment/paymentFsm.js +186 -0
- package/build/src/payment/paymentFsm.js.map +1 -0
- package/build/src/payment/paymentStore.js +24 -0
- package/build/src/payment/paymentStore.js.map +1 -0
- package/build/src/provider/DaimoPayProvider.js +267 -0
- package/build/src/provider/DaimoPayProvider.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/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 +80 -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 +7 -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 +129 -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 +61 -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 +65 -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 +4 -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 +67 -0
- package/build/world-mini-app/promptWorldPayment.d.ts +9 -0
- package/build/world.d.ts +1 -0
- package/package.json +12 -6
- package/build/index.js +0 -13685
- package/build/index.js.map +0 -1
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { useState, useRef, useEffect, useLayoutEffect } from 'react';
|
|
3
|
+
import useMeasure from 'react-use-measure';
|
|
4
|
+
import { usePayContext } from '../../../hooks/usePayContext.js';
|
|
5
|
+
import { TooltipWindow, TooltipContainer, TooltipTail } from './styles.js';
|
|
6
|
+
import { motion, AnimatePresence } from 'framer-motion';
|
|
7
|
+
import { ResetContainer } from '../../../styles/index.js';
|
|
8
|
+
import { useThemeContext } from '../../DaimoPayThemeProvider/DaimoPayThemeProvider.js';
|
|
9
|
+
import Portal from '../Portal/index.js';
|
|
10
|
+
|
|
11
|
+
const Tooltip = ({ children, message, open, xOffset = 0, yOffset = 0, delay, }) => {
|
|
12
|
+
const context = usePayContext();
|
|
13
|
+
const themeContext = useThemeContext();
|
|
14
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
15
|
+
const [outOfBounds, setOutOfBounds] = useState(false);
|
|
16
|
+
const [size, setSize] = useState("small");
|
|
17
|
+
const [ready, setReady] = useState(false);
|
|
18
|
+
const [currentRoute] = useState(context.route);
|
|
19
|
+
const targetRef = useRef(null);
|
|
20
|
+
const [ref, bounds] = useMeasure({
|
|
21
|
+
debounce: !ready ? 220 : 0, // fix alignment initial state
|
|
22
|
+
offsetSize: true,
|
|
23
|
+
scroll: true,
|
|
24
|
+
});
|
|
25
|
+
const checkBounds = () => {
|
|
26
|
+
let flag = false;
|
|
27
|
+
const x = xOffset + bounds.left + bounds.width;
|
|
28
|
+
const y = yOffset + bounds.top + bounds.height * 0.5;
|
|
29
|
+
if (x > window.innerWidth || x < 0 || y > window.innerHeight || y < 0) {
|
|
30
|
+
flag = true;
|
|
31
|
+
}
|
|
32
|
+
return flag;
|
|
33
|
+
};
|
|
34
|
+
const useIsomorphicLayoutEffect = typeof window !== "undefined" ? useLayoutEffect : useEffect;
|
|
35
|
+
const refreshLayout = () => {
|
|
36
|
+
if (!targetRef.current ||
|
|
37
|
+
bounds.top +
|
|
38
|
+
bounds.bottom +
|
|
39
|
+
bounds.left +
|
|
40
|
+
bounds.right +
|
|
41
|
+
bounds.height +
|
|
42
|
+
bounds.width ===
|
|
43
|
+
0)
|
|
44
|
+
return;
|
|
45
|
+
const x = xOffset + bounds.left + bounds.width;
|
|
46
|
+
const y = yOffset + bounds.top + bounds.height * 0.5;
|
|
47
|
+
if (!ready && x !== 0 && y !== 0)
|
|
48
|
+
setReady(true);
|
|
49
|
+
targetRef.current.style.left = `${x}px`;
|
|
50
|
+
targetRef.current.style.top = `${y}px`;
|
|
51
|
+
setSize(targetRef.current.offsetHeight <= 40 ? "small" : "large");
|
|
52
|
+
setOutOfBounds(checkBounds());
|
|
53
|
+
};
|
|
54
|
+
useIsomorphicLayoutEffect(refreshLayout, [bounds, open, isOpen]);
|
|
55
|
+
useEffect(() => {
|
|
56
|
+
if (!context.open)
|
|
57
|
+
setIsOpen(false);
|
|
58
|
+
}, [context.open]);
|
|
59
|
+
useEffect(() => {
|
|
60
|
+
setIsOpen(!!open);
|
|
61
|
+
}, [open]);
|
|
62
|
+
if (context.options?.hideTooltips)
|
|
63
|
+
return jsx(Fragment, { children: children });
|
|
64
|
+
return (jsxs(Fragment, { children: [jsx(motion.div, { ref: ref, style: open === undefined
|
|
65
|
+
? {
|
|
66
|
+
cursor: "help",
|
|
67
|
+
}
|
|
68
|
+
: {}, onHoverStart: () => setIsOpen(true), onHoverEnd: () => setIsOpen(false), onClick: () => setIsOpen(false), children: children }), jsx(Portal, { children: jsx(AnimatePresence, { children: currentRoute === context.route && !outOfBounds && isOpen && (jsx(ResetContainer, { "$useTheme": themeContext.theme, "$useMode": themeContext.mode, "$customTheme": themeContext.customTheme, children: jsx(TooltipWindow, { children: jsxs(TooltipContainer, { role: "tooltip", "$size": size, ref: targetRef, initial: "collapsed", animate: ready ? "open" : {}, exit: "collapsed", variants: {
|
|
69
|
+
collapsed: {
|
|
70
|
+
transformOrigin: "20px 50%",
|
|
71
|
+
opacity: 0,
|
|
72
|
+
scale: 0.9,
|
|
73
|
+
z: 0.01,
|
|
74
|
+
y: "-50%",
|
|
75
|
+
x: 20,
|
|
76
|
+
transition: {
|
|
77
|
+
duration: 0.1,
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
open: {
|
|
81
|
+
willChange: "opacity,transform",
|
|
82
|
+
opacity: 1,
|
|
83
|
+
scale: 1,
|
|
84
|
+
z: 0.01,
|
|
85
|
+
y: "-50%",
|
|
86
|
+
x: 20,
|
|
87
|
+
transition: {
|
|
88
|
+
ease: [0.76, 0, 0.24, 1],
|
|
89
|
+
duration: 0.15,
|
|
90
|
+
delay: delay ? delay : 0.5,
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
}, children: [message, jsx(TooltipTail, { "$size": size })] }) }) })) }) })] }));
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
export { Tooltip as default };
|
|
97
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Common/Tooltip/index.tsx"],"sourcesContent":[null],"names":["_jsx","_Fragment","_jsxs"],"mappings":";;;;;;;;;;AAYM,MAAA,OAAO,GAA2B,CAAC,EACvC,QAAQ,EACR,OAAO,EACP,IAAI,EACJ,OAAO,GAAG,CAAC,EACX,OAAO,GAAG,CAAC,EACX,KAAK,GACN,KAAI;AACH,IAAA,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;AAChC,IAAA,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IAEvC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC5C,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAmB,OAAO,CAAC,CAAC;IAE5D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE1C,MAAM,CAAC,YAAY,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAE/C,IAAA,MAAM,SAAS,GAAG,MAAM,CAAM,IAAI,CAAC,CAAC;AACpC,IAAA,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,UAAU,CAAC;AAC/B,QAAA,QAAQ,EAAE,CAAC,KAAK,GAAG,GAAG,GAAG,CAAC;AAC1B,QAAA,UAAU,EAAE,IAAI;AAChB,QAAA,MAAM,EAAE,IAAI;AACb,KAAA,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,MAAK;QACvB,IAAI,IAAI,GAAG,KAAK,CAAC;QACjB,MAAM,CAAC,GAAG,OAAO,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;AAC/C,QAAA,MAAM,CAAC,GAAG,OAAO,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC;QACrD,IAAI,CAAC,GAAG,MAAM,CAAC,UAAU,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,WAAW,IAAI,CAAC,GAAG,CAAC,EAAE;YACrE,IAAI,GAAG,IAAI,CAAC;SACb;AACD,QAAA,OAAO,IAAI,CAAC;AACd,KAAC,CAAC;AAEF,IAAA,MAAM,yBAAyB,GAC7B,OAAO,MAAM,KAAK,WAAW,GAAG,eAAe,GAAG,SAAS,CAAC;IAE9D,MAAM,aAAa,GAAG,MAAK;QACzB,IACE,CAAC,SAAS,CAAC,OAAO;AAClB,YAAA,MAAM,CAAC,GAAG;AACR,gBAAA,MAAM,CAAC,MAAM;AACb,gBAAA,MAAM,CAAC,IAAI;AACX,gBAAA,MAAM,CAAC,KAAK;AACZ,gBAAA,MAAM,CAAC,MAAM;AACb,gBAAA,MAAM,CAAC,KAAK;gBACZ,CAAC;YAEH,OAAO;QACT,MAAM,CAAC,GAAG,OAAO,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;AAC/C,QAAA,MAAM,CAAC,GAAG,OAAO,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC;QACrD,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;YAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjD,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,CAAA,EAAG,CAAC,CAAA,EAAA,CAAI,CAAC;QACxC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,CAAA,EAAG,CAAC,CAAA,EAAA,CAAI,CAAC;AACvC,QAAA,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,IAAI,EAAE,GAAG,OAAO,GAAG,OAAO,CAAC,CAAC;AAClE,QAAA,cAAc,CAAC,WAAW,EAAE,CAAC,CAAC;AAChC,KAAC,CAAC;IACF,yBAAyB,CAAC,aAAa,EAAE,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;IAEjE,SAAS,CAAC,MAAK;QACb,IAAI,CAAC,OAAO,CAAC,IAAI;YAAE,SAAS,CAAC,KAAK,CAAC,CAAC;AACtC,KAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IAEnB,SAAS,CAAC,MAAK;AACb,QAAA,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACpB,KAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;AAEX,IAAA,IAAI,OAAO,CAAC,OAAO,EAAE,YAAY;QAAE,OAAOA,GAAA,CAAAC,QAAA,EAAA,EAAA,QAAA,EAAG,QAAQ,EAAA,CAAI,CAAC;AAE1D,IAAA,QACEC,IAAA,CAAAD,QAAA,EAAA,EAAA,QAAA,EAAA,CACED,GAAC,CAAA,MAAM,CAAC,GAAG,EAAA,EACT,GAAG,EAAE,GAAG,EACR,KAAK,EACH,IAAI,KAAK,SAAS;AAChB,sBAAE;AACE,wBAAA,MAAM,EAAE,MAAM;AACf,qBAAA;sBACD,EAAE,EAER,YAAY,EAAE,MAAM,SAAS,CAAC,IAAI,CAAC,EACnC,UAAU,EAAE,MAAM,SAAS,CAAC,KAAK,CAAC,EAClC,OAAO,EAAE,MAAM,SAAS,CAAC,KAAK,CAAC,YAE9B,QAAQ,EAAA,CACE,EACbA,GAAA,CAAC,MAAM,EAAA,EAAA,QAAA,EACLA,IAAC,eAAe,EAAA,EAAA,QAAA,EACb,YAAY,KAAK,OAAO,CAAC,KAAK,IAAI,CAAC,WAAW,IAAI,MAAM,KACvDA,GAAC,CAAA,cAAc,iBACF,YAAY,CAAC,KAAK,EACnB,UAAA,EAAA,YAAY,CAAC,IAAI,EACb,cAAA,EAAA,YAAY,CAAC,WAAW,EAAA,QAAA,EAEtCA,GAAC,CAAA,aAAa,EACZ,EAAA,QAAA,EAAAE,IAAA,CAAC,gBAAgB,EACf,EAAA,IAAI,EAAC,SAAS,EACP,OAAA,EAAA,IAAI,EACX,GAAG,EAAE,SAAS,EACd,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,KAAK,GAAG,MAAM,GAAG,EAAE,EAC5B,IAAI,EAAE,WAAW,EACjB,QAAQ,EAAE;AACR,oCAAA,SAAS,EAAE;AACT,wCAAA,eAAe,EAAE,UAAU;AAC3B,wCAAA,OAAO,EAAE,CAAC;AACV,wCAAA,KAAK,EAAE,GAAG;AACV,wCAAA,CAAC,EAAE,IAAI;AACP,wCAAA,CAAC,EAAE,MAAM;AACT,wCAAA,CAAC,EAAE,EAAE;AACL,wCAAA,UAAU,EAAE;AACV,4CAAA,QAAQ,EAAE,GAAG;AACd,yCAAA;AACF,qCAAA;AACD,oCAAA,IAAI,EAAE;AACJ,wCAAA,UAAU,EAAE,mBAAmB;AAC/B,wCAAA,OAAO,EAAE,CAAC;AACV,wCAAA,KAAK,EAAE,CAAC;AACR,wCAAA,CAAC,EAAE,IAAI;AACP,wCAAA,CAAC,EAAE,MAAM;AACT,wCAAA,CAAC,EAAE,EAAE;AACL,wCAAA,UAAU,EAAE;4CACV,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;AACxB,4CAAA,QAAQ,EAAE,IAAI;4CACd,KAAK,EAAE,KAAK,GAAG,KAAK,GAAG,GAAG;AAC3B,yCAAA;AACF,qCAAA;AACF,iCAAA,EAAA,QAAA,EAAA,CAEA,OAAO,EACRF,GAAC,CAAA,WAAW,aAAQ,IAAI,EAAA,CAAI,CACX,EAAA,CAAA,EAAA,CACL,GACD,CAClB,EAAA,CACe,EACX,CAAA,CAAA,EAAA,CACR,EACH;AACJ;;;;"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { motion } from 'framer-motion';
|
|
2
|
+
import styled from '../../../styles/styled/index.js';
|
|
3
|
+
|
|
4
|
+
const TooltipWindow = styled(motion.div) `
|
|
5
|
+
z-index: 2147483647;
|
|
6
|
+
position: fixed;
|
|
7
|
+
inset: 0;
|
|
8
|
+
pointer-events: none;
|
|
9
|
+
`;
|
|
10
|
+
const TooltipContainer = styled(motion.div) `
|
|
11
|
+
--shadow: var(--ck-tooltip-shadow);
|
|
12
|
+
z-index: 2147483647;
|
|
13
|
+
position: absolute;
|
|
14
|
+
top: 0;
|
|
15
|
+
left: 0;
|
|
16
|
+
display: flex;
|
|
17
|
+
gap: 8px;
|
|
18
|
+
width: fit-content;
|
|
19
|
+
align-items: center;
|
|
20
|
+
justify-content: center;
|
|
21
|
+
border-radius: var(
|
|
22
|
+
--ck-tooltip-border-radius,
|
|
23
|
+
${(props) => (props.$size === "small" ? 11 : 14)}px
|
|
24
|
+
);
|
|
25
|
+
border-radius:;
|
|
26
|
+
padding: 10px 16px 10px 12px;
|
|
27
|
+
font-size: 14px;
|
|
28
|
+
line-height: 19px;
|
|
29
|
+
font-weight: 500;
|
|
30
|
+
letter-spacing: -0.1px;
|
|
31
|
+
color: var(--ck-tooltip-color);
|
|
32
|
+
background: var(--ck-tooltip-background);
|
|
33
|
+
box-shadow: var(--shadow);
|
|
34
|
+
> span {
|
|
35
|
+
z-index: 3;
|
|
36
|
+
position: relative;
|
|
37
|
+
}
|
|
38
|
+
> div {
|
|
39
|
+
margin: -4px 0; // offset for icon
|
|
40
|
+
}
|
|
41
|
+
strong {
|
|
42
|
+
color: var(--ck-spinner-color);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
.ck-tt-logo {
|
|
46
|
+
display: inline-block;
|
|
47
|
+
vertical-align: text-bottom;
|
|
48
|
+
height: 1em;
|
|
49
|
+
width: 1.25em;
|
|
50
|
+
svg {
|
|
51
|
+
display: block;
|
|
52
|
+
height: 100%;
|
|
53
|
+
transform: translate(0.5px, -1px) scale(1.75);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
`;
|
|
57
|
+
const TooltipTail = styled(motion.div) `
|
|
58
|
+
z-index: 2;
|
|
59
|
+
position: absolute;
|
|
60
|
+
display: flex;
|
|
61
|
+
align-items: center;
|
|
62
|
+
justify-content: center;
|
|
63
|
+
width: ${(props) => (props.$size === "small" ? 14 : 18)}px;
|
|
64
|
+
right: 100%;
|
|
65
|
+
top: 0;
|
|
66
|
+
bottom: 0;
|
|
67
|
+
overflow: hidden;
|
|
68
|
+
&:before {
|
|
69
|
+
content: "";
|
|
70
|
+
position: absolute;
|
|
71
|
+
box-shadow: var(--shadow);
|
|
72
|
+
width: ${(props) => (props.$size === "small" ? 14 : 18)}px;
|
|
73
|
+
height: ${(props) => (props.$size === "small" ? 14 : 18)}px;
|
|
74
|
+
transform: translate(75%, 0) rotate(45deg);
|
|
75
|
+
background: var(--ck-tooltip-background);
|
|
76
|
+
border-radius: ${(props) => (props.$size === "small" ? 2 : 3)}px 0 0 0;
|
|
77
|
+
}
|
|
78
|
+
`;
|
|
79
|
+
|
|
80
|
+
export { TooltipContainer, TooltipTail, TooltipWindow };
|
|
81
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sources":["../../../../../src/components/Common/Tooltip/styles.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAIa,MAAA,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;EAK7C;AACW,MAAA,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAA6B,CAAA;;;;;;;;;;;;;AAazE,IAAA,EAAA,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,OAAO,GAAG,EAAE,GAAG,EAAE,CAAC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiClD;AAEW,MAAA,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAA6B,CAAA;;;;;;AAM/D,SAAA,EAAA,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,OAAO,GAAG,EAAE,GAAG,EAAE,CAAC,CAAA;;;;;;;;;AAS5C,WAAA,EAAA,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,OAAO,GAAG,EAAE,GAAG,EAAE,CAAC,CAAA;AAC7C,YAAA,EAAA,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,OAAO,GAAG,EAAE,GAAG,EAAE,CAAC,CAAA;;;AAGvC,mBAAA,EAAA,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,KAAK,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;;;;;;"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { motion } from 'framer-motion';
|
|
3
|
+
import styled from '../../../styles/styled/index.js';
|
|
4
|
+
|
|
5
|
+
const WalletChainLogo = ({ walletIcon, walletName, chainLogo, }) => {
|
|
6
|
+
const walletIconElement = typeof walletIcon === "string" ? (jsx("img", { src: walletIcon, alt: walletName })) : (walletIcon);
|
|
7
|
+
return (jsxs(WalletChainContainer, { children: [walletIconElement, jsx(ChainContainer, { children: chainLogo })] }));
|
|
8
|
+
};
|
|
9
|
+
const WalletChainContainer = styled(motion.div) `
|
|
10
|
+
width: 100%;
|
|
11
|
+
height: 100%;
|
|
12
|
+
`;
|
|
13
|
+
const ChainContainer = styled(motion.div) `
|
|
14
|
+
position: absolute;
|
|
15
|
+
width: 16px;
|
|
16
|
+
height: 16px;
|
|
17
|
+
border-radius: 9999px;
|
|
18
|
+
overflow: hidden;
|
|
19
|
+
bottom: -4px;
|
|
20
|
+
right: -4px;
|
|
21
|
+
`;
|
|
22
|
+
|
|
23
|
+
export { WalletChainLogo as default };
|
|
24
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/Common/WalletChainLogo/index.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":";;;;AAGM,MAAA,eAAe,GAAG,CAAC,EACvB,UAAU,EACV,UAAU,EACV,SAAS,GAKV,KAAI;IACH,MAAM,iBAAiB,GACrB,OAAO,UAAU,KAAK,QAAQ,IAC5BA,GAAA,CAAA,KAAA,EAAA,EAAK,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,EAAI,CAAA,KAEzC,UAAU,CACX,CAAC;AACJ,IAAA,QACEC,IAAA,CAAC,oBAAoB,EAAA,EAAA,QAAA,EAAA,CAClB,iBAAiB,EAClBD,GAAC,CAAA,cAAc,EAAE,EAAA,QAAA,EAAA,SAAS,EAAkB,CAAA,CAAA,EAAA,CACvB,EACvB;AACJ,EAAE;AAEF,MAAM,oBAAoB,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;CAG9C,CAAC;AACF,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;;;CAQxC;;;;"}
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useEffect, useCallback, useRef } from 'react';
|
|
3
|
+
import { usePayContext } from '../../hooks/usePayContext.js';
|
|
4
|
+
import { TextContainer } from './styles.js';
|
|
5
|
+
import { getOrderSourceChainId, DaimoPayEventType, writeDaimoPayOrderID, getDaimoPayOrderView, getOrderDestChainId, assertNotNull } from '@daimo/pay-common';
|
|
6
|
+
import { AnimatePresence } from 'framer-motion';
|
|
7
|
+
import { useDaimoPay } from '../../hooks/useDaimoPay.js';
|
|
8
|
+
import { ResetContainer } from '../../styles/index.js';
|
|
9
|
+
import ThemedButton from '../Common/ThemedButton/index.js';
|
|
10
|
+
import { ThemeContainer } from '../Common/ThemedButton/styles.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* A button that shows the Daimo Pay checkout. Replaces the traditional
|
|
14
|
+
* Connect Wallet » approve » execute sequence with a single action.
|
|
15
|
+
*/
|
|
16
|
+
function DaimoPayButton(props) {
|
|
17
|
+
const { theme, mode, customTheme } = props;
|
|
18
|
+
const context = usePayContext();
|
|
19
|
+
return (jsx(DaimoPayButtonCustom, { ...props, children: ({ show }) => (jsx(ResetContainer, { "$useTheme": theme ?? context.theme, "$useMode": mode ?? context.mode, "$customTheme": customTheme ?? context.customTheme, children: jsx(ThemeContainer, { onClick: props.disabled ? undefined : show, children: jsx(ThemedButton, { theme: theme ?? context.theme, mode: mode ?? context.mode, customTheme: customTheme ?? context.customTheme, children: jsx(DaimoPayButtonInner, {}) }) }) })) }));
|
|
20
|
+
}
|
|
21
|
+
/** Like DaimoPayButton, but with custom styling. */
|
|
22
|
+
function DaimoPayButtonCustom(props) {
|
|
23
|
+
const context = usePayContext();
|
|
24
|
+
// Pre-load payment info in background.
|
|
25
|
+
// Reload when any of the info changes.
|
|
26
|
+
let payParams = "appId" in props
|
|
27
|
+
? {
|
|
28
|
+
appId: props.appId,
|
|
29
|
+
toChain: props.toChain,
|
|
30
|
+
toAddress: props.toAddress,
|
|
31
|
+
toToken: props.toToken,
|
|
32
|
+
toUnits: props.toUnits,
|
|
33
|
+
toCallData: props.toCallData,
|
|
34
|
+
intent: props.intent,
|
|
35
|
+
paymentOptions: props.paymentOptions,
|
|
36
|
+
preferredChains: props.preferredChains,
|
|
37
|
+
preferredTokens: props.preferredTokens,
|
|
38
|
+
evmChains: props.evmChains,
|
|
39
|
+
externalId: props.externalId,
|
|
40
|
+
metadata: props.metadata,
|
|
41
|
+
refundAddress: props.refundAddress,
|
|
42
|
+
}
|
|
43
|
+
: null;
|
|
44
|
+
let payId = "payId" in props ? props.payId : null;
|
|
45
|
+
const { paymentState, log } = context;
|
|
46
|
+
const { order, paymentState: payState } = useDaimoPay();
|
|
47
|
+
// Set the payId or payParams
|
|
48
|
+
useEffect(() => {
|
|
49
|
+
if (payId != null) {
|
|
50
|
+
paymentState.setPayId(payId);
|
|
51
|
+
}
|
|
52
|
+
else if (payParams != null) {
|
|
53
|
+
paymentState.setPayParams(payParams);
|
|
54
|
+
}
|
|
55
|
+
paymentState.setButtonProps(props);
|
|
56
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
57
|
+
}, [payId, JSON.stringify(payParams || {})]);
|
|
58
|
+
// Set the confirmation message
|
|
59
|
+
const { setConfirmationMessage } = context;
|
|
60
|
+
useEffect(() => {
|
|
61
|
+
if (props.confirmationMessage) {
|
|
62
|
+
setConfirmationMessage(props.confirmationMessage);
|
|
63
|
+
}
|
|
64
|
+
}, [props.confirmationMessage, setConfirmationMessage]);
|
|
65
|
+
// Set the redirect return url
|
|
66
|
+
const { setRedirectReturnUrl } = context;
|
|
67
|
+
useEffect(() => {
|
|
68
|
+
if (props.redirectReturnUrl) {
|
|
69
|
+
setRedirectReturnUrl(props.redirectReturnUrl);
|
|
70
|
+
}
|
|
71
|
+
}, [props.redirectReturnUrl, setRedirectReturnUrl]);
|
|
72
|
+
// Set the onOpen and onClose callbacks
|
|
73
|
+
const { setOnOpen, setOnClose } = context;
|
|
74
|
+
useEffect(() => {
|
|
75
|
+
setOnOpen(props.onOpen);
|
|
76
|
+
return () => setOnOpen(undefined);
|
|
77
|
+
}, [props.onOpen, setOnOpen]);
|
|
78
|
+
useEffect(() => {
|
|
79
|
+
setOnClose(props.onClose);
|
|
80
|
+
return () => setOnClose(undefined);
|
|
81
|
+
}, [props.onClose, setOnClose]);
|
|
82
|
+
// Payment events: call these three event handlers.
|
|
83
|
+
const { onPaymentStarted, onPaymentCompleted, onPaymentBounced } = props;
|
|
84
|
+
// Functions to show and hide the modal
|
|
85
|
+
const { children, closeOnSuccess, resetOnSuccess, connectedWalletOnly } = props;
|
|
86
|
+
const show = useCallback(() => {
|
|
87
|
+
if (order == null)
|
|
88
|
+
return;
|
|
89
|
+
const modalOptions = {
|
|
90
|
+
closeOnSuccess,
|
|
91
|
+
resetOnSuccess,
|
|
92
|
+
connectedWalletOnly,
|
|
93
|
+
};
|
|
94
|
+
context.showPayment(modalOptions);
|
|
95
|
+
}, [order, connectedWalletOnly, closeOnSuccess, resetOnSuccess, context]);
|
|
96
|
+
const hide = useCallback(() => context.setOpen(false), [context]);
|
|
97
|
+
// Emit onPaymentStart handler when payment state changes to payment_started
|
|
98
|
+
const sentStart = useRef(false);
|
|
99
|
+
useEffect(() => {
|
|
100
|
+
if (sentStart.current)
|
|
101
|
+
return;
|
|
102
|
+
if (payState !== "payment_started")
|
|
103
|
+
return;
|
|
104
|
+
// TODO: Populate source payment details immediately when the user pays.
|
|
105
|
+
// Use this hack because source chain id is not immediately populated when
|
|
106
|
+
// payment_started
|
|
107
|
+
const sourceChainId = getOrderSourceChainId(order);
|
|
108
|
+
if (sourceChainId == null)
|
|
109
|
+
return;
|
|
110
|
+
sentStart.current = true;
|
|
111
|
+
onPaymentStarted?.({
|
|
112
|
+
type: DaimoPayEventType.PaymentStarted,
|
|
113
|
+
paymentId: writeDaimoPayOrderID(order.id),
|
|
114
|
+
chainId: sourceChainId,
|
|
115
|
+
txHash: order.sourceInitiateTxHash,
|
|
116
|
+
payment: getDaimoPayOrderView(order),
|
|
117
|
+
});
|
|
118
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
119
|
+
}, [order, payState]);
|
|
120
|
+
// Emit onPaymentComplete or onPaymentBounced handler when payment state
|
|
121
|
+
// changes to payment_completed or payment_bounced
|
|
122
|
+
const sentComplete = useRef(false);
|
|
123
|
+
useEffect(() => {
|
|
124
|
+
if (sentComplete.current)
|
|
125
|
+
return;
|
|
126
|
+
if (payState !== "payment_completed" && payState !== "payment_bounced")
|
|
127
|
+
return;
|
|
128
|
+
sentComplete.current = true;
|
|
129
|
+
const eventType = payState === "payment_completed"
|
|
130
|
+
? DaimoPayEventType.PaymentCompleted
|
|
131
|
+
: DaimoPayEventType.PaymentBounced;
|
|
132
|
+
const event = {
|
|
133
|
+
type: eventType,
|
|
134
|
+
paymentId: writeDaimoPayOrderID(order.id),
|
|
135
|
+
chainId: getOrderDestChainId(order),
|
|
136
|
+
txHash: assertNotNull(order.destFastFinishTxHash ?? order.destClaimTxHash, `[PAY BUTTON] dest tx hash null on order ${order.id} when intent status is ${order.intentStatus}`),
|
|
137
|
+
payment: getDaimoPayOrderView(order),
|
|
138
|
+
};
|
|
139
|
+
if (payState === "payment_completed") {
|
|
140
|
+
onPaymentCompleted?.(event);
|
|
141
|
+
}
|
|
142
|
+
else if (payState === "payment_bounced") {
|
|
143
|
+
onPaymentBounced?.(event);
|
|
144
|
+
}
|
|
145
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
146
|
+
}, [order, payState]);
|
|
147
|
+
// Open the modal by default if the defaultOpen prop is true
|
|
148
|
+
const hasAutoOpened = useRef(false);
|
|
149
|
+
useEffect(() => {
|
|
150
|
+
if (!props.defaultOpen || hasAutoOpened.current)
|
|
151
|
+
return;
|
|
152
|
+
if (order == null)
|
|
153
|
+
return;
|
|
154
|
+
show();
|
|
155
|
+
hasAutoOpened.current = true;
|
|
156
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
157
|
+
}, [order, props.defaultOpen, hasAutoOpened.current]);
|
|
158
|
+
// Validation
|
|
159
|
+
if ((payId == null) == (payParams == null)) {
|
|
160
|
+
throw new Error("Must specify either payId or appId, not both");
|
|
161
|
+
}
|
|
162
|
+
return children({ show, hide });
|
|
163
|
+
}
|
|
164
|
+
DaimoPayButtonCustom.displayName = "DaimoPayButton.Custom";
|
|
165
|
+
DaimoPayButton.Custom = DaimoPayButtonCustom;
|
|
166
|
+
const contentVariants = {
|
|
167
|
+
initial: {
|
|
168
|
+
zIndex: 2,
|
|
169
|
+
opacity: 0,
|
|
170
|
+
x: "-100%",
|
|
171
|
+
},
|
|
172
|
+
animate: {
|
|
173
|
+
opacity: 1,
|
|
174
|
+
x: 0.1,
|
|
175
|
+
transition: {
|
|
176
|
+
duration: 0.4,
|
|
177
|
+
ease: [0.25, 1, 0.5, 1],
|
|
178
|
+
},
|
|
179
|
+
},
|
|
180
|
+
exit: {
|
|
181
|
+
zIndex: 1,
|
|
182
|
+
opacity: 0,
|
|
183
|
+
x: "-100%",
|
|
184
|
+
pointerEvents: "none",
|
|
185
|
+
position: "absolute",
|
|
186
|
+
transition: {
|
|
187
|
+
duration: 0.4,
|
|
188
|
+
ease: [0.25, 1, 0.5, 1],
|
|
189
|
+
},
|
|
190
|
+
},
|
|
191
|
+
};
|
|
192
|
+
function DaimoPayButtonInner() {
|
|
193
|
+
const { order } = useDaimoPay();
|
|
194
|
+
const label = order?.metadata?.intent ?? "Pay";
|
|
195
|
+
return (jsx(AnimatePresence, { initial: false, children: jsx(TextContainer, { initial: "initial", animate: "animate", exit: "exit", variants: contentVariants, style: {
|
|
196
|
+
height: 40,
|
|
197
|
+
}, children: label }) }));
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
export { DaimoPayButton, DaimoPayButtonInner };
|
|
201
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../src/components/DaimoPayButton/index.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;;;;;;;;AAgJA;;;AAGG;AACG,SAAU,cAAc,CAAC,KAA0B,EAAA;IACvD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,KAAK,CAAC;AAC3C,IAAA,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;AAEhC,IAAA,QACEA,GAAC,CAAA,oBAAoB,OAAK,KAAK,EAAA,QAAA,EAC5B,CAAC,EAAE,IAAI,EAAE,MACRA,GAAA,CAAC,cAAc,EACF,EAAA,WAAA,EAAA,KAAK,IAAI,OAAO,CAAC,KAAK,EAAA,UAAA,EACvB,IAAI,IAAI,OAAO,CAAC,IAAI,EAAA,cAAA,EAChB,WAAW,IAAI,OAAO,CAAC,WAAW,EAAA,QAAA,EAEhDA,IAAC,cAAc,EAAA,EAAC,OAAO,EAAE,KAAK,CAAC,QAAQ,GAAG,SAAS,GAAG,IAAI,EAAA,QAAA,EACxDA,IAAC,YAAY,EAAA,EACX,KAAK,EAAE,KAAK,IAAI,OAAO,CAAC,KAAK,EAC7B,IAAI,EAAE,IAAI,IAAI,OAAO,CAAC,IAAI,EAC1B,WAAW,EAAE,WAAW,IAAI,OAAO,CAAC,WAAW,YAE/CA,GAAC,CAAA,mBAAmB,KAAG,EACV,CAAA,EAAA,CACA,GACF,CAClB,EAAA,CACoB,EACvB;AACJ,CAAC;AAED;AACA,SAAS,oBAAoB,CAAC,KAAgC,EAAA;AAC5D,IAAA,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;;;AAIhC,IAAA,IAAI,SAAS,GACX,OAAO,IAAI,KAAK;AACd,UAAE;YACE,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,eAAe,EAAE,KAAK,CAAC,eAAe;YACtC,eAAe,EAAE,KAAK,CAAC,eAAe;YACtC,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,aAAa,EAAE,KAAK,CAAC,aAAa;AACnC,SAAA;UACD,IAAI,CAAC;AACX,IAAA,IAAI,KAAK,GAAG,OAAO,IAAI,KAAK,GAAG,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC;AAElD,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC;IACtC,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,GAAG,WAAW,EAAE,CAAC;;IAGxD,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,KAAK,IAAI,IAAI,EAAE;AACjB,YAAA,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SAC9B;AAAM,aAAA,IAAI,SAAS,IAAI,IAAI,EAAE;AAC5B,YAAA,YAAY,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;SACtC;AACD,QAAA,YAAY,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;;AAErC,KAAC,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;;AAG7C,IAAA,MAAM,EAAE,sBAAsB,EAAE,GAAG,OAAO,CAAC;IAC3C,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,KAAK,CAAC,mBAAmB,EAAE;AAC7B,YAAA,sBAAsB,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;SACnD;KACF,EAAE,CAAC,KAAK,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,CAAC,CAAC;;AAGxD,IAAA,MAAM,EAAE,oBAAoB,EAAE,GAAG,OAAO,CAAC;IACzC,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,KAAK,CAAC,iBAAiB,EAAE;AAC3B,YAAA,oBAAoB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;SAC/C;KACF,EAAE,CAAC,KAAK,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,CAAC,CAAC;;AAGpD,IAAA,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAC1C,SAAS,CAAC,MAAK;AACb,QAAA,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,SAAS,CAAC,SAAS,CAAC,CAAC;KACnC,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAE9B,SAAS,CAAC,MAAK;AACb,QAAA,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;AAC1B,QAAA,OAAO,MAAM,UAAU,CAAC,SAAS,CAAC,CAAC;KACpC,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;;IAGhC,MAAM,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,GAAG,KAAK,CAAC;;IAGzE,MAAM,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,EAAE,mBAAmB,EAAE,GACrE,KAAK,CAAC;AACR,IAAA,MAAM,IAAI,GAAG,WAAW,CAAC,MAAK;QAC5B,IAAI,KAAK,IAAI,IAAI;YAAE,OAAO;AAC1B,QAAA,MAAM,YAAY,GAAG;YACnB,cAAc;YACd,cAAc;YACd,mBAAmB;SACpB,CAAC;AACF,QAAA,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;AACpC,KAAC,EAAE,CAAC,KAAK,EAAE,mBAAmB,EAAE,cAAc,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC;AAC1E,IAAA,MAAM,IAAI,GAAG,WAAW,CAAC,MAAM,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;;AAGlE,IAAA,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,SAAS,CAAC,MAAK;QACb,IAAI,SAAS,CAAC,OAAO;YAAE,OAAO;QAC9B,IAAI,QAAQ,KAAK,iBAAiB;YAAE,OAAO;;;;AAK3C,QAAA,MAAM,aAAa,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,aAAa,IAAI,IAAI;YAAE,OAAO;AAElC,QAAA,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;AACzB,QAAA,gBAAgB,GAAG;YACjB,IAAI,EAAE,iBAAiB,CAAC,cAAc;AACtC,YAAA,SAAS,EAAE,oBAAoB,CAAC,KAAK,CAAC,EAAE,CAAC;AACzC,YAAA,OAAO,EAAE,aAAa;YACtB,MAAM,EAAE,KAAK,CAAC,oBAAoB;AAClC,YAAA,OAAO,EAAE,oBAAoB,CAAC,KAAK,CAAC;AACrC,SAAA,CAAC,CAAC;;AAEL,KAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;;;AAItB,IAAA,MAAM,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACnC,SAAS,CAAC,MAAK;QACb,IAAI,YAAY,CAAC,OAAO;YAAE,OAAO;AACjC,QAAA,IAAI,QAAQ,KAAK,mBAAmB,IAAI,QAAQ,KAAK,iBAAiB;YACpE,OAAO;AAET,QAAA,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC;AAC5B,QAAA,MAAM,SAAS,GACb,QAAQ,KAAK,mBAAmB;cAC5B,iBAAiB,CAAC,gBAAgB;AACpC,cAAE,iBAAiB,CAAC,cAAc,CAAC;AACvC,QAAA,MAAM,KAAK,GAAG;AACZ,YAAA,IAAI,EAAE,SAAS;AACf,YAAA,SAAS,EAAE,oBAAoB,CAAC,KAAK,CAAC,EAAE,CAAC;AACzC,YAAA,OAAO,EAAE,mBAAmB,CAAC,KAAK,CAAC;YACnC,MAAM,EAAE,aAAa,CACnB,KAAK,CAAC,oBAAoB,IAAI,KAAK,CAAC,eAAe,EACnD,CAA2C,wCAAA,EAAA,KAAK,CAAC,EAAE,CAAA,uBAAA,EAA0B,KAAK,CAAC,YAAY,EAAE,CAClG;AACD,YAAA,OAAO,EAAE,oBAAoB,CAAC,KAAK,CAAC;SACrC,CAAC;AAEF,QAAA,IAAI,QAAQ,KAAK,mBAAmB,EAAE;AACpC,YAAA,kBAAkB,GAAG,KAA8B,CAAC,CAAC;SACtD;AAAM,aAAA,IAAI,QAAQ,KAAK,iBAAiB,EAAE;AACzC,YAAA,gBAAgB,GAAG,KAA4B,CAAC,CAAC;SAClD;;AAEH,KAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;;AAGtB,IAAA,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACpC,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,aAAa,CAAC,OAAO;YAAE,OAAO;QACxD,IAAI,KAAK,IAAI,IAAI;YAAE,OAAO;AAC1B,QAAA,IAAI,EAAE,CAAC;AACP,QAAA,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;;AAE/B,KAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,WAAW,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC;;AAGtD,IAAA,IAAI,CAAC,KAAK,IAAI,IAAI,MAAM,SAAS,IAAI,IAAI,CAAC,EAAE;AAC1C,QAAA,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;KACjE;IAED,OAAO,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;AAClC,CAAC;AAED,oBAAoB,CAAC,WAAW,GAAG,uBAAuB,CAAC;AAE3D,cAAc,CAAC,MAAM,GAAG,oBAAoB,CAAC;AAE7C,MAAM,eAAe,GAAa;AAChC,IAAA,OAAO,EAAE;AACP,QAAA,MAAM,EAAE,CAAC;AACT,QAAA,OAAO,EAAE,CAAC;AACV,QAAA,CAAC,EAAE,OAAO;AACX,KAAA;AACD,IAAA,OAAO,EAAE;AACP,QAAA,OAAO,EAAE,CAAC;AACV,QAAA,CAAC,EAAE,GAAG;AACN,QAAA,UAAU,EAAE;AACV,YAAA,QAAQ,EAAE,GAAG;YACb,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;AACxB,SAAA;AACF,KAAA;AACD,IAAA,IAAI,EAAE;AACJ,QAAA,MAAM,EAAE,CAAC;AACT,QAAA,OAAO,EAAE,CAAC;AACV,QAAA,CAAC,EAAE,OAAO;AACV,QAAA,aAAa,EAAE,MAAM;AACrB,QAAA,QAAQ,EAAE,UAAU;AACpB,QAAA,UAAU,EAAE;AACV,YAAA,QAAQ,EAAE,GAAG;YACb,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;AACxB,SAAA;AACF,KAAA;CACF,CAAC;SAEc,mBAAmB,GAAA;AACjC,IAAA,MAAM,EAAE,KAAK,EAAE,GAAG,WAAW,EAAE,CAAC;IAChC,MAAM,KAAK,GAAG,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,KAAK,CAAC;AAE/C,IAAA,QACEA,GAAA,CAAC,eAAe,EAAA,EAAC,OAAO,EAAE,KAAK,EAAA,QAAA,EAC7BA,GAAC,CAAA,aAAa,EACZ,EAAA,OAAO,EAAE,SAAS,EAClB,OAAO,EAAE,SAAS,EAClB,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,eAAe,EACzB,KAAK,EAAE;AACL,gBAAA,MAAM,EAAE,EAAE;AACX,aAAA,EAAA,QAAA,EAEA,KAAK,EAAA,CACQ,EACA,CAAA,EAClB;AACJ;;;;"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { motion } from 'framer-motion';
|
|
2
|
+
import styled from '../../styles/styled/index.js';
|
|
3
|
+
|
|
4
|
+
const TextContainer = styled(motion.div) `
|
|
5
|
+
top: 0;
|
|
6
|
+
bottom: 0;
|
|
7
|
+
left: 0;
|
|
8
|
+
display: inline-flex;
|
|
9
|
+
align-items: center;
|
|
10
|
+
justify-content: center;
|
|
11
|
+
white-space: nowrap;
|
|
12
|
+
`;
|
|
13
|
+
styled(motion.div) `
|
|
14
|
+
position: relative;
|
|
15
|
+
width: 24px;
|
|
16
|
+
height: 24px;
|
|
17
|
+
border-radius: 12px;
|
|
18
|
+
overflow: hidden;
|
|
19
|
+
svg {
|
|
20
|
+
display: block;
|
|
21
|
+
}
|
|
22
|
+
`;
|
|
23
|
+
styled(motion.div) `
|
|
24
|
+
pointer-events: none;
|
|
25
|
+
user-select: none;
|
|
26
|
+
position: relative;
|
|
27
|
+
width: 24px;
|
|
28
|
+
height: 24px;
|
|
29
|
+
margin-right: 8px;
|
|
30
|
+
`;
|
|
31
|
+
styled(motion.div) `
|
|
32
|
+
z-index: 1;
|
|
33
|
+
position: absolute;
|
|
34
|
+
inset: 0;
|
|
35
|
+
display: flex;
|
|
36
|
+
align-items: center;
|
|
37
|
+
justify-content: center;
|
|
38
|
+
border-radius: 100%;
|
|
39
|
+
box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.02);
|
|
40
|
+
background: var(--ck-body-color-danger, red);
|
|
41
|
+
color: #fff;
|
|
42
|
+
svg {
|
|
43
|
+
display: block;
|
|
44
|
+
position: relative;
|
|
45
|
+
top: -1px;
|
|
46
|
+
}
|
|
47
|
+
`;
|
|
48
|
+
|
|
49
|
+
export { TextContainer };
|
|
50
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sources":["../../../../src/components/DaimoPayButton/styles.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAGa,MAAA,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;;;EAQ7C;AAE4B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;;;;EAS9C;AAC2B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;;EAO7C;AAEyC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { AnimatePresence, motion } from 'framer-motion';
|
|
3
|
+
import { useState, useEffect } from 'react';
|
|
4
|
+
import { usePayContext } from '../../hooks/usePayContext.js';
|
|
5
|
+
import { useWallet } from '../../wallets/useWallets.js';
|
|
6
|
+
import ConnectWithInjector from './ConnectWithInjector/index.js';
|
|
7
|
+
import ConnectWithQRCode from './ConnectWithQRCode.js';
|
|
8
|
+
import Alert from '../Common/Alert/index.js';
|
|
9
|
+
import { contentVariants } from '../Common/Modal/index.js';
|
|
10
|
+
|
|
11
|
+
const states = {
|
|
12
|
+
QRCODE: "qrcode",
|
|
13
|
+
INJECTOR: "injector",
|
|
14
|
+
};
|
|
15
|
+
const ConnectUsing = () => {
|
|
16
|
+
const context = usePayContext();
|
|
17
|
+
const { pendingConnectorId } = context;
|
|
18
|
+
const wallet = useWallet(pendingConnectorId ?? "");
|
|
19
|
+
// If cannot be scanned, display injector flow, which if extension is not installed will show CTA to install it
|
|
20
|
+
const isQrCode = !wallet?.isInstalled;
|
|
21
|
+
const [status, setStatus] = useState(isQrCode ? states.QRCODE : states.INJECTOR);
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
// if no provider, change to qrcode
|
|
24
|
+
const checkProvider = async () => {
|
|
25
|
+
const res = await wallet?.connector?.getProvider();
|
|
26
|
+
if (!res) {
|
|
27
|
+
setStatus(states.QRCODE);
|
|
28
|
+
setTimeout(context.triggerResize, 10); // delay required here for modal to resize
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
if (status === states.INJECTOR)
|
|
32
|
+
checkProvider();
|
|
33
|
+
}, []); // eslint-disable-line react-hooks/exhaustive-deps
|
|
34
|
+
if (!wallet)
|
|
35
|
+
return jsx(Alert, { children: "Connector not found" });
|
|
36
|
+
return (jsxs(AnimatePresence, { children: [status === states.QRCODE && (jsx(motion.div, { initial: "initial", animate: "animate", exit: "exit", variants: contentVariants, children: jsx(ConnectWithQRCode, {}) }, states.QRCODE)), status === states.INJECTOR && (jsx(motion.div, { initial: "initial", animate: "animate", exit: "exit", variants: contentVariants, children: jsx(ConnectWithInjector, { switchConnectMethod: () => {
|
|
37
|
+
setStatus(states.QRCODE);
|
|
38
|
+
} }) }, states.INJECTOR))] }));
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export { ConnectUsing as default };
|
|
42
|
+
//# sourceMappingURL=ConnectUsing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConnectUsing.js","sources":["../../../../src/components/DaimoPayModal/ConnectUsing.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":";;;;;;;;;;AAYA,MAAM,MAAM,GAAG;AACb,IAAA,MAAM,EAAE,QAAQ;AAChB,IAAA,QAAQ,EAAE,UAAU;CACrB,CAAC;AAEI,MAAA,YAAY,GAAG,MAAK;AACxB,IAAA,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;AAChC,IAAA,MAAM,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC;IAEvC,MAAM,MAAM,GAAG,SAAS,CAAC,kBAAkB,IAAI,EAAE,CAAC,CAAC;;AAGnD,IAAA,MAAM,QAAQ,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC;IAEtC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAClC,QAAQ,GAAG,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,QAAQ,CAC3C,CAAC;IAEF,SAAS,CAAC,MAAK;;AAEb,QAAA,MAAM,aAAa,GAAG,YAAW;YAC/B,MAAM,GAAG,GAAG,MAAM,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC;YACnD,IAAI,CAAC,GAAG,EAAE;AACR,gBAAA,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACzB,UAAU,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;aACvC;AACH,SAAC,CAAC;AACF,QAAA,IAAI,MAAM,KAAK,MAAM,CAAC,QAAQ;AAAE,YAAA,aAAa,EAAE,CAAC;AAClD,KAAC,EAAE,EAAE,CAAC,CAAC;AAEP,IAAA,IAAI,CAAC,MAAM;QAAE,OAAOA,GAAA,CAAC,KAAK,EAAA,EAAA,QAAA,EAAA,qBAAA,EAAA,CAA4B,CAAC;AAEvD,IAAA,QACEC,IAAC,CAAA,eAAe,EACb,EAAA,QAAA,EAAA,CAAA,MAAM,KAAK,MAAM,CAAC,MAAM,KACvBD,GAAC,CAAA,MAAM,CAAC,GAAG,IAET,OAAO,EAAE,SAAS,EAClB,OAAO,EAAE,SAAS,EAClB,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,eAAe,EAEzB,QAAA,EAAAA,GAAA,CAAC,iBAAiB,EAAA,EAAA,CAAG,IANhB,MAAM,CAAC,MAAM,CAOP,CACd,EACA,MAAM,KAAK,MAAM,CAAC,QAAQ,KACzBA,GAAA,CAAC,MAAM,CAAC,GAAG,EAET,EAAA,OAAO,EAAE,SAAS,EAClB,OAAO,EAAE,SAAS,EAClB,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,eAAe,EAAA,QAAA,EAEzBA,IAAC,mBAAmB,EAAA,EAClB,mBAAmB,EAAE,MAAK;AACxB,wBAAA,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;qBAC1B,EAAA,CACD,IAVG,MAAM,CAAC,QAAQ,CAWT,CACd,CACe,EAAA,CAAA,EAClB;AACJ;;;;"}
|