personal-website/app/blog/[slug]/head.tsx
Filipe Medeiros 40f7fbf1a1
fix: meta info and more
Signed-off-by: Filipe Medeiros <hello@filipesm.eu>
2023-12-03 12:25:57 +01:00

53 lines
1.5 KiB
TypeScript

import { notFound } from 'next/navigation'
import CommonHead from '@/components/server/CommonHead'
import { getBlogPostBySlug } from '@/lib/notion/content/blogPosts'
import getProxiedAssetUrl from '@/lib/notion/utils/getProxiedAssetUrl'
import richTextAsPlainText from '@/lib/notion/utils/richTextToPlainText'
export default async function Head({
params: { slug },
}: {
params: { slug: string }
}) {
const blogPost = await getBlogPostBySlug({ slug })
if (!blogPost) {
notFound()
}
const title = `${richTextAsPlainText(
blogPost.properties.Name.title,
)} - Filipe Medeiros`
const description = richTextAsPlainText(
blogPost.properties.MetaDescription.rich_text,
)
return (
<>
<CommonHead />
<title>{title}</title>
<meta name="description" content={description} />
<meta
name="og:image"
content={`https://filipesm.eu${getProxiedAssetUrl({
pageId: blogPost.id,
lastEditedTime: blogPost.last_edited_time,
})}`}
/>
<link rel="canonical" href={`https://filipesm.eu/blog/${slug}`} />
<meta
name="twitter:card"
content={
blogPost.properties.MetaTwitterCard.select?.name ??
'summary_large_image'
}
/>
<meta property="og:url" content={`https://filipesm.eu/blog/${slug}`} />
<meta property="og:title" content={title} />
<meta property="og:description" content={description} />
<meta property="og:type" content="article" />
</>
)
}