mkdocs
MkDocs is a static site generator for building project documentation. Documentation source files are written in Markdown, and configured with a single YAML configuration file.
I chose mkdocs to build the site because of its simplicity.
Some other options: hugo.
My install
Install a virtual environment such as virtualenvwrapper.
Create your virtual environment and activate it:
Install mkdocs. It's version 1.5.3. in my case:
Install material theme for mkdocs:
Install plugins such as glightbox:
Install plugins such as "git-revision-date-localized"
Install plugins such as "mkdocs-pdf-export"
Customizing Material theme: pluggins and extensions
Some plugins like "mkdocs-glightbox", "mkdocs-git-revision-date-localized-plugin", or "mkdocs-pdf-export-plugin", need to be added when the web app is deployed, so for that reason they are added at .github/workflow/doc.yml.
But some other pluggings just need to be added in the mkdocs configuration file (mkdocs.yml) like this:
Admonition extension
Source: https://squidfunk.github.io/mkdocs-material/reference/admonitions/
In mkdocs.yml:
Basic syntax
Code in the document:
How it is seen:
title
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla et euismod nulla.
Admonitions follow a simple syntax: a block starts with !!!
, followed by a single keyword used as a type qualifier. The content of the block follows on the next line, indented by four spaces
When Details is enabled and an admonition block is started with ???
instead of !!!
, the admonition is rendered as a collapsible block with a small toggle on the right side.
These are the type qualifier: note
abstract
info
tip
success
question
warning
failure
danger
bug
example
quote
Content tabs
Source: https://squidfunk.github.io/mkdocs-material/reference/content-tabs/
In mkdocs.yml:
Code in the document:
How it is seen:
Content
Content
Content
Data tables
Source: https://squidfunk.github.io/mkdocs-material/reference/data-tables/#customization
In mkdocs.yml:
After applying the customization, data tables can be sorted by clicking on a column-. This is code in the document
Data table, columns sortable | |
---|---|
This is how it is seen:
Method | Description |
---|---|
GET |
Fetch resource |
PUT |
Update resource |
DELETE |
Delete resource |
PDF button in every page
Most of the existing plugins offer a print-all-in-one-file solution, which is not my intended development.
mkdocs-pdf-export-plugin
https://github.com/zhaoterryy/mkdocs-pdf-export-plugin
Install and add to gh-deploy workflow:
mkdocs.yml
/docs/css/extra.css
Resolving relative link issues when rendering
https://octoprint.github.io/mkdocs-site-urls/
Revision date
https://timvink.github.io/mkdocs-git-revision-date-localized-plugin/ ]
Install and add to gh-deploy workflow:
mkdocs.yml
This plugin needs access to the last commit that touched a specific file to be able to retrieve the date. By default many build environments only retrieve the last commit, which means you might need to:
- github actions: set
fetch-depth
to0
(docs)
Types
To add a revision date to the default mkdocs
theme, add a overrides/partials
folder to your docs
folder and update your mkdocs.yml
file. Then you can extend the base mkdocs
theme by adding a new file docs/overrides/content.html
: