-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocs-page.tsx
More file actions
68 lines (58 loc) · 1.71 KB
/
docs-page.tsx
File metadata and controls
68 lines (58 loc) · 1.71 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import { getDocsSidebar } from './util';
import { ReactDocsConfig } from './config';
import { getAllDocs, getDocBySlug } from './mdx';
import { DocumentationLayout } from './documentation-layout';
interface DocsPageProps {
config: ReactDocsConfig;
slug: string[];
}
export interface DocsMetadata {
title: string;
}
export async function generateDocsMetadata(docsConfig: ReactDocsConfig, slug: string[]): Promise<DocsMetadata> {
const { navigation } = getDocsSidebar(docsConfig);
const currentPath = slug.join("/");
// Find the current page in navigation
let pageTitle = "Documentation";
for (const section of navigation) {
const page = section.pages.find(p => p.slug === currentPath);
if (page) {
pageTitle = page.title;
break;
}
}
return {
title: pageTitle,
};
}
export async function generateDocsStaticParams(docsConfig: ReactDocsConfig) {
const docs = getAllDocs(docsConfig);
return docs.map((doc: any) => ({
slug: doc.slug.split('/')
}));
}
export async function DocsPage({ config, slug }: DocsPageProps) {
const { navigation } = getDocsSidebar(config);
const curSlug = slug.join("/");
const { content, frontmatter, headings } = await getDocBySlug(config, curSlug);
const currentPath = config.basePath + `/${curSlug}`;
console.log(currentPath);
if (!content) {
return null;
}
return (
<DocumentationLayout
config={config}
navigation={navigation}
currentPath={currentPath}
headings={headings}
>
<div className="prose prose-invert max-w-none">
<h1 id="title" className="text-3xl font-medium mb-8 mt-2">
{frontmatter.title}
</h1>
{content}
</div>
</DocumentationLayout>
);
}