This extends the Grundgesetz Skeleton created by Resi Respati at kata ai
When creating a new file, enter the full path (not just the title) to put it in a subdir that corresponds with the table of contents. You will also need to manually add the directory(if its new) and the file to the toc.json to get it to show in the toc component. This is TBD until we get the jsonForm to work with an array of objects.
The next
and prev
front matter values for the docs need to match the id
from toc.json
The project structure of Grundgesetz is specifically designed for easy maintenance of documentation and the site's code.
.
|-- docs
| |-- [path-1]
| | |-- [page-1].md
| | `-- [page-2].md
| |-- [path-2]
| | |-- [page-3].md
| | `-- [page-4].md
| |-- ...
| |-- [index.md]
| `-- toc.json
|-- [static]
| `-- ...
`-- src
|-- assets
| `-- ...
|-- components
| `-- ...
|-- layouts
| `-- ...
|-- pages
| `-- ...
|-- styles
| |-- theme.ts
| `-- ...
|-- ...
`-- typings.d.ts
docs/
- Where the documentation lives. Grundgesetz will read all.md
files and builds it in a path following the directory tree.[index.md]
- An optional Index page, if you want it to be written in Markdown. This can be replaced by a customised Index page located atpages/index.tsx
toc.json
- The file that holds the table of contents. See Table of Contents for more information.
[static/]
- Holds the static assets of the site.[src/]
- The root folder for the JavaScript source.
The toc.json
file inside the docs/
folder holds our table of contents. It will be automatically populated on the left-side drawer as a sectioned menu.
[
{
"title": "Menu Section 1",
"items": [
{
"id": "page-1",
"slug": "/section-1/page-1/",
"title": "Page 1"
},
{
"id": "page-2",
"slug": "/section-1/page-2",
"title": "Page 2"
},
{
"id": "page-3",
"slug": "/section-1/page-3",
"title": "Page 3"
}
]
},
{
"title": "Menu Section 2",
"items": [
{
"id": "page-1",
"slug": "/section-2/page-1/",
"title": "Page 1"
},
{
"id": "page-2",
"slug": "/section-2/page-2",
"title": "Page 2"
},
{
"id": "page-3",
"slug": "/section-2/page-3",
"title": "Page 3"
}
]
}
]
Writing documentation in Gatsby is done in Markdown. Grundgesetz uses Remark to parse Markdown files and turn them into HTML.
We provide the following Markdown front matter in each documentation page.
id
- A unique identifier representing the markdown page. This will be referenced intoc.json
when getting the links for the navigation sidebar, as well as theprev
andnext
items of the pagination. Note that the ID must be unique between pages, as this will also be used to look up the table of contents.permalink
- Optional. By default Grundgesetz will generate page paths relative to the path of the Markdown file. If you want to override the output path for a page, add this frontmatter with the absolute path of the output.title
- The title of the page.subtitle
- Optional. The subtitle of the page (if any)prev
- Optional. This contains theid
of the page that appears on the "Previous Page" navigation item.next
- Optional. This contains theid
of the page that appears on the "Next Page" navigation item.