import { useRef, useMemo, memo, useCallback } from 'react'; import { t } from '@vegaprotocol/i18n'; import { useBottomPlaceholder } from '@vegaprotocol/datagrid'; import { useDataProvider } from '@vegaprotocol/data-provider'; import { AsyncRenderer } from '@vegaprotocol/ui-toolkit'; import type { AgGridReact } from 'ag-grid-react'; import type { AccountFields } from './accounts-data-provider'; import { aggregatedAccountsDataProvider } from './accounts-data-provider'; import type { PinnedAsset } from './accounts-table'; import { AccountTable } from './accounts-table'; interface AccountManagerProps { partyId: string; onClickAsset: (assetId: string) => void; onClickWithdraw?: (assetId?: string) => void; onClickDeposit?: (assetId?: string) => void; isReadOnly: boolean; pinnedAsset?: PinnedAsset; noBottomPlaceholder?: boolean; storeKey?: string; } export const AccountManager = ({ onClickAsset, onClickWithdraw, onClickDeposit, partyId, isReadOnly, pinnedAsset, noBottomPlaceholder, storeKey, }: AccountManagerProps) => { const gridRef = useRef(null); const variables = useMemo(() => ({ partyId }), [partyId]); const { data, loading, error, reload } = useDataProvider({ dataProvider: aggregatedAccountsDataProvider, variables, }); const setId = useCallback( (data: AccountFields, id: string) => ({ ...data, asset: { ...data.asset, id }, }), [] ); const bottomPlaceholderProps = useBottomPlaceholder({ gridRef, setId, disabled: noBottomPlaceholder, }); return (
!(data && data.length)} error={error} loading={loading} noDataMessage={pinnedAsset ? ' ' : t('No accounts')} reload={reload} />
); }; export default memo(AccountManager);