import type { Route } from '@lifi/sdk' import { useAccount } from '@lifi/wallet-management' import type { BoxProps } from '@mui/material' import { useMemo } from 'react' import { useTranslation } from 'react-i18next' import { ProgressToNextUpdate } from '../../components/ProgressToNextUpdate.js' import { RouteCard } from '../../components/RouteCard/RouteCard.js' import { RouteCardSkeleton } from '../../components/RouteCard/RouteCardSkeleton.js' import { RouteNotFoundCard } from '../../components/RouteCard/RouteNotFoundCard.js' import { useHeader } from '../../hooks/useHeader.js' import { useNavigateBack } from '../../hooks/useNavigateBack.js' import { useRoutes } from '../../hooks/useRoutes.js' import { useToAddressRequirements } from '../../hooks/useToAddressRequirements.js' import { useWidgetEvents } from '../../hooks/useWidgetEvents.js' import { useFieldValues } from '../../stores/form/useFieldValues.js' import { WidgetEvent } from '../../types/events.js' import { navigationRoutes } from '../../utils/navigationRoutes.js' import { Stack } from './RoutesPage.style.js' export const RoutesPage: React.FC = () => { const { t } = useTranslation() const { navigate } = useNavigateBack() const emitter = useWidgetEvents() const { routes, isLoading, isFetching, dataUpdatedAt, refetchTime, fromChain, refetch, setReviewableRoute, } = useRoutes() const { account } = useAccount({ chainType: fromChain?.chainType }) const [toAddress] = useFieldValues('toAddress') const { requiredToAddress } = useToAddressRequirements() const headerAction = useMemo( () => ( refetch()} sx={{ marginRight: -1 }} size="medium" /> ), [dataUpdatedAt, isFetching, refetch, refetchTime] ) useHeader(t('header.receive'), headerAction) const handleRouteClick = (route: Route) => { setReviewableRoute(route) navigate(navigationRoutes.transactionExecution, { state: { routeId: route.id }, }) emitter.emit(WidgetEvent.RouteSelected, { route, routes: routes!, }) } const routeNotFound = !routes?.length && !isLoading && !isFetching const toAddressUnsatisfied = routes?.[0] && requiredToAddress && !toAddress const allowInteraction = account.isConnected && !toAddressUnsatisfied return ( {routeNotFound ? ( ) : isLoading && !routes?.length ? ( Array.from({ length: 3 }).map((_, index) => ( )) ) : ( routes?.map((route: Route, index: number) => ( handleRouteClick(route) : undefined } active={index === 0} expanded={routes?.length === 1} /> )) )} ) }