import classNames from 'classnames' import { useLocation, useNavigate } from 'react-router-dom' import useAccountBalancesColumns from 'components/Account/AccountBalancesTable/Columns/useAccountBalancesColumns' import useAccountBalanceData from 'components/Account/AccountBalancesTable/useAccountBalanceData' import AccountFundFullPage from 'components/Account/AccountFund/AccountFundFullPage' import ActionButton from 'components/Button/ActionButton' import Card from 'components/Card' import Table from 'components/Table' import ConditionalWrapper from 'hocs/ConditionalWrapper' import useCurrentAccount from 'hooks/useCurrentAccount' import useStore from 'store' import { getPage, getRoute } from 'utils/route' interface Props { account: Account isHls?: boolean lendingData: LendingMarketTableData[] borrowingData: BorrowMarketTableData[] hideCard?: boolean tableBodyClassName?: string } export default function AccountBalancesTable(props: Props) { const { account, lendingData, borrowingData, tableBodyClassName, hideCard } = props const currentAccount = useCurrentAccount() const navigate = useNavigate() const { pathname } = useLocation() const address = useStore((s) => s.address) const updatedAccount = useStore((s) => s.updatedAccount) const accountBalanceData = useAccountBalanceData({ account, updatedAccount, lendingData, borrowingData, isHls: props.isHls, }) const columns = useAccountBalancesColumns() if (accountBalanceData.length === 0) return ( ( {children} )} >
{ if (currentAccount?.id !== account.id) { navigate(getRoute(getPage(pathname), address, account.id)) } useStore.setState({ focusComponent: { component: , onClose: () => { useStore.setState({ getStartedModal: true }) }, }, }) }} />
) return ( ) }