ag-grid-community
Version:
Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
45 lines (44 loc) • 1.91 kB
TypeScript
import { NumberSequence } from "../utils";
import { RowNode } from "../entities/rowNode";
import { RowBounds } from "./iRowModel";
import { ServerSideTransaction, ServerSideTransactionResult } from "./serverSideTransaction";
import { ServerSideStoreType } from "../entities/gridOptions";
export interface IServerSideStore {
clearDisplayIndexes(): void;
getDisplayIndexEnd(): number | undefined;
isDisplayIndexInStore(displayIndex: number): boolean;
setDisplayIndexes(displayIndexSeq: NumberSequence, nextRowTop: {
value: number;
}): void;
forEachNodeDeep(callback: (rowNode: RowNode, index: number) => void, sequence?: NumberSequence): void;
retryLoads(): void;
getRowUsingDisplayIndex(displayRowIndex: number, dontCreateBlock?: boolean): RowNode | null;
getRowBounds(index: number): RowBounds | null;
isPixelInRange(pixel: number): boolean;
getRowIndexAtPixel(pixel: number): number | null;
getChildStore(keys: string[]): IServerSideStore | null;
refreshAfterSort(params: StoreRefreshAfterParams): void;
refreshAfterFilter(params: StoreRefreshAfterParams): void;
applyTransaction(transaction: ServerSideTransaction): ServerSideTransactionResult;
refreshStore(purge: boolean): void;
getRowCount(): number;
getTopLevelRowDisplayedIndex(topLevelIndex: number): number;
isLastRowIndexKnown(): boolean;
getRowNodesInRange(firstInRange: RowNode, lastInRange: RowNode): RowNode[];
addStoreStates(result: ServerSideStoreState[]): void;
}
export interface StoreRefreshAfterParams {
valueColChanged: boolean;
secondaryColChanged: boolean;
alwaysReset: boolean;
changedColumns: string[];
}
export interface ServerSideStoreState {
type: ServerSideStoreType;
route: string[];
rowCount: number;
lastRowIndexKnown?: boolean;
info?: any;
maxBlocksInCache?: number;
cacheBlockSize?: number;
}