41 lines
1000 B
TypeScript
41 lines
1000 B
TypeScript
|
import React from "react";
|
||
|
import PageButton from "./PageButton";
|
||
|
|
||
|
type PageControlProps = {
|
||
|
pageNumber: number;
|
||
|
pageSize: number;
|
||
|
total: number;
|
||
|
};
|
||
|
|
||
|
const PageControl: React.FC<PageControlProps> = ({
|
||
|
pageNumber,
|
||
|
pageSize,
|
||
|
total,
|
||
|
}) => {
|
||
|
const totalPages = Math.max(1, Math.ceil(total / pageSize));
|
||
|
const isFirst = pageNumber === 1;
|
||
|
const isLast = pageNumber === totalPages;
|
||
|
|
||
|
return (
|
||
|
<div className="flex items-baseline space-x-1 text-xs">
|
||
|
<PageButton goToPage={1} disabled={isFirst}>
|
||
|
First
|
||
|
</PageButton>
|
||
|
<PageButton goToPage={pageNumber - 1} disabled={isFirst}>
|
||
|
{"<"}
|
||
|
</PageButton>
|
||
|
<PageButton goToPage={1} disabled>
|
||
|
Page {pageNumber} of {totalPages}
|
||
|
</PageButton>
|
||
|
<PageButton goToPage={pageNumber + 1} disabled={isLast}>
|
||
|
{">"}
|
||
|
</PageButton>
|
||
|
<PageButton goToPage={totalPages} disabled={isLast}>
|
||
|
Last
|
||
|
</PageButton>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default React.memo(PageControl);
|