@patternfly/react-core
Version:
This library provides a set of common React components for use with the PatternFly reference implementation.
102 lines • 6.03 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.PaginationOptionsMenu = void 0;
const tslib_1 = require("tslib");
const React = tslib_1.__importStar(require("react"));
const react_styles_1 = require("@patternfly/react-styles");
const Menu_1 = require("../Menu");
const MenuToggle_1 = require("../MenuToggle");
const Popper_1 = require("../../helpers/Popper/Popper");
const ToggleTemplate_1 = require("./ToggleTemplate");
const helpers_1 = require("../../helpers");
const PaginationOptionsMenu = ({ className, widgetId, page: pageProp, itemCount, isDisabled = false, minWidth, dropDirection = 'down', perPageOptions = [],
// eslint-disable-next-line @typescript-eslint/no-unused-vars
itemsPerPageTitle = 'Items per page', perPageSuffix = 'per page', optionsToggleAriaLabel, ofWord = 'of', perPage = 0, firstIndex = 0, lastIndex = 0, isLastFullPageShown = false, itemsTitle = 'items', toggleTemplate, onPerPageSelect = () => null, containerRef }) => {
const [isOpen, setIsOpen] = React.useState(false);
const toggleRef = React.useRef(null);
const menuRef = React.useRef(null);
const onToggle = () => {
setIsOpen((prevState) => !prevState);
};
const onSelect = () => {
var _a;
setIsOpen((prevState) => !prevState);
(_a = toggleRef.current) === null || _a === void 0 ? void 0 : _a.focus();
};
const handleNewPerPage = (_evt, newPerPage) => {
let newPage = pageProp;
while (Math.ceil(itemCount / newPerPage) < newPage) {
newPage--;
}
if (isLastFullPageShown) {
if (itemCount / newPerPage !== newPage) {
while (newPage > 1 && itemCount - newPerPage * newPage < 0) {
newPage--;
}
}
}
const startIdx = (newPage - 1) * newPerPage;
const endIdx = newPage * newPerPage;
return onPerPageSelect(_evt, newPerPage, newPage, startIdx, endIdx);
};
React.useEffect(() => {
const handleMenuKeys = (event) => {
var _a, _b, _c;
// Close the menu on tab or escape
if ((isOpen && ((_a = menuRef.current) === null || _a === void 0 ? void 0 : _a.contains(event.target))) ||
((_b = toggleRef.current) === null || _b === void 0 ? void 0 : _b.contains(event.target))) {
if (event.key === 'Escape' || event.key === 'Tab') {
setIsOpen(false);
(_c = toggleRef.current) === null || _c === void 0 ? void 0 : _c.focus();
}
}
};
const handleClick = (event) => {
var _a, _b, _c;
// Focus the first non-disabled menu item on toggle 'click'
if (isOpen && ((_a = toggleRef.current) === null || _a === void 0 ? void 0 : _a.contains(event.target))) {
setTimeout(() => {
var _a;
const firstElement = (_a = menuRef === null || menuRef === void 0 ? void 0 : menuRef.current) === null || _a === void 0 ? void 0 : _a.querySelector('li button:not(:disabled)');
firstElement && firstElement.focus();
}, 0);
}
// If the event is not on the toggle, close the menu
if (isOpen &&
!((_b = toggleRef === null || toggleRef === void 0 ? void 0 : toggleRef.current) === null || _b === void 0 ? void 0 : _b.contains(event.target)) &&
!((_c = menuRef.current) === null || _c === void 0 ? void 0 : _c.contains(event.target))) {
setIsOpen(false);
}
};
window.addEventListener('keydown', handleMenuKeys);
window.addEventListener('click', handleClick);
return () => {
window.removeEventListener('keydown', handleMenuKeys);
window.removeEventListener('click', handleClick);
};
}, [isOpen, menuRef]);
const renderItems = () => perPageOptions.map(({ value, title }) => (React.createElement(Menu_1.MenuItem, { key: value, "data-action": `per-page-${value}`, isSelected: perPage === value, onClick: (event) => handleNewPerPage(event, value) },
title,
` ${perPageSuffix}`)));
const toggle = (React.createElement(MenuToggle_1.MenuToggle, Object.assign({ ref: toggleRef, onClick: onToggle }, (optionsToggleAriaLabel && { 'aria-label': optionsToggleAriaLabel }), { isDisabled: isDisabled || (itemCount && itemCount <= 0), isExpanded: isOpen }, (widgetId && { id: `${widgetId}-toggle` }), { variant: "plainText", "aria-haspopup": "listbox" }),
toggleTemplate &&
typeof toggleTemplate === 'string' &&
(0, helpers_1.fillTemplate)(toggleTemplate, { firstIndex, lastIndex, ofWord, itemCount, itemsTitle }),
toggleTemplate &&
typeof toggleTemplate !== 'string' &&
toggleTemplate({
firstIndex,
lastIndex,
ofWord,
itemCount,
itemsTitle
}),
!toggleTemplate && (React.createElement(ToggleTemplate_1.ToggleTemplate, { firstIndex: firstIndex, lastIndex: lastIndex, ofWord: ofWord, itemCount: itemCount, itemsTitle: itemsTitle }))));
const menu = (React.createElement(Menu_1.Menu, { className: (0, react_styles_1.css)(className), onSelect: onSelect, ref: menuRef },
React.createElement(Menu_1.MenuContent, null,
React.createElement(Menu_1.MenuList, null, renderItems()))));
return (React.createElement(Popper_1.Popper, { trigger: toggle, triggerRef: toggleRef, popper: menu, popperRef: menuRef, isVisible: isOpen, direction: dropDirection, appendTo: (containerRef === null || containerRef === void 0 ? void 0 : containerRef.current) || undefined, minWidth: minWidth !== undefined ? minWidth : 'revert' }));
};
exports.PaginationOptionsMenu = PaginationOptionsMenu;
exports.PaginationOptionsMenu.displayName = 'PaginationOptionsMenu';
//# sourceMappingURL=PaginationOptionsMenu.js.map