mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-21 07:26:49 +00:00
44 lines
1.2 KiB
JavaScript
44 lines
1.2 KiB
JavaScript
import BLOG from '@/blog.config'
|
|
import { getPageTableOfContents } from 'notion-utils'
|
|
import 'prismjs'
|
|
import 'prismjs/components/prism-bash'
|
|
import 'prismjs/components/prism-javascript'
|
|
import 'prismjs/components/prism-markup'
|
|
import 'prismjs/components/prism-python'
|
|
import 'prismjs/components/prism-typescript'
|
|
import ArticleDetail from './components/ArticleDetail'
|
|
import LayoutBase from './LayoutBase'
|
|
import { useState } from 'react'
|
|
import { ArticleLock } from './components/ArticleLock'
|
|
|
|
export const LayoutSlug = (props) => {
|
|
const { post } = props
|
|
const meta = {
|
|
title: `${post.title} | ${BLOG.TITLE}`,
|
|
description: post.summary,
|
|
type: 'article',
|
|
tags: post.tags
|
|
}
|
|
|
|
// 文章加锁
|
|
const articleLock = post.password && post.password !== ''
|
|
const [lock, setLock] = useState(articleLock)
|
|
const validPassword = result => {
|
|
if (result) {
|
|
setLock(false)
|
|
}
|
|
}
|
|
|
|
if (post?.blockMap?.block) {
|
|
post.content = Object.keys(post.blockMap.block)
|
|
post.toc = getPageTableOfContents(post, post.blockMap)
|
|
}
|
|
|
|
return (
|
|
<LayoutBase meta={meta} {...props} >
|
|
{!lock && <ArticleDetail {...props} />}
|
|
{lock && <ArticleLock password={post.password} validPassword={validPassword} />}
|
|
</LayoutBase>
|
|
)
|
|
}
|