We love your input! We want to make contributing to this project as easy and transparent as possible, whether it's:
- Reporting a bug
- Discussing the current state of the code
- Submitting a fix
- Proposing new features
- Becoming a maintainer
We use github to host code, to track issues and feature requests, as well as accept pull requests.
We Use Github Flow, So All Code Changes Happen Through Pull Requests
Pull requests are the best way to propose changes to the codebase (we use Github Flow). We actively welcome your pull requests:
- Fork the repo and create your branch from
main
ortesting
. - Setup commit hooks for automatic calculation of cache busting hashes for resources.
- Please add comments when reasonable, and when possible, use JSDoc for documenting types. Lack of this will not prevent your pull being merged, but it would be nice to have.
- If you've added code that should be tested please pull into
testing
. For documentation and smaller fixes, a pull request directly tomain
should be okay, unless it pertains to changes only present intesting
. - Create a pull request with a short description of what you did. Thanks for your contribution!
In short, when you submit code changes, your submissions are understood to be under the same MIT License that covers the project. Feel free to contact the maintainers if that's a concern.
Report bugs using Github's issues
We use GitHub issues to track public bugs. Report a bug by opening a new issue; it's that easy!
If possible, bug reports should have the most detail it is reasonable to have for the bug in question. If you are more versed in javascript, pointing out the issue in code, or even creating a pull request is also appreciated!
Great Bug Reports tend to have:
- A quick summary and/or background
- Steps to reproduce
- Be specific!
- Give sample code or screenshots if you can!
- What you expected would happen
- What actually happens
- Notes (possibly including why you think this might be happening, or stuff you tried that didn't work)
We have some issue templates that are, admittedly, basically github's default templates. You can and should use that as a guide. Sometimes some fields may not be applicable to your particular report. In this case, things such as alternative solutions don't need to be included.
People love thorough bug reports. I'm not even kidding.
For styling, we are currently using prettier for linting. And that's basically it. We are currently using tabs and some other defaults defined in the .prettierrc.json file. We don't use npm on our project, so you would have to install prettier and prettier-eslint locally. We have a handy lint.sh script you can run, but it is recommended to use an IDE with prettier support for more practical use.
Any suggestions regarding change of styles or style guides (Airbnb, Google, or whatnot) are welcome, as the current file is quite simplistic.
By contributing, you agree that your contributions will be licensed under its MIT License.
This document was adapted from the open-source contribution guidelines for Facebook's Draft and based on this template from briandk.