Skip to content

Latest commit

 

History

History
69 lines (38 loc) · 6.17 KB

CONTRIBUTING.md

File metadata and controls

69 lines (38 loc) · 6.17 KB

Docs Contributing Guidelines

Welcome to the Mina Docs open source repository. Thank you for your interest in contributing to the Mina Docs website.

We realize that technical documentation is a high-visibility interface with you: our community and our users. We work hard to deliver well-written docs to help you discover, understand, and use the Mina Protocol and SnarkyJS.

We treat documentation like code. The Mina Docs use a docs-as-code workflow to develop and publish product documentation using the same tools and processes as software code development. All user-impacting updates on the codebase require corresponding updates to the relevant documentation in the docs repo. Developers who know the feature best write the first draft of content for all changes and new features. Feature documentation is part of our development “definition of done.”

By contributing, you can help us improve the functionality and user experience of the docs which in turn helps you build better projects. To ensure a smooth and effective collaboration, please follow these contribution guidelines.

Style Guidance

Follow the style guidance in the Docs Style Guide and recommended Word List to ensure a consistent user experience. Look around. Match the style you see used in the rest of the project.

Get Involved

To learn about ways to participate and interact with community members, see Online Communities.

Code of Conduct

All contributors agree to respect and follow the Mina Protocol Code of Conduct.

Docs Toolset

The Mina Docs website is published with the Docusaurus static site generator. The docs source files are written in Markdown .mdx files that support Markdown with embedded components through the JSX syntax extension to JavaScript. Docusaurus has built-in support for MDX that renders the JSX in Markdown files as React components.

Even if you're unfamiliar with Markdown, you can still contribute to the docs in a helpful and meaningful way. Use Markdown Basic Syntax and look at existing docs for models to follow. You can start contributing by submitting fixes for typos, spelling, and broken links.

To build the docs locally during development, see the README file.

Using this repo

If you don't find what you are looking for or something in the docs is not working as expected, review existing docs2 issues on GitHub. Before you report a problem, take a look around and see if someone already opened an issue. If you are certain this is a new, unreported bug, submit a new issue to help us improve.

  • One issue, one bug: Report a single bug per issue.
  • If you're ready to fix a bug, it's fine to submit a pull request right away, but we still recommend filing an issue detailing what you're fixing. This workflow is helpful in case we don't accept that specific fix but want to keep track of the issue.
  • Provide steps to reproduce the bug, be sure to list all the steps necessary to reproduce the issue.

Reviewing Technical Content PRs

Some of the best content contributions come during the PR review cycles. To ensure quality, follow best practices for technical content PR reviews just like you do for code reviews. When reviewing a pull request, the end-goal is to suggest useful changes to the author.

  • For in-line suggestions, use the GitHub suggesting feature.
  • You can comment on one line or several lines. You can provide changes or edits, and the person who authored the PR can easily apply your change, or create their own competing suggestion, and you can discuss it. To invite others to the conversation, tag their GitHub @username in a comment to notify them. In this way, you can discuss any change. It’s transparent and inclusive.
  • The PR owner can merge in your suggested commits one at a time or in batch (preferred).
  • When you are providing a more granular extensive review that results a large number (more than 20) of in-line suggestions, work with the PR owner to develop a workflow. You might decide together that as a reviewer, you can check out the branch and make the changes yourself.

Pull Requests (PRs)

You are welcome to provide a fix or update directly. We appreciate your contributions!

  • For a simple fix to single page, you can select EDIT THIS PAGE at the top of the page to make changes to the file in a web browser. In the Propose changes section, you can follow the GitHub workflow to submit a pull request.

  • If you're not a member or maintainer, fork the repo and then submit a pull request (PR) from your forked repo to the main branch.

Provide a helpful, informative PR title that includes the context and page you are updating. Each PR must address only one issue or feature.

Start by creating a draft pull request. Create your draft PR early, even if your work is just beginning or incomplete. Your draft PR indicates to the community that you're working on something and provides a space for conversations early in the development process. Merging is blocked for Draft PRs, so they provide a safe place to experiment and invite comments.

All pull requests must go through the code review process. As the PR submitter, you are responsible for addressing each comment and suggestion in the Files changed view during the review process.

  • If you are a member of the docs repo, you can merge the approved PR.
  • If your PR is a fork, the code maintainers will merge the approved PR.

SnarkyJS Reference

The zkApp Developers > SnarkyJS Reference docs are generated content and are outside the scope of the Mina Docs repository.

Thank you for contributing to the Mina docs. It's better together.