mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-14 15:09:22 +00:00
41 lines
1.7 KiB
JavaScript
41 lines
1.7 KiB
JavaScript
|
|
import BLOG from '@/blog.config'
|
|
import { useRouter } from 'next/router'
|
|
import Link from 'next/link'
|
|
import { BlogItem } from './BlogItem'
|
|
|
|
export const BlogListPage = props => {
|
|
const { page = 1, posts, postCount } = props
|
|
const router = useRouter()
|
|
const totalPage = Math.ceil(postCount / BLOG.POSTS_PER_PAGE)
|
|
const currentPage = +page
|
|
|
|
const showPrev = currentPage > 1
|
|
const showNext = page < totalPage
|
|
const pagePrefix = router.asPath.replace(/\/page\/[1-9]\d*/, '').replace(/\/$/, '')
|
|
|
|
return (
|
|
<div className="w-full md:pr-8 mb-12">
|
|
|
|
<div id="container">
|
|
{posts?.map(p => (
|
|
<BlogItem key={p.id} post={p}/>
|
|
))}
|
|
</div>
|
|
|
|
<div className="flex justify-between text-xs">
|
|
<Link
|
|
href={{ pathname: currentPage - 1 === 1 ? `${pagePrefix}/` : `${pagePrefix}/page/${currentPage - 1}`, query: router.query.s ? { s: router.query.s } : {} }}
|
|
className={`${showPrev ? 'text-blue-400 border-b border-blue-400 ' : 'bg-gray pointer-events-none '} text-white no-underline pb-1 px-3`}>
|
|
NEWER POSTS <i className="fa-solid fa-arrow-left"></i>
|
|
</Link>
|
|
<Link
|
|
href={{ pathname: `${pagePrefix}/page/${currentPage + 1}`, query: router.query.s ? { s: router.query.s } : {} }}
|
|
className={`${showNext ? 'text-blue-400 border-b border-blue-400 ' : 'bg-gray pointer-events-none '} text-white no-underline pb-1 px-3`}>
|
|
OLDER POSTS <i className="fa-solid fa-arrow-right"></i>
|
|
</Link>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|