Files
NotionNext/themes/plog/components/BlogListPage.js
2024-06-28 16:57:47 +08:00

94 lines
2.7 KiB
JavaScript

import { siteConfig } from '@/lib/config'
import { useGlobal } from '@/lib/global'
import Link from 'next/link'
import { useRouter } from 'next/router'
import { useEffect, useRef } from 'react'
import BlogPost from './BlogPost'
export const BlogListPage = props => {
const { page = 1, posts, postCount } = props
const { locale } = useGlobal()
const router = useRouter()
const { NOTION_CONFIG } = useGlobal()
const POSTS_PER_PAGE = siteConfig('POSTS_PER_PAGE', null, NOTION_CONFIG)
const totalPage = Math.ceil(postCount / POSTS_PER_PAGE)
const currentPage = +page
const showPrev = currentPage > 1
const showNext = page < totalPage
const pagePrefix = router.asPath
.split('?')[0]
.replace(/\/page\/[1-9]\d*/, '')
.replace(/\/$/, '')
.replace('.html', '')
const blogPostRefs = useRef([])
useEffect(() => {
const observer = new IntersectionObserver(
entries => {
entries.forEach(entry => {
if (entry.isIntersecting) {
entry.target.classList.toggle('visible')
}
})
},
{
threshold: 0.1 // 调整阈值以达到最佳效果
}
)
blogPostRefs.current.forEach(ref => {
observer.observe(ref)
})
return () => {
observer.disconnect()
}
}, [])
return (
<div className='w-full'>
<div
id='posts-wrapper'
className='grid lg:grid-cols-3 grid-cols-1 md:grid-cols-2'>
{posts?.map((post, index) => (
<BlogPost
index={index}
key={post.id}
className='blog-post'
post={post}
{...props}
ref={el => blogPostRefs.current.push(el)}
/>
))}
</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 ? ' ' : ' invisible block pointer-events-none '}no-underline py-2 px-3 rounded`}>
<button rel='prev' className='block cursor-pointer'>
{locale.PAGINATION.PREV}
</button>
</Link>
<Link
href={{
pathname: `${pagePrefix}/page/${currentPage + 1}`,
query: router.query.s ? { s: router.query.s } : {}
}}
className={`${showNext ? ' ' : 'invisible pointer-events-none '} no-underline py-2 px-3 rounded`}>
<button rel='next' className='block cursor-pointer'>
{locale.PAGINATION.NEXT}
</button>
</Link>
</div>
</div>
)
}