mirror of
https://github.com/koreanbots/core.git
synced 2025-12-16 06:20:24 +00:00
fix: fixed paginator
This commit is contained in:
parent
b3f614db1d
commit
448343335d
@ -1,7 +1,6 @@
|
||||
import Link from 'next/link'
|
||||
|
||||
const Paginator = ({ currentPage, totalPage }:PaginatorProps):JSX.Element => {
|
||||
const pages = [currentPage === 1 ? 2 : currentPage === 2 ? 1 : currentPage - 2, currentPage === 1 || currentPage === 2 ? 3 : currentPage - 1, currentPage, currentPage === 1 || currentPage === 2 ? 4 : currentPage + 1, currentPage === 1 || currentPage === 2 ? 5 : currentPage + 2]
|
||||
const pages = [1, currentPage - 1, currentPage, currentPage + 1, totalPage ]
|
||||
return <div className='flex flex-col items-center my-12 text-center justify-center'>
|
||||
<div className='flex text-gray-700 dark:text-gray-400'>
|
||||
<Link href={{ pathname: '/list/votes', query: { page: currentPage - 1} }}>
|
||||
@ -10,12 +9,21 @@ const Paginator = ({ currentPage, totalPage }:PaginatorProps):JSX.Element => {
|
||||
</a>
|
||||
</Link>
|
||||
<div className='flex h-12 font-medium rounded-full bg-gray-200 dark:bg-discord-black'>
|
||||
<a className={`w-12 md:flex justify-center items-center hidden cursor-pointer leading-5 transition duration-150 ease-in hover:bg-gray-400 dark:hover:bg-discord-dark-hover order-1${currentPage === 1 ? '' : ' rounded-l-full'}`}>{pages[0]}</a>
|
||||
<a className={`w-12 md:flex justify-center items-center hidden cursor-pointer leading-5 transition duration-150 ease-in hover:bg-gray-400 dark:hover:bg-discord-dark-hover order-6${(pages[3]) >= totalPage ? ' rounded-r-full' : ''}`}>{pages[1]}</a>
|
||||
<a className={`w-12 md:flex justify-center items-center hidden cursor-pointer leading-5 transition duration-150 ease-in bg-gray-300 dark:bg-very-black text-gray-900 dark:text-white ${currentPage === 1 ? 'order-first rounded-l-full' : currentPage === 2 ? 'order-2' : 'order-7'}`}>{pages[2]}</a>
|
||||
<a className={`${(pages[3]) >= totalPage ? 'hidden ' : `md:flex ${(pages[4]) >= totalPage ? 'rounded-r-full' : ''}`}w-12 justify-center items-center hidden cursor-pointer leading-5 transition duration-150 ease-in hover:bg-gray-400 dark:hover:bg-discord-dark-hover order-8`}>{pages[3]}</a>
|
||||
<a className={`${(pages[4]) >= totalPage ? 'hidden ' : 'md:flex rounded-r-full'}w-12 justify-center items-center hidden cursor-pointer leading-5 transition duration-150 ease-in hover:bg-gray-400 dark:hover:bg-discord-dark-hover order-9`}>{pages[4]}</a>
|
||||
<a className='w-12 h-12 md:hidden flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in text-gray-900 dark:text-white hover:bg-gray-400 dark:hover:bg-discord-dark-hover'>{pages[2]}</a>
|
||||
<a className={`w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in rounded-l-full ${pages[0] === currentPage ? 'bg-gray-400 dark:bg-discord-dark-hover' : ' hover:bg-gray-400 dark:hover:bg-discord-dark-hover'}`}>{pages[0]}</a>
|
||||
{
|
||||
pages[1] - pages[0] <= 1 ? '' : <>
|
||||
<a className='w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in'>...</a>
|
||||
<a className='w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in hover:bg-gray-400 dark:hover:bg-discord-dark-hover'>{pages[1]}</a>
|
||||
</>
|
||||
}
|
||||
<a className={`w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in ${currentPage === 1 || currentPage === totalPage ? 'hover:bg-gray-400 dark:hover:bg-discord-dark-hover' : 'bg-gray-400 dark:bg-discord-dark-hover '}`}>{pages[2] === pages[4] ? pages[4] - 1 : pages[2]}</a>
|
||||
{
|
||||
pages[4] - pages[3] <= 1 ? '' : <>
|
||||
<a className='w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in hover:bg-gray-400 dark:hover:bg-discord-dark-hover'>{pages[3]}</a>
|
||||
<a className='w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in'>...</a>
|
||||
</>
|
||||
}
|
||||
<a className={`w-12 md:flex justify-center items-center cursor-pointer leading-5 transition duration-150 ease-in rounded-r-full ${pages[4] === currentPage ? 'bg-gray-400 dark:bg-discord-dark-hover' : ' hover:bg-gray-400 dark:hover:bg-discord-dark-hover'}`}>{pages[4]}</a>
|
||||
</div>
|
||||
<Link href={{ pathname: '/list/votes', query: { page: currentPage + 1} }}>
|
||||
<a className={`${currentPage === totalPage ? 'hidden' : '' } h-12 w-12 ml-1 flex justify-center items-center rounded-full transition duration-150 ease-in bg-gray-200 dark:bg-discord-black hover:bg-gray-400 dark:hover:bg-discord-dark-hover cursor-pointer text-center`}>
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user