Skip to content

Commit

Permalink
Merge pull request #251 from Enterwell/feature/pagination-enabled-by-…
Browse files Browse the repository at this point in the history
…default

feat(react-mui-hooks): Pagination enabled by default
  • Loading branch information
AleksandarDev authored Dec 20, 2023
2 parents 07ced57 + 0d939a8 commit d9ea50d
Show file tree
Hide file tree
Showing 5 changed files with 24 additions and 1 deletion.
5 changes: 5 additions & 0 deletions packages/react-mui-hooks/.changelog.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"categories": [
"useDataGrid"
]
}
Empty file.
Empty file.
17 changes: 17 additions & 0 deletions packages/react-mui-hooks/hooks/useDataGrid.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import {
type GridValidRowModel,
type DataGridPro,
type GridSortItem,
type GridRowScrollEndParams,
} from '@mui/x-data-grid-pro';
import { useResizeObserver } from '@enterwell/react-hooks';
import { format } from 'date-fns';
Expand Down Expand Up @@ -271,6 +272,7 @@ export type UseDataGridProps = {
rowHeight?: number,
selection?: boolean,
checkboxSelection?: boolean,
enablePagination?: boolean,
infiniteLoading?: boolean,
keepNonExistentRowsSelected?: boolean
};
Expand Down Expand Up @@ -306,6 +308,7 @@ export function useDataGrid({
rowHeight = 40,
selection,
checkboxSelection,
enablePagination = true,
infiniteLoading,
keepNonExistentRowsSelected = true
}: UseDataGridProps): UseDataGridResponse {
Expand Down Expand Up @@ -495,6 +498,16 @@ export function useDataGrid({
...resolveCustomTypeOperators(c),
})), [columns, headerRenderer, rowHeight]);

/**
* Handles rows scroll end action.
*/
const handleRowsScrollEnd = (params: GridRowScrollEndParams) => {
if (!infiniteLoading) return;

console.debug('Infinite loading: loading next page', params);
handlePaginationModelChange({ page: pageIndex + 1, pageSize });
};

return {
props: {
ref: resizeRef,
Expand All @@ -511,11 +524,13 @@ export function useDataGrid({
columns: columnsMemo,
columnVisibilityModel: columnVisibility,
onColumnVisibilityModelChange: handleColumnVisibilityChange,
pagination: !infiniteLoading && enablePagination,
paginationMode: 'server',
paginationModel: {
page: Math.max(pageIndex, 0),
pageSize,
},
hideFooterPagination: infiniteLoading,
onPaginationModelChange: handlePaginationModelChange,
sortingMode: 'server',
sortModel,
Expand All @@ -529,6 +544,8 @@ export function useDataGrid({
},
onRowClick,
rowHeight,
scrollEndThreshold: rowHeight * Math.round(pageSize / 2),
onRowsScrollEnd: handleRowsScrollEnd,
onCellKeyDown: handleCellKeyDown,
columnHeaderHeight: rowHeight + 1,
disableRowSelectionOnClick: !selection,
Expand Down
3 changes: 2 additions & 1 deletion packages/react-mui-hooks/temp/react-mui-hooks.api.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ export type TypedSortModel<T> = (GridSortItem & {
})[];

// @public
export function useDataGrid({ tableId, pageSize, columns, columnVisibilityModel, defaultSort, onPage, onRowClick, rowHeight, selection, checkboxSelection, infiniteLoading, keepNonExistentRowsSelected }: UseDataGridProps): UseDataGridResponse;
export function useDataGrid({ tableId, pageSize, columns, columnVisibilityModel, defaultSort, onPage, onRowClick, rowHeight, selection, checkboxSelection, enablePagination, infiniteLoading, keepNonExistentRowsSelected }: UseDataGridProps): UseDataGridResponse;

// @public
export type UseDataGridProps = {
Expand All @@ -56,6 +56,7 @@ export type UseDataGridProps = {
rowHeight?: number;
selection?: boolean;
checkboxSelection?: boolean;
enablePagination?: boolean;
infiniteLoading?: boolean;
keepNonExistentRowsSelected?: boolean;
};
Expand Down

0 comments on commit d9ea50d

Please sign in to comment.