import { useEffect } from 'react'; import type { ReactNode } from 'react'; import { LayoutPriority } from 'allotment'; import { useIncompleteWithdrawals } from '@vegaprotocol/withdraws'; import { Tab, LocalStoragePersistTabs as Tabs } from '@vegaprotocol/ui-toolkit'; import { AccountsContainer, AccountsSettings, } from '../../components/accounts-container'; import { DepositsContainer } from '../../components/deposits-container'; import { FillsContainer, FillsSettings, } from '../../components/fills-container'; import { FundingPaymentsContainer, FundingPaymentsSettings, } from '../../components/funding-payments-container'; import { PositionsContainer, PositionsSettings, } from '../../components/positions-container'; import { PositionsMenu } from '../../components/positions-menu'; import { WithdrawalsContainer } from '../../components/withdrawals-container'; import { OrdersContainer, OrdersSettings, } 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'; import { usePageTitle } from '../../lib/hooks/use-page-title'; 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(); usePageTitle(t('Portfolio')); const [sizes, handleOnLayoutChange] = usePaneLayout({ id: 'portfolio' }); const wrapperClasses = 'p-0.5 h-full max-h-full flex flex-col'; return (
} settings={} > }> }> } > } menu={} > }> } menu={} >
); }; interface PortfolioGridChildProps { children: ReactNode; } const PortfolioGridChild = ({ children }: PortfolioGridChildProps) => { return (
{children}
); };