@mui/x-data-grid
Version:
The community edition of the data grid component (MUI X).
78 lines • 4.07 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
import * as React from 'react';
import TablePagination, { tablePaginationClasses } from '@mui/material/TablePagination';
import { styled } from '@mui/material/styles';
import { useGridSelector } from '../hooks/utils/useGridSelector';
import { useGridApiContext } from '../hooks/utils/useGridApiContext';
import { useGridRootProps } from '../hooks/utils/useGridRootProps';
import { gridFilteredTopLevelRowCountSelector } from '../hooks/features/filter';
import { gridPaginationModelSelector } from '../hooks/features/pagination/gridPaginationSelector';
import { jsx as _jsx } from "react/jsx-runtime";
var GridPaginationRoot = styled(TablePagination)(function (_ref) {
var _ref2;
var theme = _ref.theme;
return _ref2 = {}, _defineProperty(_ref2, "& .".concat(tablePaginationClasses.selectLabel), _defineProperty({
display: 'none'
}, theme.breakpoints.up('sm'), {
display: 'block'
})), _defineProperty(_ref2, "& .".concat(tablePaginationClasses.input), _defineProperty({
display: 'none'
}, theme.breakpoints.up('sm'), {
display: 'inline-flex'
})), _ref2;
});
export var GridPagination = /*#__PURE__*/React.forwardRef(function GridPagination(props, ref) {
var apiRef = useGridApiContext();
var rootProps = useGridRootProps();
var paginationModel = useGridSelector(apiRef, gridPaginationModelSelector);
var visibleTopLevelRowCount = useGridSelector(apiRef, gridFilteredTopLevelRowCountSelector);
var rowCount = React.useMemo(function () {
var _ref3, _rootProps$rowCount;
return (_ref3 = (_rootProps$rowCount = rootProps.rowCount) != null ? _rootProps$rowCount : visibleTopLevelRowCount) != null ? _ref3 : 0;
}, [rootProps.rowCount, visibleTopLevelRowCount]);
var lastPage = React.useMemo(function () {
return Math.floor(rowCount / (paginationModel.pageSize || 1));
}, [rowCount, paginationModel.pageSize]);
var handlePageSizeChange = React.useCallback(function (event) {
var pageSize = Number(event.target.value);
apiRef.current.setPageSize(pageSize);
}, [apiRef]);
var handlePageChange = React.useCallback(function (_, page) {
apiRef.current.setPage(page);
}, [apiRef]);
var isPageSizeIncludedInPageSizeOptions = function isPageSizeIncludedInPageSizeOptions(pageSize) {
for (var i = 0; i < rootProps.pageSizeOptions.length; i += 1) {
var option = rootProps.pageSizeOptions[i];
if (typeof option === 'number') {
if (option === pageSize) {
return true;
}
} else if (option.value === pageSize) {
return true;
}
}
return false;
};
if (process.env.NODE_ENV !== 'production') {
var _rootProps$pagination, _rootProps$pagination2;
// eslint-disable-next-line react-hooks/rules-of-hooks
var warnedOnceMissingInPageSizeOptions = React.useRef(false);
var pageSize = (_rootProps$pagination = (_rootProps$pagination2 = rootProps.paginationModel) == null ? void 0 : _rootProps$pagination2.pageSize) != null ? _rootProps$pagination : paginationModel.pageSize;
if (!warnedOnceMissingInPageSizeOptions.current && !rootProps.autoPageSize && !isPageSizeIncludedInPageSizeOptions(pageSize)) {
console.warn(["MUI: The page size `".concat(paginationModel.pageSize, "` is not preset in the `pageSizeOptions`"), "Add it to show the pagination select."].join('\n'));
warnedOnceMissingInPageSizeOptions.current = true;
}
}
var pageSizeOptions = isPageSizeIncludedInPageSizeOptions(paginationModel.pageSize) ? rootProps.pageSizeOptions : [];
return /*#__PURE__*/_jsx(GridPaginationRoot, _extends({
ref: ref,
component: "div",
count: rowCount,
page: paginationModel.page <= lastPage ? paginationModel.page : lastPage,
rowsPerPageOptions: pageSizeOptions,
rowsPerPage: paginationModel.pageSize,
onPageChange: handlePageChange,
onRowsPerPageChange: handlePageSizeChange
}, apiRef.current.getLocaleText('MuiTablePagination'), props));
});