2022-06-30 07:52:25 +00:00
|
|
|
import type { AgGridReact } from 'ag-grid-react';
|
2022-09-22 11:09:12 +00:00
|
|
|
import { useRef } from 'react';
|
2022-06-30 07:52:25 +00:00
|
|
|
import { AsyncRenderer } from '@vegaprotocol/ui-toolkit';
|
2022-07-05 13:33:50 +00:00
|
|
|
import { FillsTable } from './fills-table';
|
2022-07-21 13:25:37 +00:00
|
|
|
import type { BodyScrollEvent, BodyScrollEndEvent } from 'ag-grid-community';
|
2022-09-22 11:09:12 +00:00
|
|
|
import { useFillsList } from './use-fills-list';
|
2022-06-30 07:52:25 +00:00
|
|
|
|
|
|
|
interface FillsManagerProps {
|
|
|
|
partyId: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const FillsManager = ({ partyId }: FillsManagerProps) => {
|
|
|
|
const gridRef = useRef<AgGridReact | null>(null);
|
2022-07-20 09:37:28 +00:00
|
|
|
const scrolledToTop = useRef(true);
|
2022-09-22 11:09:12 +00:00
|
|
|
const { data, error, loading, addNewRows, getRows } = useFillsList({
|
|
|
|
partyId,
|
|
|
|
gridRef,
|
|
|
|
scrolledToTop,
|
|
|
|
});
|
2022-06-30 07:52:25 +00:00
|
|
|
|
2022-07-20 09:37:28 +00:00
|
|
|
const onBodyScrollEnd = (event: BodyScrollEndEvent) => {
|
|
|
|
if (event.top === 0) {
|
|
|
|
addNewRows();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const onBodyScroll = (event: BodyScrollEvent) => {
|
|
|
|
scrolledToTop.current = event.top <= 0;
|
|
|
|
};
|
|
|
|
|
2022-06-30 07:52:25 +00:00
|
|
|
return (
|
2022-07-05 13:33:50 +00:00
|
|
|
<AsyncRenderer loading={loading} error={error} data={data}>
|
2022-07-20 09:37:28 +00:00
|
|
|
<FillsTable
|
|
|
|
ref={gridRef}
|
|
|
|
partyId={partyId}
|
2022-09-27 18:48:53 +00:00
|
|
|
rowModelType={data?.length ? 'infinite' : 'clientSide'}
|
|
|
|
rowData={data?.length ? undefined : []}
|
2022-07-20 09:37:28 +00:00
|
|
|
datasource={{ getRows }}
|
|
|
|
onBodyScrollEnd={onBodyScrollEnd}
|
|
|
|
onBodyScroll={onBodyScroll}
|
|
|
|
/>
|
2022-06-30 07:52:25 +00:00
|
|
|
</AsyncRenderer>
|
|
|
|
);
|
|
|
|
};
|