Skip to content

Latest commit

 

History

History
161 lines (104 loc) · 4.49 KB

CONTRIBUTING.md

File metadata and controls

161 lines (104 loc) · 4.49 KB

Contributing

Contributors must follow these guidelines.

Development

Requirements

You must install these first.

Installation

To install everything:

yarn

Local Development

yarn start

This command starts a local development server and opens up a browser window. Most changes are reflected live without having to restart the server.

Build

yarn build

This command generates static content into the build directory and can be served using any static contents hosting service.

Checklist

Please follow the checklist below either before opening or during your pull request:

  • Read and follow the "Formatting Guidelines" below.
  • Ensure that the automated Github Workflows pass.
  • You've run yarn start to:
    • Verify no errors or warnings in the console/yarn output (e.g. broken links).
    • Check that the rendered version of your additions looks appropriate.

Formatting Guidelines

Editor

I personally use Visual Studio Code to edit my markdown files. I encourage you use this editor as well. There's a list of recommended extensions in the workspace VS Code settings that you should install to make editing files here an easier experience.

If you do not want to use VS Code, that's fine too, but be prepared to potentially do style/formatting changes by hand. It's also possible that we spend more time on formatting/style issues in pull requests too.

Markdown Lint

Markdown lint rules must be followed. See .markdownlint.json. I personally use the markdownlint extension for VS Code.

Each pull request opened will run a workflow to verify markdownlint rules are not violated.

Table Formatting

Markdown tables must be formatted and aligned.

The VS Code extension named Markdown All In One can be used to automatically resize and reformat markdown tables. Workspace settings already have this extension set up as the default formatter for markdown files. Simply do a "Reformat Document" operation to have your tables fixed up.

Line Length & Wrapping

Max line length is 100. Hard wraps must be used instead of soft wraps.

The Rewrap extension in VS Code can assist with wrapping. Simply put your caret in a paragraph that needs to be hard-wrapped and press ALT+Q.

Version Requirements

When documenting features, especially when that feature has not been released yet, it's important to call out specific version requirements. There's almost always a minimum version requirement.

Using the :::note admonition, follow the example below to point out the minimum version required. Typically this should be done at the top of a section under a heading or page that describes the feature.

Example:

:::note Version Requirement

This functionality requires `v3.0.0` or greater!

:::

Admonitions

Admonitions are the colored sections of text in the guide (Info, Caution, etc). Docusaurus documents its admonitions here. For consistency, please use the general guidelines below to know which admonition types to use in what situation.

  • 🔵 INFO (:::info)
    Optional steps, informational text. Directly related to the subject matter.

  • 🟢 TIP (:::tip)
    Advice or tips that help the user. Topics might not be directly related to surrounding subject matter.

  • 🟡 CAUTION (:::caution)
    Warning messages about an action or piece of information. Things the user should heed, but it won't be the end of the world if they don't.

  • 🔴 DANGER (:::danger)
    Most critical admonition. Represents things the user should not do.

Additionally, admonitions should have spaces before and after the text inside of it. For example:

:::tip

This is a tip

:::

Don't squeeze it all together like this:

:::tip
This is a tip
:::

Reason: Some formatting tools will wrap the latter example all onto one line, like below. Having the spaces prevents this.

:::tip This is a tip:::

Development Notes

To upgrade Docusaurus to latest:

yarn upgrade @docusaurus/core@latest @docusaurus/preset-classic@latest