Reading this document carefully will help you understand how to contribute your own content to the Flow Docs, and avoid problems along the way.
In most cases you should be able to iterate and deploy changes to your documentation with no to little involvement the engineering team that is maintaining the Flow Docs.
Before diving into the contribution process, make sure you're set up for a smooth experience.
To get started, you'll need a GitHub account. If you don't have one yet, no worries! Sign up here. Once you have your account ready, you're all set to proceed.
The contribution process is designed to be straightforward and collaborative. Here's the basic workflow:
-
Create a Pull Request: Head over to the onflow/docs repository and create a Pull Request into the
main
branch. This is where you'll submit your proposed changes. -
Validation and Preview: Wait for the automated check runs to complete. Address any validation errors that pop up. You can also preview the changes using the provided link to ensure everything looks as intended.
-
Merge and Publish: Once your PR is ready and error-free, go ahead and merge it. Your updated documentation will promptly become accessible on https://developers.flow.com!
Note: Previews are built for each Git branch by Vercel workflow.
For additional assistance or integration support, feel free to request help in the #devex-builders
channel on the Flow Discord server.
Updating existing content is a seamless process:
-
Look for the "Edit this page" link at the bottom of each page, just before the footer.
![edit page](./static/images/contributing/edit-light.png#gh-light-mode-only) ![edit page](./static/images/contributing/edit-dark.png#gh-dark-mode-only) -
Clicking the link will take you directly to the source code of the page you're viewing.
Expanding the Flow Docs with new content is straightforward:
-
Markdown Mastery: To display content on the Flow Docs, use Markdown format. Markdown syntax resources are available for learning and reference:
-
From Google Docs to Markdown: While Markdown is perfect for single authors, Google Docs is more suited for collaborative writing. If you're using Google Docs, consider using this browser plugin to generate Markdown files from your Google Docs documents.
Adding a new section/category is as easy as creating a new folder and populating it with Markdown files.
For instance, to add a new toolchain
, the structure might look like this:
./docs/tools/toolchains
├── tools...
| ├── toolchains
| | ├── new-toolchain // new section/category
| | | ├── index.md
| | | ├── _category_.yml
| | | ├── page1.md
| | | ├── page2.mdx
| | | ├── dir1
| | | | ├── nested-page1.md
| | | │ └── ...
| | │ └── ...
_category_
file is used to customize the category/section menu items content related to it.
Possible format:
_category_.json
_category_.yml
_category_.yaml
Example using .yml
:
label: Deploying Contracts
position: 2
customProps:
icon: 🧱
description: How to deploy smart contracts to mainnet and testnet
For more information refer to the Official Docusaurus documentation
The index
page should contain links to the content inside of a category:
- list of available pages and categories
- short descriptions
Examples:
# Clients
## Go SDK
[Flow Go SDK](./flow-go-sdk/index.md) provides a set of packages for Go developers to build applications that interact with the Flow network.
## JavaScript (FCL)
[Flow Client Library (FCL)](./fcl-js/index.md) is a package used to interact with user wallets and the Flow blockchain.
<!-- ... Other sections ... -->
---
sidebar_position: 1
title: Tools
description: Essential tools for the Flow blockchain ecosystem
---
import DocCardList from '@theme/DocCardList';
import { isSamePath } from '@docusaurus/theme-common/internal';
import { useDocsSidebar } from '@docusaurus/plugin-content-docs/client';
import { useLocation } from '@docusaurus/router';
<DocCardList items={useDocsSidebar().items.filter(item => !isSamePath(item.href, useLocation().pathname))}/>
:::warning
The index
page should only include information that is available elsewhere within the category's other pages.
:::
Using DocCardList
improves the layout of the index page:
:::note Example
:::
On the most pages you can use just <DocCardList />
component imported from '@theme/DocCardList'
import DocCardList from '@theme/DocCardList';
# Deployments
This section contains guides to deploying and testing smart contracts.
## All Sections
<DocCardList />
On the top level index category pages you have to use useDocsSidebar
react hook to avoid rendering errors
import DocCardList from '@theme/DocCardList';
import { isSamePath } from '@docusaurus/theme-common/internal';
import { useDocsSidebar } from '@docusaurus/plugin-content-docs/client';
import { useLocation } from '@docusaurus/router';
<DocCardList items={useDocsSidebar().items.filter(item => !isSamePath(item.href, useLocation().pathname))}/>
:::warning
If you use <DocCardList/>
on the top level category index page (e.g. ./docs/tools/index.mdx
), Docusaurus will throw an error:
useCurrentSidebarCategory() should only be used on category index pages.
:::
Basic SEO metadata can be included in markdown frontmatter
. The Flow Docs supports title
and description
metadata. If none is provided, a default will be applied.
Example frontmatter
:
---
title: "Hello World"
description: "A Great Document"
---
It is not required to supply this SEO metadata. Flow's in-house SEO experts will provide custom search-engine appropriate metadata for each page. Your custom metadata will be used in lieu of metadata supplied by our SEO experts.
Include images and media using relative URLs within the docs
folder. If your media is viewable in GitHub, then it should display on the Flow Docs.
For external media or URLs, use fully qualified URLs, eg:
![image](https://github.com/onflow/cadence/images/image.png)
The same rule applies to all other external media.
Linking to documents within the docs
folder of your repo can be done in the standard way that is acceptable to GitHub, eg.
[link](./doc-two.md#hash-link)
Writing links in your documents is easy if you follow this rule-of-thumb: If it works in GitHub it should work on the Flow Docs, with one notable exception.
Links to content outside the docs
folder in your repository, or elsewhere on the web must be in the form of a fully-qualified URL, eg:
[link](https://www.google.com)
:::tip
Use relative links directly to .md/.mdx files
:::
Many pages have callouts/admonitions. It is a slightly customized version of standard admonitions
Available types:
note
(alsosecondary
)tip
(alsosuccess
)info
(alsoimportant
)caution
warning
danger
Example:
:::tip
Use relative links directly to .md/.mdx files
:::
To include code from a file using a direct URL use !from
operand inside a code block.
Example:
```cadence DepositFees.cdc
!from https://github.com/onflow/flow-core-contracts/blob/master/transactions/FlowServiceAccount/deposit_fees.cdc#L23
```
```cadence DepositFees.cdc
!from https://github.com/onflow/flow-core-contracts/blob/master/transactions/FlowServiceAccount/deposit_fees.cdc#L23-L26
```
Specific blocks of code that are embedded in documentation are defined using [START <snippet_name>]
and [END <snippet_name>]
region tags.
def create_bucket project_id:, bucket_name:
# [START create_bucket]
# project_id = "Your Google Cloud project ID"
# bucket_name = "Your Google Cloud Storage bucket name"
require "google/cloud/storage"
storage = Google::Cloud::Storage.new project: project_id
bucket = storage.create_bucket bucket_name
puts "Created bucket #{bucket.name}"
# [END create_bucket]
end
and the reference would look like
```ruby
!from https://github.com/emosei/ruby-docs-samples/blob/master/storage/buckets.rb#create_bucket
```
This method keeps your documentation synchronized with your codebase by pulling the latest code directly into your docs.
Content is validated each time a PR is submitted to the docs
repository.
Validation status is available in the check run output for your PR on GitHub.
Currently, the Flow Docs validates content using the following conditions:
- Do pages render without errors? This check accounts for errors in your markdown syntax.
- Are all links URLs valid? Broken links make for bad user experience.
Here is an example of check run output with successful validation.
The Flow Docs automatically scans relative links in all your documents when you submit changes to your docs. This is done to ensure that cross-links are valid, within your set of documentation.
A special preview link is provided for content PRs as part of the GitHub PR check run.
Previews are generated against the PR branch of the Flow Docs, to ensure your content can be integrated with the latest updates to the Flow Docs itself.
Here is an example of preview output for changed documents in a PR
When you merge updates to documents in your PR, previews will deployed with a few minutes delay.