shlink-web-client/src/short-urls/Paginator.tsx

53 lines
1.7 KiB
TypeScript
Raw Normal View History

2018-06-17 19:13:55 +03:00
import { Link } from 'react-router-dom';
import { Pagination, PaginationItem, PaginationLink } from 'reactstrap';
2023-02-18 13:11:01 +03:00
import type { ShlinkPaginator } from '../api/types';
2023-02-18 12:40:37 +03:00
import type {
NumberOrEllipsis } from '../utils/helpers/pagination';
import {
keyForPage,
2023-02-18 13:11:01 +03:00
pageIsEllipsis,
prettifyPageNumber,
2023-02-18 13:11:01 +03:00
progressivePagination,
} from '../utils/helpers/pagination';
2018-06-17 19:13:55 +03:00
interface PaginatorProps {
paginator?: ShlinkPaginator;
serverId: string;
currentQueryString?: string;
}
2018-06-17 19:13:55 +03:00
export const Paginator = ({ paginator, serverId, currentQueryString = '' }: PaginatorProps) => {
const { currentPage = 0, pagesCount = 0 } = paginator ?? {};
const urlForPage = (pageNumber: NumberOrEllipsis) =>
`/server/${serverId}/list-short-urls/${pageNumber}${currentQueryString}`;
if (pagesCount <= 1) {
return <div className="pb-3" />; // Return some space
}
2018-08-26 00:45:03 +03:00
const renderPages = () =>
progressivePagination(currentPage, pagesCount).map((pageNumber, index) => (
<PaginationItem
key={keyForPage(pageNumber, index)}
2020-08-28 21:05:01 +03:00
disabled={pageIsEllipsis(pageNumber)}
active={currentPage === pageNumber}
>
<PaginationLink tag={Link} to={urlForPage(pageNumber)}>
{prettifyPageNumber(pageNumber)}
2018-08-26 00:45:03 +03:00
</PaginationLink>
</PaginationItem>
));
return (
<Pagination className="sticky-card-paginator py-3" listClassName="flex-wrap justify-content-center mb-0">
<PaginationItem disabled={currentPage === 1}>
<PaginationLink previous tag={Link} to={urlForPage(currentPage - 1)} />
</PaginationItem>
{renderPages()}
<PaginationItem disabled={currentPage >= pagesCount}>
<PaginationLink next tag={Link} to={urlForPage(currentPage + 1)} />
</PaginationItem>
</Pagination>
);
};