@lifi/widget 3.40.11 → 4.0.0-alpha.2
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/esm/AppDefault.d.ts +8 -0
- package/dist/esm/AppDefault.js +231 -14
- package/dist/esm/AppDefault.js.map +1 -1
- package/dist/esm/AppLayout.d.ts +1 -0
- package/dist/esm/AppLayout.js +19 -0
- package/dist/esm/AppLayout.js.map +1 -0
- package/dist/esm/AppProvider.js +7 -20
- package/dist/esm/AppProvider.js.map +1 -1
- package/dist/esm/components/ActiveTransactions/ActiveTransactionItem.js +9 -6
- package/dist/esm/components/ActiveTransactions/ActiveTransactionItem.js.map +1 -1
- package/dist/esm/components/ActiveTransactions/ActiveTransactions.js +2 -2
- package/dist/esm/components/ActiveTransactions/ActiveTransactions.js.map +1 -1
- package/dist/esm/components/ActiveTransactions/ActiveTransactions.style.d.ts +2 -2
- package/dist/esm/components/AmountInput/AmountInput.js +5 -7
- package/dist/esm/components/AmountInput/AmountInput.js.map +1 -1
- package/dist/esm/components/AmountInput/AmountInput.style.d.ts +2 -2
- package/dist/esm/components/AmountInput/AmountInputAdornment.style.d.ts +1 -1
- package/dist/esm/components/AmountInput/AmountInputEndAdornment.js +1 -1
- package/dist/esm/components/AmountInput/AmountInputEndAdornment.js.map +1 -1
- package/dist/esm/components/AmountInput/PriceFormHelperText.style.d.ts +1 -1
- package/dist/esm/components/AppContainer.d.ts +1 -1
- package/dist/esm/components/Avatar/AccountAvatar.d.ts +1 -1
- package/dist/esm/components/Avatar/AccountAvatar.js.map +1 -1
- package/dist/esm/components/Avatar/Avatar.style.d.ts +1 -1
- package/dist/esm/components/Avatar/SmallAvatar.d.ts +1 -1
- package/dist/esm/components/ButtonTertiary.d.ts +1 -1
- package/dist/esm/components/Card/Card.d.ts +1 -1
- package/dist/esm/components/Card/CardButton.style.d.ts +2 -2
- package/dist/esm/components/Card/CardHeader.d.ts +1 -1
- package/dist/esm/components/Card/CardIconButton.d.ts +3 -3
- package/dist/esm/components/Card/CardLabel.d.ts +1 -1
- package/dist/esm/components/Card/CardTitle.d.ts +1 -1
- package/dist/esm/components/Card/InputCard.d.ts +1 -1
- package/dist/esm/components/ChainSelect/ChainSelect.js +8 -3
- package/dist/esm/components/ChainSelect/ChainSelect.js.map +1 -1
- package/dist/esm/components/ChainSelect/ChainSelect.style.d.ts +3 -3
- package/dist/esm/components/Chains/ChainList.style.d.ts +4 -4
- package/dist/esm/components/Chains/VirtualizedChainList.d.ts +1 -1
- package/dist/esm/components/Chains/VirtualizedChainList.js +7 -1
- package/dist/esm/components/Chains/VirtualizedChainList.js.map +1 -1
- package/dist/esm/components/ContractComponent/ItemPrice.d.ts +1 -1
- package/dist/esm/components/ContractComponent/ItemPrice.js +1 -1
- package/dist/esm/components/ContractComponent/ItemPrice.js.map +1 -1
- package/dist/esm/components/ContractComponent/NFT/NFT.js +1 -1
- package/dist/esm/components/ContractComponent/NFT/NFT.js.map +1 -1
- package/dist/esm/components/ContractComponent/NFT/NFT.style.d.ts +1 -1
- package/dist/esm/components/Header/BackButton.d.ts +1 -2
- package/dist/esm/components/Header/BackButton.js +16 -2
- package/dist/esm/components/Header/BackButton.js.map +1 -1
- package/dist/esm/components/Header/DisconnectIconButton.d.ts +1 -1
- package/dist/esm/components/Header/DisconnectIconButton.js.map +1 -1
- package/dist/esm/components/Header/Header.js +1 -1
- package/dist/esm/components/Header/Header.js.map +1 -1
- package/dist/esm/components/Header/Header.style.d.ts +3 -3
- package/dist/esm/components/Header/NavigationHeader.js +7 -13
- package/dist/esm/components/Header/NavigationHeader.js.map +1 -1
- package/dist/esm/components/Header/SettingsButton.js +3 -3
- package/dist/esm/components/Header/SettingsButton.js.map +1 -1
- package/dist/esm/components/Header/SettingsButton.style.d.ts +2 -2
- package/dist/esm/components/Header/TransactionHistoryButton.js +3 -3
- package/dist/esm/components/Header/TransactionHistoryButton.js.map +1 -1
- package/dist/esm/components/Header/WalletHeader.js.map +1 -1
- package/dist/esm/components/ListItem/ListItem.d.ts +1 -1
- package/dist/esm/components/ListItem/ListItemButton.d.ts +1 -1
- package/dist/esm/components/ListItemButton.d.ts +1 -1
- package/dist/esm/components/Messages/GasSufficiencyMessage.js +1 -1
- package/dist/esm/components/Messages/GasSufficiencyMessage.js.map +1 -1
- package/dist/esm/components/PageContainer.d.ts +1 -1
- package/dist/esm/components/PageEntered.js +1 -1
- package/dist/esm/components/PageEntered.js.map +1 -1
- package/dist/esm/components/PoweredBy/PoweredBy.style.d.ts +1 -1
- package/dist/esm/components/ReverseTokensButton/ReverseTokensButton.js +0 -9
- package/dist/esm/components/ReverseTokensButton/ReverseTokensButton.js.map +1 -1
- package/dist/esm/components/ReverseTokensButton/ReverseTokensButton.style.d.ts +1 -1
- package/dist/esm/components/RouteCard/RouteCard.js +1 -3
- package/dist/esm/components/RouteCard/RouteCard.js.map +1 -1
- package/dist/esm/components/Routes/Routes.js +3 -4
- package/dist/esm/components/Routes/Routes.js.map +1 -1
- package/dist/esm/components/Routes/RoutesContent.js +1 -2
- package/dist/esm/components/Routes/RoutesContent.js.map +1 -1
- package/dist/esm/components/Routes/RoutesExpanded.js +4 -3
- package/dist/esm/components/Routes/RoutesExpanded.js.map +1 -1
- package/dist/esm/components/Routes/RoutesExpanded.style.d.ts +1 -1
- package/dist/esm/components/Search/SearchInput.style.d.ts +1 -1
- package/dist/esm/components/Search/SearchNotFound.style.d.ts +2 -2
- package/dist/esm/components/SelectChainAndToken.js +2 -3
- package/dist/esm/components/SelectChainAndToken.js.map +1 -1
- package/dist/esm/components/SelectTokenButton/SelectTokenButton.js +10 -10
- package/dist/esm/components/SelectTokenButton/SelectTokenButton.js.map +1 -1
- package/dist/esm/components/SelectTokenButton/SelectTokenButton.style.d.ts +3 -3
- package/dist/esm/components/SendToWallet/SendToWallet.style.d.ts +1 -1
- package/dist/esm/components/SendToWallet/SendToWalletButton.js +10 -8
- package/dist/esm/components/SendToWallet/SendToWalletButton.js.map +1 -1
- package/dist/esm/components/SettingsListItemButton.d.ts +1 -1
- package/dist/esm/components/Skeleton/WidgetSkeleton.style.d.ts +4 -4
- package/dist/esm/components/Step/CircularProgress.d.ts +3 -3
- package/dist/esm/components/Step/CircularProgress.js +8 -8
- package/dist/esm/components/Step/CircularProgress.js.map +1 -1
- package/dist/esm/components/Step/CircularProgress.style.d.ts +2 -2
- package/dist/esm/components/Step/CircularProgress.style.js.map +1 -1
- package/dist/esm/components/Step/Step.js +8 -11
- package/dist/esm/components/Step/Step.js.map +1 -1
- package/dist/esm/components/Step/StepAction.d.ts +5 -0
- package/dist/esm/components/Step/{StepProcess.js → StepAction.js} +16 -12
- package/dist/esm/components/Step/StepAction.js.map +1 -0
- package/dist/esm/components/StepActions/StepActions.js +3 -2
- package/dist/esm/components/StepActions/StepActions.js.map +1 -1
- package/dist/esm/components/StepActions/StepActions.style.d.ts +2 -2
- package/dist/esm/components/StepDivider/StepDivider.style.d.ts +1 -1
- package/dist/esm/components/Tabs/NavigationTabs.d.ts +4 -4
- package/dist/esm/components/Tabs/Tabs.style.d.ts +3 -3
- package/dist/esm/components/Timer/StepTimer.js +26 -74
- package/dist/esm/components/Timer/StepTimer.js.map +1 -1
- package/dist/esm/components/Token/Token.style.d.ts +1 -1
- package/dist/esm/components/TokenList/PinTokenButton.d.ts +6 -0
- package/dist/esm/components/TokenList/PinTokenButton.js +29 -0
- package/dist/esm/components/TokenList/PinTokenButton.js.map +1 -0
- package/dist/esm/components/TokenList/TokenDetailsSheetContent.style.d.ts +2 -2
- package/dist/esm/components/TokenList/TokenList.js +13 -5
- package/dist/esm/components/TokenList/TokenList.js.map +1 -1
- package/dist/esm/components/TokenList/TokenList.style.d.ts +6 -6
- package/dist/esm/components/TokenList/TokenListItem.js +5 -4
- package/dist/esm/components/TokenList/TokenListItem.js.map +1 -1
- package/dist/esm/components/TokenList/VirtualizedTokenList.js +63 -38
- package/dist/esm/components/TokenList/VirtualizedTokenList.js.map +1 -1
- package/dist/esm/components/TokenList/types.d.ts +2 -3
- package/dist/esm/components/TokenList/useTokenSelect.js +2 -3
- package/dist/esm/components/TokenList/useTokenSelect.js.map +1 -1
- package/dist/esm/components/TokenRate/TokenRate.d.ts +1 -1
- package/dist/esm/components/TokenRate/TokenRate.js +1 -1
- package/dist/esm/components/TokenRate/TokenRate.js.map +1 -1
- package/dist/esm/components/TokenRate/TokenRate.style.d.ts +1 -1
- package/dist/esm/components/TransactionDetails.js +3 -2
- package/dist/esm/components/TransactionDetails.js.map +1 -1
- package/dist/esm/config/version.d.ts +1 -1
- package/dist/esm/config/version.js +1 -1
- package/dist/esm/config/version.js.map +1 -1
- package/dist/esm/hooks/useActionMessage.d.ts +5 -0
- package/dist/esm/hooks/useActionMessage.js +18 -0
- package/dist/esm/hooks/useActionMessage.js.map +1 -0
- package/dist/esm/hooks/useAddressActivity.js +18 -9
- package/dist/esm/hooks/useAddressActivity.js.map +1 -1
- package/dist/esm/hooks/useAddressValidation.js +5 -2
- package/dist/esm/hooks/useAddressValidation.js.map +1 -1
- package/dist/esm/hooks/useAvailableChains.d.ts +2 -1
- package/dist/esm/hooks/useAvailableChains.js +32 -11
- package/dist/esm/hooks/useAvailableChains.js.map +1 -1
- package/dist/esm/hooks/useExplorer.js +1 -2
- package/dist/esm/hooks/useExplorer.js.map +1 -1
- package/dist/esm/hooks/useFilteredByTokenBalances.js +3 -1
- package/dist/esm/hooks/useFilteredByTokenBalances.js.map +1 -1
- package/dist/esm/hooks/useFromTokenSufficiency.d.ts +1 -1
- package/dist/esm/hooks/useFromTokenSufficiency.js +4 -4
- package/dist/esm/hooks/useFromTokenSufficiency.js.map +1 -1
- package/dist/esm/hooks/useGasRecommendation.js +3 -1
- package/dist/esm/hooks/useGasRecommendation.js.map +1 -1
- package/dist/esm/hooks/useGasSufficiency.js +21 -15
- package/dist/esm/hooks/useGasSufficiency.js.map +1 -1
- package/dist/esm/hooks/useHasChainExpansion.d.ts +1 -1
- package/dist/esm/hooks/useHasChainExpansion.js +11 -3
- package/dist/esm/hooks/useHasChainExpansion.js.map +1 -1
- package/dist/esm/hooks/useInitializeSDKProviders.d.ts +1 -0
- package/dist/esm/hooks/useInitializeSDKProviders.js +11 -0
- package/dist/esm/hooks/useInitializeSDKProviders.js.map +1 -0
- package/dist/esm/hooks/useIsBatchingSupported.js +7 -3
- package/dist/esm/hooks/useIsBatchingSupported.js.map +1 -1
- package/dist/esm/hooks/useIsContractAddress.js +12 -9
- package/dist/esm/hooks/useIsContractAddress.js.map +1 -1
- package/dist/esm/hooks/useNavigateBack.d.ts +1 -4
- package/dist/esm/hooks/useNavigateBack.js +9 -23
- package/dist/esm/hooks/useNavigateBack.js.map +1 -1
- package/dist/esm/hooks/useRouteExecution.js +12 -13
- package/dist/esm/hooks/useRouteExecution.js.map +1 -1
- package/dist/esm/hooks/useRoutes.js +23 -60
- package/dist/esm/hooks/useRoutes.js.map +1 -1
- package/dist/esm/hooks/useToAddressAutoPopulate.js +3 -1
- package/dist/esm/hooks/useToAddressAutoPopulate.js.map +1 -1
- package/dist/esm/hooks/useToAddressRequirements.js +3 -2
- package/dist/esm/hooks/useToAddressRequirements.js.map +1 -1
- package/dist/esm/hooks/useTokenBalance.d.ts +3 -3
- package/dist/esm/hooks/useTokenBalance.js +8 -6
- package/dist/esm/hooks/useTokenBalance.js.map +1 -1
- package/dist/esm/hooks/useTokenBalances.d.ts +1 -0
- package/dist/esm/hooks/useTokenBalances.js +70 -5
- package/dist/esm/hooks/useTokenBalances.js.map +1 -1
- package/dist/esm/hooks/useTokenBalancesQueries.js +4 -2
- package/dist/esm/hooks/useTokenBalancesQueries.js.map +1 -1
- package/dist/esm/hooks/useTokenSearch.js +3 -1
- package/dist/esm/hooks/useTokenSearch.js.map +1 -1
- package/dist/esm/hooks/useTokens.js +11 -5
- package/dist/esm/hooks/useTokens.js.map +1 -1
- package/dist/esm/hooks/useTools.js +3 -1
- package/dist/esm/hooks/useTools.js.map +1 -1
- package/dist/esm/hooks/useTransactionDetails.js +3 -1
- package/dist/esm/hooks/useTransactionDetails.js.map +1 -1
- package/dist/esm/hooks/useTransactionHistory.js +3 -1
- package/dist/esm/hooks/useTransactionHistory.js.map +1 -1
- package/dist/esm/hooks/useWidgetChains.d.ts +6 -0
- package/dist/esm/hooks/useWidgetChains.js +5 -0
- package/dist/esm/hooks/useWidgetChains.js.map +1 -0
- package/dist/esm/i18n/bn.json +4 -1
- package/dist/esm/i18n/de.json +4 -1
- package/dist/esm/i18n/en.json +3 -14
- package/dist/esm/i18n/es.json +4 -1
- package/dist/esm/i18n/fr.json +4 -1
- package/dist/esm/i18n/hi.json +4 -1
- package/dist/esm/i18n/id.json +4 -1
- package/dist/esm/i18n/it.json +4 -1
- package/dist/esm/i18n/ja.json +4 -1
- package/dist/esm/i18n/ko.json +4 -1
- package/dist/esm/i18n/pl.json +4 -1
- package/dist/esm/i18n/pt.json +4 -1
- package/dist/esm/i18n/th.json +4 -1
- package/dist/esm/i18n/tr.json +4 -1
- package/dist/esm/i18n/uk.json +4 -1
- package/dist/esm/i18n/vi.json +4 -1
- package/dist/esm/i18n/zh.json +4 -1
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.js +2 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/pages/LanguagesPage.js +7 -6
- package/dist/esm/pages/LanguagesPage.js.map +1 -1
- package/dist/esm/pages/MainPage/MainPage.js +1 -3
- package/dist/esm/pages/MainPage/MainPage.js.map +1 -1
- package/dist/esm/pages/MainPage/ReviewButton.js +5 -5
- package/dist/esm/pages/MainPage/ReviewButton.js.map +1 -1
- package/dist/esm/pages/RoutesPage/RoutesPage.d.ts +1 -2
- package/dist/esm/pages/RoutesPage/RoutesPage.js +5 -4
- package/dist/esm/pages/RoutesPage/RoutesPage.js.map +1 -1
- package/dist/esm/pages/SelectChainPage/SelectChainPage.js +1 -1
- package/dist/esm/pages/SelectChainPage/SelectChainPage.js.map +1 -1
- package/dist/esm/pages/SelectTokenPage/SelectTokenPage.js +2 -13
- package/dist/esm/pages/SelectTokenPage/SelectTokenPage.js.map +1 -1
- package/dist/esm/pages/SendToWallet/BookmarksPage.js +3 -5
- package/dist/esm/pages/SendToWallet/BookmarksPage.js.map +1 -1
- package/dist/esm/pages/SendToWallet/ConfirmAddressSheet.js +1 -1
- package/dist/esm/pages/SendToWallet/ConfirmAddressSheet.js.map +1 -1
- package/dist/esm/pages/SendToWallet/ConnectedWalletsPage.js +4 -3
- package/dist/esm/pages/SendToWallet/ConnectedWalletsPage.js.map +1 -1
- package/dist/esm/pages/SendToWallet/RecentWalletsPage.js +4 -7
- package/dist/esm/pages/SendToWallet/RecentWalletsPage.js.map +1 -1
- package/dist/esm/pages/SendToWallet/SendToConfiguredWalletPage.js +1 -1
- package/dist/esm/pages/SendToWallet/SendToConfiguredWalletPage.js.map +1 -1
- package/dist/esm/pages/SendToWallet/SendToWalletPage.d.ts +1 -1
- package/dist/esm/pages/SendToWallet/SendToWalletPage.js +5 -5
- package/dist/esm/pages/SendToWallet/SendToWalletPage.js.map +1 -1
- package/dist/esm/pages/SendToWallet/SendToWalletPage.style.d.ts +8 -8
- package/dist/esm/pages/SettingsPage/BridgeAndExchangeSettings.js +4 -2
- package/dist/esm/pages/SettingsPage/BridgeAndExchangeSettings.js.map +1 -1
- package/dist/esm/pages/SettingsPage/LanguageSetting.js +2 -2
- package/dist/esm/pages/SettingsPage/LanguageSetting.js.map +1 -1
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingCard.style.d.ts +1 -1
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingCardExpandable.d.ts +12 -2
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingCardExpandable.js +10 -4
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingCardExpandable.js.map +1 -1
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingsAccordian.d.ts +1 -1
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingsAccordian.js +2 -2
- package/dist/esm/pages/SettingsPage/SettingsCard/SettingsAccordian.js.map +1 -1
- package/dist/esm/pages/SettingsPage/SettingsPage.js +5 -1
- package/dist/esm/pages/SettingsPage/SettingsPage.js.map +1 -1
- package/dist/esm/pages/SettingsPage/SlippageSettings/SlippageSettings.js +3 -3
- package/dist/esm/pages/SettingsPage/SlippageSettings/SlippageSettings.js.map +1 -1
- package/dist/esm/pages/SettingsPage/SlippageSettings/SlippageSettings.style.d.ts +3 -3
- package/dist/esm/pages/SettingsPage/SlippageSettings/SlippageSettings.style.js +9 -9
- package/dist/esm/pages/SettingsPage/SmallBalanceFilterSettings.d.ts +1 -0
- package/dist/esm/pages/SettingsPage/SmallBalanceFilterSettings.js +58 -0
- package/dist/esm/pages/SettingsPage/SmallBalanceFilterSettings.js.map +1 -0
- package/dist/esm/pages/TransactionDetailsPage/TransactionDetailsPage.js +7 -8
- package/dist/esm/pages/TransactionDetailsPage/TransactionDetailsPage.js.map +1 -1
- package/dist/esm/pages/TransactionHistoryPage/TransactionHistoryItem.js +4 -3
- package/dist/esm/pages/TransactionHistoryPage/TransactionHistoryItem.js.map +1 -1
- package/dist/esm/pages/TransactionHistoryPage/TransactionHistoryPage.d.ts +1 -2
- package/dist/esm/pages/TransactionHistoryPage/TransactionHistoryPage.js.map +1 -1
- package/dist/esm/pages/TransactionPage/StatusBottomSheet.js +13 -12
- package/dist/esm/pages/TransactionPage/StatusBottomSheet.js.map +1 -1
- package/dist/esm/pages/TransactionPage/TransactionPage.d.ts +1 -1
- package/dist/esm/pages/TransactionPage/TransactionPage.js +13 -6
- package/dist/esm/pages/TransactionPage/TransactionPage.js.map +1 -1
- package/dist/esm/providers/I18nProvider/I18nProvider.js +1 -0
- package/dist/esm/providers/I18nProvider/I18nProvider.js.map +1 -1
- package/dist/esm/providers/SDKClientProvider.d.ts +4 -0
- package/dist/esm/providers/SDKClientProvider.js +29 -0
- package/dist/esm/providers/SDKClientProvider.js.map +1 -0
- package/dist/esm/providers/WalletProvider/WalletProvider.d.ts +7 -2
- package/dist/esm/providers/WalletProvider/WalletProvider.js +27 -11
- package/dist/esm/providers/WalletProvider/WalletProvider.js.map +1 -1
- package/dist/esm/providers/WalletProvider/useExternalWalletProvider.js +15 -18
- package/dist/esm/providers/WalletProvider/useExternalWalletProvider.js.map +1 -1
- package/dist/esm/providers/WidgetProvider/WidgetProvider.js +0 -27
- package/dist/esm/providers/WidgetProvider/WidgetProvider.js.map +1 -1
- package/dist/esm/stores/StoreProvider.js +2 -1
- package/dist/esm/stores/StoreProvider.js.map +1 -1
- package/dist/esm/stores/bookmarks/types.d.ts +2 -3
- package/dist/esm/stores/chains/ChainOrderStore.js +17 -12
- package/dist/esm/stores/chains/ChainOrderStore.js.map +1 -1
- package/dist/esm/stores/chains/createChainOrderStore.d.ts +0 -8
- package/dist/esm/stores/chains/createChainOrderStore.js +1 -5
- package/dist/esm/stores/chains/createChainOrderStore.js.map +1 -1
- package/dist/esm/stores/form/FormStore.js +18 -8
- package/dist/esm/stores/form/FormStore.js.map +1 -1
- package/dist/esm/stores/form/FormUpdater.js +5 -50
- package/dist/esm/stores/form/FormUpdater.js.map +1 -1
- package/dist/esm/stores/form/URLSearchParamsBuilder.js +11 -31
- package/dist/esm/stores/form/URLSearchParamsBuilder.js.map +1 -1
- package/dist/esm/stores/form/getDefaultValuesFromQueryString.d.ts +7 -0
- package/dist/esm/stores/form/getDefaultValuesFromQueryString.js +32 -0
- package/dist/esm/stores/form/getDefaultValuesFromQueryString.js.map +1 -0
- package/dist/esm/stores/form/types.d.ts +2 -3
- package/dist/esm/stores/form/types.js.map +1 -1
- package/dist/esm/stores/header/types.d.ts +5 -3
- package/dist/esm/stores/header/useHeaderStore.js +14 -0
- package/dist/esm/stores/header/useHeaderStore.js.map +1 -1
- package/dist/esm/stores/pinnedTokens/PinnedTokensStore.d.ts +4 -0
- package/dist/esm/stores/pinnedTokens/PinnedTokensStore.js +20 -0
- package/dist/esm/stores/pinnedTokens/PinnedTokensStore.js.map +1 -0
- package/dist/esm/stores/pinnedTokens/createPinnedTokensStore.d.ts +19 -0
- package/dist/esm/stores/pinnedTokens/createPinnedTokensStore.js +61 -0
- package/dist/esm/stores/pinnedTokens/createPinnedTokensStore.js.map +1 -0
- package/dist/esm/stores/pinnedTokens/types.d.ts +17 -0
- package/dist/esm/stores/pinnedTokens/types.js +2 -0
- package/dist/esm/stores/pinnedTokens/types.js.map +1 -0
- package/dist/esm/stores/routes/RouteExecutionStore.d.ts +2 -3
- package/dist/esm/stores/routes/RouteExecutionStore.js.map +1 -1
- package/dist/esm/stores/routes/createRouteExecutionStore.js +2 -5
- package/dist/esm/stores/routes/createRouteExecutionStore.js.map +1 -1
- package/dist/esm/stores/routes/useExecutingRoutesIds.js +2 -2
- package/dist/esm/stores/routes/useExecutingRoutesIds.js.map +1 -1
- package/dist/esm/stores/routes/utils.d.ts +2 -2
- package/dist/esm/stores/routes/utils.js +15 -15
- package/dist/esm/stores/routes/utils.js.map +1 -1
- package/dist/esm/stores/settings/SettingsStore.d.ts +2 -3
- package/dist/esm/stores/settings/SettingsStore.js.map +1 -1
- package/dist/esm/stores/settings/createSettingsStore.d.ts +2 -0
- package/dist/esm/stores/settings/createSettingsStore.js +2 -1
- package/dist/esm/stores/settings/createSettingsStore.js.map +1 -1
- package/dist/esm/stores/settings/types.d.ts +3 -3
- package/dist/esm/stores/settings/types.js.map +1 -1
- package/dist/esm/types/events.d.ts +2 -10
- package/dist/esm/types/events.js +0 -1
- package/dist/esm/types/events.js.map +1 -1
- package/dist/esm/types/token.d.ts +1 -0
- package/dist/esm/types/widget.d.ts +9 -16
- package/dist/esm/types/widget.js +1 -0
- package/dist/esm/types/widget.js.map +1 -1
- package/dist/esm/utils/chainType.d.ts +1 -2
- package/dist/esm/utils/chainType.js +1 -19
- package/dist/esm/utils/chainType.js.map +1 -1
- package/dist/esm/utils/converters.js +11 -18
- package/dist/esm/utils/converters.js.map +1 -1
- package/dist/esm/utils/format.d.ts +1 -0
- package/dist/esm/utils/format.js +2 -1
- package/dist/esm/utils/format.js.map +1 -1
- package/dist/esm/utils/getActionMessage.d.ts +7 -0
- package/dist/esm/utils/getActionMessage.js +111 -0
- package/dist/esm/utils/getActionMessage.js.map +1 -0
- package/dist/esm/utils/getErrorMessage.d.ts +6 -0
- package/dist/esm/utils/getErrorMessage.js +118 -0
- package/dist/esm/utils/getErrorMessage.js.map +1 -0
- package/dist/esm/utils/prepareActions.d.ts +2 -0
- package/dist/esm/utils/prepareActions.js +24 -0
- package/dist/esm/utils/prepareActions.js.map +1 -0
- package/dist/esm/utils/tokenList.d.ts +3 -2
- package/dist/esm/utils/tokenList.js +104 -8
- package/dist/esm/utils/tokenList.js.map +1 -1
- package/package.json +30 -23
- package/src/AppDefault.tsx +279 -31
- package/src/AppLayout.tsx +36 -0
- package/src/AppProvider.tsx +12 -40
- package/src/components/ActiveTransactions/ActiveTransactionItem.tsx +9 -6
- package/src/components/ActiveTransactions/ActiveTransactions.tsx +2 -2
- package/src/components/AmountInput/AmountInput.tsx +6 -8
- package/src/components/AmountInput/AmountInputEndAdornment.tsx +1 -1
- package/src/components/Avatar/AccountAvatar.tsx +1 -1
- package/src/components/ChainSelect/ChainSelect.tsx +8 -4
- package/src/components/Chains/VirtualizedChainList.tsx +7 -3
- package/src/components/ContractComponent/ItemPrice.tsx +1 -2
- package/src/components/ContractComponent/NFT/NFT.tsx +1 -1
- package/src/components/Header/BackButton.tsx +15 -3
- package/src/components/Header/DisconnectIconButton.tsx +2 -1
- package/src/components/Header/Header.tsx +1 -1
- package/src/components/Header/NavigationHeader.tsx +23 -46
- package/src/components/Header/SettingsButton.tsx +3 -3
- package/src/components/Header/TransactionHistoryButton.tsx +3 -3
- package/src/components/Header/WalletHeader.tsx +1 -1
- package/src/components/Messages/GasSufficiencyMessage.tsx +1 -1
- package/src/components/PageEntered.ts +1 -1
- package/src/components/ReverseTokensButton/ReverseTokensButton.tsx +0 -10
- package/src/components/RouteCard/RouteCard.tsx +1 -3
- package/src/components/Routes/Routes.tsx +3 -4
- package/src/components/Routes/RoutesContent.tsx +1 -2
- package/src/components/Routes/RoutesExpanded.tsx +4 -3
- package/src/components/SelectChainAndToken.tsx +2 -4
- package/src/components/SelectTokenButton/SelectTokenButton.tsx +11 -13
- package/src/components/SendToWallet/SendToWalletButton.tsx +9 -12
- package/src/components/Step/CircularProgress.style.tsx +3 -3
- package/src/components/Step/CircularProgress.tsx +11 -11
- package/src/components/Step/Step.tsx +13 -14
- package/src/components/Step/{StepProcess.tsx → StepAction.tsx} +20 -15
- package/src/components/StepActions/StepActions.tsx +3 -2
- package/src/components/Timer/StepTimer.tsx +43 -105
- package/src/components/TokenList/PinTokenButton.tsx +50 -0
- package/src/components/TokenList/TokenList.tsx +67 -59
- package/src/components/TokenList/TokenListItem.tsx +20 -11
- package/src/components/TokenList/VirtualizedTokenList.tsx +80 -53
- package/src/components/TokenList/types.ts +2 -3
- package/src/components/TokenList/useTokenSelect.ts +2 -8
- package/src/components/TokenRate/TokenRate.tsx +1 -2
- package/src/components/TransactionDetails.tsx +3 -2
- package/src/config/version.ts +1 -1
- package/src/hooks/useActionMessage.ts +33 -0
- package/src/hooks/useAddressActivity.ts +19 -11
- package/src/hooks/useAddressValidation.ts +9 -2
- package/src/hooks/useAvailableChains.ts +42 -14
- package/src/hooks/useExplorer.ts +1 -2
- package/src/hooks/useFilteredByTokenBalances.ts +3 -1
- package/src/hooks/useFromTokenSufficiency.ts +8 -5
- package/src/hooks/useGasRecommendation.ts +3 -0
- package/src/hooks/useGasSufficiency.ts +23 -13
- package/src/hooks/useHasChainExpansion.ts +13 -3
- package/src/hooks/useInitializeSDKProviders.ts +12 -0
- package/src/hooks/useIsBatchingSupported.ts +11 -5
- package/src/hooks/useIsContractAddress.ts +14 -10
- package/src/hooks/useNavigateBack.ts +11 -29
- package/src/hooks/useRouteExecution.ts +12 -16
- package/src/hooks/useRoutes.ts +26 -74
- package/src/hooks/useToAddressAutoPopulate.ts +3 -1
- package/src/hooks/useToAddressRequirements.ts +3 -2
- package/src/hooks/useTokenBalance.ts +18 -3
- package/src/hooks/useTokenBalances.ts +91 -5
- package/src/hooks/useTokenBalancesQueries.ts +4 -2
- package/src/hooks/useTokenSearch.ts +10 -3
- package/src/hooks/useTokens.ts +11 -6
- package/src/hooks/useTools.ts +3 -1
- package/src/hooks/useTransactionDetails.ts +3 -0
- package/src/hooks/useTransactionHistory.ts +3 -0
- package/src/hooks/useWidgetChains.ts +6 -0
- package/src/index.ts +2 -8
- package/src/pages/LanguagesPage.tsx +2 -1
- package/src/pages/MainPage/MainPage.tsx +1 -3
- package/src/pages/MainPage/ReviewButton.tsx +5 -5
- package/src/pages/RoutesPage/RoutesPage.tsx +6 -6
- package/src/pages/SelectChainPage/SelectChainPage.tsx +1 -1
- package/src/pages/SelectTokenPage/SelectTokenPage.tsx +4 -28
- package/src/pages/SendToWallet/BookmarksPage.tsx +3 -5
- package/src/pages/SendToWallet/ConfirmAddressSheet.tsx +1 -1
- package/src/pages/SendToWallet/ConnectedWalletsPage.tsx +5 -4
- package/src/pages/SendToWallet/RecentWalletsPage.tsx +4 -7
- package/src/pages/SendToWallet/SendToConfiguredWalletPage.tsx +1 -1
- package/src/pages/SendToWallet/SendToWalletPage.tsx +6 -6
- package/src/pages/SettingsPage/BridgeAndExchangeSettings.tsx +4 -2
- package/src/pages/SettingsPage/LanguageSetting.tsx +2 -2
- package/src/pages/SettingsPage/SettingsCard/SettingCardExpandable.tsx +63 -33
- package/src/pages/SettingsPage/SettingsCard/SettingsAccordian.tsx +3 -2
- package/src/pages/SettingsPage/SettingsPage.tsx +7 -0
- package/src/pages/SettingsPage/SlippageSettings/SlippageSettings.style.tsx +10 -10
- package/src/pages/SettingsPage/SlippageSettings/SlippageSettings.tsx +5 -5
- package/src/pages/SettingsPage/SmallBalanceFilterSettings.tsx +116 -0
- package/src/pages/TransactionDetailsPage/TransactionDetailsPage.tsx +7 -8
- package/src/pages/TransactionHistoryPage/TransactionHistoryItem.tsx +4 -3
- package/src/pages/TransactionHistoryPage/TransactionHistoryPage.tsx +1 -2
- package/src/pages/TransactionPage/StatusBottomSheet.tsx +15 -14
- package/src/pages/TransactionPage/TransactionPage.tsx +14 -7
- package/src/providers/I18nProvider/I18nProvider.tsx +1 -0
- package/src/providers/SDKClientProvider.tsx +41 -0
- package/src/providers/WalletProvider/WalletProvider.tsx +61 -20
- package/src/providers/WalletProvider/useExternalWalletProvider.ts +20 -18
- package/src/providers/WidgetProvider/WidgetProvider.tsx +0 -29
- package/src/stores/StoreProvider.tsx +10 -7
- package/src/stores/bookmarks/types.ts +2 -3
- package/src/stores/chains/ChainOrderStore.tsx +29 -16
- package/src/stores/chains/createChainOrderStore.ts +1 -5
- package/src/stores/form/FormStore.tsx +19 -18
- package/src/stores/form/FormUpdater.tsx +5 -73
- package/src/stores/form/URLSearchParamsBuilder.tsx +12 -39
- package/src/stores/form/getDefaultValuesFromQueryString.ts +48 -0
- package/src/stores/form/types.ts +2 -5
- package/src/stores/header/types.ts +5 -3
- package/src/stores/header/useHeaderStore.tsx +14 -0
- package/src/stores/pinnedTokens/PinnedTokensStore.tsx +38 -0
- package/src/stores/pinnedTokens/createPinnedTokensStore.ts +71 -0
- package/src/stores/pinnedTokens/types.ts +20 -0
- package/src/stores/routes/RouteExecutionStore.tsx +2 -5
- package/src/stores/routes/createRouteExecutionStore.ts +4 -5
- package/src/stores/routes/useExecutingRoutesIds.ts +2 -2
- package/src/stores/routes/utils.ts +21 -19
- package/src/stores/settings/SettingsStore.tsx +2 -3
- package/src/stores/settings/createSettingsStore.ts +2 -1
- package/src/stores/settings/types.ts +3 -5
- package/src/types/events.ts +2 -11
- package/src/types/token.ts +1 -0
- package/src/types/widget.ts +18 -26
- package/src/utils/chainType.ts +1 -24
- package/src/utils/converters.ts +14 -20
- package/src/utils/format.ts +3 -1
- package/src/utils/getActionMessage.ts +168 -0
- package/src/utils/getErrorMessage.ts +144 -0
- package/src/utils/prepareActions.ts +27 -0
- package/src/utils/tokenList.ts +117 -11
- package/CHANGELOG.md +0 -2646
- package/dist/esm/AppRoutes.d.ts +0 -1
- package/dist/esm/AppRoutes.js +0 -111
- package/dist/esm/AppRoutes.js.map +0 -1
- package/dist/esm/components/Step/StepProcess.d.ts +0 -5
- package/dist/esm/components/Step/StepProcess.js.map +0 -1
- package/dist/esm/config/baseAccount.d.ts +0 -2
- package/dist/esm/config/baseAccount.js +0 -6
- package/dist/esm/config/baseAccount.js.map +0 -1
- package/dist/esm/config/coinbase.d.ts +0 -2
- package/dist/esm/config/coinbase.js +0 -6
- package/dist/esm/config/coinbase.js.map +0 -1
- package/dist/esm/config/metaMask.d.ts +0 -2
- package/dist/esm/config/metaMask.js +0 -11
- package/dist/esm/config/metaMask.js.map +0 -1
- package/dist/esm/config/walletConnect.d.ts +0 -2
- package/dist/esm/config/walletConnect.js +0 -4
- package/dist/esm/config/walletConnect.js.map +0 -1
- package/dist/esm/hooks/useExpansionRoutes.d.ts +0 -2
- package/dist/esm/hooks/useExpansionRoutes.js +0 -26
- package/dist/esm/hooks/useExpansionRoutes.js.map +0 -1
- package/dist/esm/hooks/useInternalWalletProvider.d.ts +0 -1
- package/dist/esm/hooks/useInternalWalletProvider.js +0 -6
- package/dist/esm/hooks/useInternalWalletProvider.js.map +0 -1
- package/dist/esm/hooks/useProcessMessage.d.ts +0 -11
- package/dist/esm/hooks/useProcessMessage.js +0 -199
- package/dist/esm/hooks/useProcessMessage.js.map +0 -1
- package/dist/esm/providers/WalletProvider/EVMBaseProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/EVMBaseProvider.js +0 -31
- package/dist/esm/providers/WalletProvider/EVMBaseProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/EVMExternalContext.d.ts +0 -1
- package/dist/esm/providers/WalletProvider/EVMExternalContext.js +0 -3
- package/dist/esm/providers/WalletProvider/EVMExternalContext.js.map +0 -1
- package/dist/esm/providers/WalletProvider/EVMProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/EVMProvider.js +0 -20
- package/dist/esm/providers/WalletProvider/EVMProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SDKProviders.d.ts +0 -1
- package/dist/esm/providers/WalletProvider/SDKProviders.js +0 -62
- package/dist/esm/providers/WalletProvider/SDKProviders.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SVMBaseProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/SVMBaseProvider.js +0 -27
- package/dist/esm/providers/WalletProvider/SVMBaseProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SVMExternalContext.d.ts +0 -1
- package/dist/esm/providers/WalletProvider/SVMExternalContext.js +0 -3
- package/dist/esm/providers/WalletProvider/SVMExternalContext.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SVMProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/SVMProvider.js +0 -20
- package/dist/esm/providers/WalletProvider/SVMProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SuiBaseProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/SuiBaseProvider.js +0 -17
- package/dist/esm/providers/WalletProvider/SuiBaseProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SuiExternalContext.d.ts +0 -1
- package/dist/esm/providers/WalletProvider/SuiExternalContext.js +0 -3
- package/dist/esm/providers/WalletProvider/SuiExternalContext.js.map +0 -1
- package/dist/esm/providers/WalletProvider/SuiProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/SuiProvider.js +0 -20
- package/dist/esm/providers/WalletProvider/SuiProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/UTXOBaseProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/UTXOBaseProvider.js +0 -18
- package/dist/esm/providers/WalletProvider/UTXOBaseProvider.js.map +0 -1
- package/dist/esm/providers/WalletProvider/UTXOExternalContext.d.ts +0 -1
- package/dist/esm/providers/WalletProvider/UTXOExternalContext.js +0 -3
- package/dist/esm/providers/WalletProvider/UTXOExternalContext.js.map +0 -1
- package/dist/esm/providers/WalletProvider/UTXOProvider.d.ts +0 -2
- package/dist/esm/providers/WalletProvider/UTXOProvider.js +0 -20
- package/dist/esm/providers/WalletProvider/UTXOProvider.js.map +0 -1
- package/package.json.tmp +0 -100
- package/src/AppRoutes.tsx +0 -112
- package/src/config/baseAccount.ts +0 -7
- package/src/config/coinbase.ts +0 -7
- package/src/config/metaMask.ts +0 -13
- package/src/config/walletConnect.ts +0 -5
- package/src/hooks/useExpansionRoutes.ts +0 -29
- package/src/hooks/useInternalWalletProvider.ts +0 -6
- package/src/hooks/useProcessMessage.ts +0 -273
- package/src/i18n/bn.json +0 -354
- package/src/i18n/de.json +0 -354
- package/src/i18n/en.json +0 -368
- package/src/i18n/es.json +0 -354
- package/src/i18n/fr.json +0 -354
- package/src/i18n/hi.json +0 -354
- package/src/i18n/id.json +0 -354
- package/src/i18n/it.json +0 -354
- package/src/i18n/ja.json +0 -354
- package/src/i18n/ko.json +0 -354
- package/src/i18n/pl.json +0 -354
- package/src/i18n/pt.json +0 -354
- package/src/i18n/th.json +0 -354
- package/src/i18n/tr.json +0 -354
- package/src/i18n/uk.json +0 -354
- package/src/i18n/vi.json +0 -354
- package/src/i18n/zh.json +0 -354
- package/src/providers/WalletProvider/EVMBaseProvider.tsx +0 -41
- package/src/providers/WalletProvider/EVMExternalContext.ts +0 -3
- package/src/providers/WalletProvider/EVMProvider.tsx +0 -28
- package/src/providers/WalletProvider/SDKProviders.tsx +0 -86
- package/src/providers/WalletProvider/SVMBaseProvider.tsx +0 -37
- package/src/providers/WalletProvider/SVMExternalContext.ts +0 -3
- package/src/providers/WalletProvider/SVMProvider.tsx +0 -29
- package/src/providers/WalletProvider/SuiBaseProvider.tsx +0 -31
- package/src/providers/WalletProvider/SuiExternalContext.ts +0 -3
- package/src/providers/WalletProvider/SuiProvider.tsx +0 -28
- package/src/providers/WalletProvider/UTXOBaseProvider.tsx +0 -29
- package/src/providers/WalletProvider/UTXOExternalContext.ts +0 -3
- package/src/providers/WalletProvider/UTXOProvider.tsx +0 -28
- package/src/utils/compactNumberFormatter.test.ts +0 -67
- package/src/utils/format.test.ts +0 -53
- package/tsconfig.json +0 -15
|
@@ -1,27 +1,32 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { ExecutionAction, LiFiStepExtended } from '@lifi/sdk'
|
|
2
2
|
import OpenInNewRounded from '@mui/icons-material/OpenInNewRounded'
|
|
3
3
|
import { Box, Link, Typography } from '@mui/material'
|
|
4
|
+
import { useActionMessage } from '../../hooks/useActionMessage.js'
|
|
4
5
|
import { useExplorer } from '../../hooks/useExplorer.js'
|
|
5
|
-
import { useProcessMessage } from '../../hooks/useProcessMessage.js'
|
|
6
6
|
import { CardIconButton } from '../Card/CardIconButton.js'
|
|
7
7
|
import { CircularProgress } from './CircularProgress.js'
|
|
8
8
|
|
|
9
|
-
export const
|
|
10
|
-
step:
|
|
11
|
-
|
|
12
|
-
}> = ({ step,
|
|
13
|
-
const
|
|
9
|
+
export const StepAction: React.FC<{
|
|
10
|
+
step: LiFiStepExtended
|
|
11
|
+
actionsGroup: ExecutionAction[]
|
|
12
|
+
}> = ({ step, actionsGroup }) => {
|
|
13
|
+
const action = actionsGroup.at(-1)
|
|
14
|
+
const { title, message } = useActionMessage(step, action)
|
|
14
15
|
const { getTransactionLink } = useExplorer()
|
|
15
16
|
|
|
16
|
-
|
|
17
|
+
if (!action) {
|
|
18
|
+
return null
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const transactionLink = action.txHash
|
|
17
22
|
? getTransactionLink({
|
|
18
|
-
txHash:
|
|
19
|
-
chain:
|
|
23
|
+
txHash: action.txHash,
|
|
24
|
+
chain: action.chainId,
|
|
20
25
|
})
|
|
21
|
-
:
|
|
26
|
+
: action.txLink
|
|
22
27
|
? getTransactionLink({
|
|
23
|
-
txLink:
|
|
24
|
-
chain:
|
|
28
|
+
txLink: action.txLink,
|
|
29
|
+
chain: action.chainId,
|
|
25
30
|
})
|
|
26
31
|
: undefined
|
|
27
32
|
|
|
@@ -38,14 +43,14 @@ export const StepProcess: React.FC<{
|
|
|
38
43
|
alignItems: 'center',
|
|
39
44
|
}}
|
|
40
45
|
>
|
|
41
|
-
<CircularProgress
|
|
46
|
+
<CircularProgress action={action} />
|
|
42
47
|
<Typography
|
|
43
48
|
sx={{
|
|
44
49
|
marginLeft: 2,
|
|
45
50
|
marginRight: 0.5,
|
|
46
51
|
flex: 1,
|
|
47
52
|
fontSize: 14,
|
|
48
|
-
fontWeight:
|
|
53
|
+
fontWeight: action.error ? 600 : 400,
|
|
49
54
|
}}
|
|
50
55
|
>
|
|
51
56
|
{title}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { LiFiStep, StepExtended } from '@lifi/sdk'
|
|
2
|
-
import {
|
|
2
|
+
import { useEthereumContext } from '@lifi/widget-provider'
|
|
3
3
|
import ArrowForward from '@mui/icons-material/ArrowForward'
|
|
4
4
|
import ExpandLess from '@mui/icons-material/ExpandLess'
|
|
5
5
|
import ExpandMore from '@mui/icons-material/ExpandMore'
|
|
@@ -123,6 +123,7 @@ export const StepActions: React.FC<StepActionsProps> = ({
|
|
|
123
123
|
const IncludedSteps: React.FC<IncludedStepsProps> = ({ step }) => {
|
|
124
124
|
const { subvariant, subvariantOptions, feeConfig, hiddenUI } =
|
|
125
125
|
useWidgetConfig()
|
|
126
|
+
const { isGaslessStep } = useEthereumContext()
|
|
126
127
|
|
|
127
128
|
let includedSteps = step.includedSteps
|
|
128
129
|
if (hiddenUI?.includes(HiddenUI.IntegratorStepDetails)) {
|
|
@@ -163,7 +164,7 @@ const IncludedSteps: React.FC<IncludedStepsProps> = ({ step }) => {
|
|
|
163
164
|
) : null
|
|
164
165
|
}
|
|
165
166
|
|
|
166
|
-
const hasGaslessSupport = isGaslessStep(step)
|
|
167
|
+
const hasGaslessSupport = !!isGaslessStep?.(step)
|
|
167
168
|
|
|
168
169
|
return (
|
|
169
170
|
<Box
|
|
@@ -1,49 +1,17 @@
|
|
|
1
1
|
import type { LiFiStepExtended } from '@lifi/sdk'
|
|
2
|
-
import {
|
|
2
|
+
import { useState } from 'react'
|
|
3
3
|
import { useTranslation } from 'react-i18next'
|
|
4
4
|
import { useTimer } from '../../hooks/timer/useTimer.js'
|
|
5
5
|
import { formatTimer } from '../../utils/timer.js'
|
|
6
6
|
import { TimerContent } from './TimerContent.js'
|
|
7
7
|
|
|
8
|
-
/**
|
|
9
|
-
* Finds the most recent process that is either a SWAP, CROSS_CHAIN, or RECEIVING_CHAIN.
|
|
10
|
-
* Includes RECEIVING_CHAIN to track the complete transaction lifecycle for UI updates.
|
|
11
|
-
*/
|
|
12
|
-
const getProgressProcess = (step: LiFiStepExtended) =>
|
|
13
|
-
step.execution?.process.findLast(
|
|
14
|
-
(process) =>
|
|
15
|
-
process.type === 'SWAP' ||
|
|
16
|
-
process.type === 'CROSS_CHAIN' ||
|
|
17
|
-
process.type === 'RECEIVING_CHAIN'
|
|
18
|
-
)
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Finds the most recent SWAP or CROSS_CHAIN process, excluding RECEIVING_CHAIN.
|
|
22
|
-
* Expiry time is based on when the active transaction started, not the receiving phase.
|
|
23
|
-
*/
|
|
24
|
-
const getExpiryProcess = (step: LiFiStepExtended) =>
|
|
25
|
-
step.execution?.process.findLast(
|
|
26
|
-
(process) => process.type === 'SWAP' || process.type === 'CROSS_CHAIN'
|
|
27
|
-
)
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* Calculates expiry timestamp based on process start time, estimated duration, and pause time.
|
|
31
|
-
* Pause time is added when action is required (usually for signature requests).
|
|
32
|
-
*/
|
|
33
8
|
const getExpiryTimestamp = (step: LiFiStepExtended) => {
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
const actionDoneAt =
|
|
38
|
-
lastProcess.pendingAt ?? lastProcess.doneAt ?? Date.now()
|
|
39
|
-
timeInPause = new Date(
|
|
40
|
-
actionDoneAt - lastProcess.actionRequiredAt
|
|
41
|
-
).getTime()
|
|
9
|
+
const execution = step?.execution
|
|
10
|
+
if (!execution) {
|
|
11
|
+
return new Date()
|
|
42
12
|
}
|
|
43
13
|
const expiry = new Date(
|
|
44
|
-
(
|
|
45
|
-
step.estimate.executionDuration * 1000 +
|
|
46
|
-
timeInPause
|
|
14
|
+
(execution.signedAt ?? Date.now()) + step.estimate.executionDuration * 1000
|
|
47
15
|
)
|
|
48
16
|
return expiry
|
|
49
17
|
}
|
|
@@ -52,78 +20,16 @@ export const StepTimer: React.FC<{
|
|
|
52
20
|
step: LiFiStepExtended
|
|
53
21
|
hideInProgress?: boolean
|
|
54
22
|
}> = ({ step, hideInProgress }) => {
|
|
55
|
-
const {
|
|
56
|
-
const [isExpired, setExpired] = useState(false)
|
|
57
|
-
const [isExecutionStarted, setExecutionStarted] = useState(
|
|
58
|
-
() => !!getProgressProcess(step)
|
|
59
|
-
)
|
|
60
|
-
const [expiryTimestamp, setExpiryTimestamp] = useState(() =>
|
|
61
|
-
getExpiryTimestamp(step)
|
|
62
|
-
)
|
|
63
|
-
const { days, hours, minutes, seconds, isRunning, pause, resume, restart } =
|
|
64
|
-
useTimer({
|
|
65
|
-
autoStart: false,
|
|
66
|
-
expiryTimestamp,
|
|
67
|
-
onExpire: () => setExpired(true),
|
|
68
|
-
})
|
|
69
|
-
|
|
70
|
-
useEffect(() => {
|
|
71
|
-
const executionProcess = getProgressProcess(step)
|
|
72
|
-
if (!executionProcess) {
|
|
73
|
-
return
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
if (isExecutionStarted && isExpired) {
|
|
77
|
-
return
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
const isProcessStarted =
|
|
81
|
-
executionProcess.status === 'STARTED' ||
|
|
82
|
-
executionProcess.status === 'PENDING'
|
|
83
|
-
|
|
84
|
-
const shouldRestart = !isExecutionStarted && isProcessStarted && !isRunning
|
|
85
|
-
|
|
86
|
-
const shouldPause =
|
|
87
|
-
isExecutionStarted &&
|
|
88
|
-
(executionProcess.status === 'ACTION_REQUIRED' ||
|
|
89
|
-
executionProcess.status === 'MESSAGE_REQUIRED' ||
|
|
90
|
-
executionProcess.status === 'RESET_REQUIRED') &&
|
|
91
|
-
isRunning
|
|
92
|
-
|
|
93
|
-
const shouldStop =
|
|
94
|
-
isExecutionStarted && executionProcess.status === 'FAILED'
|
|
95
|
-
|
|
96
|
-
const shouldResume = isExecutionStarted && isProcessStarted && !isRunning
|
|
97
|
-
|
|
98
|
-
if (shouldRestart) {
|
|
99
|
-
const newExpiryTimestamp = getExpiryTimestamp(step)
|
|
100
|
-
setExecutionStarted(true)
|
|
101
|
-
setExpiryTimestamp(newExpiryTimestamp)
|
|
102
|
-
return restart(newExpiryTimestamp, true)
|
|
103
|
-
}
|
|
104
|
-
if (shouldPause) {
|
|
105
|
-
return pause()
|
|
106
|
-
}
|
|
107
|
-
if (shouldResume) {
|
|
108
|
-
return resume()
|
|
109
|
-
}
|
|
110
|
-
if (shouldStop) {
|
|
111
|
-
setExecutionStarted(false)
|
|
112
|
-
setExpired(false)
|
|
113
|
-
}
|
|
114
|
-
}, [isExecutionStarted, isExpired, isRunning, pause, restart, resume, step])
|
|
115
|
-
|
|
116
|
-
const isTimerExpired = isExpired || (!minutes && !seconds)
|
|
23
|
+
const { i18n } = useTranslation()
|
|
117
24
|
|
|
118
25
|
if (
|
|
119
26
|
step.execution?.status === 'DONE' ||
|
|
120
|
-
step.execution?.status === 'FAILED'
|
|
121
|
-
(isTimerExpired && hideInProgress)
|
|
27
|
+
step.execution?.status === 'FAILED'
|
|
122
28
|
) {
|
|
123
29
|
return null
|
|
124
30
|
}
|
|
125
31
|
|
|
126
|
-
if (!
|
|
32
|
+
if (!step.execution?.signedAt) {
|
|
127
33
|
const showSeconds = step.estimate.executionDuration < 60
|
|
128
34
|
const duration = showSeconds
|
|
129
35
|
? Math.floor(step.estimate.executionDuration)
|
|
@@ -139,9 +45,41 @@ export const StepTimer: React.FC<{
|
|
|
139
45
|
)
|
|
140
46
|
}
|
|
141
47
|
|
|
142
|
-
return
|
|
143
|
-
|
|
144
|
-
|
|
48
|
+
return (
|
|
49
|
+
<ExecutionTimer
|
|
50
|
+
expiryTimestamp={getExpiryTimestamp(step)}
|
|
51
|
+
hideInProgress={hideInProgress}
|
|
52
|
+
/>
|
|
53
|
+
)
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
const ExecutionTimer = ({
|
|
57
|
+
expiryTimestamp,
|
|
58
|
+
hideInProgress,
|
|
59
|
+
}: {
|
|
60
|
+
expiryTimestamp: Date
|
|
61
|
+
hideInProgress?: boolean
|
|
62
|
+
}) => {
|
|
63
|
+
const { t, i18n } = useTranslation()
|
|
64
|
+
|
|
65
|
+
const [isExpired, setExpired] = useState(false)
|
|
66
|
+
|
|
67
|
+
const { days, hours, minutes, seconds } = useTimer({
|
|
68
|
+
autoStart: true,
|
|
69
|
+
expiryTimestamp,
|
|
70
|
+
onExpire: () => setExpired(true),
|
|
71
|
+
})
|
|
72
|
+
|
|
73
|
+
const isTimerExpired = isExpired || (!minutes && !seconds)
|
|
74
|
+
|
|
75
|
+
if (isTimerExpired) {
|
|
76
|
+
if (hideInProgress) {
|
|
77
|
+
return null
|
|
78
|
+
}
|
|
79
|
+
return t('main.inProgress')
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
return (
|
|
145
83
|
<TimerContent>
|
|
146
84
|
{formatTimer({
|
|
147
85
|
locale: i18n.language,
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import PushPinIcon from '@mui/icons-material/PushPin'
|
|
2
|
+
import PushPinOutlinedIcon from '@mui/icons-material/PushPinOutlined'
|
|
3
|
+
import { IconButton } from '@mui/material'
|
|
4
|
+
import { usePinnedTokensStore } from '../../stores/pinnedTokens/PinnedTokensStore.js'
|
|
5
|
+
|
|
6
|
+
interface PinTokenButtonProps {
|
|
7
|
+
chainId: number
|
|
8
|
+
tokenAddress: string
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export const PinTokenButton = ({
|
|
12
|
+
chainId,
|
|
13
|
+
tokenAddress,
|
|
14
|
+
}: PinTokenButtonProps) => {
|
|
15
|
+
const [pinnedTokens, pinToken, unpinToken] = usePinnedTokensStore((state) => [
|
|
16
|
+
state.pinnedTokens,
|
|
17
|
+
state.pinToken,
|
|
18
|
+
state.unpinToken,
|
|
19
|
+
])
|
|
20
|
+
|
|
21
|
+
const isPinned =
|
|
22
|
+
pinnedTokens[chainId]?.includes(tokenAddress.toLowerCase()) ?? false
|
|
23
|
+
|
|
24
|
+
const handleClick = (e: React.MouseEvent) => {
|
|
25
|
+
e.stopPropagation()
|
|
26
|
+
;(e.currentTarget as HTMLElement).blur()
|
|
27
|
+
if (isPinned) {
|
|
28
|
+
unpinToken(chainId, tokenAddress)
|
|
29
|
+
} else {
|
|
30
|
+
pinToken(chainId, tokenAddress)
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
const PinIcon = isPinned ? PushPinIcon : PushPinOutlinedIcon
|
|
35
|
+
|
|
36
|
+
return (
|
|
37
|
+
<IconButton
|
|
38
|
+
sx={{ width: 20, height: 20 }}
|
|
39
|
+
size="small"
|
|
40
|
+
onClick={handleClick}
|
|
41
|
+
>
|
|
42
|
+
<PinIcon
|
|
43
|
+
sx={{
|
|
44
|
+
fontSize: 12,
|
|
45
|
+
color: isPinned ? 'text.primary' : 'text.secondary',
|
|
46
|
+
}}
|
|
47
|
+
/>
|
|
48
|
+
</IconButton>
|
|
49
|
+
)
|
|
50
|
+
}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { Box } from '@mui/material'
|
|
2
|
-
import { type FC, memo, useEffect } from 'react'
|
|
2
|
+
import { type FC, memo, useEffect, useRef } from 'react'
|
|
3
3
|
import { useDebouncedWatch } from '../../hooks/useDebouncedWatch.js'
|
|
4
|
+
import { useListHeight } from '../../hooks/useListHeight.js'
|
|
5
|
+
import { useNavigateBack } from '../../hooks/useNavigateBack.js'
|
|
4
6
|
import { useTokenBalances } from '../../hooks/useTokenBalances.js'
|
|
5
7
|
import { useWidgetEvents } from '../../hooks/useWidgetEvents.js'
|
|
6
8
|
import { useChainOrderStore } from '../../stores/chains/ChainOrderStore.js'
|
|
@@ -12,69 +14,75 @@ import type { TokenListProps } from './types.js'
|
|
|
12
14
|
import { useTokenSelect } from './useTokenSelect.js'
|
|
13
15
|
import { VirtualizedTokenList } from './VirtualizedTokenList.js'
|
|
14
16
|
|
|
15
|
-
export const TokenList: FC<TokenListProps> = memo(
|
|
16
|
-
|
|
17
|
-
|
|
17
|
+
export const TokenList: FC<TokenListProps> = memo(({ formType, headerRef }) => {
|
|
18
|
+
const navigateBack = useNavigateBack()
|
|
19
|
+
const listParentRef = useRef<HTMLUListElement | null>(null)
|
|
20
|
+
const { listHeight } = useListHeight({
|
|
21
|
+
listParentRef,
|
|
22
|
+
headerRef,
|
|
23
|
+
})
|
|
18
24
|
|
|
19
|
-
|
|
20
|
-
FormKeyHelper.getChainKey(formType),
|
|
21
|
-
FormKeyHelper.getTokenKey(formType)
|
|
22
|
-
)
|
|
25
|
+
const emitter = useWidgetEvents()
|
|
23
26
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
)
|
|
27
|
+
const [selectedChainId, selectedTokenAddress] = useFieldValues(
|
|
28
|
+
FormKeyHelper.getChainKey(formType),
|
|
29
|
+
FormKeyHelper.getTokenKey(formType)
|
|
30
|
+
)
|
|
27
31
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
)
|
|
32
|
+
const isAllNetworks = useChainOrderStore(
|
|
33
|
+
(state) => state[`${formType}IsAllNetworks`]
|
|
34
|
+
)
|
|
32
35
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
isBalanceLoading,
|
|
38
|
-
isSearchLoading,
|
|
39
|
-
} = useTokenBalances(
|
|
40
|
-
selectedChainId,
|
|
41
|
-
formType,
|
|
42
|
-
isAllNetworks,
|
|
43
|
-
tokenSearchFilter
|
|
44
|
-
)
|
|
36
|
+
const [tokenSearchFilter]: string[] = useDebouncedWatch(
|
|
37
|
+
320,
|
|
38
|
+
'tokenSearchFilter'
|
|
39
|
+
)
|
|
45
40
|
|
|
46
|
-
|
|
41
|
+
const {
|
|
42
|
+
tokens,
|
|
43
|
+
withCategories,
|
|
44
|
+
withPinnedTokens,
|
|
45
|
+
isTokensLoading,
|
|
46
|
+
isBalanceLoading,
|
|
47
|
+
isSearchLoading,
|
|
48
|
+
} = useTokenBalances(
|
|
49
|
+
selectedChainId,
|
|
50
|
+
formType,
|
|
51
|
+
isAllNetworks,
|
|
52
|
+
tokenSearchFilter
|
|
53
|
+
)
|
|
47
54
|
|
|
48
|
-
|
|
49
|
-
withCategories && !tokenSearchFilter && !isAllNetworks
|
|
55
|
+
const handleTokenClick = useTokenSelect(formType, navigateBack)
|
|
50
56
|
|
|
51
|
-
|
|
52
|
-
const normalizedSearchFilter = tokenSearchFilter?.replaceAll('$', '')
|
|
53
|
-
if (normalizedSearchFilter) {
|
|
54
|
-
emitter.emit(WidgetEvent.TokenSearch, {
|
|
55
|
-
value: normalizedSearchFilter,
|
|
56
|
-
tokens,
|
|
57
|
-
})
|
|
58
|
-
}
|
|
59
|
-
}, [tokenSearchFilter, tokens, emitter])
|
|
57
|
+
const showCategories = withCategories && !tokenSearchFilter && !isAllNetworks
|
|
60
58
|
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
59
|
+
useEffect(() => {
|
|
60
|
+
const normalizedSearchFilter = tokenSearchFilter?.replaceAll('$', '')
|
|
61
|
+
if (normalizedSearchFilter) {
|
|
62
|
+
emitter.emit(WidgetEvent.TokenSearch, {
|
|
63
|
+
value: normalizedSearchFilter,
|
|
64
|
+
tokens,
|
|
65
|
+
})
|
|
66
|
+
}
|
|
67
|
+
}, [tokenSearchFilter, tokens, emitter])
|
|
68
|
+
|
|
69
|
+
return (
|
|
70
|
+
<Box ref={listParentRef} style={{ height: listHeight, overflow: 'auto' }}>
|
|
71
|
+
{!tokens.length && !isTokensLoading && !isSearchLoading ? (
|
|
72
|
+
<TokenNotFound formType={formType} />
|
|
73
|
+
) : null}
|
|
74
|
+
<VirtualizedTokenList
|
|
75
|
+
tokens={tokens}
|
|
76
|
+
scrollElementRef={listParentRef}
|
|
77
|
+
chainId={selectedChainId}
|
|
78
|
+
isLoading={isTokensLoading || isSearchLoading}
|
|
79
|
+
isBalanceLoading={isBalanceLoading}
|
|
80
|
+
showCategories={showCategories}
|
|
81
|
+
showPinnedTokens={withPinnedTokens}
|
|
82
|
+
onClick={handleTokenClick}
|
|
83
|
+
selectedTokenAddress={selectedTokenAddress}
|
|
84
|
+
isAllNetworks={isAllNetworks}
|
|
85
|
+
/>
|
|
86
|
+
</Box>
|
|
87
|
+
)
|
|
88
|
+
})
|
|
@@ -21,6 +21,7 @@ import { formatTokenAmount, formatTokenPrice } from '../../utils/format.js'
|
|
|
21
21
|
import { shortenAddress } from '../../utils/wallet.js'
|
|
22
22
|
import { TokenAvatar } from '../Avatar/TokenAvatar.js'
|
|
23
23
|
import { ListItemButton } from '../ListItem/ListItemButton.js'
|
|
24
|
+
import { PinTokenButton } from './PinTokenButton.js'
|
|
24
25
|
import { IconButton, ListItem } from './TokenList.style.js'
|
|
25
26
|
import type {
|
|
26
27
|
TokenListItemAvatarProps,
|
|
@@ -248,17 +249,17 @@ const TokenListItemButton: React.FC<TokenListItemButtonProps> = memo(
|
|
|
248
249
|
appear={false}
|
|
249
250
|
mountOnEnter
|
|
250
251
|
>
|
|
251
|
-
<Box
|
|
252
|
-
sx={{
|
|
253
|
-
display: 'flex',
|
|
254
|
-
}}
|
|
255
|
-
>
|
|
252
|
+
<Box>
|
|
256
253
|
<OpenTokenDetailsButton
|
|
257
254
|
tokenAddress={token.address}
|
|
258
255
|
withoutContractAddress={withoutContractAddress}
|
|
259
256
|
chainId={token.chainId}
|
|
260
257
|
onClick={onShowTokenDetails}
|
|
261
258
|
/>
|
|
259
|
+
<PinTokenButton
|
|
260
|
+
chainId={token.chainId}
|
|
261
|
+
tokenAddress={token.address}
|
|
262
|
+
/>
|
|
262
263
|
</Box>
|
|
263
264
|
</Slide>
|
|
264
265
|
</Box>
|
|
@@ -301,6 +302,8 @@ const TokenListItemButton: React.FC<TokenListItemButtonProps> = memo(
|
|
|
301
302
|
<Box
|
|
302
303
|
sx={{
|
|
303
304
|
display: 'flex',
|
|
305
|
+
alignItems: 'center',
|
|
306
|
+
gap: 0.5,
|
|
304
307
|
}}
|
|
305
308
|
>
|
|
306
309
|
<Box
|
|
@@ -312,12 +315,18 @@ const TokenListItemButton: React.FC<TokenListItemButtonProps> = memo(
|
|
|
312
315
|
>
|
|
313
316
|
{shortenAddress(token.address)}
|
|
314
317
|
</Box>
|
|
315
|
-
<
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
318
|
+
<Box>
|
|
319
|
+
<OpenTokenDetailsButton
|
|
320
|
+
tokenAddress={token.address}
|
|
321
|
+
withoutContractAddress={withoutContractAddress}
|
|
322
|
+
chainId={token.chainId}
|
|
323
|
+
onClick={onShowTokenDetails}
|
|
324
|
+
/>
|
|
325
|
+
<PinTokenButton
|
|
326
|
+
chainId={token.chainId}
|
|
327
|
+
tokenAddress={token.address}
|
|
328
|
+
/>
|
|
329
|
+
</Box>
|
|
321
330
|
</Box>
|
|
322
331
|
</Slide>
|
|
323
332
|
</Box>
|