1
0
Fork 0
freesewing/sites/org/pages/newsletter/[dir].mjs

62 lines
1.6 KiB
JavaScript

import { nsMerge, localePath } from 'shared/utils.mjs'
import { pages as posts } from 'site/prebuild/newsletter.posts.mjs'
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
import { loadMdxAsStaticProps } from 'shared/mdx/load.mjs'
import { PageWrapper, ns as pageNs } from 'shared/components/wrappers/page.mjs'
import { PostLayout, ns as layoutNs } from 'site/components/layouts/post.mjs'
const ns = nsMerge(pageNs, layoutNs)
const NewsletterPage = ({ dir, page, mdx, frontmatter }) => {
return (
<PageWrapper
{...page}
title={frontmatter.title}
intro={frontmatter.intro}
layout={(props) => (
<PostLayout
{...props}
slug={page.path.join('/')}
frontmatter={frontmatter}
mdx={mdx}
dir={dir}
type="newsletter"
/>
)}
/>
)
}
export async function getStaticProps({ params, locale }) {
const { dir } = params
// if the dir isn't present in the prebuilt posts, return 404
if (!Object.keys(posts[locale]).includes(`newsletter/${dir}`)) return { notFound: true }
return {
props: {
dir,
locale,
...(await serverSideTranslations(locale, ns)),
...(await loadMdxAsStaticProps({
language: locale,
site: 'org',
slug: `newsletter/${params.dir}`,
})),
page: {
locale,
path: ['newsletter', dir],
},
},
}
}
export const getStaticPaths = async () => {
const paths = []
for (const lang in posts) {
paths.push(...Object.keys(posts[lang]).map((slug) => localePath(lang, slug)))
}
return { paths, fallback: false }
}
export default NewsletterPage