|
import BLOG from '@/blog.config' |
|
import { getPostBlocks } from '@/lib/notion' |
|
import { getGlobalData } from '@/lib/notion/getNotionData' |
|
import { useRouter } from 'next/router' |
|
import { getLayoutByTheme } from '@/themes/theme' |
|
import { siteConfig } from '@/lib/config' |
|
|
|
|
|
|
|
|
|
|
|
|
|
const Page = props => { |
|
|
|
const Layout = getLayoutByTheme({ theme: siteConfig('THEME'), router: useRouter() }) |
|
|
|
return <Layout {...props} /> |
|
} |
|
|
|
export async function getStaticPaths() { |
|
const from = 'page-paths' |
|
const { postCount } = await getGlobalData({ from }) |
|
const totalPages = Math.ceil(postCount / BLOG.POSTS_PER_PAGE) |
|
return { |
|
|
|
paths: Array.from({ length: totalPages - 1 }, (_, i) => ({ |
|
params: { page: '' + (i + 2) } |
|
})), |
|
fallback: true |
|
} |
|
} |
|
|
|
export async function getStaticProps({ params: { page } }) { |
|
const from = `page-${page}` |
|
const props = await getGlobalData({ from }) |
|
const { allPages } = props |
|
const allPosts = allPages?.filter(page => page.type === 'Post' && page.status === 'Published') |
|
|
|
props.posts = allPosts.slice(BLOG.POSTS_PER_PAGE * (page - 1), BLOG.POSTS_PER_PAGE * page) |
|
props.page = page |
|
|
|
|
|
if (BLOG.POST_LIST_PREVIEW === 'true') { |
|
for (const i in props.posts) { |
|
const post = props.posts[i] |
|
if (post.password && post.password !== '') { |
|
continue |
|
} |
|
post.blockMap = await getPostBlocks(post.id, 'slug', BLOG.POST_PREVIEW_LINES) |
|
} |
|
} |
|
|
|
delete props.allPages |
|
return { |
|
props, |
|
revalidate: parseInt(BLOG.NEXT_REVALIDATE_SECOND) |
|
} |
|
} |
|
|
|
export default Page |
|
|