Skip to content

Latest commit

 

History

History
146 lines (89 loc) · 10.4 KB

CONTRIBUTING.md

File metadata and controls

146 lines (89 loc) · 10.4 KB

Contributing to ReaKit

We would love for you to contribute to ReaKit and help make it even better. By contributing to ReaKit, you agree to abide by the code of conduct

Ownership

If your Pull Request is merged, regardless of content, you're eligible for push access to the organization on GitHub. This is checked for on pull request merges and an invite is sent automatically, thanks to Aeryn.

Offhand, it is easy to imagine that this would make code quality suffer, but in reality it offers fresh perspectives to the codebase and encourages ownership from people who are depending on the project. If you are building a project that relies on this codebase, then you probably have the skills to improve it and offer valuable feedback.

Everyone comes in with their own perspective on what a project could/should look like, and encouraging discussion can help expose good ideas sooner.

Why do we give out push access?

It can be overwhelming to be offered the chance to wipe the source code for a project. Do not worry, we do not let you push to master. All code is peer-reviewed and needs an approval of a code owner. Also, we have the convention that someone from the core team should merge non-trivial pull requests.

As an organization contributor, you can merge other people's pull requests, or other contributors can merge yours. You likely won't be assigned a pull request, but you're welcome to jump in and take a code review on topics that interest you.

This project is not continuously deployed, there is space for debate after review too. This means there's always a chance to revert, or to make an amending pull request. If it feels right, merge.

How can we help you get comfortable contributing?

It's normal for a first pull request to be a potential fix for a problem, and moving on from there to helping the project's direction can be difficult. We try to help contributors cross that barrier by offering good first step issues. These issues can be fixed without feeling like you're stepping on toes. Ideally, these are non-critical issues that are well defined. They will be purposely avoided by mature contributors to the project, to make space for others.

We aim to keep all technical discussions inside GitHub issues, and all other discussions in our Spectrum community. This is to make sure valuable discussions are public and discoverable via search engines. If you have questions about a specific PR, want to discuss a new API idea etc GitHub issues are the right place. If you have questions about how to use the library, or how the project is running - the Spectrum community is the place to go.

Our expectations on you as a contributor

To quote @alloy from this issue:

Don't ever feel bad for not contributing to open source.

We want contributors to provide ideas, keep the ship shipping and to take some of the load from others. It is non-obligatory; we’re here to get things done in an enjoyable way. 🏆

The fact that you'll have push access will allow you to:

  • Avoid having to fork the project if you want to submit other pull requests as you'll be able to create branches directly on the project.
  • Help triage issues, merge pull requests.
  • Pick up the project if other maintainers move their focus elsewhere.

It's up to you to use those superpowers or not though 😉

If someone submits a pull request that's not perfect, and you are reviewing, it's better to think about the PR's motivation rather than the specific implementation. Having braces on the wrong line should not be a blocker. Though we do want to keep test coverage high, we will work with you to figure that out together.

What about if you have problems that cannot be discussed in a public issue?

You can send an email to [email protected].

How to start contributing?

Helping people on issues and writing docs are definitely the best ways to get started on any open source project.

Not all of us are native English speakers, so it's natural to find some grammar and writing errors. If you find any, don't hesitate to submit a PR with a correction. It'll be very much appreciated.

Navigating through our website, if you find anything that could be explained in a better way, just click on the IMPROVE THIS PAGE buttons to go straight to the markdown file and edit it directly on the GitHub interface.

Contributing with code

If you're a beginner, it'll be a pleasure to help you contribute. You can start by reading the beginner's guide to contributing to a GitHub project.

This repository is a monorepo managed by Lerna and makes use of yarn workspaces.

If you haven't already done so, install yarn and run yarn to install the project's dependencies.

Scripts

  • yarn lint --fix will lint the code and fix formatting errors while you develop.
  • yarn test will run tests for all packages.
  • yarn test --watch will run tests only on the files you affected with your updates and will keep running watching your changes.
  • yarn test --coverage will give you an overview of the parts of the code which are being covered by tests.
  • yarn dev will run a development server for components. Use it while working in the reakit package.
  • yarn website will run a development server for our website. Use it while working in the website package.

Creating components

The best way to understand how to create new components is looking at the other ones located in packages/reakit/src.

A simple component folder is composed by three files:

  • Component.js with the source code.
  • Component.md with the docs.
  • index.js exporting the component as default.

Also, an entry should be added to packages/reakit/src/index.ts.

Some other components have sub components and containers. You should understand the requirements of the component you're creating so you can find a similar one to use as a base.

Don't forget to use yarn dev while working on the component and, in the end, yarn website to ensure that it's displaying correctly on the website.

Working on website

The website package is built with react-styleguidist. You can find its configuration file on packages/website/styleguide.config.js.

We have replaced all the default components from react-styleguidist by just overriding its main component with our own, which you can find on packages/website/src/index.js.

Working on docs

You can find guide docs in the docs folder. While component docs are placed together with its component in the reakit package: packages/reakit/src.

While working on docs, make sure to run yarn website to see the changes. If the browser doesn't refresh automatically, you should do that manually.

Credits

Contributors

This project exists thanks to all the people who contribute.

Backers

Thank you to all our backers! 🙏

Sponsors

Support this project by becoming a sponsor. Your logo will show up here with a link to your website.