mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-14 07:26:52 +00:00
48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
import NavPostListEmpty from './NavPostListEmpty'
|
|
import { useRouter } from 'next/router'
|
|
import NavPostItem from './NavPostItem'
|
|
import { useGitBookGlobal } from '..'
|
|
|
|
/**
|
|
* 博客列表滚动分页
|
|
* @param posts 所有文章
|
|
* @param tags 所有标签
|
|
* @returns {JSX.Element}
|
|
* @constructor
|
|
*/
|
|
const NavPostList = (props) => {
|
|
const { filteredPosts } = useGitBookGlobal()
|
|
|
|
const router = useRouter()
|
|
let selectedSth = false
|
|
|
|
// 处理是否选中
|
|
filteredPosts.map((group) => {
|
|
let groupSelected = false
|
|
for (const post of group?.items) {
|
|
if (router.asPath.split('?')[0] === '/' + post.slug) {
|
|
groupSelected = true
|
|
selectedSth = true
|
|
}
|
|
}
|
|
group.selected = groupSelected
|
|
return null
|
|
})
|
|
|
|
// 如果都没有选中默认打开第一个
|
|
if (!selectedSth && filteredPosts && filteredPosts.length > 0) {
|
|
filteredPosts[0].selected = true
|
|
}
|
|
|
|
if (!filteredPosts || filteredPosts.length === 0) {
|
|
return <NavPostListEmpty />
|
|
} else {
|
|
return <div id='posts-wrapper' className='w-full flex-grow'>
|
|
{/* 文章列表 */}
|
|
{filteredPosts?.map((group, index) => <NavPostItem key={index} group={group} onHeightChange={props.onHeightChange}/>)}
|
|
</div>
|
|
}
|
|
}
|
|
|
|
export default NavPostList
|