UNPKG

phx-react

Version:

PHX REACT

65 lines 4.25 kB
"use strict"; exports.__esModule = true; var tslib_1 = require("tslib"); var free_solid_svg_icons_1 = require("@fortawesome/free-solid-svg-icons"); var react_fontawesome_1 = require("@fortawesome/react-fontawesome"); var react_1 = tslib_1.__importDefault(require("react")); function classNames() { var classes = []; for (var _i = 0; _i < arguments.length; _i++) { classes[_i] = arguments[_i]; } return classes.filter(Boolean).join(' '); } var Pagination = function (_a) { var currentPage = _a.currentPage, handleChangePage = _a.handleChangePage, totalPages = _a.totalPages, pagination = _a.pagination, rowQuantity = _a.rowQuantity, count = _a.count, router = _a.router, searchParams = _a.searchParams, tableKey = _a.tableKey; var pages = []; for (var i = 1; i <= totalPages; i++) { pages.push(i); } var handleClickPage = function (page) { handleChangePage(page); var params = new URLSearchParams(searchParams + ''); params.set("pagi-".concat(tableKey), page + ''); router.push("?".concat(params + ''), { scroll: false }); }; var disableNextPage = !totalPages || currentPage === totalPages; var disablePrevPage = currentPage === 1; var PreviousPage = function () { return (react_1["default"].createElement("a", { "aria-hidden": true, className: classNames('relative inline-flex min-h-[1.75rem] items-center rounded-bl-lg rounded-tl-lg bg-gray-100 px-3 pb-1 pt-0.5 text-gray-900 focus:z-20 focus:outline-offset-0', !disablePrevPage ? 'hover:bg-gray-200' : '', !disablePrevPage ? 'active:bg-gray-300 active:pb-[0.2rem] active:pt-[0.2rem] active:shadow-[0rem_0.125rem_0.1rem_0rem_#0004_inset]' : '', !disablePrevPage ? 'cursor-pointer' : ''), onClick: function () { if (!disablePrevPage) { handleClickPage(currentPage - 1); } } }, react_1["default"].createElement("p", null, react_1["default"].createElement("span", { className: 'sr-only' }, "Previous"), react_1["default"].createElement(react_fontawesome_1.FontAwesomeIcon, { className: classNames('h-3 w-2.5', disablePrevPage ? 'text-gray-300' : 'text-gray-900'), icon: free_solid_svg_icons_1.faAngleLeft })))); }; var NextPage = function () { return (react_1["default"].createElement("a", { "aria-hidden": true, className: classNames('relative inline-flex min-h-[1.75rem] items-center rounded-r-md rounded-br-lg rounded-tr-lg bg-gray-100 px-3 pb-1 pt-0.5 text-gray-900 focus:z-20 focus:outline-offset-0', !disableNextPage ? 'hover:bg-gray-200' : '', !disableNextPage ? 'active:bg-gray-300 active:pb-[0.03rem] active:pt-[0.01rem] active:shadow-[0rem_0.125rem_0.1rem_0rem_#0004_inset]' : '', !disableNextPage ? 'cursor-pointer' : ''), onClick: function () { if (!disableNextPage) { handleClickPage(currentPage + 1); } } }, react_1["default"].createElement("p", null, react_1["default"].createElement("span", { className: 'sr-only' }, "Next"), react_1["default"].createElement(react_fontawesome_1.FontAwesomeIcon, { className: classNames('h-3 w-2.5', disableNextPage ? 'text-gray-300' : 'text-gray-900'), icon: free_solid_svg_icons_1.faAngleRight })))); }; var startIndex = count > 0 ? pagination * rowQuantity + 1 : count; var endIndex = pagination * rowQuantity + rowQuantity; return (react_1["default"].createElement("div", { className: 'flex items-center gap-x-3' }, react_1["default"].createElement("p", { className: 'hidden text-xs sm:block' }, "Hi\u1EC3n th\u1ECB ", startIndex, " - ", endIndex >= count ? count : endIndex, " tr\u00EAn ", count, " b\u1EA3n ghi"), react_1["default"].createElement("div", { className: 'isolate inline-flex -space-x-px rounded-md bg-white shadow-sm' }, react_1["default"].createElement("div", { className: 'mr-1' }, react_1["default"].createElement(PreviousPage, null)), react_1["default"].createElement(NextPage, null)))); }; exports["default"] = Pagination; //# sourceMappingURL=Pagination.js.map