thirdweb 5.105.49-nightly-04862de9e4e11724720fa40a0ed4713ff2bfdad5-20250917000323 → 5.106.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/exports/react.js +3 -1
- package/dist/cjs/exports/react.js.map +1 -1
- package/dist/cjs/pay/convert/type.js +26 -43
- package/dist/cjs/pay/convert/type.js.map +1 -1
- package/dist/cjs/react/core/design-system/index.js +3 -1
- package/dist/cjs/react/core/design-system/index.js.map +1 -1
- package/dist/cjs/react/core/hooks/usePaymentMethods.js +4 -1
- package/dist/cjs/react/core/hooks/usePaymentMethods.js.map +1 -1
- package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js +1 -2
- package/dist/cjs/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/core/machines/paymentMachine.js.map +1 -1
- package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js +1 -9
- package/dist/cjs/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/BridgeOrchestrator.js +7 -5
- package/dist/cjs/react/web/ui/Bridge/BridgeOrchestrator.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/DirectPayment.js +2 -2
- package/dist/cjs/react/web/ui/Bridge/ErrorBanner.js +1 -1
- package/dist/cjs/react/web/ui/Bridge/FundWallet.js +7 -6
- package/dist/cjs/react/web/ui/Bridge/FundWallet.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/QuoteLoader.js +5 -3
- package/dist/cjs/react/web/ui/Bridge/QuoteLoader.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/StepRunner.js +3 -3
- package/dist/cjs/react/web/ui/Bridge/StepRunner.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/TransactionPayment.js +2 -2
- package/dist/cjs/react/web/ui/Bridge/UnsupportedTokenScreen.js +2 -2
- package/dist/cjs/react/web/ui/Bridge/UnsupportedTokenScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/common/TokenAndChain.js +3 -3
- package/dist/cjs/react/web/ui/Bridge/common/TokenAndChain.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/common/WithHeader.js +2 -1
- package/dist/cjs/react/web/ui/Bridge/common/WithHeader.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-details/PaymentDetails.js +28 -3
- package/dist/cjs/react/web/ui/Bridge/payment-details/PaymentDetails.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-selection/FiatProviderSelection.js +16 -22
- package/dist/cjs/react/web/ui/Bridge/payment-selection/FiatProviderSelection.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-selection/PaymentSelection.js +12 -4
- package/dist/cjs/react/web/ui/Bridge/payment-selection/PaymentSelection.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-selection/WalletFiatSelection.js +2 -2
- package/dist/cjs/react/web/ui/Bridge/payment-selection/WalletFiatSelection.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-success/PaymentReceipt.js +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-success/PaymentReceipt.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/payment-success/SuccessScreen.js +8 -7
- package/dist/cjs/react/web/ui/Bridge/payment-success/SuccessScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/Bridge/swap-widget/SearchInput.js +22 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/SearchInput.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/SelectChainButton.js +20 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/SelectChainButton.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/SwapWidget.js +257 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/SwapWidget.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/common.js +17 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/common.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/hooks.js +22 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/hooks.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/select-chain.js +66 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/select-chain.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/select-token-ui.js +208 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/select-token-ui.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/storage.js +53 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/storage.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/swap-ui.js +450 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/swap-ui.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/types.js +3 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/types.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/use-bridge-chains.js +16 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/use-bridge-chains.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/use-tokens.js +68 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/use-tokens.js.map +1 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/utils.js +7 -0
- package/dist/cjs/react/web/ui/Bridge/swap-widget/utils.js.map +1 -0
- package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js +14 -1
- package/dist/cjs/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Details.js +11 -11
- package/dist/cjs/react/web/ui/ConnectWallet/Details.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +15 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectModal.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectModal.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/NetworkSelector.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/NetworkSelector.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletEntryButton.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletEntryButton.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletSelector.js +7 -8
- package/dist/cjs/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletTypeRowButton.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/WalletTypeRowButton.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.js +9 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.js.map +1 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/WalletDotIcon.js +12 -0
- package/dist/cjs/react/web/ui/ConnectWallet/icons/WalletDotIcon.js.map +1 -0
- package/dist/cjs/react/web/ui/ConnectWallet/screens/ReceiveFunds.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/ReceiveFunds.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/SendFunds.js +7 -7
- package/dist/cjs/react/web/ui/ConnectWallet/screens/SendFunds.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/SignatureScreen.js +3 -3
- package/dist/cjs/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/screens/TokenSelector.js +2 -2
- package/dist/cjs/react/web/ui/ConnectWallet/screens/TokenSelector.js.map +1 -1
- package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js +1 -1
- package/dist/cjs/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
- package/dist/cjs/react/web/ui/components/DynamicHeight.js +1 -1
- package/dist/cjs/react/web/ui/components/DynamicHeight.js.map +1 -1
- package/dist/cjs/react/web/ui/components/Img.js +42 -7
- package/dist/cjs/react/web/ui/components/Img.js.map +1 -1
- package/dist/cjs/react/web/ui/components/Modal.js +10 -10
- package/dist/cjs/react/web/ui/components/Modal.js.map +1 -1
- package/dist/cjs/react/web/ui/components/OTPInput.js +1 -1
- package/dist/cjs/react/web/ui/components/OTPInput.js.map +1 -1
- package/dist/cjs/react/web/ui/components/Skeleton.js +1 -0
- package/dist/cjs/react/web/ui/components/Skeleton.js.map +1 -1
- package/dist/cjs/react/web/ui/components/Spinner.js +2 -1
- package/dist/cjs/react/web/ui/components/Spinner.js.map +1 -1
- package/dist/cjs/react/web/ui/components/basic.js +11 -5
- package/dist/cjs/react/web/ui/components/basic.js.map +1 -1
- package/dist/cjs/react/web/ui/components/buttons.js +9 -0
- package/dist/cjs/react/web/ui/components/buttons.js.map +1 -1
- package/dist/cjs/react/web/ui/components/formElements.js +1 -1
- package/dist/cjs/react/web/ui/components/formElements.js.map +1 -1
- package/dist/cjs/react/web/ui/components/modalElements.js +1 -1
- package/dist/cjs/react/web/ui/components/modalElements.js.map +1 -1
- package/dist/cjs/react/web/ui/components/text.js +2 -1
- package/dist/cjs/react/web/ui/components/text.js.map +1 -1
- package/dist/cjs/react/web/utils/cls.js +17 -0
- package/dist/cjs/react/web/utils/cls.js.map +1 -0
- package/dist/cjs/react/web/wallets/in-app/InputSelectionUI.js +1 -1
- package/dist/cjs/react/web/wallets/in-app/InputSelectionUI.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +9 -9
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/ConnectingScreen.js +3 -3
- package/dist/cjs/react/web/wallets/shared/ConnectingScreen.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/GuestLogin.js +1 -1
- package/dist/cjs/react/web/wallets/shared/GuestLogin.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/OTPLoginUI.js +5 -5
- package/dist/cjs/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/ScanScreen.js +5 -5
- package/dist/cjs/react/web/wallets/shared/ScanScreen.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/SocialLogin.js +1 -1
- package/dist/cjs/react/web/wallets/shared/SocialLogin.js.map +1 -1
- package/dist/cjs/stories/Bridge/Swap/SelectChain.stories.js +25 -0
- package/dist/cjs/stories/Bridge/Swap/SelectChain.stories.js.map +1 -0
- package/dist/cjs/stories/Bridge/Swap/SwapWidget.Prefill.stories.js +83 -0
- package/dist/cjs/stories/Bridge/Swap/SwapWidget.Prefill.stories.js.map +1 -0
- package/dist/cjs/stories/Bridge/Swap/SwapWidget.stories.js +52 -0
- package/dist/cjs/stories/Bridge/Swap/SwapWidget.stories.js.map +1 -0
- package/dist/cjs/stories/BuyWidget.stories.js +36 -0
- package/dist/cjs/stories/BuyWidget.stories.js.map +1 -0
- package/dist/cjs/stories/ConnectEmbed.stories.js +90 -0
- package/dist/cjs/stories/ConnectEmbed.stories.js.map +1 -0
- package/dist/cjs/stories/ConnectWallet/useWalletDetailsModal.stories.js +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/cjs/wallets/connection/autoConnect.js +0 -9
- package/dist/cjs/wallets/connection/autoConnect.js.map +1 -1
- package/dist/cjs/wallets/connection/autoConnectCore.js +8 -2
- package/dist/cjs/wallets/connection/autoConnectCore.js.map +1 -1
- package/dist/cjs/wallets/manager/index.js +1 -2
- package/dist/cjs/wallets/manager/index.js.map +1 -1
- package/dist/cjs/wallets/smart/lib/bundler.js +3 -0
- package/dist/cjs/wallets/smart/lib/bundler.js.map +1 -1
- package/dist/esm/exports/react.js +1 -0
- package/dist/esm/exports/react.js.map +1 -1
- package/dist/esm/pay/convert/type.js +26 -43
- package/dist/esm/pay/convert/type.js.map +1 -1
- package/dist/esm/react/core/design-system/index.js +3 -1
- package/dist/esm/react/core/design-system/index.js.map +1 -1
- package/dist/esm/react/core/hooks/usePaymentMethods.js +4 -1
- package/dist/esm/react/core/hooks/usePaymentMethods.js.map +1 -1
- package/dist/esm/react/core/hooks/wallets/useAutoConnect.js +1 -2
- package/dist/esm/react/core/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/core/machines/paymentMachine.js.map +1 -1
- package/dist/esm/react/web/hooks/wallets/useAutoConnect.js +1 -9
- package/dist/esm/react/web/hooks/wallets/useAutoConnect.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/BridgeOrchestrator.js +7 -5
- package/dist/esm/react/web/ui/Bridge/BridgeOrchestrator.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/DirectPayment.js +2 -2
- package/dist/esm/react/web/ui/Bridge/ErrorBanner.js +1 -1
- package/dist/esm/react/web/ui/Bridge/FundWallet.js +7 -6
- package/dist/esm/react/web/ui/Bridge/FundWallet.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/QuoteLoader.js +5 -3
- package/dist/esm/react/web/ui/Bridge/QuoteLoader.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/StepRunner.js +3 -3
- package/dist/esm/react/web/ui/Bridge/StepRunner.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/TransactionPayment.js +2 -2
- package/dist/esm/react/web/ui/Bridge/UnsupportedTokenScreen.js +2 -2
- package/dist/esm/react/web/ui/Bridge/UnsupportedTokenScreen.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/common/TokenAndChain.js +3 -3
- package/dist/esm/react/web/ui/Bridge/common/TokenAndChain.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/common/WithHeader.js +2 -1
- package/dist/esm/react/web/ui/Bridge/common/WithHeader.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-details/PaymentDetails.js +28 -3
- package/dist/esm/react/web/ui/Bridge/payment-details/PaymentDetails.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-selection/FiatProviderSelection.js +16 -22
- package/dist/esm/react/web/ui/Bridge/payment-selection/FiatProviderSelection.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-selection/PaymentSelection.js +12 -4
- package/dist/esm/react/web/ui/Bridge/payment-selection/PaymentSelection.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-selection/WalletFiatSelection.js +3 -3
- package/dist/esm/react/web/ui/Bridge/payment-selection/WalletFiatSelection.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-success/PaymentReceipt.js +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-success/PaymentReceipt.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/payment-success/SuccessScreen.js +9 -8
- package/dist/esm/react/web/ui/Bridge/payment-success/SuccessScreen.js.map +1 -1
- package/dist/esm/react/web/ui/Bridge/swap-widget/SearchInput.js +19 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/SearchInput.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/SelectChainButton.js +17 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/SelectChainButton.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/SwapWidget.js +253 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/SwapWidget.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/common.js +14 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/common.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/hooks.js +19 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/hooks.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/select-chain.js +62 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/select-chain.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/select-token-ui.js +205 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/select-token-ui.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/storage.js +49 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/storage.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/swap-ui.js +447 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/swap-ui.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/types.js +2 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/types.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/use-bridge-chains.js +13 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/use-bridge-chains.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/use-tokens.js +64 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/use-tokens.js.map +1 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/utils.js +4 -0
- package/dist/esm/react/web/ui/Bridge/swap-widget/utils.js.map +1 -0
- package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js +14 -1
- package/dist/esm/react/web/ui/ConnectWallet/ConnectButton.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Details.js +11 -11
- package/dist/esm/react/web/ui/ConnectWallet/Details.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js +2 -2
- package/dist/esm/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js +15 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectEmbed.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectModal.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectModal.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/NetworkSelector.js +2 -2
- package/dist/esm/react/web/ui/ConnectWallet/NetworkSelector.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletEntryButton.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletEntryButton.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js +8 -9
- package/dist/esm/react/web/ui/ConnectWallet/WalletSelector.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletTypeRowButton.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/WalletTypeRowButton.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.js +5 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.js.map +1 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/WalletDotIcon.js +8 -0
- package/dist/esm/react/web/ui/ConnectWallet/icons/WalletDotIcon.js.map +1 -0
- package/dist/esm/react/web/ui/ConnectWallet/screens/ReceiveFunds.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/ReceiveFunds.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/SendFunds.js +7 -7
- package/dist/esm/react/web/ui/ConnectWallet/screens/SendFunds.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/SignatureScreen.js +3 -3
- package/dist/esm/react/web/ui/ConnectWallet/screens/SignatureScreen.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/screens/TokenSelector.js +2 -2
- package/dist/esm/react/web/ui/ConnectWallet/screens/TokenSelector.js.map +1 -1
- package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js +1 -1
- package/dist/esm/react/web/ui/TransactionButton/TransactionModal.js.map +1 -1
- package/dist/esm/react/web/ui/components/DynamicHeight.js +1 -1
- package/dist/esm/react/web/ui/components/DynamicHeight.js.map +1 -1
- package/dist/esm/react/web/ui/components/Img.js +43 -8
- package/dist/esm/react/web/ui/components/Img.js.map +1 -1
- package/dist/esm/react/web/ui/components/Modal.js +10 -10
- package/dist/esm/react/web/ui/components/Modal.js.map +1 -1
- package/dist/esm/react/web/ui/components/OTPInput.js +1 -1
- package/dist/esm/react/web/ui/components/OTPInput.js.map +1 -1
- package/dist/esm/react/web/ui/components/Skeleton.js +1 -0
- package/dist/esm/react/web/ui/components/Skeleton.js.map +1 -1
- package/dist/esm/react/web/ui/components/Spinner.js +2 -1
- package/dist/esm/react/web/ui/components/Spinner.js.map +1 -1
- package/dist/esm/react/web/ui/components/basic.js +11 -5
- package/dist/esm/react/web/ui/components/basic.js.map +1 -1
- package/dist/esm/react/web/ui/components/buttons.js +9 -0
- package/dist/esm/react/web/ui/components/buttons.js.map +1 -1
- package/dist/esm/react/web/ui/components/formElements.js +1 -1
- package/dist/esm/react/web/ui/components/formElements.js.map +1 -1
- package/dist/esm/react/web/ui/components/modalElements.js +1 -1
- package/dist/esm/react/web/ui/components/modalElements.js.map +1 -1
- package/dist/esm/react/web/ui/components/text.js +2 -1
- package/dist/esm/react/web/ui/components/text.js.map +1 -1
- package/dist/esm/react/web/utils/cls.js +14 -0
- package/dist/esm/react/web/utils/cls.js.map +1 -0
- package/dist/esm/react/web/wallets/in-app/InputSelectionUI.js +1 -1
- package/dist/esm/react/web/wallets/in-app/InputSelectionUI.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +9 -9
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/ConnectingScreen.js +3 -3
- package/dist/esm/react/web/wallets/shared/ConnectingScreen.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/GuestLogin.js +1 -1
- package/dist/esm/react/web/wallets/shared/GuestLogin.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/OTPLoginUI.js +5 -5
- package/dist/esm/react/web/wallets/shared/OTPLoginUI.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/ScanScreen.js +5 -5
- package/dist/esm/react/web/wallets/shared/ScanScreen.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/SocialLogin.js +1 -1
- package/dist/esm/react/web/wallets/shared/SocialLogin.js.map +1 -1
- package/dist/esm/stories/Bridge/Swap/SelectChain.stories.js +21 -0
- package/dist/esm/stories/Bridge/Swap/SelectChain.stories.js.map +1 -0
- package/dist/esm/stories/Bridge/Swap/SwapWidget.Prefill.stories.js +74 -0
- package/dist/esm/stories/Bridge/Swap/SwapWidget.Prefill.stories.js.map +1 -0
- package/dist/esm/stories/Bridge/Swap/SwapWidget.stories.js +45 -0
- package/dist/esm/stories/Bridge/Swap/SwapWidget.stories.js.map +1 -0
- package/dist/esm/stories/BuyWidget.stories.js +29 -0
- package/dist/esm/stories/BuyWidget.stories.js.map +1 -0
- package/dist/esm/stories/ConnectEmbed.stories.js +81 -0
- package/dist/esm/stories/ConnectEmbed.stories.js.map +1 -0
- package/dist/esm/stories/ConnectWallet/useWalletDetailsModal.stories.js +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/esm/version.js.map +1 -1
- package/dist/esm/wallets/connection/autoConnect.js +0 -9
- package/dist/esm/wallets/connection/autoConnect.js.map +1 -1
- package/dist/esm/wallets/connection/autoConnectCore.js +8 -2
- package/dist/esm/wallets/connection/autoConnectCore.js.map +1 -1
- package/dist/esm/wallets/manager/index.js +1 -2
- package/dist/esm/wallets/manager/index.js.map +1 -1
- package/dist/esm/wallets/smart/lib/bundler.js +3 -0
- package/dist/esm/wallets/smart/lib/bundler.js.map +1 -1
- package/dist/types/bridge/types/Chain.d.ts +1 -0
- package/dist/types/bridge/types/Chain.d.ts.map +1 -1
- package/dist/types/exports/react.d.ts +1 -0
- package/dist/types/exports/react.d.ts.map +1 -1
- package/dist/types/pay/convert/type.d.ts +27 -3
- package/dist/types/pay/convert/type.d.ts.map +1 -1
- package/dist/types/react/core/design-system/index.d.ts +2 -0
- package/dist/types/react/core/design-system/index.d.ts.map +1 -1
- package/dist/types/react/core/hooks/usePaymentMethods.d.ts.map +1 -1
- package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts +1 -1
- package/dist/types/react/core/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/core/machines/paymentMachine.d.ts +1 -0
- package/dist/types/react/core/machines/paymentMachine.d.ts.map +1 -1
- package/dist/types/react/web/hooks/wallets/useAutoConnect.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/BridgeOrchestrator.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/BuyWidget.d.ts +1 -1
- package/dist/types/react/web/ui/Bridge/FundWallet.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/StepRunner.d.ts +2 -1
- package/dist/types/react/web/ui/Bridge/StepRunner.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/common/TokenAndChain.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/common/WithHeader.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/payment-details/PaymentDetails.d.ts +3 -1
- package/dist/types/react/web/ui/Bridge/payment-details/PaymentDetails.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/payment-selection/FiatProviderSelection.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/payment-selection/PaymentSelection.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/payment-selection/WalletFiatSelection.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/payment-success/PaymentReceipt.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/payment-success/SuccessScreen.d.ts.map +1 -1
- package/dist/types/react/web/ui/Bridge/swap-widget/SearchInput.d.ts +6 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/SearchInput.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/SelectChainButton.d.ts +8 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/SelectChainButton.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/SwapWidget.d.ts +220 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/SwapWidget.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/common.d.ts +9 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/common.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/hooks.d.ts +3 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/hooks.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/select-chain.d.ts +23 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/select-chain.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/select-token-ui.d.ts +18 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/select-token-ui.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/storage.d.ts +46 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/storage.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/swap-ui.d.ts +40 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/swap-ui.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/types.d.ts +139 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/types.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/use-bridge-chains.d.ts +4 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/use-bridge-chains.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/use-tokens.d.ts +44 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/use-tokens.d.ts.map +1 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/utils.d.ts +2 -0
- package/dist/types/react/web/ui/Bridge/swap-widget/utils.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts +13 -0
- package/dist/types/react/web/ui/ConnectWallet/ConnectButton.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Details.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Modal/AllWalletsUI.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts +13 -0
- package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectEmbed.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectModal.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/NetworkSelector.d.ts +1 -0
- package/dist/types/react/web/ui/ConnectWallet/NetworkSelector.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/WalletEntryButton.d.ts +1 -0
- package/dist/types/react/web/ui/ConnectWallet/WalletEntryButton.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/WalletSelector.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/WalletTypeRowButton.d.ts +1 -0
- package/dist/types/react/web/ui/ConnectWallet/WalletTypeRowButton.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.d.ts +3 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/WalletDotIcon.d.ts +6 -0
- package/dist/types/react/web/ui/ConnectWallet/icons/WalletDotIcon.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/screens/ReceiveFunds.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/screens/SendFunds.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/screens/SignatureScreen.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/screens/TokenSelector.d.ts.map +1 -1
- package/dist/types/react/web/ui/TransactionButton/TransactionModal.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/Img.d.ts +3 -0
- package/dist/types/react/web/ui/components/Img.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/Modal.d.ts +3 -0
- package/dist/types/react/web/ui/components/Modal.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/Skeleton.d.ts +1 -0
- package/dist/types/react/web/ui/components/Skeleton.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/Spinner.d.ts +1 -0
- package/dist/types/react/web/ui/components/Spinner.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/basic.d.ts +6 -0
- package/dist/types/react/web/ui/components/basic.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/buttons.d.ts +1 -1
- package/dist/types/react/web/ui/components/buttons.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/formElements.d.ts +1 -0
- package/dist/types/react/web/ui/components/formElements.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/modalElements.d.ts.map +1 -1
- package/dist/types/react/web/ui/components/text.d.ts +1 -0
- package/dist/types/react/web/ui/components/text.d.ts.map +1 -1
- package/dist/types/react/web/utils/cls.d.ts +12 -0
- package/dist/types/react/web/utils/cls.d.ts.map +1 -0
- package/dist/types/react/web/wallets/in-app/InputSelectionUI.d.ts +1 -0
- package/dist/types/react/web/wallets/in-app/InputSelectionUI.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/ConnectingScreen.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/GuestLogin.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/OTPLoginUI.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/ScanScreen.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/SocialLogin.d.ts.map +1 -1
- package/dist/types/stories/Bridge/Swap/SelectChain.stories.d.ts +10 -0
- package/dist/types/stories/Bridge/Swap/SelectChain.stories.d.ts.map +1 -0
- package/dist/types/stories/Bridge/Swap/SwapWidget.Prefill.stories.d.ts +15 -0
- package/dist/types/stories/Bridge/Swap/SwapWidget.Prefill.stories.d.ts.map +1 -0
- package/dist/types/stories/Bridge/Swap/SwapWidget.stories.d.ts +10 -0
- package/dist/types/stories/Bridge/Swap/SwapWidget.stories.d.ts.map +1 -0
- package/dist/types/stories/BuyWidget.stories.d.ts +13 -0
- package/dist/types/stories/BuyWidget.stories.d.ts.map +1 -0
- package/dist/types/stories/ConnectEmbed.stories.d.ts +12 -0
- package/dist/types/stories/ConnectEmbed.stories.d.ts.map +1 -0
- package/dist/types/version.d.ts +1 -1
- package/dist/types/version.d.ts.map +1 -1
- package/dist/types/wallets/connection/autoConnect.d.ts.map +1 -1
- package/dist/types/wallets/connection/autoConnectCore.d.ts +0 -1
- package/dist/types/wallets/connection/autoConnectCore.d.ts.map +1 -1
- package/dist/types/wallets/manager/index.d.ts.map +1 -1
- package/dist/types/wallets/smart/lib/bundler.d.ts.map +1 -1
- package/package.json +2 -1
- package/src/bridge/types/Chain.ts +2 -0
- package/src/exports/react.ts +4 -0
- package/src/pay/convert/type.ts +27 -44
- package/src/react/core/design-system/index.ts +3 -1
- package/src/react/core/hooks/usePaymentMethods.ts +4 -1
- package/src/react/core/hooks/wallets/useAutoConnect.ts +0 -2
- package/src/react/core/machines/paymentMachine.ts +1 -0
- package/src/react/web/hooks/wallets/useAutoConnect.ts +0 -11
- package/src/react/web/ui/Bridge/BridgeOrchestrator.tsx +7 -5
- package/src/react/web/ui/Bridge/BuyWidget.tsx +1 -1
- package/src/react/web/ui/Bridge/DirectPayment.tsx +2 -2
- package/src/react/web/ui/Bridge/ErrorBanner.tsx +1 -1
- package/src/react/web/ui/Bridge/FundWallet.tsx +9 -8
- package/src/react/web/ui/Bridge/QuoteLoader.tsx +6 -3
- package/src/react/web/ui/Bridge/StepRunner.tsx +5 -3
- package/src/react/web/ui/Bridge/TransactionPayment.tsx +2 -2
- package/src/react/web/ui/Bridge/UnsupportedTokenScreen.tsx +2 -2
- package/src/react/web/ui/Bridge/common/TokenAndChain.tsx +3 -2
- package/src/react/web/ui/Bridge/common/WithHeader.tsx +23 -13
- package/src/react/web/ui/Bridge/payment-details/PaymentDetails.tsx +47 -5
- package/src/react/web/ui/Bridge/payment-selection/FiatProviderSelection.tsx +89 -83
- package/src/react/web/ui/Bridge/payment-selection/PaymentSelection.tsx +16 -7
- package/src/react/web/ui/Bridge/payment-selection/WalletFiatSelection.tsx +12 -7
- package/src/react/web/ui/Bridge/payment-success/PaymentReceipt.tsx +1 -5
- package/src/react/web/ui/Bridge/payment-success/SuccessScreen.tsx +27 -16
- package/src/react/web/ui/Bridge/swap-widget/SearchInput.tsx +46 -0
- package/src/react/web/ui/Bridge/swap-widget/SelectChainButton.tsx +50 -0
- package/src/react/web/ui/Bridge/swap-widget/SwapWidget.tsx +548 -0
- package/src/react/web/ui/Bridge/swap-widget/common.tsx +35 -0
- package/src/react/web/ui/Bridge/swap-widget/hooks.ts +21 -0
- package/src/react/web/ui/Bridge/swap-widget/select-chain.tsx +171 -0
- package/src/react/web/ui/Bridge/swap-widget/select-token-ui.tsx +528 -0
- package/src/react/web/ui/Bridge/swap-widget/storage.ts +56 -0
- package/src/react/web/ui/Bridge/swap-widget/swap-ui.tsx +950 -0
- package/src/react/web/ui/Bridge/swap-widget/types.ts +157 -0
- package/src/react/web/ui/Bridge/swap-widget/use-bridge-chains.ts +14 -0
- package/src/react/web/ui/Bridge/swap-widget/use-tokens.ts +120 -0
- package/src/react/web/ui/Bridge/swap-widget/utils.ts +3 -0
- package/src/react/web/ui/ConnectWallet/ConnectButton.tsx +15 -0
- package/src/react/web/ui/ConnectWallet/Details.test.tsx +1 -1
- package/src/react/web/ui/ConnectWallet/Details.tsx +12 -1
- package/src/react/web/ui/ConnectWallet/Modal/AllWalletsUI.tsx +7 -1
- package/src/react/web/ui/ConnectWallet/Modal/ConnectEmbed.tsx +19 -1
- package/src/react/web/ui/ConnectWallet/Modal/ConnectModal.tsx +2 -0
- package/src/react/web/ui/ConnectWallet/NetworkSelector.tsx +4 -1
- package/src/react/web/ui/ConnectWallet/WalletEntryButton.tsx +2 -0
- package/src/react/web/ui/ConnectWallet/WalletSelector.tsx +20 -22
- package/src/react/web/ui/ConnectWallet/WalletTypeRowButton.tsx +2 -0
- package/src/react/web/ui/ConnectWallet/icons/ArrowUpDownIcon.tsx +23 -0
- package/src/react/web/ui/ConnectWallet/icons/WalletDotIcon.tsx +22 -0
- package/src/react/web/ui/ConnectWallet/screens/ReceiveFunds.tsx +5 -2
- package/src/react/web/ui/ConnectWallet/screens/SendFunds.test.tsx +1 -3
- package/src/react/web/ui/ConnectWallet/screens/SendFunds.tsx +19 -4
- package/src/react/web/ui/ConnectWallet/screens/SignatureScreen.tsx +13 -3
- package/src/react/web/ui/ConnectWallet/screens/TokenSelector.tsx +2 -0
- package/src/react/web/ui/TransactionButton/TransactionModal.tsx +2 -0
- package/src/react/web/ui/components/DynamicHeight.tsx +1 -1
- package/src/react/web/ui/components/Img.tsx +67 -9
- package/src/react/web/ui/components/Modal.tsx +17 -12
- package/src/react/web/ui/components/OTPInput.tsx +1 -1
- package/src/react/web/ui/components/Skeleton.tsx +2 -0
- package/src/react/web/ui/components/Spinner.tsx +3 -0
- package/src/react/web/ui/components/basic.tsx +17 -3
- package/src/react/web/ui/components/buttons.tsx +18 -1
- package/src/react/web/ui/components/formElements.tsx +2 -1
- package/src/react/web/ui/components/modalElements.tsx +1 -0
- package/src/react/web/ui/components/text.tsx +3 -1
- package/src/react/web/utils/cls.ts +13 -0
- package/src/react/web/wallets/in-app/InputSelectionUI.tsx +2 -0
- package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +9 -0
- package/src/react/web/wallets/shared/ConnectingScreen.tsx +21 -4
- package/src/react/web/wallets/shared/GuestLogin.tsx +6 -1
- package/src/react/web/wallets/shared/OTPLoginUI.tsx +35 -6
- package/src/react/web/wallets/shared/ScanScreen.tsx +22 -3
- package/src/react/web/wallets/shared/SocialLogin.tsx +6 -1
- package/src/stories/Bridge/Swap/SelectChain.stories.tsx +51 -0
- package/src/stories/Bridge/Swap/SwapWidget.Prefill.stories.tsx +116 -0
- package/src/stories/Bridge/Swap/SwapWidget.stories.tsx +71 -0
- package/src/stories/BuyWidget.stories.tsx +56 -0
- package/src/stories/ConnectEmbed.stories.tsx +128 -0
- package/src/stories/ConnectWallet/useWalletDetailsModal.stories.tsx +1 -1
- package/src/transaction/prepare-transaction.test.ts +2 -2
- package/src/version.ts +1 -1
- package/src/wallets/connection/autoConnect.test.ts +0 -3
- package/src/wallets/connection/autoConnect.ts +0 -11
- package/src/wallets/connection/autoConnectCore.ts +7 -3
- package/src/wallets/manager/index.ts +1 -2
- package/src/wallets/smart/lib/bundler.ts +4 -0
|
@@ -0,0 +1,447 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import styled from "@emotion/styled";
|
|
3
|
+
import { ChevronDownIcon, ChevronRightIcon, DiscIcon, } from "@radix-ui/react-icons";
|
|
4
|
+
import { useQuery } from "@tanstack/react-query";
|
|
5
|
+
import { useState } from "react";
|
|
6
|
+
import { Buy, Sell } from "../../../../../bridge/index.js";
|
|
7
|
+
import { defineChain } from "../../../../../chains/utils.js";
|
|
8
|
+
import { NATIVE_TOKEN_ADDRESS } from "../../../../../constants/addresses.js";
|
|
9
|
+
import { getToken } from "../../../../../pay/convert/get-token.js";
|
|
10
|
+
import { getFiatSymbol, } from "../../../../../pay/convert/type.js";
|
|
11
|
+
import { getAddress } from "../../../../../utils/address.js";
|
|
12
|
+
import { toTokens, toUnits } from "../../../../../utils/units.js";
|
|
13
|
+
import { useCustomTheme } from "../../../../core/design-system/CustomThemeProvider.js";
|
|
14
|
+
import { fontSize, iconSize, radius, spacing, } from "../../../../core/design-system/index.js";
|
|
15
|
+
import { useWalletBalance } from "../../../../core/hooks/others/useWalletBalance.js";
|
|
16
|
+
import { ConnectButton } from "../../ConnectWallet/ConnectButton.js";
|
|
17
|
+
import { ArrowUpDownIcon } from "../../ConnectWallet/icons/ArrowUpDownIcon.js";
|
|
18
|
+
import { WalletDotIcon } from "../../ConnectWallet/icons/WalletDotIcon.js";
|
|
19
|
+
import { PoweredByThirdweb } from "../../ConnectWallet/PoweredByTW.js";
|
|
20
|
+
import { formatTokenAmount } from "../../ConnectWallet/screens/formatTokenBalance.js";
|
|
21
|
+
import { Container } from "../../components/basic.js";
|
|
22
|
+
import { Button } from "../../components/buttons.js";
|
|
23
|
+
import { Input } from "../../components/formElements.js";
|
|
24
|
+
import { Img } from "../../components/Img.js";
|
|
25
|
+
import { Modal } from "../../components/Modal.js";
|
|
26
|
+
import { Skeleton } from "../../components/Skeleton.js";
|
|
27
|
+
import { Spacer } from "../../components/Spacer.js";
|
|
28
|
+
import { Text } from "../../components/text.js";
|
|
29
|
+
import { DecimalRenderer } from "./common.js";
|
|
30
|
+
import { SelectToken } from "./select-token-ui.js";
|
|
31
|
+
import { useBridgeChains } from "./use-bridge-chains.js";
|
|
32
|
+
import { cleanedChainName } from "./utils.js";
|
|
33
|
+
function useTokenPrice(options) {
|
|
34
|
+
return useQuery({
|
|
35
|
+
queryKey: ["token-price", options.token],
|
|
36
|
+
enabled: !!options.token,
|
|
37
|
+
queryFn: () => {
|
|
38
|
+
if (!options.token) {
|
|
39
|
+
throw new Error("Token is required");
|
|
40
|
+
}
|
|
41
|
+
return getToken(options.client, options.token.tokenAddress, options.token.chainId);
|
|
42
|
+
},
|
|
43
|
+
refetchOnMount: false,
|
|
44
|
+
refetchOnWindowFocus: false,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* @internal
|
|
49
|
+
*/
|
|
50
|
+
export function SwapUI(props) {
|
|
51
|
+
const [modalState, setModalState] = useState(undefined);
|
|
52
|
+
// Token Prices ----------------------------------------------------------------------------
|
|
53
|
+
const buyTokenQuery = useTokenPrice({
|
|
54
|
+
token: props.buyToken,
|
|
55
|
+
client: props.client,
|
|
56
|
+
});
|
|
57
|
+
const sellTokenQuery = useTokenPrice({
|
|
58
|
+
token: props.sellToken,
|
|
59
|
+
client: props.client,
|
|
60
|
+
});
|
|
61
|
+
const buyTokenWithPrices = buyTokenQuery.data;
|
|
62
|
+
const sellTokenWithPrices = sellTokenQuery.data;
|
|
63
|
+
// Swap Quote ----------------------------------------------------------------------------
|
|
64
|
+
const preparedResultQuery = useSwapQuote({
|
|
65
|
+
amountSelection: props.amountSelection,
|
|
66
|
+
buyTokenWithPrices: buyTokenWithPrices,
|
|
67
|
+
sellTokenWithPrices: sellTokenWithPrices,
|
|
68
|
+
activeWalletInfo: props.activeWalletInfo,
|
|
69
|
+
client: props.client,
|
|
70
|
+
});
|
|
71
|
+
// Amount and Amount.fetching ------------------------------------------------------------
|
|
72
|
+
const sellTokenAmount = props.amountSelection.type === "sell"
|
|
73
|
+
? props.amountSelection.amount
|
|
74
|
+
: preparedResultQuery.data &&
|
|
75
|
+
props.amountSelection.type === "buy" &&
|
|
76
|
+
sellTokenWithPrices
|
|
77
|
+
? toTokens(preparedResultQuery.data.result.originAmount, sellTokenWithPrices.decimals)
|
|
78
|
+
: "";
|
|
79
|
+
const buyTokenAmount = props.amountSelection.type === "buy"
|
|
80
|
+
? props.amountSelection.amount
|
|
81
|
+
: preparedResultQuery.data &&
|
|
82
|
+
props.amountSelection.type === "sell" &&
|
|
83
|
+
buyTokenWithPrices
|
|
84
|
+
? toTokens(preparedResultQuery.data.result.destinationAmount, buyTokenWithPrices.decimals)
|
|
85
|
+
: "";
|
|
86
|
+
// when buy amount is set, the sell amount is fetched
|
|
87
|
+
const isBuyAmountFetching = props.amountSelection.type === "sell" && preparedResultQuery.isFetching;
|
|
88
|
+
const isSellAmountFetching = props.amountSelection.type === "buy" && preparedResultQuery.isFetching;
|
|
89
|
+
// token balances ------------------------------------------------------------
|
|
90
|
+
const sellTokenBalanceQuery = useTokenBalance({
|
|
91
|
+
chainId: sellTokenWithPrices?.chainId,
|
|
92
|
+
tokenAddress: sellTokenWithPrices?.address,
|
|
93
|
+
client: props.client,
|
|
94
|
+
walletAddress: props.activeWalletInfo?.activeAccount.address,
|
|
95
|
+
});
|
|
96
|
+
const buyTokenBalanceQuery = useTokenBalance({
|
|
97
|
+
chainId: buyTokenWithPrices?.chainId,
|
|
98
|
+
tokenAddress: buyTokenWithPrices?.address,
|
|
99
|
+
client: props.client,
|
|
100
|
+
walletAddress: props.activeWalletInfo?.activeAccount.address,
|
|
101
|
+
});
|
|
102
|
+
const notEnoughBalance = !!(sellTokenBalanceQuery.data &&
|
|
103
|
+
sellTokenWithPrices &&
|
|
104
|
+
props.amountSelection.amount &&
|
|
105
|
+
!!sellTokenAmount &&
|
|
106
|
+
sellTokenBalanceQuery.data.value <
|
|
107
|
+
Number(toUnits(sellTokenAmount, sellTokenWithPrices.decimals)));
|
|
108
|
+
// ----------------------------------------------------------------------------
|
|
109
|
+
return (_jsxs(Container, { p: "md", children: [_jsxs(Modal, { className: "tw-modal__swap-widget", size: "compact", title: "Select Token", open: !!modalState, crossContainerStyles: {
|
|
110
|
+
right: spacing.md,
|
|
111
|
+
top: spacing["md+"],
|
|
112
|
+
transform: "none",
|
|
113
|
+
}, setOpen: (v) => {
|
|
114
|
+
if (!v) {
|
|
115
|
+
setModalState(undefined);
|
|
116
|
+
}
|
|
117
|
+
}, children: [modalState === "select-buy-token" && (_jsx(SelectToken, { activeWalletInfo: props.activeWalletInfo, onBack: () => setModalState(undefined), client: props.client, selectedToken: props.buyToken, setSelectedToken: (token) => {
|
|
118
|
+
props.setBuyToken(token);
|
|
119
|
+
setModalState(undefined);
|
|
120
|
+
// if buy token is same as sell token, unset sell token
|
|
121
|
+
if (props.sellToken &&
|
|
122
|
+
token.tokenAddress.toLowerCase() ===
|
|
123
|
+
props.sellToken.tokenAddress.toLowerCase() &&
|
|
124
|
+
token.chainId === props.sellToken.chainId) {
|
|
125
|
+
props.setSellToken(undefined);
|
|
126
|
+
}
|
|
127
|
+
} })), modalState === "select-sell-token" && (_jsx(SelectToken, { onBack: () => setModalState(undefined), client: props.client, selectedToken: props.sellToken, setSelectedToken: (token) => {
|
|
128
|
+
props.setSellToken(token);
|
|
129
|
+
setModalState(undefined);
|
|
130
|
+
// if sell token is same as buy token, unset buy token
|
|
131
|
+
if (props.buyToken &&
|
|
132
|
+
token.tokenAddress.toLowerCase() ===
|
|
133
|
+
props.buyToken.tokenAddress.toLowerCase() &&
|
|
134
|
+
token.chainId === props.buyToken.chainId) {
|
|
135
|
+
props.setBuyToken(undefined);
|
|
136
|
+
}
|
|
137
|
+
}, activeWalletInfo: props.activeWalletInfo }))] }), _jsx(TokenSection, { isConnected: !!props.activeWalletInfo, notEnoughBalance: notEnoughBalance, balance: {
|
|
138
|
+
data: sellTokenBalanceQuery.data?.value,
|
|
139
|
+
isFetching: sellTokenBalanceQuery.isFetching,
|
|
140
|
+
}, amount: {
|
|
141
|
+
data: sellTokenAmount,
|
|
142
|
+
isFetching: isSellAmountFetching,
|
|
143
|
+
}, label: "Sell", setAmount: (value) => {
|
|
144
|
+
props.setAmountSelection({ type: "sell", amount: value });
|
|
145
|
+
}, selectedToken: props.sellToken
|
|
146
|
+
? {
|
|
147
|
+
data: sellTokenQuery.data,
|
|
148
|
+
isFetching: sellTokenQuery.isFetching,
|
|
149
|
+
}
|
|
150
|
+
: undefined, client: props.client, currency: props.currency, onSelectToken: () => setModalState("select-sell-token") }), _jsx(SwitchButton, { onClick: () => {
|
|
151
|
+
// switch tokens
|
|
152
|
+
const temp = props.sellToken;
|
|
153
|
+
props.setSellToken(props.buyToken);
|
|
154
|
+
props.setBuyToken(temp);
|
|
155
|
+
props.setAmountSelection({
|
|
156
|
+
type: props.amountSelection.type === "buy" ? "sell" : "buy",
|
|
157
|
+
amount: props.amountSelection.amount,
|
|
158
|
+
});
|
|
159
|
+
} }), _jsx(TokenSection, { isConnected: !!props.activeWalletInfo, notEnoughBalance: false, balance: {
|
|
160
|
+
data: buyTokenBalanceQuery.data?.value,
|
|
161
|
+
isFetching: buyTokenBalanceQuery.isFetching,
|
|
162
|
+
}, amount: {
|
|
163
|
+
data: buyTokenAmount,
|
|
164
|
+
isFetching: isBuyAmountFetching,
|
|
165
|
+
}, label: "Buy", selectedToken: props.buyToken
|
|
166
|
+
? {
|
|
167
|
+
data: buyTokenQuery.data,
|
|
168
|
+
isFetching: buyTokenQuery.isFetching,
|
|
169
|
+
}
|
|
170
|
+
: undefined, setAmount: (value) => {
|
|
171
|
+
props.setAmountSelection({ type: "buy", amount: value });
|
|
172
|
+
}, client: props.client, currency: props.currency, onSelectToken: () => setModalState("select-buy-token") }), preparedResultQuery.error ? (_jsx(Text, { size: "sm", color: "danger", center: true, style: {
|
|
173
|
+
paddingBlock: spacing.md,
|
|
174
|
+
}, children: "Failed to get a quote" })) : (_jsx(Spacer, { y: "lg" })), !props.activeWalletInfo ? (_jsx(ConnectButton, { client: props.client, connectButton: {
|
|
175
|
+
label: "Swap",
|
|
176
|
+
style: {
|
|
177
|
+
width: "100%",
|
|
178
|
+
borderRadius: radius.lg,
|
|
179
|
+
},
|
|
180
|
+
}, theme: props.theme, ...props.connectOptions })) : (_jsx(Button, { disabled: !preparedResultQuery.data ||
|
|
181
|
+
preparedResultQuery.isFetching ||
|
|
182
|
+
notEnoughBalance, fullWidth: true, onClick: () => {
|
|
183
|
+
if (preparedResultQuery.data &&
|
|
184
|
+
buyTokenWithPrices &&
|
|
185
|
+
sellTokenWithPrices &&
|
|
186
|
+
sellTokenBalanceQuery.data &&
|
|
187
|
+
preparedResultQuery.data.type === "preparedResult") {
|
|
188
|
+
props.onSwap({
|
|
189
|
+
result: preparedResultQuery.data.result,
|
|
190
|
+
request: preparedResultQuery.data.request,
|
|
191
|
+
buyToken: buyTokenWithPrices,
|
|
192
|
+
sellToken: sellTokenWithPrices,
|
|
193
|
+
sellTokenBalance: sellTokenBalanceQuery.data.value,
|
|
194
|
+
mode: props.amountSelection.type,
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
}, style: {
|
|
198
|
+
fontSize: fontSize.md,
|
|
199
|
+
padding: `${spacing.sm} ${spacing.md}`,
|
|
200
|
+
borderRadius: radius.lg,
|
|
201
|
+
}, variant: "primary", children: "Swap" })), props.showThirdwebBranding ? (_jsxs("div", { children: [_jsx(Spacer, { y: "md" }), _jsx(PoweredByThirdweb, { link: "https://thirdweb.com/monetize/bridge" })] })) : null] }));
|
|
202
|
+
}
|
|
203
|
+
function useSwapQuote(params) {
|
|
204
|
+
const { amountSelection, buyTokenWithPrices, sellTokenWithPrices, activeWalletInfo, client, } = params;
|
|
205
|
+
return useQuery({
|
|
206
|
+
queryKey: [
|
|
207
|
+
"swap-quote",
|
|
208
|
+
amountSelection,
|
|
209
|
+
buyTokenWithPrices,
|
|
210
|
+
sellTokenWithPrices,
|
|
211
|
+
activeWalletInfo?.activeAccount.address,
|
|
212
|
+
],
|
|
213
|
+
retry: false,
|
|
214
|
+
enabled: !!buyTokenWithPrices && !!sellTokenWithPrices && !!amountSelection.amount,
|
|
215
|
+
queryFn: async () => {
|
|
216
|
+
if (!buyTokenWithPrices ||
|
|
217
|
+
!sellTokenWithPrices ||
|
|
218
|
+
!amountSelection.amount) {
|
|
219
|
+
throw new Error("Invalid state");
|
|
220
|
+
}
|
|
221
|
+
if (!activeWalletInfo) {
|
|
222
|
+
if (amountSelection.type === "buy") {
|
|
223
|
+
const res = await Buy.quote({
|
|
224
|
+
amount: toUnits(amountSelection.amount, buyTokenWithPrices.decimals),
|
|
225
|
+
// origin = sell
|
|
226
|
+
originChainId: sellTokenWithPrices.chainId,
|
|
227
|
+
originTokenAddress: sellTokenWithPrices.address,
|
|
228
|
+
// destination = buy
|
|
229
|
+
destinationChainId: buyTokenWithPrices.chainId,
|
|
230
|
+
destinationTokenAddress: buyTokenWithPrices.address,
|
|
231
|
+
client: client,
|
|
232
|
+
});
|
|
233
|
+
return {
|
|
234
|
+
type: "quote",
|
|
235
|
+
result: res,
|
|
236
|
+
};
|
|
237
|
+
}
|
|
238
|
+
const res = await Sell.quote({
|
|
239
|
+
amount: toUnits(amountSelection.amount, sellTokenWithPrices.decimals),
|
|
240
|
+
// origin = sell
|
|
241
|
+
originChainId: sellTokenWithPrices.chainId,
|
|
242
|
+
originTokenAddress: sellTokenWithPrices.address,
|
|
243
|
+
// destination = buy
|
|
244
|
+
destinationChainId: buyTokenWithPrices.chainId,
|
|
245
|
+
destinationTokenAddress: buyTokenWithPrices.address,
|
|
246
|
+
client: client,
|
|
247
|
+
});
|
|
248
|
+
return {
|
|
249
|
+
type: "quote",
|
|
250
|
+
result: res,
|
|
251
|
+
};
|
|
252
|
+
}
|
|
253
|
+
if (amountSelection.type === "buy") {
|
|
254
|
+
const buyRequestOptions = {
|
|
255
|
+
amount: toUnits(amountSelection.amount, buyTokenWithPrices.decimals),
|
|
256
|
+
// origin = sell
|
|
257
|
+
originChainId: sellTokenWithPrices.chainId,
|
|
258
|
+
originTokenAddress: sellTokenWithPrices.address,
|
|
259
|
+
// destination = buy
|
|
260
|
+
destinationChainId: buyTokenWithPrices.chainId,
|
|
261
|
+
destinationTokenAddress: buyTokenWithPrices.address,
|
|
262
|
+
client: client,
|
|
263
|
+
receiver: activeWalletInfo.activeAccount.address,
|
|
264
|
+
sender: activeWalletInfo.activeAccount.address,
|
|
265
|
+
};
|
|
266
|
+
const buyRequest = {
|
|
267
|
+
type: "buy",
|
|
268
|
+
...buyRequestOptions,
|
|
269
|
+
};
|
|
270
|
+
const res = await Buy.prepare(buyRequest);
|
|
271
|
+
return {
|
|
272
|
+
type: "preparedResult",
|
|
273
|
+
result: { type: "buy", ...res },
|
|
274
|
+
request: buyRequest,
|
|
275
|
+
};
|
|
276
|
+
}
|
|
277
|
+
else if (amountSelection.type === "sell") {
|
|
278
|
+
const sellRequestOptions = {
|
|
279
|
+
amount: toUnits(amountSelection.amount, sellTokenWithPrices.decimals),
|
|
280
|
+
// origin = sell
|
|
281
|
+
originChainId: sellTokenWithPrices.chainId,
|
|
282
|
+
originTokenAddress: sellTokenWithPrices.address,
|
|
283
|
+
// destination = buy
|
|
284
|
+
destinationChainId: buyTokenWithPrices.chainId,
|
|
285
|
+
destinationTokenAddress: buyTokenWithPrices.address,
|
|
286
|
+
client: client,
|
|
287
|
+
receiver: activeWalletInfo.activeAccount.address,
|
|
288
|
+
sender: activeWalletInfo.activeAccount.address,
|
|
289
|
+
};
|
|
290
|
+
const res = await Sell.prepare(sellRequestOptions);
|
|
291
|
+
const sellRequest = {
|
|
292
|
+
type: "sell",
|
|
293
|
+
...sellRequestOptions,
|
|
294
|
+
};
|
|
295
|
+
return {
|
|
296
|
+
type: "preparedResult",
|
|
297
|
+
result: { type: "sell", ...res },
|
|
298
|
+
request: sellRequest,
|
|
299
|
+
};
|
|
300
|
+
}
|
|
301
|
+
throw new Error("Invalid amount selection type");
|
|
302
|
+
},
|
|
303
|
+
refetchInterval: 20000,
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
function DecimalInput(props) {
|
|
307
|
+
const handleAmountChange = (inputValue) => {
|
|
308
|
+
let processedValue = inputValue;
|
|
309
|
+
// Replace comma with period if it exists
|
|
310
|
+
processedValue = processedValue.replace(",", ".");
|
|
311
|
+
if (processedValue.startsWith(".")) {
|
|
312
|
+
processedValue = `0${processedValue}`;
|
|
313
|
+
}
|
|
314
|
+
const numValue = Number(processedValue);
|
|
315
|
+
if (Number.isNaN(numValue)) {
|
|
316
|
+
return;
|
|
317
|
+
}
|
|
318
|
+
if (processedValue.startsWith("0") && !processedValue.startsWith("0.")) {
|
|
319
|
+
props.setValue(processedValue.slice(1));
|
|
320
|
+
}
|
|
321
|
+
else {
|
|
322
|
+
props.setValue(processedValue);
|
|
323
|
+
}
|
|
324
|
+
};
|
|
325
|
+
return (_jsx(Input, { inputMode: "decimal", onChange: (e) => {
|
|
326
|
+
handleAmountChange(e.target.value);
|
|
327
|
+
}, onClick: (e) => {
|
|
328
|
+
// put cursor at the end of the input
|
|
329
|
+
if (props.value === "") {
|
|
330
|
+
e.currentTarget.setSelectionRange(e.currentTarget.value.length, e.currentTarget.value.length);
|
|
331
|
+
}
|
|
332
|
+
}, pattern: "^[0-9]*[.,]?[0-9]*$", placeholder: "0.0", style: {
|
|
333
|
+
border: "none",
|
|
334
|
+
boxShadow: "none",
|
|
335
|
+
fontSize: fontSize.xxl,
|
|
336
|
+
fontWeight: 500,
|
|
337
|
+
paddingInline: 0,
|
|
338
|
+
paddingBlock: 0,
|
|
339
|
+
}, type: "text", value: props.value, variant: "transparent" }));
|
|
340
|
+
}
|
|
341
|
+
function TokenSection(props) {
|
|
342
|
+
const chainQuery = useBridgeChains(props.client);
|
|
343
|
+
const chain = chainQuery.data?.find((chain) => chain.chainId === props.selectedToken?.data?.chainId);
|
|
344
|
+
const fiatPricePerToken = props.selectedToken?.data?.prices[props.currency];
|
|
345
|
+
const totalFiatValue = !props.amount.data
|
|
346
|
+
? undefined
|
|
347
|
+
: fiatPricePerToken
|
|
348
|
+
? fiatPricePerToken * Number(props.amount.data)
|
|
349
|
+
: undefined;
|
|
350
|
+
return (_jsxs(Container, { p: "sm", borderColor: "borderColor", bg: "tertiaryBg", style: { borderRadius: radius.lg, borderWidth: 1, borderStyle: "solid" }, children: [_jsx(Text, { size: "md", color: "primaryText", weight: 500, children: props.label }), _jsxs("div", { style: {
|
|
351
|
+
display: "flex",
|
|
352
|
+
alignItems: "center",
|
|
353
|
+
justifyContent: "space-between",
|
|
354
|
+
gap: spacing.sm,
|
|
355
|
+
paddingBottom: spacing.sm,
|
|
356
|
+
paddingTop: spacing.sm,
|
|
357
|
+
}, children: [props.amount.isFetching ? (_jsx(Skeleton, { height: fontSize.xxl, width: "140px", style: {
|
|
358
|
+
borderRadius: radius.lg,
|
|
359
|
+
} })) : (_jsx(DecimalInput, { value: props.amount.data, setValue: props.setAmount })), !props.selectedToken ? (_jsxs(Button, { variant: "accent", style: {
|
|
360
|
+
borderRadius: radius.full,
|
|
361
|
+
gap: spacing.xxs,
|
|
362
|
+
paddingBlock: spacing.sm,
|
|
363
|
+
paddingInline: spacing.sm,
|
|
364
|
+
}, onClick: props.onSelectToken, children: [" ", "Select Token", _jsx(ChevronDownIcon, { width: iconSize.sm, height: iconSize.sm })] })) : (_jsx(SelectedTokenButton, { selectedToken: props.selectedToken, client: props.client, onSelectToken: props.onSelectToken, chain: chain }))] }), _jsxs("div", { style: {
|
|
365
|
+
display: "flex",
|
|
366
|
+
alignItems: "center",
|
|
367
|
+
gap: "4px",
|
|
368
|
+
justifyContent: "space-between",
|
|
369
|
+
}, children: [props.notEnoughBalance ? (_jsxs(Text, { size: "md", color: "danger", weight: 500, children: [" ", "Exceeds Balance", " "] })) : (_jsxs("div", { style: {
|
|
370
|
+
display: "flex",
|
|
371
|
+
alignItems: "center",
|
|
372
|
+
gap: "4px",
|
|
373
|
+
}, children: [_jsx(Text, { size: "md", color: "secondaryText", weight: 500, children: getFiatSymbol(props.currency) }), props.amount.isFetching ? (_jsx(Skeleton, { height: fontSize.md, width: "50px" })) : (_jsx("div", { children: _jsx(DecimalRenderer, { integerSize: "md", fractionSize: "sm", value: totalFiatValue?.toFixed(5) || "0.00", color: "secondaryText", weight: 500 }) }))] })), props.isConnected && props.selectedToken && (_jsx("div", { children: props.balance.data === undefined ||
|
|
374
|
+
props.selectedToken.data === undefined ? (_jsx(Skeleton, { height: fontSize.md, width: "50px" })) : (_jsxs(Text, { size: "md", color: "secondaryText", weight: 500, style: {
|
|
375
|
+
display: "flex",
|
|
376
|
+
alignItems: "center",
|
|
377
|
+
gap: spacing.xxs,
|
|
378
|
+
}, children: [_jsx(WalletDotIcon, { size: fontSize.xs }), _jsx(DecimalRenderer, { integerSize: "md", fractionSize: "sm", color: "secondaryText", weight: 500, value: formatTokenAmount(props.balance.data, props.selectedToken.data.decimals, 5) })] })) }))] })] }));
|
|
379
|
+
}
|
|
380
|
+
function SelectedTokenButton(props) {
|
|
381
|
+
return (_jsxs(Button, { variant: "outline", bg: "secondaryButtonBg", onClick: props.onSelectToken, gap: "xs", style: {
|
|
382
|
+
borderRadius: radius.full,
|
|
383
|
+
paddingBlock: spacing.xxs,
|
|
384
|
+
paddingInline: spacing.xs,
|
|
385
|
+
}, children: [_jsxs(Container, { relative: true, color: "secondaryText", children: [_jsx(Img, { src: props.selectedToken?.data === undefined
|
|
386
|
+
? undefined
|
|
387
|
+
: props.selectedToken.data.iconUri || "", client: props.client, width: iconSize.lg, height: iconSize.lg, skeletonColor: "modalBg", fallback: _jsx(DiscIcon, { width: iconSize.lg, height: iconSize.lg }), style: {
|
|
388
|
+
borderRadius: radius.full,
|
|
389
|
+
} }, props.selectedToken?.data?.iconUri), _jsx(Container, { bg: "modalBg", style: {
|
|
390
|
+
padding: "2px",
|
|
391
|
+
position: "absolute",
|
|
392
|
+
bottom: -2,
|
|
393
|
+
right: -2,
|
|
394
|
+
display: "flex",
|
|
395
|
+
borderRadius: radius.full,
|
|
396
|
+
}, children: _jsx(Img, { src: props.chain?.icon, client: props.client, width: iconSize.sm, height: iconSize.sm, style: {
|
|
397
|
+
borderRadius: radius.full,
|
|
398
|
+
} }) })] }), _jsxs(Container, { flex: "column", style: { gap: "2px" }, children: [props.selectedToken?.isFetching ? (_jsx(Skeleton, { width: "40px", height: fontSize.sm, color: "modalBg" })) : (_jsx(Text, { size: "sm", color: "primaryText", weight: 500, children: props.selectedToken?.data?.symbol })), props.chain ? (_jsx(Text, { size: "xs", color: "secondaryText", weight: 500, style: {
|
|
399
|
+
maxWidth: "100px",
|
|
400
|
+
overflow: "hidden",
|
|
401
|
+
textOverflow: "ellipsis",
|
|
402
|
+
whiteSpace: "nowrap",
|
|
403
|
+
}, children: cleanedChainName(props.chain.name) })) : (_jsx(Skeleton, { width: "70px", height: fontSize.xs, color: "modalBg" }))] }), _jsx(Container, { color: "secondaryText", children: _jsx(ChevronRightIcon, { width: iconSize.xs, height: iconSize.xs }) })] }));
|
|
404
|
+
}
|
|
405
|
+
function SwitchButton(props) {
|
|
406
|
+
return (_jsx("div", { style: {
|
|
407
|
+
display: "flex",
|
|
408
|
+
justifyContent: "center",
|
|
409
|
+
marginBlock: `-14px`,
|
|
410
|
+
}, children: _jsx(SwitchButtonInner, { variant: "outline", onClick: (e) => {
|
|
411
|
+
props.onClick();
|
|
412
|
+
const node = e.currentTarget.querySelector("svg");
|
|
413
|
+
if (node) {
|
|
414
|
+
node.style.transform = "rotate(180deg)";
|
|
415
|
+
node.style.transition = "transform 300ms ease";
|
|
416
|
+
setTimeout(() => {
|
|
417
|
+
node.style.transition = "";
|
|
418
|
+
node.style.transform = "rotate(0deg)";
|
|
419
|
+
}, 300);
|
|
420
|
+
}
|
|
421
|
+
}, children: _jsx(ArrowUpDownIcon, { size: iconSize.md }) }) }));
|
|
422
|
+
}
|
|
423
|
+
const SwitchButtonInner = /* @__PURE__ */ styled(Button)(() => {
|
|
424
|
+
const theme = useCustomTheme();
|
|
425
|
+
return {
|
|
426
|
+
"&:hover": {
|
|
427
|
+
background: theme.colors.modalBg,
|
|
428
|
+
},
|
|
429
|
+
borderRadius: radius.lg,
|
|
430
|
+
padding: spacing.xs,
|
|
431
|
+
background: theme.colors.modalBg,
|
|
432
|
+
border: `1px solid ${theme.colors.borderColor}`,
|
|
433
|
+
};
|
|
434
|
+
});
|
|
435
|
+
function useTokenBalance(props) {
|
|
436
|
+
return useWalletBalance({
|
|
437
|
+
address: props.walletAddress,
|
|
438
|
+
chain: props.chainId ? defineChain(props.chainId) : undefined,
|
|
439
|
+
client: props.client,
|
|
440
|
+
tokenAddress: props.tokenAddress
|
|
441
|
+
? getAddress(props.tokenAddress) === getAddress(NATIVE_TOKEN_ADDRESS)
|
|
442
|
+
? undefined
|
|
443
|
+
: getAddress(props.tokenAddress)
|
|
444
|
+
: undefined,
|
|
445
|
+
});
|
|
446
|
+
}
|
|
447
|
+
//# sourceMappingURL=swap-ui.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"swap-ui.js","sourceRoot":"","sources":["../../../../../../../src/react/web/ui/Bridge/swap-widget/swap-ui.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../../src/react/web/ui/Bridge/swap-widget/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useQuery } from "@tanstack/react-query";
|
|
2
|
+
import { chains } from "../../../../../bridge/index.js";
|
|
3
|
+
export function useBridgeChains(client) {
|
|
4
|
+
return useQuery({
|
|
5
|
+
queryKey: ["bridge-chains"],
|
|
6
|
+
queryFn: () => {
|
|
7
|
+
return chains({ client });
|
|
8
|
+
},
|
|
9
|
+
refetchOnMount: false,
|
|
10
|
+
refetchOnWindowFocus: false,
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=use-bridge-chains.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-bridge-chains.js","sourceRoot":"","sources":["../../../../../../../src/react/web/ui/Bridge/swap-widget/use-bridge-chains.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAGxD,MAAM,UAAU,eAAe,CAAC,MAAsB;IACpD,OAAO,QAAQ,CAAC;QACd,QAAQ,EAAE,CAAC,eAAe,CAAC;QAC3B,OAAO,EAAE,GAAG,EAAE;YACZ,OAAO,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAC5B,CAAC;QACD,cAAc,EAAE,KAAK;QACrB,oBAAoB,EAAE,KAAK;KAC5B,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { useQuery } from "@tanstack/react-query";
|
|
2
|
+
import { tokens } from "../../../../../bridge/Token.js";
|
|
3
|
+
import { isAddress } from "../../../../../utils/address.js";
|
|
4
|
+
import { getThirdwebBaseUrl } from "../../../../../utils/domains.js";
|
|
5
|
+
export function useTokens(options) {
|
|
6
|
+
return useQuery({
|
|
7
|
+
queryKey: ["tokens", options],
|
|
8
|
+
enabled: !!options.chainId,
|
|
9
|
+
queryFn: () => {
|
|
10
|
+
if (!options.chainId) {
|
|
11
|
+
throw new Error("Chain ID is required");
|
|
12
|
+
}
|
|
13
|
+
const isSearchAddress = options.search
|
|
14
|
+
? isAddress(options.search)
|
|
15
|
+
: false;
|
|
16
|
+
return tokens({
|
|
17
|
+
chainId: options.chainId,
|
|
18
|
+
client: options.client,
|
|
19
|
+
offset: options.offset,
|
|
20
|
+
limit: options.limit,
|
|
21
|
+
includePrices: false,
|
|
22
|
+
name: !options.search || isSearchAddress ? undefined : options.search,
|
|
23
|
+
tokenAddress: isSearchAddress ? options.search : undefined,
|
|
24
|
+
});
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
export function useTokenBalances(options) {
|
|
29
|
+
return useQuery({
|
|
30
|
+
queryKey: ["bridge/v1/wallets", options],
|
|
31
|
+
enabled: !!options.chainId && !!options.walletAddress,
|
|
32
|
+
queryFn: async () => {
|
|
33
|
+
if (!options.chainId || !options.walletAddress) {
|
|
34
|
+
throw new Error("invalid options");
|
|
35
|
+
}
|
|
36
|
+
const baseUrl = getThirdwebBaseUrl("bridge");
|
|
37
|
+
const isDev = baseUrl.includes("thirdweb-dev");
|
|
38
|
+
const url = new URL(`https://api.${isDev ? "thirdweb-dev" : "thirdweb"}.com/v1/wallets/${options.walletAddress}/tokens`);
|
|
39
|
+
url.searchParams.set("chainId", options.chainId.toString());
|
|
40
|
+
url.searchParams.set("limit", options.limit.toString());
|
|
41
|
+
url.searchParams.set("page", options.page.toString());
|
|
42
|
+
url.searchParams.set("metadata", "true");
|
|
43
|
+
url.searchParams.set("resolveMetadataLinks", "true");
|
|
44
|
+
url.searchParams.set("includeSpam", "false");
|
|
45
|
+
url.searchParams.set("includeNative", "true");
|
|
46
|
+
url.searchParams.set("sortBy", "usd_value");
|
|
47
|
+
url.searchParams.set("sortOrder", "desc");
|
|
48
|
+
url.searchParams.set("includeWithoutPrice", "false"); // filter out tokens with no price
|
|
49
|
+
const response = await fetch(url.toString(), {
|
|
50
|
+
headers: {
|
|
51
|
+
"x-client-id": options.clientId,
|
|
52
|
+
},
|
|
53
|
+
});
|
|
54
|
+
if (!response.ok) {
|
|
55
|
+
throw new Error(`Failed to fetch token balances: ${response.statusText}`);
|
|
56
|
+
}
|
|
57
|
+
const json = (await response.json());
|
|
58
|
+
return json.result;
|
|
59
|
+
},
|
|
60
|
+
refetchOnMount: false,
|
|
61
|
+
refetchOnWindowFocus: false,
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=use-tokens.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-tokens.js","sourceRoot":"","sources":["../../../../../../../src/react/web/ui/Bridge/swap-widget/use-tokens.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../src/react/web/ui/Bridge/swap-widget/utils.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,gBAAgB,CAAC,IAAY;IAC3C,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;AACrC,CAAC"}
|
|
@@ -154,6 +154,19 @@ const TW_CONNECT_WALLET = "tw-connect-wallet";
|
|
|
154
154
|
*
|
|
155
155
|
* [View all available themes properties](https://portal.thirdweb.com/references/typescript/v5/Theme)
|
|
156
156
|
*
|
|
157
|
+
* ### Overriding styles using class names
|
|
158
|
+
*
|
|
159
|
+
* Some elements in this component have classes with a `tw-` prefix.
|
|
160
|
+
* You can target these classes in your own CSS stylesheet to override their styles.
|
|
161
|
+
*
|
|
162
|
+
* In some cases, you may need to use the `!important` flag for the override to take effect. Do not use on auto-generated class names, as they may change between builds.
|
|
163
|
+
*
|
|
164
|
+
* ```css
|
|
165
|
+
* .tw-back-button {
|
|
166
|
+
* background-color: red !important;
|
|
167
|
+
* }
|
|
168
|
+
* ```
|
|
169
|
+
*
|
|
157
170
|
* ### Changing the display language
|
|
158
171
|
*
|
|
159
172
|
* ```tsx
|
|
@@ -402,7 +415,7 @@ function ConnectButtonInner(props) {
|
|
|
402
415
|
minHeight: "50px",
|
|
403
416
|
minWidth: "165px",
|
|
404
417
|
...props.signInButton?.style,
|
|
405
|
-
}, type: "button", variant: "primary", children: siweAuth.isLoggingIn ? (_jsx(Spinner, { color: "primaryButtonText", size: "sm" })) : (_jsxs(Container, { center: "y", flex: "row", gap: "sm", children: [_jsx(LockIcon, { size: iconSize.sm }), _jsxs("span", { children: [" ", props.signInButton?.label || locale.signIn, " "] })] })) }), _jsx(Modal, { open: showSignatureModal, setOpen: setShowSignatureModal, size: "compact", children: _jsx(SignatureScreen, { auth: props.auth, client: props.client, connectLocale: locale, modalSize: "compact", onDone: () => setShowSignatureModal(false), privacyPolicyUrl: props.connectModal?.privacyPolicyUrl, termsOfServiceUrl: props.connectModal?.termsOfServiceUrl }) })] }));
|
|
418
|
+
}, type: "button", variant: "primary", children: siweAuth.isLoggingIn ? (_jsx(Spinner, { color: "primaryButtonText", size: "sm" })) : (_jsxs(Container, { center: "y", flex: "row", gap: "sm", children: [_jsx(LockIcon, { size: iconSize.sm }), _jsxs("span", { children: [" ", props.signInButton?.label || locale.signIn, " "] })] })) }), _jsx(Modal, { className: "tw-modal__sign-in", title: "Sign in", open: showSignatureModal, setOpen: setShowSignatureModal, size: "compact", children: _jsx(SignatureScreen, { auth: props.auth, client: props.client, connectLocale: locale, modalSize: "compact", onDone: () => setShowSignatureModal(false), privacyPolicyUrl: props.connectModal?.privacyPolicyUrl, termsOfServiceUrl: props.connectModal?.termsOfServiceUrl }) })] }));
|
|
406
419
|
}
|
|
407
420
|
// otherwise, show the details button
|
|
408
421
|
}
|