Skip to content

Instantly share code, notes, and snippets.

@laurisstepanovs
Created May 20, 2023 18:21
Show Gist options
  • Save laurisstepanovs/d6761bacd67743ba43812f78c5414e0c to your computer and use it in GitHub Desktop.
Save laurisstepanovs/d6761bacd67743ba43812f78c5414e0c to your computer and use it in GitHub Desktop.
Functions for pagination
/* eslint-disable jsx-a11y/anchor-is-valid */
import clsx from 'clsx'
import {useQueryResponseLoading, useQueryResponsePagination} from '../../core/QueryResponseProvider'
import {useQueryRequest} from '../../core/QueryRequestProvider'
import {round} from "@popperjs/core/lib/utils/math";
import del from "del";
import {PaginationState} from "../../../../../../../_metronic/helpers";
import {useMemo, useState} from "react";
const mappedLabel = (label: string): string => {
if (label === '« Previous') {
return 'Previous'
}
if (label === 'Next »') {
return 'Next'
}
return label
}
const UsersListPagination = () => {
const pagination = useQueryResponsePagination()
const isLoading = useQueryResponseLoading()
const {updateState} = useQueryRequest()
const updatePage = (page: number | null) => {
if (!page || isLoading || pagination.page === page) {
return
}
updateState({page, items_per_page: 2})
}
const PAGINATION_PAGES_COUNT = 5;
const sliceLinks = (pagination: PaginationState) => {
if(!pagination.links?.length){
return [];
}
let scopedLinks = [...pagination.links];
let pageLinks: Array<{label: string; active: boolean; url: string | null; page: number | null}> = []
let previousLink: {label: string; active: boolean; url: string | null; page: number | null} = scopedLinks.shift()!;
let nextLink: {label: string; active: boolean; url: string | null; page: number | null} = scopedLinks.pop()!;
const halfOfPagesCount = Math.floor(PAGINATION_PAGES_COUNT/2);
pageLinks.push(previousLink);
if(pagination.page <= Math.round(PAGINATION_PAGES_COUNT/2) || scopedLinks.length <= PAGINATION_PAGES_COUNT){
pageLinks = [...pageLinks, ...scopedLinks.slice(0, PAGINATION_PAGES_COUNT)];
}
if(pagination.page > scopedLinks.length-halfOfPagesCount && scopedLinks.length > PAGINATION_PAGES_COUNT){
pageLinks = [...pageLinks, ...scopedLinks.slice(scopedLinks.length-PAGINATION_PAGES_COUNT, scopedLinks.length)];
}
if(!(pagination.page <= Math.round(PAGINATION_PAGES_COUNT/2) || scopedLinks.length <= PAGINATION_PAGES_COUNT) && !(pagination.page > scopedLinks.length-halfOfPagesCount)){
pageLinks = [...pageLinks, ...scopedLinks.slice(pagination.page-1-halfOfPagesCount, pagination.page+halfOfPagesCount)];
}
pageLinks.push(nextLink);
return pageLinks;
}
const paginationLinks = useMemo(
() => sliceLinks(pagination),
[pagination]
);
return (
<div className='row'>
<div className='col-sm-12 col-md-5 d-flex align-items-center justify-content-center justify-content-md-start'></div>
<div className='col-sm-12 col-md-7 d-flex align-items-center justify-content-center justify-content-md-end'>
<div id='kt_table_users_paginate'>
<ul className='pagination'>
{paginationLinks
?.map((link) => {
return {...link, label: mappedLabel(link.label)}
})
.map((link) => (
<li
key={link.label}
className={clsx('page-item', {
active: pagination.page === link.page,
disabled: isLoading,
previous: link.label === 'Previous',
next: link.label === 'Next',
})}
>
<a
className={clsx('page-link', {
'page-text': link.label === 'Previous' || link.label === 'Next',
'me-5': link.label === 'Previous',
})}
onClick={() => updatePage(link.page)}
style={{cursor: 'pointer'}}
>
{mappedLabel(link.label)}
</a>
</li>
))}
</ul>
</div>
</div>
</div>
)
}
export {UsersListPagination}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment