Skip to main content

Documentation categories

You can group the documentation to provide an easier user experience to navigate. This is accomplished by adding a directive to all the types you want to have grouped.

For example, we have two mutations called addCourse and dropCourse, and we want to group them under a category called Courses.

type Mutation {
AddCourse(input: String): String
}

type Mutation {
DropCourse(input: String): String
}

Usage

We can accomplish this by adding a directive called doc with a field category to each mutation.

type Mutation {
AddCourse(input: String): String @doc(category: "Course")
}

type Mutation {
DropCourse(input: String): String @doc(category: "Course")
}

We can add a fallback option called Common which is for types that we don't explicitly add a directive to.

It can be set either with the command line flag --groupByDirective:

npx docusaurus graphql-to-doc --groupByDirective "@doc(category|=Common)"

or the plugin configuration groupByDirective:

docusaurus.config.js
plugins: [
[
"@graphql-markdown/docusaurus",
/** @type {import('@graphql-markdown/types').ConfigOptions} */
{
// ... other options
groupByDirective: {
directive: "doc",
field: "category",
fallback: "Common", // default is Miscellaneous
}
},
],
],