import type { GetServerSideProps, NextPage } from "next"; import ContentPage from "../../../components/Blog/ContentPage"; import Layout from "../../../components/Blog/Layout"; import { generateContent, getContentList, prepareDOM } from "../../../lib/content/generateBackend"; import type { ContentList, ProjectRender } from "../../../lib/content/types"; const Post: NextPage<{ content: ProjectRender }> = ({ content }) => { return ; }; export const getServerSideProps: GetServerSideProps = async (context) => { const { pid } = context.query; const contentList = await getContentList(); const contentEntry = (contentList as ContentList).find((c) => c.name === pid && c.type === "project"); if (!contentEntry) return { notFound: true }; const contentHtml = await generateContent(contentEntry) as string; const contentPrepared = prepareDOM(contentHtml); context.res.setHeader("Cache-Control", "public, s-maxage=3600, stale-while-revalidate=600"); return { props: { content: { more: contentEntry.more || null, repo: contentEntry.repo || null, title: contentEntry.title, html: contentPrepared, } } }; }; export default Post;