Customize the repository
File structure overview
The most important files in the repository are markdown (.md
) files, containing the website content, and configuration files that specify the layout and theme of the website. The most important configuration file is mkdocs.yml
which specifies the layout and theme of the website. Below we explain the most important files and how to customize them.
The template is based on (https://squidfunk.github.io/mkdocs-material/), so most features are inherited from this theme, and ample documentation can be found on their (https://squidfunk.github.io/mkdocs-material/).
index.md
This file renders the home page of the website and is found in the /docs
folder. This is the first page a visitor to the website will see when using the base URL. It is by default called About
in this template. It contains information about the trainig material.
mkdocs.yml
This file is where most of the layout options are made and where the (https://www.mkdocs.org/) theme (https://squidfunk.github.io/mkdocs-material/) is specified. The navigation menu is customised here as well as the header and footer etc.
README.md
This file is displayed by default on the main page of the GitHub repository and liked in the About section. It should contain important information about the repository on how to use the material and explain how to contribute.
LICENCE.md
This file is linked in the About section of the GitHub repository and should contain a full licence statement. By default it is set to the Creative Commons (https://creativecommons.org/licenses/by-sa/4.0/legalcode)
docs folder
The docs folder contains several subfolders
/chapters
contains documents for course content, onechapter_X.md
per topic/assets/images
contains images that are embedded in the course content
Customizing the new repository
About/index page
Start by adding information to the About page (index.md).
Adding/removing menu items
The left side navigation menu is specified in the nav:
section of the mkdocs.yml
file. Add the title to be displayed in the menu for each chapter like this: "title": chapters/filename.md
followed by the file name of the chapter.
To add a new item in the menu:
- Add a new file if needed by:
- navigating to the
docs
folder and then clickingAdd file
on the top right - name the new file
- commit the new file to the
main
branch at the bottom of the page
- navigating to the
- Add a row
"title": chapter/filename.md
to thenav
section of themkdocs.yml
file
Modify the footer
Modify the Licence statement in the footer by editing the following section of the mkdocs.yml
file
# Footer
copyright: Creation of this material was funded by project# and is made availiable under a CC-BY 4.0 licence
Removing the banner
When the training material is no longer under active devlopment, remove the banner at the top by removing the following section of the main.html
file located in the overrides
folder:
{% block announce %}
This lesson is under active development and considered pre-alpha.
{% endblock %}
Adding bioschemas markup
For adding metadata to your training material, it is recommended to use (https://bioschemas.org/) markup. More info on bioschemas TrainingMaterial profile (https://bioschemas.org/profiles/TrainingMaterial).
To add bioschemas to your website html use the extension (https://pypi.org/project/addbioschemas/). Everything should be set up in the template to use this extension.
To add metadata create either a json or yaml file with bioschemas markup. In the template, an example is stored in _data
:
"@context": https://schema.org/
"@type": LearningResource
"@id": https://elixir-europe-training.github.io/ELIXIR-TrP-LessonTemplate-MkDocs/
http://purl.org/dc/terms/conformsTo:
"@type": CreativeWork
"@id": https://bioschemas.org/profiles/TrainingMaterial/1.0-RELEASE
description: Template for ELIXIR lessons
keywords: FAIR, OPEN, Bioinformatics, Teaching
name: ELIXIR Training Lesson template
# lookup at https://spdx.org/licenses/
license: CC-BY-4.0
author:
- "@type": Person
name: Geert van Geest
email: geert.vangeest@sib.swiss
github: GeertvanGeest
orcid: 0000-0002-1561-078X
- "@type": Person
name: Elin Kronander
github: elinkronander
orcid: 0000-0003-0280-6318
After that, add a placeholder in the markdown file you’d like to add the metadata to:
Markdown before placeholder
In combination with mkdocs-material the placeholder should be placed after markdown text, so never at the very top of the page. See this (https://github.com/GeertvanGeest/addbioschemas/issues/5).
Add course content
See next chapter for instructions how to add course content