UNPKG

@mui/x-data-grid

Version:

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

142 lines (140 loc) 5.4 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import * as React from 'react'; import { styled } from '@mui/material/styles'; import PropTypes from 'prop-types'; import TablePagination, { tablePaginationClasses } from '@mui/material/TablePagination'; import { useGridSelector } from '../hooks/utils/useGridSelector'; import { useGridApiContext } from '../hooks/utils/useGridApiContext'; import { useGridRootProps } from '../hooks/utils/useGridRootProps'; import { gridPaginationModelSelector, gridPaginationRowCountSelector, gridPageCountSelector } from '../hooks/features/pagination/gridPaginationSelector'; import { jsx as _jsx } from "react/jsx-runtime"; const GridPaginationRoot = styled(TablePagination)(({ theme }) => ({ [`& .${tablePaginationClasses.selectLabel}`]: { display: 'none', [theme.breakpoints.up('sm')]: { display: 'block' } }, [`& .${tablePaginationClasses.input}`]: { display: 'none', [theme.breakpoints.up('sm')]: { display: 'inline-flex' } } })); const wrapLabelDisplayedRows = (labelDisplayedRows, estimated) => { return ({ from, to, count, page }) => labelDisplayedRows({ from, to, count, page, estimated }); }; const defaultLabelDisplayedRows = ({ from, to, count, estimated }) => { if (!estimated) { return `${from}${to} of ${count !== -1 ? count : `more than ${to}`}`; } return `${from}${to} of ${count !== -1 ? count : `more than ${estimated > to ? estimated : to}`}`; }; // A mutable version of a readonly array. const GridPagination = /*#__PURE__*/React.forwardRef(function GridPagination(props, ref) { const apiRef = useGridApiContext(); const rootProps = useGridRootProps(); const paginationModel = useGridSelector(apiRef, gridPaginationModelSelector); const rowCount = useGridSelector(apiRef, gridPaginationRowCountSelector); const pageCount = useGridSelector(apiRef, gridPageCountSelector); const { paginationMode, loading, estimatedRowCount } = rootProps; const computedProps = React.useMemo(() => { if (rowCount === -1 && paginationMode === 'server' && loading) { return { backIconButtonProps: { disabled: true }, nextIconButtonProps: { disabled: true } }; } return {}; }, [loading, paginationMode, rowCount]); 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(event => { const pageSize = Number(event.target.value); 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 : []; const locales = apiRef.current.getLocaleText('MuiTablePagination'); const wrappedLabelDisplayedRows = wrapLabelDisplayedRows(locales.labelDisplayedRows || defaultLabelDisplayedRows, estimatedRowCount); return /*#__PURE__*/_jsx(GridPaginationRoot, _extends({ ref: ref, component: "div", count: rowCount, page: computedPage // TODO: Remove the cast once the type is fixed in Material UI and that the min Material UI version // for x-data-grid is past the fix. // Note that Material UI will not mutate the array, so this is safe. , rowsPerPageOptions: pageSizeOptions, rowsPerPage: paginationModel.pageSize, onPageChange: handlePageChange, onRowsPerPageChange: handlePageSizeChange }, computedProps, locales, { labelDisplayedRows: wrappedLabelDisplayedRows }, props)); }); 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 "yarn proptypes" | // ---------------------------------------------------------------------- component: PropTypes.elementType } : void 0; export { GridPagination };