Docs Contribution Guidelines
Thank you for your interest in contributing to the documentation! You will be helping the open source community and other developers interested in learning more about argsh and using it.
This guide is specific to contributing to the documentation. If you’re interested in contributing to argsh’s codebase, check out the contributing guidelines in the Medusa GitHub repository.
Documentation Workspace
Argsh's documentation projects are all part of the documentation yarn workspace, which you can find in the argsh repository under the www
directory.
The workspace has the following two directories:
apps
: this directory holds the different documentation websites and projects.docs
: includes the codebase for the main documentation website (the one you're viewing this documentation on). It's built with Docusaurus.
packages
: this directory holds the shared packages and components necessary for the development of the projects in theapps
directory.docs-ui
includes the shared React components between the different apps.eslint-config-docs
includes the shared ESLint configuration between the different apps and packages.tailwind
includes the shared Tailwind CSS configuration between the different apps and packages.tsconfig
includes the shared TypeScript configuration between the different apps and packages.
Documentation Content
Main Documentation Website
The documentation content is written in Markdown format and is located in the www/apps/docs/content directory of the argsh repository. If you’re not familiar with Markdown, check out this cheat sheet for a quick start.
You’ll also find MDX files. MDX files combine the power of Markdown with React. So, the content of the file can contain JSX components and import statements, among other features. You can learn more about MDX in docusaurus’s guide..
Style Guide
When you contribute to the documentation content, make sure to follow the documentation style guide.
How to Contribute
If you’re fixing errors in an existing documentation page, you can scroll down to the end of the page and click on the “Edit this page” link. You’ll be redirected to the GitHub edit form of that page and you can make edits directly and submit a pull request (PR).
If you’re adding a new page or contributing to the codebase, you need to fork the repository, create a new branch, and make all changes necessary in your repository. Then, once you’re done, create a PR in the argsh repository.
Base Branch
When you make an edit to an existing documentation page or fork the repository to make changes to the documentation, you have to create a new branch.
Documentation contributions always use main
as the base branch. Make sure to also open your PR against the main
branch.
Pull Request Conventions
When you create a pull request, prefix the title with docs:
.
In the body of the PR, explain clearly what the PR does. If the PR solves an issue, use closing keywords with the issue number. For example, “Closes #1333”.
Main Documentation Sidebar
When you add a new page to the documentation, you must add the new page in www/apps/docs/sidebars.js
. In this file, an object is exported. This object holds more than one sidebar. The properties of the object indicate the internal sidebar name, and the value is an array of sidebar items in that sidebar.
You can learn more about the syntax used here.
Terminology
When the documentation page is a conceptual or an overview documentation, the label in the sidebar should start with a noun.
When the documentation page is tutorial documentation, the label in the sidebar should start with a verb. Exceptions to this rule are integration documentation and upgrade guides.
Sidebar Icon
To add an icon to the sidebar item, start by checking if the icon is already exported in the file www/apps/docs/src/theme/Icon
. If not, you can either export the icon from the @medusajs/icons, or add the new icon as a React component in the www/apps/docs/src/theme/Icon/Icon<Name>/index.tsx
file, where <Name>
is the camel-case name of your icon. The icon must be added to the React component as an SVG element.
For example:
import React from "react"
import { IconProps } from "@medusajs/icons/dist/types"
export default function IconBolt(props: IconProps) {
return (
<svg
width={props.width || 20}
height={props.height || 20}
viewBox="0 0 20 20"
fill="none" xmlns="http://www.w3.org/2000/svg"
{...props}
>
<path
d="M3.125..."
strokeWidth="1.5"
strokeLinecap="round"
strokeLinejoin="round"
stroke="currentColor" />
</svg>
)
}
Make sure to set the stroke
or fill
of the icon to currentColor
as shown in the example above. The source code for the Sidebar passes the icon a color. So, this ensures the color is correctly used.
If you added a new icon, add it in the exported object in the file www/apps/docs/src/theme/Icon/index.ts
, where the property is the kebab-case version of the icon's name, and the value being the component you created. Make sure to add it in the correct alphabetical position as well. For example:
Finally, you can add the icon to the sidebar item by adding a sidebar_icon
property to the customProps
property and setting its value to the kebab-cased version of the icon's name. For example:
Sidebar Item Types
There are different sidebar item types used in the documentation:
-
Homepage Items: If a sidebar item is shown under the
homepage
sidebar, you should set theclassName
property of the item tohomepage-sidebar-item
. You can use this with other sidebar item types. For example: -
Sidebar Title: This item is used as a title to the sidebar, typically added at the top of the sidebar. You typically would also use an icon with it. To use this item, add a
sidebar_is_title
property to thecustomProps
object of the item with its value beingtrue
. For example: -
Back Item: This item is used to show a back button, typically at the top of the sidebar. To use this item, add the
sidebar_is_back_link
property to thecustomProps
object of the item, with its value set to true. Also, add thesidebar_icon
property to thecustomProps
object with its value set toback-arrow
. For example: -
Group Divider Item: This item is used if a sidebar item does not link to any document and is only used to separate between sidebar sections. The item must be of type
html
, and itsvalue
property holds the text that should be shown in the divider. You must also add in thecustomProps
object of the item the propertysidebar_is_group_divider
with its value beingtrue
. For example: -
Group Headline Item: This item is used if a sidebar item does not link to any document and is only used to indicate the beginning of a new section or group in the sidebar. To use this item, set the
type
of the item tocategory
, and add thesidebar_is_group_headline
property to thecustomProps
object of the item, with its value set totrue
. For example: -
Soon Item: This item is used to indicate that a certain guide will be added soon, but it does not actually link to any document. To use this item, set the
type
of the item tolink
, itshref
property to#
, and add to thecustomProps
object the propertysidebar_is_soon
with its value set totrue
. For example:
Notes and Additional Information
When displaying notes and additional information on a documentation page, use Admonitions. Make sure the type of admonition used matches the note’s importance to the current document.
If the note is something developers have to be careful of doing or not doing, use the danger
admonition based on how critical it is.
If the note displays helpful information and tips that may not be in the scope of the documentation page, use the tip
admonition.
For all other note types, use the note
admonition.
Images
If you are adding images to a documentation page, you can host the image on Imgur for free to include it in the PR. Our team will later upload it to our image hosting.
Code Blocks
These sections only works in the main documentation website.
Use Tabs with Code Blocks
To use Tabs with Code Blocks, you have to use Docusaurus's Tabs
and TabItem
components.
You must also pass to the Tabs
component the prop isCodeTabs={true}
to ensure correct styling.
For example:
import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';
<Tabs groupId="request-type" isCodeTabs={true}>
<TabItem value="globally" label="Install global" default>
```bash
curl -sL https://get.arg.sh | sudo tee /usr/local/bin/argsh > /dev/null
sudo chmod +x /usr/local/bin/argsh
```
</TabItem>
<TabItem value="locally" label="Withing a project">
```bash
curl -sL https://get.arg.sh > .bin/argsh
chmod +x .bin/argsh
```
</TabItem>
</Tabs>
Add Title to Code Block with Tabs
If you want to add a title to a code block with tabs, add the codeTitle
prop to the Tabs
component.
For example:
Add Title to Code Block without Tabs
To add a title to a code block without tabs:
Remove Report Button
Some code block don't need a report button. To remove the report button, use the noReport
metadata.
For example:
Remove Copy Button
Some code blocks don't need a copy button. To remove the copy button, use the noCopy
metadata:
For example:
Linting with Vale
Argsh uses Vale to lint documentation pages and perform checks on incoming PRs into the repository.
Result of Vale PR Checks
You can check the result of running the "lint" action on your PR by clicking the Details link next to it. You can find there all errors that you need to fix.
Run Vale Locally
If you want to check your work locally, you can do that by:
- Installing direnv and running
direnv allow
in the root directory of the argsh repository. - Linting with
vale
:
VS Code Extension
To facilitate writing documentation, you can optionally use the Vale VS Code extension. This will show you any errors in your documentation while writing it.
Linter Exceptions
If it's needed to break some style guide rules in a document, you can wrap the parts that the linter shouldn't scan with the following comments in the md
or mdx
files:
You can also disable specific rules. For example:
If you use this in your PR, you must justify its usage.
Linting with ESLint
Argsh uses ESlint to lint code blocks both in the content and the code base of the documentation apps.
Linting Code/Content with ESLint
Each PR runs through a check that lints the code in the content files using ESLint. The action's name is code-docs-eslint
.
If you want to check code ESLint errors locally and fix them, you can do that by:
1. Set up direnv then run in the root
directory:
2. Then execute the following command anywhere:
This will fix any fixable errors, and show errors that require your action.
ESLint Exceptions
These exceptions only work in the main documentation website.
If some code blocks have errors that can't or shouldn't be fixed, you can add the following command before the code block:
You can also disable specific rules. For example:
Need Additional Help
If you need any additional help while contributing, you can join argsh's Discord server and ask argsh’s core team as well as the community any questions.