1
0
Fork 0
freesewing/sites/org/pages/blog/[dir].mjs
2023-10-10 07:35:11 +02:00

56 lines
1.4 KiB
JavaScript

import { nsMerge } from 'shared/utils.mjs'
import { pages as posts } from 'site/prebuild/blog.mjs'
import { getPostSlugPaths } from 'site/components/mdx/posts/utils.mjs'
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
import { loadMdxAsStaticProps } from 'shared/mdx/load.mjs'
import { PostLayout, ns as layoutNs } from 'site/components/layouts/post.mjs'
import { PageWrapper, ns as pageNs } from 'shared/components/wrappers/page.mjs'
const ns = nsMerge(pageNs, layoutNs)
const BlogPage = ({ locale, dir, page, mdx, frontmatter }) => {
return (
<PageWrapper
{...page}
title={frontmatter.title}
layout={(props) => (
<PostLayout
{...props}
slug={page.path.join('/')}
frontmatter={frontmatter}
mdx={mdx}
dir={dir}
type="blog"
/>
)}
/>
)
}
export async function getStaticProps({ params, locale }) {
return {
props: {
dir: params.dir,
locale,
...(await serverSideTranslations(locale, ns)),
...(await loadMdxAsStaticProps({
language: locale,
site: 'org',
slug: `blog/${params.dir}`,
})),
page: {
locale,
path: ['blog', params.dir],
},
},
}
}
export const getStaticPaths = async () => {
return {
paths: getPostSlugPaths(posts),
fallback: 'blocking',
}
}
export default BlogPage