mirror of https://github.com/portainer/portainer
94 lines
2.2 KiB
TypeScript
94 lines
2.2 KiB
TypeScript
import './pagination-controls.css';
|
|
|
|
import { generatePagesArray } from './generatePagesArray';
|
|
import { PageButton } from './PageButton';
|
|
import { PageInput } from './PageInput';
|
|
|
|
interface Props {
|
|
boundaryLinks?: boolean;
|
|
currentPage: number;
|
|
directionLinks?: boolean;
|
|
onPageChange(page: number): void;
|
|
pageCount: number;
|
|
maxSize: number;
|
|
isInputVisible?: boolean;
|
|
}
|
|
|
|
export function PageSelector({
|
|
currentPage,
|
|
pageCount,
|
|
onPageChange,
|
|
maxSize = 5,
|
|
directionLinks = true,
|
|
boundaryLinks = false,
|
|
isInputVisible = false,
|
|
}: Props) {
|
|
const pages = generatePagesArray(currentPage, pageCount, maxSize);
|
|
const last = pages[pages.length - 1];
|
|
|
|
if (pages.length <= 1) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<>
|
|
{isInputVisible && (
|
|
<PageInput
|
|
onChange={(page) => onPageChange(page)}
|
|
totalPages={pageCount}
|
|
/>
|
|
)}
|
|
<ul className="pagination">
|
|
{boundaryLinks ? (
|
|
<PageButton
|
|
onPageChange={onPageChange}
|
|
page={1}
|
|
disabled={currentPage === 1}
|
|
>
|
|
«
|
|
</PageButton>
|
|
) : null}
|
|
{directionLinks ? (
|
|
<PageButton
|
|
onPageChange={onPageChange}
|
|
page={currentPage - 1}
|
|
disabled={currentPage === 1}
|
|
>
|
|
‹
|
|
</PageButton>
|
|
) : null}
|
|
{pages.map((pageNumber, index) => (
|
|
<PageButton
|
|
onPageChange={onPageChange}
|
|
page={pageNumber}
|
|
disabled={pageNumber === '...'}
|
|
active={currentPage === pageNumber}
|
|
key={index}
|
|
>
|
|
{pageNumber}
|
|
</PageButton>
|
|
))}
|
|
|
|
{directionLinks ? (
|
|
<PageButton
|
|
onPageChange={onPageChange}
|
|
page={currentPage + 1}
|
|
disabled={currentPage === last}
|
|
>
|
|
›
|
|
</PageButton>
|
|
) : null}
|
|
{boundaryLinks ? (
|
|
<PageButton
|
|
disabled={currentPage === last}
|
|
onPageChange={onPageChange}
|
|
page={last}
|
|
>
|
|
»
|
|
</PageButton>
|
|
) : null}
|
|
</ul>
|
|
</>
|
|
);
|
|
}
|