Skip to content

Commit

Permalink
Merge branch 'feat/add-footer-prop-infinite' into v2
Browse files Browse the repository at this point in the history
  • Loading branch information
mguellsegarra committed Jul 17, 2024
2 parents 15b15ec + 3a772e3 commit 47083f8
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 37 deletions.
77 changes: 46 additions & 31 deletions src/components/InfiniteTable/InfiniteTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ export type InfiniteTableProps = Omit<
totalRows: number;
allRowSelectedMode?: boolean;
onAllRowSelectedModeChange?: (allRowSelectedMode: boolean) => void;
footer?: React.ReactNode;
footerHeight?: number;
};

export type InfiniteTableRef = {
Expand All @@ -59,7 +61,7 @@ const InfiniteTableComp = forwardRef<InfiniteTableRef, InfiniteTableProps>(
columns: columnsProps,
onRowDoubleClick,
onRowSelectionChange,
height,
height: heightProps = 600,
onRowStyle,
onColumnChanged: onColumnsChangedProps,
onGetColumnsState,
Expand All @@ -69,6 +71,8 @@ const InfiniteTableComp = forwardRef<InfiniteTableRef, InfiniteTableProps>(
totalRows,
onAllRowSelectedModeChange,
allRowSelectedMode: allRowSelectedModeProps,
footer,
footerHeight = 50,
} = props;

const gridRef = useRef<AgGridReact>(null);
Expand All @@ -77,6 +81,8 @@ const InfiniteTableComp = forwardRef<InfiniteTableRef, InfiniteTableProps>(
const columnsPersistedStateRef = useRef<any>();
const containerRef = useRef<HTMLDivElement>(null);
const columnChangeListenerReady = useRef(false);
const totalHeight = footer ? heightProps + footerHeight : heightProps;
const tableHeight = footer ? heightProps - footerHeight : heightProps;

const { autoSizeColumnsIfNecessary } = useAutoFitColumns({
gridRef,
Expand Down Expand Up @@ -271,37 +277,46 @@ const InfiniteTableComp = forwardRef<InfiniteTableRef, InfiniteTableProps>(

return (
<div
ref={containerRef}
className={`ag-grid-default-table ag-theme-quartz`}
style={{ height: height || 600, width: "100%" }}
style={{
display: "flex",
flexDirection: "column",
height: totalHeight,
}}
>
<AgGridReact
ref={gridRef}
columnDefs={colDefs}
defaultColDef={defaultColDef}
onRowDoubleClicked={onRowDoubleClicked}
rowStyle={{
cursor: onRowDoubleClick ? "pointer" : "auto",
}}
getRowStyle={onRowStyle}
suppressCellFocus={true}
suppressRowClickSelection={true}
rowBuffer={0}
rowSelection={"multiple"}
onColumnMoved={onColumnChanged}
onColumnResized={onColumnChanged}
rowModelType={"infinite"}
cacheBlockSize={20}
onSelectionChanged={onSelectionChangedDebounced}
cacheOverflowSize={2}
maxConcurrentDatasourceRequests={1}
infiniteInitialRowCount={50}
maxBlocksInCache={10}
onGridReady={onGridReady}
onFirstDataRendered={onFirstDataRendered}
onBodyScroll={onBodyScroll}
blockLoadDebounceMillis={DEBOUNCE_TIME}
/>
<div
ref={containerRef}
className={`ag-grid-default-table ag-theme-quartz`}
style={{ height: tableHeight, width: "100%" }}
>
<AgGridReact
ref={gridRef}
columnDefs={colDefs}
defaultColDef={defaultColDef}
onRowDoubleClicked={onRowDoubleClicked}
rowStyle={{
cursor: onRowDoubleClick ? "pointer" : "auto",
}}
getRowStyle={onRowStyle}
suppressCellFocus={true}
suppressRowClickSelection={true}
rowBuffer={0}
rowSelection={"multiple"}
onColumnMoved={onColumnChanged}
onColumnResized={onColumnChanged}
rowModelType={"infinite"}
cacheBlockSize={20}
onSelectionChanged={onSelectionChangedDebounced}
cacheOverflowSize={2}
maxConcurrentDatasourceRequests={1}
infiniteInitialRowCount={50}
maxBlocksInCache={10}
onGridReady={onGridReady}
onFirstDataRendered={onFirstDataRendered}
onBodyScroll={onBodyScroll}
blockLoadDebounceMillis={DEBOUNCE_TIME}
/>
</div>
{footer && <div style={{ height: footerHeight }}>{footer}</div>}
</div>
);
},
Expand Down
6 changes: 0 additions & 6 deletions src/components/InfiniteTable/useRowSelection.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,12 +78,6 @@ export const useRowSelection = ({
}, 1000);
}, [allRowSelectedMode, internalSelectedRowKeys.length, totalRows, gridRef]);

useEffect(() => {
return () => {
timeoutRef.current && clearTimeout(timeoutRef.current);
};
}, [onHeaderCheckboxChange]);

const onSelectionChanged = useCallback(
(event: { api: { getSelectedNodes: () => any } }) => {
if (allRowSelectedModeLock.current) {
Expand Down
1 change: 1 addition & 0 deletions src/stories/InfiniteTable.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ export const HeavyTable = (): React.ReactElement => {
const columnsState = localStorage.getItem("columnsState");
return columnsState ? JSON.parse(columnsState) : undefined;
}}
footer={<p>This is a footer</p>}
/>
</>
);
Expand Down

0 comments on commit 47083f8

Please sign in to comment.