forked from react-hook-form/documentation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontentlayer.config.ts
39 lines (37 loc) · 1.07 KB
/
contentlayer.config.ts
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
import { defineDocumentType, makeSource } from "contentlayer/source-files"
import { remarkHeadingId } from "remark-custom-heading-id"
import remarkGfm from "remark-gfm"
import rehypeMdxCodeProps from "rehype-mdx-code-props"
import emoji from "remark-emoji"
export const Doc = defineDocumentType(() => ({
name: "Doc",
contentType: "mdx",
filePathPattern: "**/*.mdx",
fields: {
title: { type: "string", required: true },
description: { type: "string", required: true },
sidebar: { type: "string", required: true },
},
computedFields: {
slug: {
type: "string",
resolve: (doc) => `/${doc._raw.flattenedPath}`,
},
slugAsParams: {
type: "string",
resolve: (doc) => doc._raw.flattenedPath.split("/").slice(1).join("/"),
},
segment: {
type: "list",
resolve: (doc) => doc._raw.flattenedPath.split("/"),
},
},
}))
export default makeSource({
contentDirPath: "src/content",
documentTypes: [Doc],
mdx: {
remarkPlugins: [remarkGfm, remarkHeadingId, emoji],
rehypePlugins: [rehypeMdxCodeProps],
},
})