forked from kenkoooo/AtCoderProblems
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathListPaginationPanel.tsx
More file actions
119 lines (112 loc) · 2.98 KB
/
ListPaginationPanel.tsx
File metadata and controls
119 lines (112 loc) · 2.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import React from "react";
import { PaginationPanelProps } from "react-bootstrap-table";
import {
DropdownItem,
DropdownMenu,
DropdownToggle,
UncontrolledDropdown,
PaginationLink,
} from "reactstrap";
export interface ListPaginationPanelProps extends PaginationPanelProps {
totalPages: number;
}
const range = (start: number, end: number): number[] =>
Array.from({ length: end - start + 1 }, (v, k) => k + start);
const pageList = (
currPage: number,
pageStartIndex: number,
totalPage: number
): number[] => {
if (totalPage === 0) {
return [];
}
if (totalPage <= 10) {
return range(1, totalPage);
}
const pageNumbers: number[] = [currPage];
let tmpExp = 1;
for (;;) {
tmpExp *= 2;
const tmpPageNumber = currPage - tmpExp + 1;
if (tmpPageNumber < pageStartIndex) {
break;
}
pageNumbers.unshift(tmpPageNumber);
}
if (pageNumbers[0] !== pageStartIndex) {
pageNumbers.unshift(pageStartIndex);
}
tmpExp = 1;
for (;;) {
tmpExp *= 2;
const tmpPageNumber = currPage + tmpExp - 1;
if (tmpPageNumber > totalPage) {
break;
}
pageNumbers.push(tmpPageNumber);
}
if (pageNumbers.slice(-1)[0] !== totalPage) {
pageNumbers.push(totalPage);
}
return pageNumbers;
};
export const ListPaginationPanel: React.FC<ListPaginationPanelProps> = (
props
) => {
const pageNumbers = pageList(
props.currPage,
props.pageStartIndex,
props.totalPages
);
return (
<>
<div className="col-md-2 col-xs-2 col-sm-2 col-lg-2">
<UncontrolledDropdown className="react-bs-table-sizePerPage-dropdown">
<DropdownToggle caret>{props.sizePerPage}</DropdownToggle>
<DropdownMenu>
{(
props.sizePerPageList as Array<{
text: string;
value: number;
}>
).map((p) => (
<DropdownItem
key={p.text}
onClick={(): void => props.changeSizePerPage(p.value)}
>
{p.text}
</DropdownItem>
))}
</DropdownMenu>
</UncontrolledDropdown>
</div>
<div
className="col-md-10 col-xs-10 col-sm-10 col-lg-10"
style={{ display: "block" }}
>
<ul
className="react-bootstrap-table-page-btns-ul pagination"
style={{ flexWrap: "wrap", justifyContent: "flex-end" }}
>
{pageNumbers.map((pageNumber: number) => {
const className =
(pageNumber === props.currPage ? "active " : "") + "page-item";
return (
<li
className={className}
key={pageNumber}
title={pageNumber.toString()}
>
<PaginationLink
onClick={(): void => props.changePage(pageNumber)}
>
{pageNumber}
</PaginationLink>
</li>
);
})}
</ul>
</div>
</>
);
};