@wheelx/widget 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +531 -0
- package/dist/WheelxBridgeSwapWidget.d.ts +6 -0
- package/dist/WheelxBridgeSwapWidget.d.ts.map +1 -0
- package/dist/WheelxBridgeSwapWidget.js +13 -0
- package/dist/WheelxBridgeSwapWidget.js.map +1 -0
- package/dist/WheelxWidgetProvider.d.ts +3 -0
- package/dist/WheelxWidgetProvider.d.ts.map +1 -0
- package/dist/WheelxWidgetProvider.js +9 -0
- package/dist/WheelxWidgetProvider.js.map +1 -0
- package/dist/config.d.ts +120 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +120 -0
- package/dist/config.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/internal/SelectTokenModal/AllChainsIcon.d.ts +2 -0
- package/dist/internal/SelectTokenModal/AllChainsIcon.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/AllChainsIcon.js +11 -0
- package/dist/internal/SelectTokenModal/AllChainsIcon.js.map +1 -0
- package/dist/internal/SelectTokenModal/DesktopContent.d.ts +33 -0
- package/dist/internal/SelectTokenModal/DesktopContent.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/DesktopContent.js +99 -0
- package/dist/internal/SelectTokenModal/DesktopContent.js.map +1 -0
- package/dist/internal/SelectTokenModal/FavoriteButton.d.ts +7 -0
- package/dist/internal/SelectTokenModal/FavoriteButton.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/FavoriteButton.js +25 -0
- package/dist/internal/SelectTokenModal/FavoriteButton.js.map +1 -0
- package/dist/internal/SelectTokenModal/FavoritesContext.d.ts +22 -0
- package/dist/internal/SelectTokenModal/FavoritesContext.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/FavoritesContext.js +125 -0
- package/dist/internal/SelectTokenModal/FavoritesContext.js.map +1 -0
- package/dist/internal/SelectTokenModal/MobileContent.d.ts +35 -0
- package/dist/internal/SelectTokenModal/MobileContent.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/MobileContent.js +150 -0
- package/dist/internal/SelectTokenModal/MobileContent.js.map +1 -0
- package/dist/internal/SelectTokenModal/Network.d.ts +13 -0
- package/dist/internal/SelectTokenModal/Network.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/Network.js +112 -0
- package/dist/internal/SelectTokenModal/Network.js.map +1 -0
- package/dist/internal/SelectTokenModal/SearchHistoryContext.d.ts +30 -0
- package/dist/internal/SelectTokenModal/SearchHistoryContext.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/SearchHistoryContext.js +144 -0
- package/dist/internal/SelectTokenModal/SearchHistoryContext.js.map +1 -0
- package/dist/internal/SelectTokenModal/SearchInput.d.ts +8 -0
- package/dist/internal/SelectTokenModal/SearchInput.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/SearchInput.js +34 -0
- package/dist/internal/SelectTokenModal/SearchInput.js.map +1 -0
- package/dist/internal/SelectTokenModal/TokenAndAddress.d.ts +11 -0
- package/dist/internal/SelectTokenModal/TokenAndAddress.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/TokenAndAddress.js +138 -0
- package/dist/internal/SelectTokenModal/TokenAndAddress.js.map +1 -0
- package/dist/internal/SelectTokenModal/TokenFavoriteButton.d.ts +7 -0
- package/dist/internal/SelectTokenModal/TokenFavoriteButton.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/TokenFavoriteButton.js +27 -0
- package/dist/internal/SelectTokenModal/TokenFavoriteButton.js.map +1 -0
- package/dist/internal/SelectTokenModal/TokenFavoritesContext.d.ts +30 -0
- package/dist/internal/SelectTokenModal/TokenFavoritesContext.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/TokenFavoritesContext.js +144 -0
- package/dist/internal/SelectTokenModal/TokenFavoritesContext.js.map +1 -0
- package/dist/internal/SelectTokenModal/TokenList.d.ts +16 -0
- package/dist/internal/SelectTokenModal/TokenList.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/TokenList.js +258 -0
- package/dist/internal/SelectTokenModal/TokenList.js.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/index.d.ts +4 -0
- package/dist/internal/SelectTokenModal/hooks/index.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/index.js +4 -0
- package/dist/internal/SelectTokenModal/hooks/index.js.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/useChainsAndTokensForSelect.d.ts +22 -0
- package/dist/internal/SelectTokenModal/hooks/useChainsAndTokensForSelect.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/useChainsAndTokensForSelect.js +180 -0
- package/dist/internal/SelectTokenModal/hooks/useChainsAndTokensForSelect.js.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/useSearchTokens.d.ts +12 -0
- package/dist/internal/SelectTokenModal/hooks/useSearchTokens.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/useSearchTokens.js +71 -0
- package/dist/internal/SelectTokenModal/hooks/useSearchTokens.js.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/useUserHasSelectedFromNetwork.d.ts +7 -0
- package/dist/internal/SelectTokenModal/hooks/useUserHasSelectedFromNetwork.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/hooks/useUserHasSelectedFromNetwork.js +6 -0
- package/dist/internal/SelectTokenModal/hooks/useUserHasSelectedFromNetwork.js.map +1 -0
- package/dist/internal/SelectTokenModal/index.d.ts +10 -0
- package/dist/internal/SelectTokenModal/index.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/index.js +274 -0
- package/dist/internal/SelectTokenModal/index.js.map +1 -0
- package/dist/internal/SelectTokenModal/storageUtils.d.ts +55 -0
- package/dist/internal/SelectTokenModal/storageUtils.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/storageUtils.js +216 -0
- package/dist/internal/SelectTokenModal/storageUtils.js.map +1 -0
- package/dist/internal/SelectTokenModal/utils.d.ts +16 -0
- package/dist/internal/SelectTokenModal/utils.d.ts.map +1 -0
- package/dist/internal/SelectTokenModal/utils.js +399 -0
- package/dist/internal/SelectTokenModal/utils.js.map +1 -0
- package/dist/internal/SwapAndBridge/DifferentAddressDialog.d.ts +13 -0
- package/dist/internal/SwapAndBridge/DifferentAddressDialog.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/DifferentAddressDialog.js +127 -0
- package/dist/internal/SwapAndBridge/DifferentAddressDialog.js.map +1 -0
- package/dist/internal/SwapAndBridge/FormBody.d.ts +10 -0
- package/dist/internal/SwapAndBridge/FormBody.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/FormBody.js +471 -0
- package/dist/internal/SwapAndBridge/FormBody.js.map +1 -0
- package/dist/internal/SwapAndBridge/FormButton.d.ts +19 -0
- package/dist/internal/SwapAndBridge/FormButton.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/FormButton.js +373 -0
- package/dist/internal/SwapAndBridge/FormButton.js.map +1 -0
- package/dist/internal/SwapAndBridge/FormTop.d.ts +11 -0
- package/dist/internal/SwapAndBridge/FormTop.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/FormTop.js +35 -0
- package/dist/internal/SwapAndBridge/FormTop.js.map +1 -0
- package/dist/internal/SwapAndBridge/MainForm.d.ts +26 -0
- package/dist/internal/SwapAndBridge/MainForm.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/MainForm.js +445 -0
- package/dist/internal/SwapAndBridge/MainForm.js.map +1 -0
- package/dist/internal/SwapAndBridge/SlippageSettings.d.ts +3 -0
- package/dist/internal/SwapAndBridge/SlippageSettings.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/SlippageSettings.js +121 -0
- package/dist/internal/SwapAndBridge/SlippageSettings.js.map +1 -0
- package/dist/internal/SwapAndBridge/Timer.d.ts +8 -0
- package/dist/internal/SwapAndBridge/Timer.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/Timer.js +53 -0
- package/dist/internal/SwapAndBridge/Timer.js.map +1 -0
- package/dist/internal/SwapAndBridge/TipsContent.d.ts +18 -0
- package/dist/internal/SwapAndBridge/TipsContent.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/TipsContent.js +217 -0
- package/dist/internal/SwapAndBridge/TipsContent.js.map +1 -0
- package/dist/internal/SwapAndBridge/TokenInfoCom.d.ts +7 -0
- package/dist/internal/SwapAndBridge/TokenInfoCom.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/TokenInfoCom.js +28 -0
- package/dist/internal/SwapAndBridge/TokenInfoCom.js.map +1 -0
- package/dist/internal/SwapAndBridge/TokenSelectAndInput.d.ts +18 -0
- package/dist/internal/SwapAndBridge/TokenSelectAndInput.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/TokenSelectAndInput.js +257 -0
- package/dist/internal/SwapAndBridge/TokenSelectAndInput.js.map +1 -0
- package/dist/internal/SwapAndBridge/TxInfo.d.ts +25 -0
- package/dist/internal/SwapAndBridge/TxInfo.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/TxInfo.js +101 -0
- package/dist/internal/SwapAndBridge/TxInfo.js.map +1 -0
- package/dist/internal/SwapAndBridge/TxState.d.ts +8 -0
- package/dist/internal/SwapAndBridge/TxState.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/TxState.js +371 -0
- package/dist/internal/SwapAndBridge/TxState.js.map +1 -0
- package/dist/internal/SwapAndBridge/animations/Failure.d.ts +3 -0
- package/dist/internal/SwapAndBridge/animations/Failure.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/animations/Failure.js +12 -0
- package/dist/internal/SwapAndBridge/animations/Failure.js.map +1 -0
- package/dist/internal/SwapAndBridge/animations/Success.d.ts +3 -0
- package/dist/internal/SwapAndBridge/animations/Success.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/animations/Success.js +12 -0
- package/dist/internal/SwapAndBridge/animations/Success.js.map +1 -0
- package/dist/internal/SwapAndBridge/animations/Wheel.d.ts +3 -0
- package/dist/internal/SwapAndBridge/animations/Wheel.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/animations/Wheel.js +12 -0
- package/dist/internal/SwapAndBridge/animations/Wheel.js.map +1 -0
- package/dist/internal/SwapAndBridge/animations/index.d.ts +4 -0
- package/dist/internal/SwapAndBridge/animations/index.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/animations/index.js +4 -0
- package/dist/internal/SwapAndBridge/animations/index.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/index.d.ts +5 -0
- package/dist/internal/SwapAndBridge/hooks/index.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/index.js +5 -0
- package/dist/internal/SwapAndBridge/hooks/index.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useGuardChain.d.ts +5 -0
- package/dist/internal/SwapAndBridge/hooks/useGuardChain.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useGuardChain.js +48 -0
- package/dist/internal/SwapAndBridge/hooks/useGuardChain.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useRefreshLoading.d.ts +5 -0
- package/dist/internal/SwapAndBridge/hooks/useRefreshLoading.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useRefreshLoading.js +41 -0
- package/dist/internal/SwapAndBridge/hooks/useRefreshLoading.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useRetryAbleTransactionReceipt.d.ts +818 -0
- package/dist/internal/SwapAndBridge/hooks/useRetryAbleTransactionReceipt.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useRetryAbleTransactionReceipt.js +69 -0
- package/dist/internal/SwapAndBridge/hooks/useRetryAbleTransactionReceipt.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useSwapAndBridgeContextStore.d.ts +52 -0
- package/dist/internal/SwapAndBridge/hooks/useSwapAndBridgeContextStore.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useSwapAndBridgeContextStore.js +454 -0
- package/dist/internal/SwapAndBridge/hooks/useSwapAndBridgeContextStore.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useTokenBalance.d.ts +13 -0
- package/dist/internal/SwapAndBridge/hooks/useTokenBalance.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useTokenBalance.js +11 -0
- package/dist/internal/SwapAndBridge/hooks/useTokenBalance.js.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useTxStateContextStore.d.ts +18 -0
- package/dist/internal/SwapAndBridge/hooks/useTxStateContextStore.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/hooks/useTxStateContextStore.js +22 -0
- package/dist/internal/SwapAndBridge/hooks/useTxStateContextStore.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/consts.d.ts +4 -0
- package/dist/internal/SwapAndBridge/utils/consts.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/consts.js +4 -0
- package/dist/internal/SwapAndBridge/utils/consts.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/debounce.d.ts +2 -0
- package/dist/internal/SwapAndBridge/utils/debounce.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/debounce.js +14 -0
- package/dist/internal/SwapAndBridge/utils/debounce.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/defaultData.d.ts +9 -0
- package/dist/internal/SwapAndBridge/utils/defaultData.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/defaultData.js +71 -0
- package/dist/internal/SwapAndBridge/utils/defaultData.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/getErc20Approval.d.ts +17 -0
- package/dist/internal/SwapAndBridge/utils/getErc20Approval.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/getErc20Approval.js +57 -0
- package/dist/internal/SwapAndBridge/utils/getErc20Approval.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/index.d.ts +16 -0
- package/dist/internal/SwapAndBridge/utils/index.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/index.js +140 -0
- package/dist/internal/SwapAndBridge/utils/index.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/retry.d.ts +2 -0
- package/dist/internal/SwapAndBridge/utils/retry.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/retry.js +33 -0
- package/dist/internal/SwapAndBridge/utils/retry.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/slippage.d.ts +3 -0
- package/dist/internal/SwapAndBridge/utils/slippage.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/slippage.js +14 -0
- package/dist/internal/SwapAndBridge/utils/slippage.js.map +1 -0
- package/dist/internal/SwapAndBridge/utils/twoApprove.d.ts +47 -0
- package/dist/internal/SwapAndBridge/utils/twoApprove.d.ts.map +1 -0
- package/dist/internal/SwapAndBridge/utils/twoApprove.js +131 -0
- package/dist/internal/SwapAndBridge/utils/twoApprove.js.map +1 -0
- package/dist/internal/WidgetDataBootstrap.d.ts +3 -0
- package/dist/internal/WidgetDataBootstrap.d.ts.map +1 -0
- package/dist/internal/WidgetDataBootstrap.js +42 -0
- package/dist/internal/WidgetDataBootstrap.js.map +1 -0
- package/dist/internal/api/consts.d.ts +2 -0
- package/dist/internal/api/consts.d.ts.map +1 -0
- package/dist/internal/api/consts.js +8 -0
- package/dist/internal/api/consts.js.map +1 -0
- package/dist/internal/api/index.d.ts +8 -0
- package/dist/internal/api/index.d.ts.map +1 -0
- package/dist/internal/api/index.js +8 -0
- package/dist/internal/api/index.js.map +1 -0
- package/dist/internal/api/normalizeAssetUrl.d.ts +2 -0
- package/dist/internal/api/normalizeAssetUrl.d.ts.map +1 -0
- package/dist/internal/api/normalizeAssetUrl.js +15 -0
- package/dist/internal/api/normalizeAssetUrl.js.map +1 -0
- package/dist/internal/api/useChainsAndTokens.d.ts +61 -0
- package/dist/internal/api/useChainsAndTokens.d.ts.map +1 -0
- package/dist/internal/api/useChainsAndTokens.js +117 -0
- package/dist/internal/api/useChainsAndTokens.js.map +1 -0
- package/dist/internal/api/useGetQuote.d.ts +50 -0
- package/dist/internal/api/useGetQuote.d.ts.map +1 -0
- package/dist/internal/api/useGetQuote.js +41 -0
- package/dist/internal/api/useGetQuote.js.map +1 -0
- package/dist/internal/api/useHyperliquid.d.ts +8 -0
- package/dist/internal/api/useHyperliquid.d.ts.map +1 -0
- package/dist/internal/api/useHyperliquid.js +40 -0
- package/dist/internal/api/useHyperliquid.js.map +1 -0
- package/dist/internal/api/useIntervalGetOrderDetail.d.ts +602 -0
- package/dist/internal/api/useIntervalGetOrderDetail.d.ts.map +1 -0
- package/dist/internal/api/useIntervalGetOrderDetail.js +70 -0
- package/dist/internal/api/useIntervalGetOrderDetail.js.map +1 -0
- package/dist/internal/api/useTokenBalance.d.ts +55 -0
- package/dist/internal/api/useTokenBalance.d.ts.map +1 -0
- package/dist/internal/api/useTokenBalance.js +29 -0
- package/dist/internal/api/useTokenBalance.js.map +1 -0
- package/dist/internal/api/useTokenInfo.d.ts +53 -0
- package/dist/internal/api/useTokenInfo.d.ts.map +1 -0
- package/dist/internal/api/useTokenInfo.js +38 -0
- package/dist/internal/api/useTokenInfo.js.map +1 -0
- package/dist/internal/api/useUsdPrice.d.ts +13 -0
- package/dist/internal/api/useUsdPrice.d.ts.map +1 -0
- package/dist/internal/api/useUsdPrice.js +18 -0
- package/dist/internal/api/useUsdPrice.js.map +1 -0
- package/dist/internal/assets/icons/ai.svg +7 -0
- package/dist/internal/assets/icons/all2.svg +6 -0
- package/dist/internal/assets/icons/arrow-down.svg +4 -0
- package/dist/internal/assets/icons/arrow-fill-right.svg +5 -0
- package/dist/internal/assets/icons/arrow-right.svg +6 -0
- package/dist/internal/assets/icons/back.svg +5 -0
- package/dist/internal/assets/icons/close.svg +9 -0
- package/dist/internal/assets/icons/date.svg +9 -0
- package/dist/internal/assets/icons/ding.svg +1 -0
- package/dist/internal/assets/icons/info.svg +7 -0
- package/dist/internal/assets/icons/liked.svg +6 -0
- package/dist/internal/assets/icons/link.svg +8 -0
- package/dist/internal/assets/icons/metamask.svg +36 -0
- package/dist/internal/assets/icons/money.svg +14 -0
- package/dist/internal/assets/icons/plus.svg +5 -0
- package/dist/internal/assets/icons/router.svg +10 -0
- package/dist/internal/assets/icons/search-history.svg +6 -0
- package/dist/internal/assets/icons/search.svg +6 -0
- package/dist/internal/assets/icons/settings.svg +7 -0
- package/dist/internal/assets/icons/stab.svg +6 -0
- package/dist/internal/assets/icons/stock.svg +12 -0
- package/dist/internal/assets/icons/switch.svg +6 -0
- package/dist/internal/assets/icons/time.svg +12 -0
- package/dist/internal/assets/icons/wallet.svg +8 -0
- package/dist/internal/assets/images/ai_bot.gif +0 -0
- package/dist/internal/assets/images/default-token-icon.png +0 -0
- package/dist/internal/assets/images/error.png +0 -0
- package/dist/internal/assets/images/gas.png +0 -0
- package/dist/internal/assets/images/jth.png +0 -0
- package/dist/internal/assets/images/loader.png +0 -0
- package/dist/internal/assets/images/nabox.svg +1 -0
- package/dist/internal/assets/images/networks/1.png +0 -0
- package/dist/internal/assets/images/networks/42161.png +0 -0
- package/dist/internal/assets/images/networks/56.png +0 -0
- package/dist/internal/assets/images/networks/8453.png +0 -0
- package/dist/internal/assets/images/no_data.png +0 -0
- package/dist/internal/assets/images/success-sprites.png +0 -0
- package/dist/internal/assets/images/switch.png +0 -0
- package/dist/internal/assets/images/tokens/eth.png +0 -0
- package/dist/internal/assets/images/verified.png +0 -0
- package/dist/internal/assets/images/wheel-sprites.png +0 -0
- package/dist/internal/commons/TokenAmountHeading.d.ts +11 -0
- package/dist/internal/commons/TokenAmountHeading.d.ts.map +1 -0
- package/dist/internal/commons/TokenAmountHeading.js +20 -0
- package/dist/internal/commons/TokenAmountHeading.js.map +1 -0
- package/dist/internal/commons/TokenAmountText.d.ts +11 -0
- package/dist/internal/commons/TokenAmountText.d.ts.map +1 -0
- package/dist/internal/commons/TokenAmountText.js +20 -0
- package/dist/internal/commons/TokenAmountText.js.map +1 -0
- package/dist/internal/commons/TokenIconWithNetworkLogo.d.ts +15 -0
- package/dist/internal/commons/TokenIconWithNetworkLogo.d.ts.map +1 -0
- package/dist/internal/commons/TokenIconWithNetworkLogo.js +28 -0
- package/dist/internal/commons/TokenIconWithNetworkLogo.js.map +1 -0
- package/dist/internal/commons/index.d.ts +4 -0
- package/dist/internal/commons/index.d.ts.map +1 -0
- package/dist/internal/commons/index.js +4 -0
- package/dist/internal/commons/index.js.map +1 -0
- package/dist/internal/commons/utils.d.ts +29 -0
- package/dist/internal/commons/utils.d.ts.map +1 -0
- package/dist/internal/commons/utils.js +100 -0
- package/dist/internal/commons/utils.js.map +1 -0
- package/dist/internal/consts/chainsCatalog.d.ts +8 -0
- package/dist/internal/consts/chainsCatalog.d.ts.map +1 -0
- package/dist/internal/consts/chainsCatalog.js +116 -0
- package/dist/internal/consts/chainsCatalog.js.map +1 -0
- package/dist/internal/consts/chainsInfo.d.ts +2 -0
- package/dist/internal/consts/chainsInfo.d.ts.map +1 -0
- package/dist/internal/consts/chainsInfo.js +3 -0
- package/dist/internal/consts/chainsInfo.js.map +1 -0
- package/dist/internal/consts/giwa.d.ts +46 -0
- package/dist/internal/consts/giwa.d.ts.map +1 -0
- package/dist/internal/consts/giwa.js +30 -0
- package/dist/internal/consts/giwa.js.map +1 -0
- package/dist/internal/consts/hyperevm.d.ts +46 -0
- package/dist/internal/consts/hyperevm.d.ts.map +1 -0
- package/dist/internal/consts/hyperevm.js +30 -0
- package/dist/internal/consts/hyperevm.js.map +1 -0
- package/dist/internal/consts/index.d.ts +2 -0
- package/dist/internal/consts/index.d.ts.map +1 -0
- package/dist/internal/consts/index.js +2 -0
- package/dist/internal/consts/index.js.map +1 -0
- package/dist/internal/consts/katana.d.ts +46 -0
- package/dist/internal/consts/katana.d.ts.map +1 -0
- package/dist/internal/consts/katana.js +30 -0
- package/dist/internal/consts/katana.js.map +1 -0
- package/dist/internal/consts/mainnet.d.ts +50 -0
- package/dist/internal/consts/mainnet.d.ts.map +1 -0
- package/dist/internal/consts/mainnet.js +39 -0
- package/dist/internal/consts/mainnet.js.map +1 -0
- package/dist/internal/consts/megaeth.d.ts +46 -0
- package/dist/internal/consts/megaeth.d.ts.map +1 -0
- package/dist/internal/consts/megaeth.js +30 -0
- package/dist/internal/consts/megaeth.js.map +1 -0
- package/dist/internal/consts/metis.d.ts +47 -0
- package/dist/internal/consts/metis.d.ts.map +1 -0
- package/dist/internal/consts/metis.js +43 -0
- package/dist/internal/consts/metis.js.map +1 -0
- package/dist/internal/consts/monad.d.ts +51 -0
- package/dist/internal/consts/monad.d.ts.map +1 -0
- package/dist/internal/consts/monad.js +36 -0
- package/dist/internal/consts/monad.js.map +1 -0
- package/dist/internal/consts/plasma.d.ts +46 -0
- package/dist/internal/consts/plasma.d.ts.map +1 -0
- package/dist/internal/consts/plasma.js +30 -0
- package/dist/internal/consts/plasma.js.map +1 -0
- package/dist/internal/consts/polygonZkEvm.d.ts +46 -0
- package/dist/internal/consts/polygonZkEvm.d.ts.map +1 -0
- package/dist/internal/consts/polygonZkEvm.js +25 -0
- package/dist/internal/consts/polygonZkEvm.js.map +1 -0
- package/dist/internal/consts/rari.d.ts +46 -0
- package/dist/internal/consts/rari.d.ts.map +1 -0
- package/dist/internal/consts/rari.js +30 -0
- package/dist/internal/consts/rari.js.map +1 -0
- package/dist/internal/consts/stable.d.ts +46 -0
- package/dist/internal/consts/stable.d.ts.map +1 -0
- package/dist/internal/consts/stable.js +30 -0
- package/dist/internal/consts/stable.js.map +1 -0
- package/dist/internal/consts/stabletestnet.d.ts +46 -0
- package/dist/internal/consts/stabletestnet.d.ts.map +1 -0
- package/dist/internal/consts/stabletestnet.js +30 -0
- package/dist/internal/consts/stabletestnet.js.map +1 -0
- package/dist/internal/consts/tempo.d.ts +41 -0
- package/dist/internal/consts/tempo.d.ts.map +1 -0
- package/dist/internal/consts/tempo.js +30 -0
- package/dist/internal/consts/tempo.js.map +1 -0
- package/dist/internal/providers/ClientProviders.d.ts +4 -0
- package/dist/internal/providers/ClientProviders.d.ts.map +1 -0
- package/dist/internal/providers/ClientProviders.js +25 -0
- package/dist/internal/providers/ClientProviders.js.map +1 -0
- package/dist/internal/providers/nabox.d.ts +6 -0
- package/dist/internal/providers/nabox.d.ts.map +1 -0
- package/dist/internal/providers/nabox.js +59 -0
- package/dist/internal/providers/nabox.js.map +1 -0
- package/dist/internal/providers/wagmi.d.ts +3 -0
- package/dist/internal/providers/wagmi.d.ts.map +1 -0
- package/dist/internal/providers/wagmi.js +89 -0
- package/dist/internal/providers/wagmi.js.map +1 -0
- package/dist/internal/stores/index.d.ts +3 -0
- package/dist/internal/stores/index.d.ts.map +1 -0
- package/dist/internal/stores/index.js +3 -0
- package/dist/internal/stores/index.js.map +1 -0
- package/dist/internal/stores/useChainsStore.d.ts +15 -0
- package/dist/internal/stores/useChainsStore.d.ts.map +1 -0
- package/dist/internal/stores/useChainsStore.js +12 -0
- package/dist/internal/stores/useChainsStore.js.map +1 -0
- package/dist/internal/stores/useDifferentAddressStore.d.ts +9 -0
- package/dist/internal/stores/useDifferentAddressStore.d.ts.map +1 -0
- package/dist/internal/stores/useDifferentAddressStore.js +8 -0
- package/dist/internal/stores/useDifferentAddressStore.js.map +1 -0
- package/dist/internal/ui/BoxWithBg.d.ts +4 -0
- package/dist/internal/ui/BoxWithBg.d.ts.map +1 -0
- package/dist/internal/ui/BoxWithBg.js +6 -0
- package/dist/internal/ui/BoxWithBg.js.map +1 -0
- package/dist/internal/ui/WidgetAnimationsGlobalStyle.d.ts +2 -0
- package/dist/internal/ui/WidgetAnimationsGlobalStyle.d.ts.map +1 -0
- package/dist/internal/ui/WidgetAnimationsGlobalStyle.js +312 -0
- package/dist/internal/ui/WidgetAnimationsGlobalStyle.js.map +1 -0
- package/dist/internal/ui/color-mode.d.ts +22 -0
- package/dist/internal/ui/color-mode.d.ts.map +1 -0
- package/dist/internal/ui/color-mode.js +44 -0
- package/dist/internal/ui/color-mode.js.map +1 -0
- package/dist/internal/ui/componentRecipes/button.d.ts +123 -0
- package/dist/internal/ui/componentRecipes/button.d.ts.map +1 -0
- package/dist/internal/ui/componentRecipes/button.js +101 -0
- package/dist/internal/ui/componentRecipes/button.js.map +1 -0
- package/dist/internal/ui/componentRecipes/heading.d.ts +53 -0
- package/dist/internal/ui/componentRecipes/heading.d.ts.map +1 -0
- package/dist/internal/ui/componentRecipes/heading.js +54 -0
- package/dist/internal/ui/componentRecipes/heading.js.map +1 -0
- package/dist/internal/ui/componentRecipes/index.d.ts +4 -0
- package/dist/internal/ui/componentRecipes/index.d.ts.map +1 -0
- package/dist/internal/ui/componentRecipes/index.js +4 -0
- package/dist/internal/ui/componentRecipes/index.js.map +1 -0
- package/dist/internal/ui/componentRecipes/text.d.ts +4 -0
- package/dist/internal/ui/componentRecipes/text.d.ts.map +1 -0
- package/dist/internal/ui/componentRecipes/text.js +59 -0
- package/dist/internal/ui/componentRecipes/text.js.map +1 -0
- package/dist/internal/ui/index.d.ts +2 -0
- package/dist/internal/ui/index.d.ts.map +1 -0
- package/dist/internal/ui/index.js +2 -0
- package/dist/internal/ui/index.js.map +1 -0
- package/dist/internal/ui/provider.d.ts +5 -0
- package/dist/internal/ui/provider.d.ts.map +1 -0
- package/dist/internal/ui/provider.js +9 -0
- package/dist/internal/ui/provider.js.map +1 -0
- package/dist/internal/ui/theme.d.ts +2 -0
- package/dist/internal/ui/theme.d.ts.map +1 -0
- package/dist/internal/ui/theme.js +53 -0
- package/dist/internal/ui/theme.js.map +1 -0
- package/dist/internal/ui/toaster.d.ts +8 -0
- package/dist/internal/ui/toaster.d.ts.map +1 -0
- package/dist/internal/ui/toaster.js +19 -0
- package/dist/internal/ui/toaster.js.map +1 -0
- package/dist/internal/ui/tooltip.d.ts +17 -0
- package/dist/internal/ui/tooltip.d.ts.map +1 -0
- package/dist/internal/ui/tooltip.js +17 -0
- package/dist/internal/ui/tooltip.js.map +1 -0
- package/dist/internal/utils/address.d.ts +2 -0
- package/dist/internal/utils/address.d.ts.map +1 -0
- package/dist/internal/utils/address.js +9 -0
- package/dist/internal/utils/address.js.map +1 -0
- package/dist/internal/utils/consts.d.ts +2 -0
- package/dist/internal/utils/consts.d.ts.map +1 -0
- package/dist/internal/utils/consts.js +2 -0
- package/dist/internal/utils/consts.js.map +1 -0
- package/dist/internal/utils/format.d.ts +12 -0
- package/dist/internal/utils/format.d.ts.map +1 -0
- package/dist/internal/utils/format.js +72 -0
- package/dist/internal/utils/format.js.map +1 -0
- package/dist/internal/utils/getAssetSrc.d.ts +6 -0
- package/dist/internal/utils/getAssetSrc.d.ts.map +1 -0
- package/dist/internal/utils/getAssetSrc.js +4 -0
- package/dist/internal/utils/getAssetSrc.js.map +1 -0
- package/dist/internal/utils/getTxLink.d.ts +4 -0
- package/dist/internal/utils/getTxLink.d.ts.map +1 -0
- package/dist/internal/utils/getTxLink.js +17 -0
- package/dist/internal/utils/getTxLink.js.map +1 -0
- package/dist/internal/utils/index.d.ts +16 -0
- package/dist/internal/utils/index.d.ts.map +1 -0
- package/dist/internal/utils/index.js +33 -0
- package/dist/internal/utils/index.js.map +1 -0
- package/dist/internal/utils/localstorage.d.ts +14 -0
- package/dist/internal/utils/localstorage.d.ts.map +1 -0
- package/dist/internal/utils/localstorage.js +54 -0
- package/dist/internal/utils/localstorage.js.map +1 -0
- package/dist/internal/utils/logger.d.ts +8 -0
- package/dist/internal/utils/logger.d.ts.map +1 -0
- package/dist/internal/utils/logger.js +34 -0
- package/dist/internal/utils/logger.js.map +1 -0
- package/dist/internal/utils/shortLinkRegex.d.ts +8 -0
- package/dist/internal/utils/shortLinkRegex.d.ts.map +1 -0
- package/dist/internal/utils/shortLinkRegex.js +18 -0
- package/dist/internal/utils/shortLinkRegex.js.map +1 -0
- package/package.json +81 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect, useCallback, useRef } from 'react';
|
|
3
|
+
import { Text } from '../ui';
|
|
4
|
+
const Timer = ({ stop, onTick, valueStyle }) => {
|
|
5
|
+
const [seconds, setSeconds] = useState(0);
|
|
6
|
+
const [isRunning, setIsRunning] = useState(false);
|
|
7
|
+
const timer = useRef(null);
|
|
8
|
+
const formatTime = (totalSeconds) => {
|
|
9
|
+
return `${totalSeconds} s`;
|
|
10
|
+
};
|
|
11
|
+
const startTimer = useCallback(() => {
|
|
12
|
+
if (!isRunning) {
|
|
13
|
+
setIsRunning(true);
|
|
14
|
+
setSeconds(0);
|
|
15
|
+
}
|
|
16
|
+
}, [isRunning]);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
startTimer();
|
|
19
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
20
|
+
}, []);
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
if (onTick) {
|
|
23
|
+
onTick(seconds);
|
|
24
|
+
}
|
|
25
|
+
}, [seconds, onTick]);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (isRunning) {
|
|
28
|
+
timer.current = setInterval(() => {
|
|
29
|
+
setSeconds((prev) => prev + 1);
|
|
30
|
+
}, 1000);
|
|
31
|
+
}
|
|
32
|
+
return () => {
|
|
33
|
+
if (timer.current) {
|
|
34
|
+
clearInterval(timer.current);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
}, [isRunning]);
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (stop) {
|
|
40
|
+
setIsRunning(false);
|
|
41
|
+
if (timer.current) {
|
|
42
|
+
clearInterval(timer.current);
|
|
43
|
+
timer.current = null;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}, [stop]);
|
|
47
|
+
return (_jsx(Text, { variant: {
|
|
48
|
+
base: 'content8',
|
|
49
|
+
md: 'content7'
|
|
50
|
+
}, color: '#15003E', ...(valueStyle || {}), children: formatTime(seconds) }));
|
|
51
|
+
};
|
|
52
|
+
export default Timer;
|
|
53
|
+
//# sourceMappingURL=Timer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Timer.js","sourceRoot":"","sources":["../../../src/internal/SwapAndBridge/Timer.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AACvE,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAA;AAQ5B,MAAM,KAAK,GAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAS,EAAE,EAAE;IACpD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAS,CAAC,CAAC,CAAA;IACjD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAA;IAC1D,MAAM,KAAK,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAA;IAEjD,MAAM,UAAU,GAAG,CAAC,YAAoB,EAAU,EAAE;QAClD,OAAO,GAAG,YAAY,IAAI,CAAA;IAC5B,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE;QAClC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,YAAY,CAAC,IAAI,CAAC,CAAA;YAClB,UAAU,CAAC,CAAC,CAAC,CAAA;QACf,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,SAAS,CAAC,GAAG,EAAE;QACb,UAAU,EAAE,CAAA;QACZ,uDAAuD;IACzD,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,CAAC,OAAO,CAAC,CAAA;QACjB,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;IAErB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,EAAE,CAAC;YACd,KAAK,CAAC,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE;gBAC/B,UAAU,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,CAAA;YAChC,CAAC,EAAE,IAAI,CAAC,CAAA;QACV,CAAC;QAED,OAAO,GAAG,EAAE;YACV,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;gBAClB,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC9B,CAAC;QACH,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,IAAI,EAAE,CAAC;YACT,YAAY,CAAC,KAAK,CAAC,CAAA;YACnB,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;gBAClB,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;gBAC5B,KAAK,CAAC,OAAO,GAAG,IAAI,CAAA;YACtB,CAAC;QACH,CAAC;IACH,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAEV,OAAO,CACL,KAAC,IAAI,IACH,OAAO,EAAE;YACP,IAAI,EAAE,UAAU;YAChB,EAAE,EAAE,UAAU;SACf,EACD,KAAK,EAAE,SAAS,KACZ,CAAC,UAAU,IAAI,EAAE,CAAC,YAErB,UAAU,CAAC,OAAO,CAAC,GACf,CACR,CAAA;AACH,CAAC,CAAA;AAED,eAAe,KAAK,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { TokenInfo } from '../api';
|
|
2
|
+
interface TipsContentProps {
|
|
3
|
+
priceImpact: {
|
|
4
|
+
bridgeFee: string;
|
|
5
|
+
dstGasFee: string;
|
|
6
|
+
swapFee: string;
|
|
7
|
+
before_discount_fee: string;
|
|
8
|
+
discount_percentage: string | undefined;
|
|
9
|
+
};
|
|
10
|
+
toTokenInfo: TokenInfo;
|
|
11
|
+
fromTokenInfo: TokenInfo;
|
|
12
|
+
router_type: string | null | undefined;
|
|
13
|
+
fromAmountToUsd: string | null | undefined;
|
|
14
|
+
toAmountToUsd: string | null | undefined;
|
|
15
|
+
}
|
|
16
|
+
export declare const TipsContent: ({ priceImpact, fromTokenInfo, toTokenInfo, fromAmountToUsd, toAmountToUsd }: TipsContentProps) => import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=TipsContent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TipsContent.d.ts","sourceRoot":"","sources":["../../../src/internal/SwapAndBridge/TipsContent.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAGlC,UAAU,gBAAgB;IACxB,WAAW,EAAE;QACX,SAAS,EAAE,MAAM,CAAA;QACjB,SAAS,EAAE,MAAM,CAAA;QACjB,OAAO,EAAE,MAAM,CAAA;QACf,mBAAmB,EAAE,MAAM,CAAA;QAC3B,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAA;KACxC,CAAA;IACD,WAAW,EAAE,SAAS,CAAA;IACtB,aAAa,EAAE,SAAS,CAAA;IACxB,WAAW,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;IACtC,eAAe,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;IAC1C,aAAa,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;CACzC;AAED,eAAO,MAAM,WAAW,GAAI,6EAOzB,gBAAgB,4CAmclB,CAAA"}
|
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { HStack, VStack, Icon, Box } from '@chakra-ui/react';
|
|
4
|
+
import { Heading, Text } from '../ui';
|
|
5
|
+
import { Fraction } from 'bi-fraction';
|
|
6
|
+
import { FaGasPump } from 'react-icons/fa6';
|
|
7
|
+
import { useEffect, useState } from 'react';
|
|
8
|
+
export const TipsContent = ({ priceImpact, fromTokenInfo, toTokenInfo,
|
|
9
|
+
// router_type,
|
|
10
|
+
fromAmountToUsd, toAmountToUsd }) => {
|
|
11
|
+
const { chain_id: toChainId /*symbol: toTokenSymbol*/ } = toTokenInfo;
|
|
12
|
+
const { chain_id: fromChainId /*symbol: fromTokenSymbol*/ } = fromTokenInfo;
|
|
13
|
+
const totalPriceImpact = new Fraction(priceImpact.bridgeFee)
|
|
14
|
+
.add(priceImpact.dstGasFee)
|
|
15
|
+
.add(priceImpact.swapFee);
|
|
16
|
+
const [hasDiscount, setHasDiscount] = useState(false);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (priceImpact) {
|
|
19
|
+
if (priceImpact.before_discount_fee &&
|
|
20
|
+
priceImpact.before_discount_fee !== priceImpact.swapFee &&
|
|
21
|
+
// priceImpact.swapFee !== '0' &&
|
|
22
|
+
priceImpact.before_discount_fee !== '0') {
|
|
23
|
+
setHasDiscount(true);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
setHasDiscount(false);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}, [priceImpact]);
|
|
30
|
+
const renderTotalPriceImpact = () => {
|
|
31
|
+
if (toAmountToUsd === null) {
|
|
32
|
+
return '-';
|
|
33
|
+
}
|
|
34
|
+
// only exact match 0, return free, if 0.00000 is not free
|
|
35
|
+
if (priceImpact.bridgeFee === '0' &&
|
|
36
|
+
priceImpact.dstGasFee === '0' &&
|
|
37
|
+
priceImpact.swapFee === '0') {
|
|
38
|
+
return 'Free';
|
|
39
|
+
}
|
|
40
|
+
const priceImpactValue = +totalPriceImpact.toFormat({ decimalPlaces: 2 });
|
|
41
|
+
const sif = +swapImpactFee();
|
|
42
|
+
// console.log('priceImpactValue:', priceImpactValue, 'sif:', sif)
|
|
43
|
+
const total = -priceImpactValue + -sif;
|
|
44
|
+
if (total < 0) {
|
|
45
|
+
return `-$${(-total).toFixed(2)}`;
|
|
46
|
+
}
|
|
47
|
+
return `+$${total.toFixed(2)}`;
|
|
48
|
+
};
|
|
49
|
+
// const renderTotalPriceImpact = () => {
|
|
50
|
+
// // only exact match 0, return free, if 0.00000 is not free
|
|
51
|
+
// if (
|
|
52
|
+
// +fromAmountToUsd - +toAmountToUsd === 0 ||
|
|
53
|
+
// +fromAmountToUsd - +toAmountToUsd < 0
|
|
54
|
+
// ) {
|
|
55
|
+
// return 'Free'
|
|
56
|
+
// }
|
|
57
|
+
// return `-$${(+fromAmountToUsd - +toAmountToUsd).toFixed(2)} `
|
|
58
|
+
// }
|
|
59
|
+
const renderDiscount = (beforeFee, afterFee) => {
|
|
60
|
+
if (beforeFee && afterFee) {
|
|
61
|
+
return (_jsxs(HStack, { gap: 0, children: [_jsxs(Box, { color: 'brand-purple', marginRight: '3px', children: ["-$", new Fraction(afterFee).toFormat({ decimalPlaces: 2 })] }), _jsxs(Box, { textDecoration: 'line-through', color: "gray", children: ["$", new Fraction(beforeFee).toFormat({ decimalPlaces: 2 })] }), renderDiscountPercentage()] }));
|
|
62
|
+
}
|
|
63
|
+
return null;
|
|
64
|
+
};
|
|
65
|
+
const renderDiscountPercentage = () => {
|
|
66
|
+
if (priceImpact.discount_percentage) {
|
|
67
|
+
return (_jsxs(Box, { color: '#000', backgroundColor: '#ffd400', width: '30px', borderRadius: '4px', textAlign: 'center', fontSize: '10px', marginLeft: '3px', children: [priceImpact.discount_percentage, "%"] }));
|
|
68
|
+
}
|
|
69
|
+
return null;
|
|
70
|
+
};
|
|
71
|
+
const renderFee = (fee) => {
|
|
72
|
+
if (fee === '0') {
|
|
73
|
+
return (_jsx(Text, { variant: 'content9', color: 'white', bg: '#00CBB3', p: '3px', borderRadius: '4px', children: "Free" }));
|
|
74
|
+
}
|
|
75
|
+
return (_jsxs(Text, { variant: {
|
|
76
|
+
base: 'content9',
|
|
77
|
+
md: 'content8'
|
|
78
|
+
}, color: 'brand-grey1', children: ["-$", new Fraction(fee).toFormat({ decimalPlaces: 2 })] }));
|
|
79
|
+
};
|
|
80
|
+
const swapImpactFee = () => {
|
|
81
|
+
const i = fromAmountToUsd ? +fromAmountToUsd.replace(/,/g, '') : 0;
|
|
82
|
+
const o = toAmountToUsd ? +toAmountToUsd.replace(/,/g, '') : 0;
|
|
83
|
+
const fee = +totalPriceImpact.toFormat({ decimalPlaces: 2 });
|
|
84
|
+
const fio = i - (o + fee);
|
|
85
|
+
return fio.toFixed(2);
|
|
86
|
+
};
|
|
87
|
+
const renderSwapImpactFee = () => {
|
|
88
|
+
const sif = +swapImpactFee();
|
|
89
|
+
if (toAmountToUsd === null) {
|
|
90
|
+
return (_jsx(Text, { variant: {
|
|
91
|
+
base: 'content9',
|
|
92
|
+
md: 'content8'
|
|
93
|
+
}, color: 'brand-grey1', children: "-" }));
|
|
94
|
+
}
|
|
95
|
+
// console.log('sif:', sif)
|
|
96
|
+
if (sif > 0 || sif === 0) {
|
|
97
|
+
return (_jsxs(Text, { variant: {
|
|
98
|
+
base: 'content9',
|
|
99
|
+
md: 'content8'
|
|
100
|
+
}, color: 'brand-grey1', children: ["-$", sif] }));
|
|
101
|
+
}
|
|
102
|
+
return (_jsxs(Text, { variant: {
|
|
103
|
+
base: 'content9',
|
|
104
|
+
md: 'content8'
|
|
105
|
+
}, color: 'brand-grey1', children: ["+$", -sif] }));
|
|
106
|
+
};
|
|
107
|
+
// if (
|
|
108
|
+
// router_type === 'bridge' &&
|
|
109
|
+
// fromTokenSymbol === 'ETH' &&
|
|
110
|
+
// toTokenSymbol === 'ETH'
|
|
111
|
+
// ) {
|
|
112
|
+
// // console.log('Cross-chain only (ETH only)')
|
|
113
|
+
// return (
|
|
114
|
+
// <VStack p={4}>
|
|
115
|
+
// <Heading
|
|
116
|
+
// variant={{
|
|
117
|
+
// base: 'heading13',
|
|
118
|
+
// md: 'heading12'
|
|
119
|
+
// }}
|
|
120
|
+
// borderBottom={'1px solid #B5B5B5'}
|
|
121
|
+
// pb={2}
|
|
122
|
+
// w={'100%'}
|
|
123
|
+
// textAlign={'center'}
|
|
124
|
+
// >
|
|
125
|
+
// Total Price Impact: {renderTotalPriceImpact()}
|
|
126
|
+
// </Heading>
|
|
127
|
+
// {/* <HStack justify={'space-between'} w={'100%'}>
|
|
128
|
+
// <Text
|
|
129
|
+
// variant={{
|
|
130
|
+
// base: 'content9',
|
|
131
|
+
// md: 'content8'
|
|
132
|
+
// }}
|
|
133
|
+
// color={'brand-grey4'}
|
|
134
|
+
// >
|
|
135
|
+
// Provider Fee
|
|
136
|
+
// </Text>
|
|
137
|
+
// {renderFee(priceImpact.swapFee)}
|
|
138
|
+
// </HStack> */}
|
|
139
|
+
// <HStack justify={'space-between'} w={'100%'}>
|
|
140
|
+
// <Text
|
|
141
|
+
// variant={{
|
|
142
|
+
// base: 'content9',
|
|
143
|
+
// md: 'content8'
|
|
144
|
+
// }}
|
|
145
|
+
// color={'brand-grey4'}
|
|
146
|
+
// >
|
|
147
|
+
// Dst. Gas Fee
|
|
148
|
+
// </Text>
|
|
149
|
+
// <HStack gap={1}>
|
|
150
|
+
// {priceImpact.dstGasFee !== '0' && (
|
|
151
|
+
// <Icon boxSize={'10px'} as={FaGasPump} color={'#c1c8cd'} />
|
|
152
|
+
// )}
|
|
153
|
+
// {renderFee(priceImpact.dstGasFee)}
|
|
154
|
+
// </HStack>
|
|
155
|
+
// </HStack>
|
|
156
|
+
// <HStack justify={'space-between'} w={'100%'}>
|
|
157
|
+
// <Text
|
|
158
|
+
// variant={{
|
|
159
|
+
// base: 'content9',
|
|
160
|
+
// md: 'content8'
|
|
161
|
+
// }}
|
|
162
|
+
// color={'brand-grey4'}
|
|
163
|
+
// >
|
|
164
|
+
// WheelX Fee
|
|
165
|
+
// </Text>
|
|
166
|
+
// {priceImpact.bridgeFee === '0' && priceImpact.swapFee === '0' ? (
|
|
167
|
+
// <Text
|
|
168
|
+
// variant={'content9'}
|
|
169
|
+
// color={'white'}
|
|
170
|
+
// bg={'#00CBB3'}
|
|
171
|
+
// p={'3px'}
|
|
172
|
+
// borderRadius={'4px'}
|
|
173
|
+
// >
|
|
174
|
+
// Free
|
|
175
|
+
// </Text>
|
|
176
|
+
// ) : hasDiscount ? (
|
|
177
|
+
// renderDiscount(
|
|
178
|
+
// priceImpact.before_discount_fee,
|
|
179
|
+
// priceImpact.bridgeFee + priceImpact.swapFee
|
|
180
|
+
// )
|
|
181
|
+
// ) : (
|
|
182
|
+
// <>
|
|
183
|
+
// {renderFee(priceImpact.bridgeFee + priceImpact.swapFee)}
|
|
184
|
+
// {renderDiscountPercentage()}
|
|
185
|
+
// </>
|
|
186
|
+
// )}
|
|
187
|
+
// </HStack>
|
|
188
|
+
// </VStack>
|
|
189
|
+
// )
|
|
190
|
+
// }
|
|
191
|
+
if (fromChainId === toChainId) {
|
|
192
|
+
return (_jsxs(VStack, { p: 4, children: [_jsxs(Heading, { variant: {
|
|
193
|
+
base: 'heading13',
|
|
194
|
+
md: 'heading12'
|
|
195
|
+
}, borderBottom: '1px solid #B5B5B5', pb: 2, w: '100%', textAlign: 'center', children: ["Total Price Impact: ", renderTotalPriceImpact()] }), _jsxs(HStack, { justify: 'space-between', w: '100%', children: [_jsx(Text, { variant: {
|
|
196
|
+
base: 'content9',
|
|
197
|
+
md: 'content8'
|
|
198
|
+
}, color: 'brand-grey4', children: "Swap Impact" }), _jsx(HStack, { gap: 1, children: renderSwapImpactFee() })] }), _jsxs(HStack, { justify: 'space-between', w: '100%', children: [_jsx(Text, { variant: {
|
|
199
|
+
base: 'content9',
|
|
200
|
+
md: 'content8'
|
|
201
|
+
}, color: 'brand-grey4', children: "WheelX Fee" }), priceImpact.bridgeFee === '0' && priceImpact.swapFee === '0' ? (_jsx(Text, { variant: 'content9', color: 'white', bg: '#00CBB3', p: '3px', borderRadius: '4px', children: "Free" })) : hasDiscount ? (renderDiscount(priceImpact.before_discount_fee, priceImpact.bridgeFee + priceImpact.swapFee)) : (_jsxs(_Fragment, { children: [renderFee(priceImpact.bridgeFee + priceImpact.swapFee), renderDiscountPercentage()] }))] })] }));
|
|
202
|
+
}
|
|
203
|
+
return (_jsxs(VStack, { p: 4, children: [_jsxs(Heading, { variant: {
|
|
204
|
+
base: 'heading13',
|
|
205
|
+
md: 'heading12'
|
|
206
|
+
}, borderBottom: '1px solid #B5B5B5', pb: 2, w: '100%', textAlign: 'center', children: ["Total Price Impact: ", renderTotalPriceImpact()] }), _jsxs(HStack, { justify: 'space-between', w: '100%', children: [_jsx(Text, { variant: {
|
|
207
|
+
base: 'content9',
|
|
208
|
+
md: 'content8'
|
|
209
|
+
}, color: 'brand-grey4', children: "Swap Impact" }), _jsx(HStack, { gap: 1, children: renderSwapImpactFee() })] }), _jsxs(HStack, { justify: 'space-between', w: '100%', children: [_jsx(Text, { variant: {
|
|
210
|
+
base: 'content9',
|
|
211
|
+
md: 'content8'
|
|
212
|
+
}, color: 'brand-grey4', children: "Dst. Gas Fee" }), _jsxs(HStack, { gap: 1, children: [priceImpact.dstGasFee !== '0' && (_jsx(Icon, { boxSize: '10px', as: FaGasPump, color: '#c1c8cd' })), renderFee(priceImpact.dstGasFee)] })] }), _jsxs(HStack, { justify: 'space-between', w: '100%', children: [_jsx(Text, { variant: {
|
|
213
|
+
base: 'content9',
|
|
214
|
+
md: 'content8'
|
|
215
|
+
}, color: 'brand-grey4', children: "WheelX Fee" }), priceImpact.bridgeFee === '0' && priceImpact.swapFee === '0' ? (_jsx(Text, { variant: 'content9', color: 'white', bg: '#00CBB3', p: '3px', borderRadius: '4px', children: "Free" })) : hasDiscount ? (renderDiscount(priceImpact.before_discount_fee, priceImpact.bridgeFee + priceImpact.swapFee)) : (_jsxs(_Fragment, { children: [renderFee(priceImpact.bridgeFee + priceImpact.swapFee), renderDiscountPercentage()] }))] })] }));
|
|
216
|
+
};
|
|
217
|
+
//# sourceMappingURL=TipsContent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TipsContent.js","sourceRoot":"","sources":["../../../src/internal/SwapAndBridge/TipsContent.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenInfoCom.d.ts","sourceRoot":"","sources":["../../../src/internal/SwapAndBridge/TokenInfoCom.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAOlC,UAAU,KAAK;IACb,SAAS,EAAE,SAAS,CAAA;CACrB;AAED,eAAO,MAAM,YAAY,GAAI,eAAe,KAAK,4CAiDhD,CAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { HStack, VStack } from '@chakra-ui/react';
|
|
3
|
+
import { useChainsStore } from '../stores';
|
|
4
|
+
import { TokenIconWithNetworkLogo } from '../commons/TokenIconWithNetworkLogo';
|
|
5
|
+
import { Heading, Text } from '../ui';
|
|
6
|
+
import { useWheelxWidgetStyles } from '../../config';
|
|
7
|
+
export const TokenInfoCom = ({ tokenInfo }) => {
|
|
8
|
+
const widgetStyles = useWheelxWidgetStyles();
|
|
9
|
+
const { chain_id, symbol, platform_id } = tokenInfo;
|
|
10
|
+
const { chains } = useChainsStore();
|
|
11
|
+
const chainInfo = chains?.find((chain) => {
|
|
12
|
+
if (platform_id && platform_id > 0) {
|
|
13
|
+
return chain.platform_id === platform_id;
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
return chain.chain_id === chain_id;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
// console.log('#######chainInfo#########:', chainInfo)
|
|
20
|
+
return (_jsxs(HStack, { children: [_jsx(TokenIconWithNetworkLogo, { tokenInfo: tokenInfo, customChainLogo: chainInfo?.chain_icon }), _jsxs(VStack, { align: 'start', gap: 1, flex: 1, children: [_jsx(Heading, { variant: {
|
|
21
|
+
base: 'heading11',
|
|
22
|
+
md: 'heading10'
|
|
23
|
+
}, color: 'brand-grey1', lineClamp: 1, wordBreak: 'break-all', ...widgetStyles.tokenPrimaryText, children: symbol }), _jsx(Text, { variant: {
|
|
24
|
+
base: 'content9',
|
|
25
|
+
md: 'content8'
|
|
26
|
+
}, color: 'brand-grey4', lineClamp: 1, wordBreak: 'break-all', ...widgetStyles.tokenSecondaryText, children: chainInfo?.name })] })] }));
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=TokenInfoCom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenInfoCom.js","sourceRoot":"","sources":["../../../src/internal/SwapAndBridge/TokenInfoCom.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAGjD,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAE1C,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAA;AAC9E,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAA;AACrC,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAMpD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,SAAS,EAAS,EAAE,EAAE;IACnD,MAAM,YAAY,GAAG,qBAAqB,EAAE,CAAA;IAC5C,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,SAAS,CAAA;IAEnD,MAAM,EAAE,MAAM,EAAE,GAAG,cAAc,EAAE,CAAA;IACnC,MAAM,SAAS,GAAG,MAAM,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;QACvC,IAAI,WAAW,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;YACnC,OAAO,KAAK,CAAC,WAAW,KAAK,WAAW,CAAA;QAC1C,CAAC;aAAM,CAAC;YACN,OAAO,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAA;QACpC,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,uDAAuD;IAEvD,OAAO,CACL,MAAC,MAAM,eACL,KAAC,wBAAwB,IACvB,SAAS,EAAE,SAAS,EACpB,eAAe,EAAE,SAAS,EAAE,UAAU,GACtC,EACF,MAAC,MAAM,IAAC,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,aACrC,KAAC,OAAO,IACN,OAAO,EAAE;4BACP,IAAI,EAAE,WAAW;4BACjB,EAAE,EAAE,WAAW;yBAChB,EACD,KAAK,EAAE,aAAa,EACpB,SAAS,EAAE,CAAC,EACZ,SAAS,EAAE,WAAW,KAClB,YAAY,CAAC,gBAAgB,YAEhC,MAAM,GACC,EACV,KAAC,IAAI,IACH,OAAO,EAAE;4BACP,IAAI,EAAE,UAAU;4BAChB,EAAE,EAAE,UAAU;yBACf,EACD,KAAK,EAAE,aAAa,EACpB,SAAS,EAAE,CAAC,EACZ,SAAS,EAAE,WAAW,KAClB,YAAY,CAAC,kBAAkB,YAElC,SAAS,EAAE,IAAI,GACX,IACA,IACF,CACV,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Fraction } from 'bi-fraction';
|
|
2
|
+
import { TokenInfo } from '../api';
|
|
3
|
+
interface TokenSelectAndInputProps {
|
|
4
|
+
text: 'From' | 'To';
|
|
5
|
+
onClick: () => void;
|
|
6
|
+
amount: string;
|
|
7
|
+
onChange: (value: string) => void;
|
|
8
|
+
userBalance: Fraction;
|
|
9
|
+
tokenInfo: TokenInfo;
|
|
10
|
+
usdPrice?: Fraction;
|
|
11
|
+
totalGasFee?: bigint;
|
|
12
|
+
isLoadingFeeData?: boolean;
|
|
13
|
+
isInsufficientBalance?: boolean;
|
|
14
|
+
onOpenDialog?: () => void;
|
|
15
|
+
}
|
|
16
|
+
export declare const TokenSelectAndInput: ({ text, tokenInfo, onClick, amount, onChange, userBalance, usdPrice, totalGasFee, isLoadingFeeData, isInsufficientBalance, onOpenDialog }: TokenSelectAndInputProps) => import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=TokenSelectAndInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenSelectAndInput.d.ts","sourceRoot":"","sources":["../../../src/internal/SwapAndBridge/TokenSelectAndInput.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AAEtC,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAwBlC,UAAU,wBAAwB;IAChC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;IACnB,OAAO,EAAE,MAAM,IAAI,CAAA;IACnB,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACjC,WAAW,EAAE,QAAQ,CAAA;IACrB,SAAS,EAAE,SAAS,CAAA;IACpB,QAAQ,CAAC,EAAE,QAAQ,CAAA;IACnB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B,qBAAqB,CAAC,EAAE,OAAO,CAAA;IAC/B,YAAY,CAAC,EAAE,MAAM,IAAI,CAAA;CAC1B;AAED,eAAO,MAAM,mBAAmB,GAAI,2IAYjC,wBAAwB,4CAggB1B,CAAA"}
|
|
@@ -0,0 +1,257 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button, HStack, Icon, Input, Image } from '@chakra-ui/react';
|
|
3
|
+
import { VStack } from '@chakra-ui/react';
|
|
4
|
+
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
5
|
+
import { Fraction } from 'bi-fraction';
|
|
6
|
+
import { TokenInfoCom } from './TokenInfoCom';
|
|
7
|
+
import ArrowDownIcon from '../assets/icons/arrow-down.svg';
|
|
8
|
+
import { Heading, Text } from '../ui';
|
|
9
|
+
import { debounce, hyperliquidChainId, toBigInt } from './utils';
|
|
10
|
+
import { formatTokenAmount, sliceAddress } from '../utils';
|
|
11
|
+
import { zeroAddress } from 'viem';
|
|
12
|
+
import { useAccount } from 'wagmi';
|
|
13
|
+
import { useSwapAndBridgeContextStore, useTokenBalance } from './hooks';
|
|
14
|
+
import { FiEdit } from 'react-icons/fi';
|
|
15
|
+
import { useDifferentAddressStore } from '../stores/useDifferentAddressStore';
|
|
16
|
+
import MetamaskIcon from '../assets/icons/metamask.svg';
|
|
17
|
+
import { useHyperliquidBalance } from '../api/useHyperliquid';
|
|
18
|
+
import { useWheelxWidgetStyles } from '../../config';
|
|
19
|
+
export const TokenSelectAndInput = ({ text, tokenInfo, onClick, amount, onChange, userBalance, usdPrice, totalGasFee, isLoadingFeeData, isInsufficientBalance, onOpenDialog }) => {
|
|
20
|
+
const { address, connector } = useAccount();
|
|
21
|
+
const widgetStyles = useWheelxWidgetStyles();
|
|
22
|
+
const quickHalfButtonStyles = widgetStyles.quickHalfButton || {};
|
|
23
|
+
const quickMaxButtonStyles = widgetStyles.quickMaxButton || {};
|
|
24
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
25
|
+
const [isNative, setIsNative] = useState(false);
|
|
26
|
+
// set value to state immediately to avoid the input value is not updated immediately when use debounce
|
|
27
|
+
const [value, setValue] = useState(amount);
|
|
28
|
+
const { setFromAmountToUsd, setToAmountToUsd, fromAmountToUsd, toAmountToUsd } = useSwapAndBridgeContextStore();
|
|
29
|
+
useEffect(() => {
|
|
30
|
+
setValue(amount);
|
|
31
|
+
}, [amount]);
|
|
32
|
+
const isFrom = text === 'From';
|
|
33
|
+
const { differentAddress, isDepositPlatformToken } = useDifferentAddressStore();
|
|
34
|
+
const toTokenDifferentAddressBalance = useTokenBalance({
|
|
35
|
+
chainId: tokenInfo.chain_id,
|
|
36
|
+
tokenAddress: tokenInfo.address === zeroAddress ? undefined : tokenInfo.address,
|
|
37
|
+
connectAddress: differentAddress ? differentAddress : address
|
|
38
|
+
});
|
|
39
|
+
const [isToHyperChain, setIsToHyperChain] = useState(false);
|
|
40
|
+
const { data: toTokenBalanceHyperBack } = useHyperliquidBalance(differentAddress ? differentAddress : address, isToHyperChain);
|
|
41
|
+
const toTokenBalanceHyper = {
|
|
42
|
+
decimals: 6,
|
|
43
|
+
formatted: toTokenBalanceHyperBack?.withdrawable,
|
|
44
|
+
symbol: 'USDC',
|
|
45
|
+
value: toBigInt(toTokenBalanceHyperBack?.withdrawable
|
|
46
|
+
? toTokenBalanceHyperBack?.withdrawable
|
|
47
|
+
: '0', 6)
|
|
48
|
+
};
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
if (!isFrom) {
|
|
51
|
+
if (tokenInfo.chain_id === hyperliquidChainId) {
|
|
52
|
+
setIsToHyperChain(true);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
setIsToHyperChain(false);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}, [tokenInfo, isFrom]);
|
|
59
|
+
const toDifferentAddressBalance = isToHyperChain
|
|
60
|
+
? new Fraction(toTokenBalanceHyper?.value ?? 0n)
|
|
61
|
+
: new Fraction(toTokenDifferentAddressBalance?.value ?? 0n);
|
|
62
|
+
const differentAddressBalance = formatTokenAmount({
|
|
63
|
+
amount: toDifferentAddressBalance,
|
|
64
|
+
decimals: tokenInfo.decimals
|
|
65
|
+
});
|
|
66
|
+
const walletIcon = useMemo(() => {
|
|
67
|
+
return connector?.icon ? (_jsx(Image, { src: connector.icon, alt: "connector", boxSize: {
|
|
68
|
+
base: '12px',
|
|
69
|
+
md: '14px'
|
|
70
|
+
}, borderRadius: 'full' })) : (_jsx(Icon, { boxSize: {
|
|
71
|
+
base: '12px',
|
|
72
|
+
md: '14px'
|
|
73
|
+
}, as: MetamaskIcon }));
|
|
74
|
+
}, [connector]);
|
|
75
|
+
// console.log('######differentAddressBalance######:', differentAddressBalance)
|
|
76
|
+
useEffect(() => {
|
|
77
|
+
if (isFrom) {
|
|
78
|
+
const { tags } = tokenInfo;
|
|
79
|
+
if (tags.includes('native')) {
|
|
80
|
+
setIsNative(true);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
setIsNative(false);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}, [tokenInfo, isFrom]);
|
|
87
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
88
|
+
const debouncedOnChange = useCallback(debounce(onChange, 500), [onChange]);
|
|
89
|
+
const handleValueChange = useCallback((e) => {
|
|
90
|
+
const value = e.target.value;
|
|
91
|
+
if (value === '.') {
|
|
92
|
+
setValue('0.');
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
if (value === '' || /^\d*\.?\d*$/.test(value)) {
|
|
96
|
+
// set value to state immediately
|
|
97
|
+
setValue(value);
|
|
98
|
+
// debounce the onChange function
|
|
99
|
+
const isSame = new Fraction(value).eq(amount);
|
|
100
|
+
if (!isSame) {
|
|
101
|
+
debouncedOnChange(value);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}, [amount, debouncedOnChange]);
|
|
105
|
+
const handleFocus = useCallback(() => {
|
|
106
|
+
setIsFocused(true);
|
|
107
|
+
}, []);
|
|
108
|
+
const handleBlur = useCallback(() => {
|
|
109
|
+
setIsFocused(false);
|
|
110
|
+
}, []);
|
|
111
|
+
const handleQuickInput = useCallback(async (value) => {
|
|
112
|
+
const plusGasFee = new Fraction('0.00008')
|
|
113
|
+
.shl(tokenInfo.decimals)
|
|
114
|
+
.add(totalGasFee ?? 0n);
|
|
115
|
+
const maxValue = (tokenInfo.address === zeroAddress || isNative) &&
|
|
116
|
+
userBalance.gt(plusGasFee)
|
|
117
|
+
? userBalance.sub(plusGasFee)
|
|
118
|
+
: userBalance;
|
|
119
|
+
const _value = value === '50%' ? userBalance.div(2) : maxValue;
|
|
120
|
+
if (value === 'Max' && isLoadingFeeData) {
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
const _amount = formatTokenAmount({
|
|
124
|
+
amount: _value,
|
|
125
|
+
decimals: tokenInfo.decimals,
|
|
126
|
+
useGroupSeparator: false
|
|
127
|
+
});
|
|
128
|
+
if (_amount !== amount) {
|
|
129
|
+
onChange(_amount);
|
|
130
|
+
}
|
|
131
|
+
}, [
|
|
132
|
+
amount,
|
|
133
|
+
isLoadingFeeData,
|
|
134
|
+
isNative,
|
|
135
|
+
onChange,
|
|
136
|
+
tokenInfo.address,
|
|
137
|
+
tokenInfo.decimals,
|
|
138
|
+
totalGasFee,
|
|
139
|
+
userBalance
|
|
140
|
+
]);
|
|
141
|
+
const balance = formatTokenAmount({
|
|
142
|
+
amount: userBalance,
|
|
143
|
+
decimals: tokenInfo.decimals
|
|
144
|
+
});
|
|
145
|
+
// useEffect(() => {
|
|
146
|
+
// if (isFrom) {
|
|
147
|
+
// console.log('######userBalance.gt(0)######:', userBalance.gt(0))
|
|
148
|
+
// console.log('######isFrom######:', isFrom)
|
|
149
|
+
// }
|
|
150
|
+
// }, [isFrom, userBalance])
|
|
151
|
+
const usdValue = usdPrice && amount && usdPrice.gt(0)
|
|
152
|
+
? new Fraction(amount).mul(usdPrice).toFormat({
|
|
153
|
+
decimalPlaces: 2
|
|
154
|
+
})
|
|
155
|
+
: null;
|
|
156
|
+
useEffect(() => {
|
|
157
|
+
if (isFrom) {
|
|
158
|
+
setFromAmountToUsd(usdValue);
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
setToAmountToUsd(usdValue);
|
|
162
|
+
}
|
|
163
|
+
}, [isFrom, setFromAmountToUsd, setToAmountToUsd, usdValue]);
|
|
164
|
+
const renderLossWarning = () => {
|
|
165
|
+
if (!isFrom && fromAmountToUsd && toAmountToUsd) {
|
|
166
|
+
if (+fromAmountToUsd > 50 && +fromAmountToUsd > +toAmountToUsd) {
|
|
167
|
+
const loss = -(+toAmountToUsd - +fromAmountToUsd) / +fromAmountToUsd;
|
|
168
|
+
if (loss >= 0.1) {
|
|
169
|
+
// console.log('###loss###:', loss)
|
|
170
|
+
return (_jsx(Text, { as: 'span', color: '#ff4267', children: ` (-${(loss * 100).toFixed(2)}%)` }));
|
|
171
|
+
}
|
|
172
|
+
return _jsx(_Fragment, {});
|
|
173
|
+
}
|
|
174
|
+
return _jsx(_Fragment, {});
|
|
175
|
+
}
|
|
176
|
+
return _jsx(_Fragment, {});
|
|
177
|
+
};
|
|
178
|
+
const FiEditDom = () => {
|
|
179
|
+
return (_jsx(FiEdit, { cursor: 'pointer', width: '16px', height: '16px', onClick: () => {
|
|
180
|
+
onOpenDialog?.();
|
|
181
|
+
} }));
|
|
182
|
+
};
|
|
183
|
+
const renderDifferentAddress = () => {
|
|
184
|
+
if (address && !isFrom) {
|
|
185
|
+
if (isDepositPlatformToken) {
|
|
186
|
+
if (differentAddress) {
|
|
187
|
+
return (_jsxs(HStack, { gap: 1, children: [walletIcon, _jsx(Text, { variant: 'content8', backgroundColor: '#fff', padding: '2px', ...widgetStyles.balanceText, children: sliceAddress(differentAddress) }), FiEditDom()] }));
|
|
188
|
+
}
|
|
189
|
+
return (_jsxs(HStack, { gap: 1, children: [_jsx(Text, { variant: 'content8', backgroundColor: '#fff', padding: '2px 6px', borderRadius: '14px', cursor: 'pointer', onClick: () => {
|
|
190
|
+
onOpenDialog?.();
|
|
191
|
+
}, ...widgetStyles.balanceText, children: "Enter Address" }), FiEditDom()] }));
|
|
192
|
+
}
|
|
193
|
+
return (_jsxs(HStack, { gap: 1, children: [walletIcon, _jsx(Text, { variant: 'content8', backgroundColor: '#fff', padding: '2px', ...widgetStyles.balanceText, children: sliceAddress(differentAddress ? differentAddress : address) }), FiEditDom()] }));
|
|
194
|
+
}
|
|
195
|
+
return null;
|
|
196
|
+
};
|
|
197
|
+
return (_jsxs(VStack, { align: 'start', w: '100%', bg: '#F5F6FF', px: {
|
|
198
|
+
base: 2,
|
|
199
|
+
md: 4
|
|
200
|
+
}, paddingBottom: {
|
|
201
|
+
base: isFrom ? 2 : 7,
|
|
202
|
+
md: isFrom ? 3 : 8
|
|
203
|
+
}, paddingTop: {
|
|
204
|
+
base: 2,
|
|
205
|
+
md: 3
|
|
206
|
+
}, borderRadius: {
|
|
207
|
+
base: '8px',
|
|
208
|
+
md: '16px'
|
|
209
|
+
}, gap: '0', ...widgetStyles.sectionContainer, children: [_jsxs(HStack, { w: '100%', justify: 'space-between', color: '#81728C', marginBottom: [2], children: [_jsx(Heading, { variant: 'heading11', height: '18px', ...widgetStyles.sectionLabelText, children: text }), address ? (_jsx(_Fragment, { children: isFrom && userBalance.gt(0) ? (_jsxs(HStack, { color: '#15003E', children: [_jsx(Button, { variant: 'outline', minW: '30px', h: {
|
|
210
|
+
base: '18px'
|
|
211
|
+
}, borderRadius: '4px', border: '1px solid', borderColor: 'brand-purple', onClick: () => handleQuickInput('50%'), ...quickHalfButtonStyles, children: _jsx(Text, { variant: 'content9', ...widgetStyles.balanceText, children: "50%" }) }), _jsx(Button, { minW: '30px', h: {
|
|
212
|
+
base: '18px'
|
|
213
|
+
}, borderRadius: '4px', bg: 'brand-purple', onClick: () => handleQuickInput('Max'), ...quickMaxButtonStyles, children: _jsx(Text, { variant: 'content9', ...widgetStyles.balanceText, children: "Max" }) }), _jsxs(Text, { variant: 'content8', color: '#81728C', ...widgetStyles.balanceText, children: ["Balance: ", balance] })] })) : (_jsx(_Fragment, {})) })) : null, renderDifferentAddress()] }), _jsxs(HStack, { w: '100%', justify: 'space-between', align: 'center', gap: {
|
|
214
|
+
base: 2.5,
|
|
215
|
+
md: 6
|
|
216
|
+
}, children: [_jsxs(HStack, { gap: {
|
|
217
|
+
base: 1,
|
|
218
|
+
md: 3
|
|
219
|
+
}, onClick: onClick, cursor: 'pointer', justify: 'space-between', px: {
|
|
220
|
+
base: 1.5,
|
|
221
|
+
md: 2.5
|
|
222
|
+
}, py: {
|
|
223
|
+
base: 2.5
|
|
224
|
+
}, bg: '#E3E4FA', borderRadius: {
|
|
225
|
+
base: '8px',
|
|
226
|
+
md: '12px'
|
|
227
|
+
}, w: '50%', ...widgetStyles.tokenSelector, children: [_jsx(TokenInfoCom, { tokenInfo: tokenInfo }), _jsx(Icon, { boxSize: {
|
|
228
|
+
base: '20px',
|
|
229
|
+
md: '24px'
|
|
230
|
+
}, as: ArrowDownIcon })] }), _jsxs(VStack, { w: '50%', pb: 2, h: {
|
|
231
|
+
base: '48px',
|
|
232
|
+
md: '52px'
|
|
233
|
+
}, border: '1px solid', borderColor: isFocused ? '#8143FF' : '#B5B5B5', bg: 'white', borderRadius: {
|
|
234
|
+
base: '8px',
|
|
235
|
+
md: '12px'
|
|
236
|
+
}, align: 'flex-end', position: 'relative', ...widgetStyles.amountInputContainer, children: [_jsx(Input, { id: `${text.toLowerCase()}-input`, px: {
|
|
237
|
+
base: 2,
|
|
238
|
+
md: 3
|
|
239
|
+
}, textAlign: 'right', fontWeight: '600', fontSize: {
|
|
240
|
+
base: '16px',
|
|
241
|
+
md: '18px'
|
|
242
|
+
}, _placeholder: {
|
|
243
|
+
color: 'brand-grey3'
|
|
244
|
+
}, onBlur: handleBlur, onFocus: handleFocus, disabled: !isFrom, color: isInsufficientBalance ? 'red' : 'brand-grey1', _disabled: {
|
|
245
|
+
color: 'brand-grey1',
|
|
246
|
+
opacity: 1
|
|
247
|
+
}, border: 'none', _focus: {
|
|
248
|
+
outlineWidth: '0px'
|
|
249
|
+
}, placeholder: "0", onChange: handleValueChange, value: value, inputMode: "decimal", type: "text", autoComplete: "off", ...widgetStyles.amountInputText }), _jsxs(Text, { variant: {
|
|
250
|
+
base: 'content9',
|
|
251
|
+
md: 'content8'
|
|
252
|
+
}, color: 'brand-grey4', pos: 'absolute', right: {
|
|
253
|
+
base: 2,
|
|
254
|
+
md: 3
|
|
255
|
+
}, bottom: '5px', ...widgetStyles.amountUsdText, children: [usdValue ? `~$${usdValue}` : null, renderLossWarning()] })] })] }), _jsx(HStack, { w: '100%', justify: 'flex-end', color: '#81728C', height: '18px', overflow: 'hidden', lineHeight: '18px', position: 'absolute', bottom: ['6px', '8px'], left: 0, paddingRight: [2, 4], children: address && (_jsx(_Fragment, { children: !isFrom && !isDepositPlatformToken && (_jsxs(Text, { variant: 'content8', children: ["Balance: ", differentAddressBalance] })) })) })] }));
|
|
256
|
+
};
|
|
257
|
+
//# sourceMappingURL=TokenSelectAndInput.js.map
|