Add model pages

This commit is contained in:
Marcus Blättermann 2022-11-15 01:49:53 +01:00
parent 07614e1625
commit 703e0a9186
No known key found for this signature in database
GPG Key ID: A1E1F04008AC450D
2 changed files with 78 additions and 0 deletions

View File

@ -0,0 +1,13 @@
import models from './languages.json'
const recordLanguages = Object.fromEntries(
models.languages.map((language, index) => [
language.code,
{
...language,
next: index < models.languages.length - 1 ? models.languages[index + 1] : null,
},
])
)
export default recordLanguages

View File

@ -0,0 +1,65 @@
import type { GetStaticPaths, GetStaticProps } from 'next'
import models from '../../meta/languages.json'
import recordSection from '../../meta/recordSections'
import recordLanguages from '../../meta/recordLanguages'
import Layout from '../../src/components/layout'
type PropsPageModel = {
id: string
slug: ReadonlyArray<string>
isIndex: false
title: string
section: 'models'
sectionTitle: string
theme: string
next: { title: string; slug: string } | null
meta: { models?: ReadonlyArray<string>; example?: string; hasExamples?: boolean }
}
const PostPageModel = (props: PropsPageModel) => {
return <Layout {...props} />
}
export default PostPageModel
export const getStaticPaths: GetStaticPaths<{ slug: string }> = async () => {
return {
paths: models.languages
.filter(({ models }) => models && models.length)
.map((language) => `/models/${language.code}`),
fallback: false,
}
}
export const getStaticProps: GetStaticProps<
PropsPageModel,
{
slug: string
}
> = async (args) => {
if (args.params === undefined) {
return { notFound: true }
}
const language = recordLanguages[args.params.slug]
return {
props: {
id: language.code,
slug: ['models', language.code],
isIndex: false,
title: language.name,
section: 'models',
sectionTitle: recordSection.models.title,
theme: recordSection.models.theme,
next: language.next
? { title: language.next.name, slug: `/models/${language.next.code}` }
: null,
meta: {
models: language.models,
example: language.example,
hasExamples: language.has_examples,
},
},
}
}