import { useEffect } from 'react'; import type { ReactNode } from 'react'; import { LayoutPriority } from 'allotment'; import { titlefy } from '@vegaprotocol/utils'; import { useIncompleteWithdrawals } from '@vegaprotocol/withdraws'; import { Tab, LocalStoragePersistTabs as Tabs } from '@vegaprotocol/ui-toolkit'; import { usePageTitleStore } from '../../stores'; import { AccountsContainer } from '../../components/accounts-container'; import { DepositsContainer } from '../../components/deposits-container'; import { FillsContainer } from '../../components/fills-container'; import { FundingPaymentsContainer } from '../../components/funding-payments-container'; import { PositionsContainer } from '../../components/positions-container'; import { PositionsMenu } from '../../components/positions-menu'; import { WithdrawalsContainer } from '../../components/withdrawals-container'; import { OrdersContainer } from '../../components/orders-container'; import { LedgerContainer } from '../../components/ledger-container'; import { ResizableGrid, ResizableGridPanel, usePaneLayout, } from '../../components/resizable-grid'; import { ViewType, useSidebar } from '../../components/sidebar'; import { AccountsMenu } from '../../components/accounts-menu'; import { DepositsMenu } from '../../components/deposits-menu'; import { WithdrawalsMenu } from '../../components/withdrawals-menu'; import { useGetCurrentRouteId } from '../../lib/hooks/use-get-current-route-id'; import { useT } from '../../lib/use-t'; import { ErrorBoundary } from '../../components/error-boundary'; const WithdrawalsIndicator = () => { const { ready } = useIncompleteWithdrawals(); if (!ready || ready.length === 0) { return null; } return ( {ready.length} ); }; const SidebarViewInitializer = () => { const currentRouteId = useGetCurrentRouteId(); const { getView, setViews } = useSidebar(); const view = getView(currentRouteId); // Make transfer sidebar open by default useEffect(() => { if (view === undefined) { setViews({ type: ViewType.Transfer }, currentRouteId); } }, [view, setViews, currentRouteId]); return null; }; export const Portfolio = () => { const t = useT(); const { updateTitle } = usePageTitleStore((store) => ({ updateTitle: store.updateTitle, })); useEffect(() => { updateTitle(titlefy([t('Portfolio')])); }, [updateTitle, t]); const [sizes, handleOnLayoutChange] = usePaneLayout({ id: 'portfolio' }); const wrapperClasses = 'p-0.5 h-full max-h-full flex flex-col'; return (