UNPKG

@mui/x-data-grid

Version:

The Community plan edition of the Data Grid components (MUI X).

87 lines (86 loc) 4.13 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.GridPagination = GridPagination; var React = _interopRequireWildcard(require("react")); var _styles = require("@mui/material/styles"); var _propTypes = _interopRequireDefault(require("prop-types")); var _assert = require("../utils/assert"); var _useGridSelector = require("../hooks/utils/useGridSelector"); var _useGridApiContext = require("../hooks/utils/useGridApiContext"); var _useGridRootProps = require("../hooks/utils/useGridRootProps"); var _gridPaginationSelector = require("../hooks/features/pagination/gridPaginationSelector"); var _jsxRuntime = require("react/jsx-runtime"); const GridPaginationRoot = (0, _styles.styled)(_assert.NotRendered)({ maxHeight: 'calc(100% + 1px)', // border width flexGrow: 1 }); function GridPagination() { const apiRef = (0, _useGridApiContext.useGridApiContext)(); const rootProps = (0, _useGridRootProps.useGridRootProps)(); const paginationModel = (0, _useGridSelector.useGridSelector)(apiRef, _gridPaginationSelector.gridPaginationModelSelector); const rowCount = (0, _useGridSelector.useGridSelector)(apiRef, _gridPaginationSelector.gridPaginationRowCountSelector); const pageCount = (0, _useGridSelector.useGridSelector)(apiRef, _gridPaginationSelector.gridPageCountSelector); const { paginationMode, loading } = rootProps; const disabled = rowCount === -1 && paginationMode === 'server' && loading; const lastPage = React.useMemo(() => Math.max(0, pageCount - 1), [pageCount]); const computedPage = React.useMemo(() => { if (rowCount === -1) { return paginationModel.page; } return paginationModel.page <= lastPage ? paginationModel.page : lastPage; }, [lastPage, paginationModel.page, rowCount]); const handlePageSizeChange = React.useCallback(pageSize => { apiRef.current.setPageSize(pageSize); }, [apiRef]); const handlePageChange = React.useCallback((_, page) => { apiRef.current.setPage(page); }, [apiRef]); const isPageSizeIncludedInPageSizeOptions = pageSize => { for (let i = 0; i < rootProps.pageSizeOptions.length; i += 1) { const 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') { // eslint-disable-next-line react-hooks/rules-of-hooks const warnedOnceMissingInPageSizeOptions = React.useRef(false); const pageSize = rootProps.paginationModel?.pageSize ?? paginationModel.pageSize; if (!warnedOnceMissingInPageSizeOptions.current && !rootProps.autoPageSize && !isPageSizeIncludedInPageSizeOptions(pageSize)) { console.warn([`MUI X: The page size \`${paginationModel.pageSize}\` is not present in the \`pageSizeOptions\`.`, `Add it to show the pagination select.`].join('\n')); warnedOnceMissingInPageSizeOptions.current = true; } } const pageSizeOptions = isPageSizeIncludedInPageSizeOptions(paginationModel.pageSize) ? rootProps.pageSizeOptions : []; return /*#__PURE__*/(0, _jsxRuntime.jsx)(GridPaginationRoot, { as: rootProps.slots.basePagination, count: rowCount, page: computedPage, rowsPerPageOptions: pageSizeOptions, rowsPerPage: paginationModel.pageSize, onPageChange: handlePageChange, onRowsPerPageChange: handlePageSizeChange, disabled: disabled }); } process.env.NODE_ENV !== "production" ? GridPagination.propTypes = { // ----------------------------- Warning -------------------------------- // | These PropTypes are generated from the TypeScript type definitions | // | To update them edit the TypeScript types and run "pnpm proptypes" | // ---------------------------------------------------------------------- component: _propTypes.default.elementType } : void 0;