UNPKG

@spaced-out/ui-design-system

Version:
128 lines (127 loc) 5.03 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.PaginationItem = exports.PaginationButton = void 0; var React = _interopRequireWildcard(require("react")); var _classify = _interopRequireDefault(require("../../utils/classify")); var _Button = require("../Button"); var _Text = require("../Text"); var _PaginationModule = _interopRequireDefault(require("./Pagination.module.css")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } const PaginationButton = props => { const { disabled, onClick, page, selected, type } = props; const paginationBtnRef = React.useRef(null); React.useEffect(() => { if (selected) { paginationBtnRef.current?.blur(); } }, [selected]); switch (type) { case 'first': return /*#__PURE__*/React.createElement(_Button.Button, { classNames: { icon: (0, _classify.default)(_PaginationModule.default.icon, { [_PaginationModule.default.disabled]: disabled }), wrapper: (0, _classify.default)(_PaginationModule.default.paginatorButton, { [_PaginationModule.default.disabled]: disabled }) }, type: selected ? 'secondary' : 'ghost', size: "small", onClick: onClick, disabled: disabled, ref: paginationBtnRef, iconLeftName: "chevrons-left", ariaLabel: "First page" }); case 'previous': return /*#__PURE__*/React.createElement(_Button.Button, { classNames: { icon: (0, _classify.default)(_PaginationModule.default.icon, { [_PaginationModule.default.disabled]: disabled }), wrapper: (0, _classify.default)(_PaginationModule.default.paginatorButton, { [_PaginationModule.default.disabled]: disabled }) }, type: selected ? 'secondary' : 'ghost', size: "small", onClick: onClick, disabled: disabled, ref: paginationBtnRef, iconLeftName: "chevron-left", ariaLabel: "Previous page" }); case 'page': return /*#__PURE__*/React.createElement(_Button.Button, { classNames: { wrapper: (0, _classify.default)(_PaginationModule.default.paginatorButton, { [_PaginationModule.default.selected]: selected }) }, type: selected ? 'secondary' : 'ghost', size: "small", onClick: onClick, disabled: disabled, ref: paginationBtnRef, tabIndex: selected ? -1 : 0 }, page); case 'start-ellipsis': case 'end-ellipsis': return /*#__PURE__*/React.createElement("div", { className: (0, _classify.default)(_PaginationModule.default.separator) }, /*#__PURE__*/React.createElement(_Text.ButtonTextSmall, { color: "disabled" }, "...")); case 'next': return /*#__PURE__*/React.createElement(_Button.Button, { classNames: { icon: (0, _classify.default)(_PaginationModule.default.icon, { [_PaginationModule.default.disabled]: disabled }), wrapper: (0, _classify.default)(_PaginationModule.default.paginatorButton, { [_PaginationModule.default.disabled]: disabled }) }, type: selected ? 'secondary' : 'ghost', size: "small", onClick: onClick, disabled: disabled, ref: paginationBtnRef, iconLeftName: "chevron-right", ariaLabel: "Next page" }); case 'last': return /*#__PURE__*/React.createElement(_Button.Button, { classNames: { icon: (0, _classify.default)(_PaginationModule.default.icon, { [_PaginationModule.default.disabled]: disabled }), wrapper: (0, _classify.default)(_PaginationModule.default.paginatorButton, { [_PaginationModule.default.disabled]: disabled }) }, type: selected ? 'secondary' : 'ghost', size: "small", onClick: onClick, disabled: disabled, ref: paginationBtnRef, iconLeftName: "chevrons-right", ariaLabel: "Last page" }); default: break; } }; exports.PaginationButton = PaginationButton; const PaginationItem = props => /*#__PURE__*/React.createElement(PaginationButton, props); exports.PaginationItem = PaginationItem;