import BLOG from '@/blog.config' import { getPostBlocks } from '@/lib/notion' import { getGlobalNotionData } from '@/lib/notion/getNotionData' import { useGlobal } from '@/lib/global' import * as ThemeMap from '@/themes' /** * 根据notion的slug访问页面 * @param {*} props * @returns */ const Slug = (props) => { const { theme } = useGlobal() const ThemeComponents = ThemeMap[theme] if (!props.post) { return } return } export async function getStaticPaths () { if (!BLOG.isProd) { return { paths: [], fallback: true } } const from = 'slug-paths' const { allPosts } = await getGlobalNotionData({ from }) return { paths: allPosts.map(row => ({ params: { slug: row.slug } })), fallback: true } } export async function getStaticProps ({ params: { slug } }) { const from = `slug-props-${slug}` const { customNav, allPosts, categories, tags, postCount, latestPosts } = await getGlobalNotionData({ from, pageType: ['Post'] }) const post = allPosts.find(p => p.slug === slug) if (!post) { return { props: {}, revalidate: 1 } } post.blockMap = await getPostBlocks(post.id, 'slug') const index = allPosts.indexOf(post) const prev = allPosts.slice(index - 1, index)[0] ?? allPosts.slice(-1)[0] const next = allPosts.slice(index + 1, index + 2)[0] ?? allPosts[0] const recommendPosts = getRecommendPost(post, allPosts) return { props: { post, tags, prev, next, recommendPosts, categories, postCount, latestPosts, customNav }, revalidate: 1 } } /** * 获取文章的关联推荐文章列表,目前根据标签关联性筛选 * @param post * @param {*} allPosts * @param {*} count * @returns */ function getRecommendPost (post, allPosts, count = 5) { let filteredPosts = [] for (const i in allPosts) { const p = allPosts[i] filteredPosts.push(Object.assign(p)) } if (post.tags && post.tags.length) { const currentTag = post.tags[0] filteredPosts = filteredPosts.filter( p => p && p.slug !== post.slug && p.tags && p.tags?.includes(currentTag) && p.type === ['Post'] ) } // 筛选前5个 if (filteredPosts.length > count) { filteredPosts = filteredPosts.slice(0, count) } return filteredPosts } export default Slug