Skip to content

Commit

Permalink
New pagination
Browse files Browse the repository at this point in the history
  • Loading branch information
alexzhang1618 committed Apr 13, 2024
1 parent 5cd0cc6 commit 743bb2d
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 63 deletions.
62 changes: 35 additions & 27 deletions src/components/common/PaginationControls/index.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import Typography from '@/components/common/Typography';
import LeftArrowIcon from '@/public/assets/icons/arrow-left.svg';
import RightArrowIcon from '@/public/assets/icons/arrow-right.svg';
import { useEffect, useState } from 'react';
import style from './style.module.scss';

interface PaginationControlsProps {
Expand All @@ -9,18 +9,12 @@ interface PaginationControlsProps {
pages: number;
}

function calculatePagesToDisplay(page: number, totalPages: number, maxWidth: number): number[] {
const radius = (maxWidth - 1) / 2;
if (page + radius >= totalPages) {
return Array.from({ length: maxWidth }, (_, key) => totalPages - maxWidth + 1 + key);
}
const displayPage = page + 1;
const start = Math.max(1, displayPage - radius);
return Array.from({ length: Math.min(maxWidth, totalPages) }, (_, key) => start + key);
}

const PaginationControls = ({ page, onPage, pages }: PaginationControlsProps) => {
const pagesToDisplay = calculatePagesToDisplay(page, pages, 5);
const [value, setValue] = useState(String(page + 1));

useEffect(() => {
setValue(String(page + 1));
}, [page]);

return (
<div className={style.paginationBtns}>
Expand All @@ -33,21 +27,35 @@ const PaginationControls = ({ page, onPage, pages }: PaginationControlsProps) =>
<LeftArrowIcon />
</button>
<div className={style.paginationText}>
{pagesToDisplay.map(displayPage => (
<button
type="button"
onClick={() => onPage(displayPage - 1)}
key={displayPage}
className={style.pageButton}
>
<Typography
variant="h5/regular"
className={displayPage === page + 1 ? style.active : style.pageText}
>
{displayPage}
</Typography>
</button>
))}
<input
className={style.pageNumber}
type="text"
inputMode="numeric"
pattern="[0-9]*"
value={value}
onChange={e => {
setValue(e.currentTarget.value);
const page = +e.currentTarget.value - 1;
if (Number.isInteger(page) && page >= 0 && page < pages) {
onPage(page);
}
}}
onBlur={e => {
// Clamp page number between 1 and pages
const inputPage = Math.min(
Math.max(Math.trunc(+e.currentTarget.value - 1), 0),
pages - 1
);
if (Number.isNaN(inputPage)) {
setValue(String(page + 1));
} else {
onPage(inputPage);
setValue(String(inputPage + 1));
}
}}
/>
<span>/</span>
<span className={style.pageNumber}>{pages}</span>
</div>
<button
type="button"
Expand Down
54 changes: 22 additions & 32 deletions src/components/common/PaginationControls/style.module.scss
Original file line number Diff line number Diff line change
@@ -1,55 +1,45 @@
@use 'src/styles/vars.scss' as vars;

.paginationBtns {
align-items: center;
display: flex;
gap: 1.5rem;
gap: 20px;
justify-content: center;

.paginationBtn {
background-color: var(--theme-surface-1);
background: var(--theme-elevated-background);
border: 1px solid var(--theme-elevated-stroke);
border-radius: 50%;
color: var(--theme-primary-2);
font-size: 0;
padding: 0;

&:disabled {
color: var(--theme-elevated-stroke);
cursor: auto;
opacity: 0.5;
}
}

@media screen and (width <= vars.$breakpoint-md) {
gap: 1rem;
}

.paginationText {
align-items: center;
background-color: var(--theme-surface-1);
border-radius: 1.5rem;
background-color: var(--theme-elevated-background);
border: 1px solid var(--theme-elevated-stroke);
border-radius: 1rem;
display: flex;
font-weight: bold;
gap: 1.5rem;
padding: 0.25rem 1.5rem;

.pageButton {
background: none;
display: flex;
justify-content: center;
width: 1rem;

.active {
color: var(--theme-primary-2);
font-weight: 700 !important;
}

@media screen and (width <= vars.$breakpoint-md) {
width: 0.75rem;

.active,
.pageText {
font-size: 1rem !important;
line-height: 1.5rem !important;
}
gap: 0.5rem;
padding: 0.375rem 1rem;

.pageNumber {
text-align: center;
width: 24px;

&:is(input) {
background-color: inherit;
border-bottom: 1.5px solid var(--theme-text-on-background-1);
color: var(--theme-text-on-background-1);
font: inherit;
margin-bottom: -1.5px;
text-align: center;
}
}
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
export type Styles = {
active: string;
pageButton: string;
pageText: string;
pageNumber: string;
paginationBtn: string;
paginationBtns: string;
paginationText: string;
Expand Down
2 changes: 1 addition & 1 deletion src/pages/events.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ const DEFAULT_FILTER_STATE = {
search: '',
};

const ROWS_PER_PAGE = 4;
const ROWS_PER_PAGE = 25;

const EventsPage = ({ events, attendances, initialFilters }: EventsPageProps) => {
const [page, setPage] = useState(0);
Expand Down

0 comments on commit 743bb2d

Please sign in to comment.