Guides

Documentation

📘

This page is about contributing Documentation

For current Documentation see Getting Started

Overview

Our documentation is held in markdown files in the Monty repo under the /docs folder. This documentation is synchronized to readme.com for viewing whenever a change is made. The order of sections, documents, and subdocuments is maintained by a hierarchy file called /docs/hierarchy.md. This is a fairly straightforward markdown document that is used to tell readme how to order the categories, documents and sub-documents.

📘

Edits to the documentation need to be submitted in the form of PRs to the Monty repository.

Linting

We use Vale to lint our documentation. The linting process checks for spelling errors and ensures that headings follow the APA title case style.

The linting rules are defined in the /.vale/ directory.

How to Install and Use Vale

  1. Install Vale
    Download Vale from its installation page.

  2. Run Vale
    Use the following command in your terminal to run Vale:

    vale .
    

    Example output:

    ➜  tbp.monty git:(main) vale .
    ✔ 0 errors, 0 warnings and 0 suggestions in 141 files.
    

Relative Links

Links to other documents should use the standard markdown link syntax, and should be relative to the documents location.

relative link in the same directory
[Link Text](placeholder-example-doc.md)

a relative link, with a deep-link to a heading
[Link Text](../contributing/placeholder-example-doc.md#relative-links)

These links will work even if you're on a designated version of the documentation.

Modifying a Document or Sub-Document

This is the simplest flow. To modify a document simply edit the markdown file in your forked version of the Monty repository and commit the changes by following the normal Pull Requests process.

Creating a Document

To create a new document, create the new file in the category directory, then add a corresponding line in the /docs/hierarchy.md file.

# my-category: My Category
- [my-new-doc](/my-category/new-placeholder-example-doc.md)
- [some-existing-doc](/my-category/placeholder-example-doc.md)

Then, create your markdown document /docs/my-category/new-placeholder-example-doc.md and add the appropriate Frontmatter.

---
title: 'New Placeholder Example Doc'
---
# My first heading

🚧

Quotes

Please put the title in single quotes and, if applicable, escape any single quotes using two single quotes in a row.
Example: title: 'My New Doc''s'

🚧

Your title must match the url-safe slug

If your title is My New Doc's then your file name should be my-new-docs.md

Continue with the Pull Requests process.

Creating Sub-Documents

Documents that are nested under other documents require that you create a folder with the same name as the parent document but without the .md extension. Then, you place any sub-documents in that folder. For example, if you were creating a document called new-placeholder-example-doc.md beneath the document Category One/some-existing-doc.md file you would create a folder called category-one/some-existing-doc and place the new document in that folder.

And then update the hierarchy.md file

# category-one: Category One
- [some-existing-doc](category-one/some-existing-doc.md)
  - [new-doc](category-one/some-existing-doc/new-placeholder-example-doc.md)

# category-two: Category Two
...

Continue with the Pull Requests process.

Reordering a Document

If the move is within a category or sub-pages within a page, you can simply edit the hierarchy.md file and update the locations by moving the lines around.

If you are changing the parent path of a document (i.e., sub-page -> page, or page -> sub-page, or page/sub-page -> new category, or sub-page -> new page, then along with updating the hierarchy.md file you also must update the folder structure to make sure the document is correctly located. The sync tool will fail with a pre-check error saying there is a mismatch between the hierarchy file and the location on disk if they do not match up.

Continue with the Pull Requests process.

🚧

You cannot reorder categories as the readme.com API does not support this.

Changes to the category order should be done in the readme.com UI and reflected in the hierarchy.md file.

Deleting or Renaming a Document

If a document is well established (it has been around for more than 6 months), people may be using permalinks to it. Therefore, it is a good idea to create a redirect file rather than deleting or renaming it. To do this, set the document to hidden with a relocation link to a relevant area or new document location. Hidden files are reachable from the URL, just not shown in the navigation.

---
title: 'Badly Named Doc'
hidden: true
---
>  ⚠️ this document has moved to <insert link>

Continue with the usual Pull Requests process.

Creating a New Top-Level Category

To create a new category, simply create a new folder inside the /docs folder and add a reference to it in the hierarchy.md file. Categories in the hierarchy file need a slug and title separated by a colon.

# category-one: Category One

# category-two: Category Two

Checking Links

In our documentation sync tool there is a flag to check internal links, image references and hierarchy file references. This is a good way to ensure that all links are working correctly before submitting a PR.

To check the links, activate the conda environment, and then run the following command:

python -m tools.github_readme_sync.cli check docs

Images

See the Style Guide images section for details about creating and referencing images correctly.

VS Code Snippets

👍

You have access to VS Code snippets

When you checkout the repository, you have access to markdown snippets for tables, code blocks, warnings and more. While your cursor is in a markdown file, press CMD + Shift + P and select Insert snippet to select a desired documentation snippet.

Style Guide

The documentation Style Guide

Versioning

The Monty documentation uses the first two parts of semantic versioning (semver), as there is nothing to document for patch changes. You can read about semver here https://semver.org/.