import { Suspense } from "react"; import { ErrorBoundary } from "react-error-boundary"; import Content from "../../../components/Content"; import Link from "../../../components/Link"; import Time from "../../../components/Time"; import Comments from "../../../components/Comments"; import Loading from "../../../components/Loading"; import HitCounter from "./counter"; import { getPostSlugs, getPostData } from "../../../lib/helpers/posts"; import { metadata as defaultMetadata } from "../../layout"; import config from "../../../lib/config"; import { FiCalendar, FiTag, FiEdit, FiEye } from "react-icons/fi"; import type { Metadata, Route } from "next"; import type { Article, WithContext } from "schema-dts"; import styles from "./page.module.css"; // https://nextjs.org/docs/app/api-reference/functions/generate-static-params#disable-rendering-for-unspecified-paths export const dynamicParams = false; // https://nextjs.org/docs/app/building-your-application/rendering/partial-prerendering#using-partial-prerendering export const experimental_ppr = true; export async function generateStaticParams() { const slugs = await getPostSlugs(); // map slugs into a static paths object required by next.js return slugs.map((slug) => ({ slug, })); } export async function generateMetadata({ params }: { params: Promise<{ slug: string }> }): Promise { const { slug } = await params; const { frontMatter } = await getPostData(slug); return { title: frontMatter.title, description: frontMatter.description, openGraph: { ...defaultMetadata.openGraph, title: frontMatter.title, url: `/notes/${slug}`, type: "article", authors: [config.authorName], tags: frontMatter.tags, publishedTime: frontMatter.date, modifiedTime: frontMatter.date, images: frontMatter.image ? [{ url: frontMatter.image, alt: frontMatter.title }] : defaultMetadata.openGraph?.images, }, alternates: { ...defaultMetadata.alternates, canonical: `/notes/${slug}`, }, }; } export default async function Page({ params }: { params: Promise<{ slug: string }> }) { const { slug } = await params; const { frontMatter } = await getPostData(slug); const jsonLd: WithContext
= { "@context": "https://schema.org", "@type": "Article", name: frontMatter.title, description: frontMatter.description || config.longDescription, url: frontMatter.permalink, image: frontMatter.image, datePublished: frontMatter.date, dateModified: frontMatter.date, author: { "@type": "Person", name: config.authorName, url: config.baseUrl, }, }; const { default: MDXContent } = await import(`../../../notes/${slug}.mdx`); return ( <>