Skip to content

Overview

Documentation is powered by MkDocs with MkDocs Material, hosted on Github Pages. Pipenv is the package manager the documentation uses.

Setup

For developers, an MkDocs setup is included as part of the dev install script.

Note

The dev install script requires a .env file for any environment variables needed. To create a .env file, copy ".example.env" and make any necessary changes.

Updating

Updating documentation is as simple as updating Markdown files, all contained within the docs folder in the Monorepo.

To preview your changes, this will build the site locally, with automatic updates as you make changes:

pipenv run mkdocs serve

Note

For any mkdocs commands, you must be in the outermost docs folder for it to find your files correctly.

Deploying

With Github Actions, updates to the main branch will automatically build and deploy the static site to the gh-pages branch.

To deploy manually, run

pipenv run mkdocs gh-deploy --force

Warning

This updates the gh-pages branch with the static site. Keep in mind, if there are unpublished changes, it will display those changes as well, so beware!

To preview what files will be generated and published, this generates the static website files under docs/site/:

pipenv run mkdocs build

Notes

There are many MkDocs Plugins that may be useful while updating documentation, so consider them as this documentation evolves! More information about plugins here.

The Github Action for automatic deployment was found here, slightly changed.

If time allows for it, consider looking at Sphinx instead, for documentation. It seems more advanced, with more features and apparently better code integration with documentation, but may be harder to set up and learn.