mirror of
https://github.com/jeffvli/feishin.git
synced 2026-06-20 19:04:23 +02:00
add additional list pagination helpers and components
This commit is contained in:
@@ -0,0 +1,23 @@
|
||||
import { useSearchParams } from 'react-router-dom';
|
||||
|
||||
interface UseItemListPaginationProps {
|
||||
initialPage?: number;
|
||||
}
|
||||
|
||||
export const useItemListPagination = ({ initialPage }: UseItemListPaginationProps) => {
|
||||
const [searchParams, setSearchParams] = useSearchParams();
|
||||
|
||||
const currentPage = initialPage || Number(searchParams.get('currentPage')) || 0;
|
||||
|
||||
const onChange = (index: number) => {
|
||||
setSearchParams(
|
||||
(params) => {
|
||||
params.set('currentPage', String(index));
|
||||
return params;
|
||||
},
|
||||
{ replace: true },
|
||||
);
|
||||
};
|
||||
|
||||
return { currentPage, onChange };
|
||||
};
|
||||
Reference in New Issue
Block a user