Files
iNaturalistReactNative/CONTRIBUTING.md
Dan Rademacher bb2aacb0c5 Revise contributing guidelines, LEAD-26
Shift emphasis to transparency, reduce open invitation for contributions
2026-05-13 21:30:48 -07:00

6.4 KiB

Contribution Guidelines for iNaturalistReactNative

About this codebase

iNaturalist's code is open source primarily for transparency — we want our community to be able to see how the platform works. Unlike many open source projects, we don't maintain this codebase as a general-purpose tool for forking or customization. We build it with one deployment in mind: iNaturalist.org and the iNaturalist mobile apps.

We will probably close pull requests that don't address open issues. Again, if you want to change functionality, the discussion should start in the Forum, and if staff agree something should change, we'll make an issue, label it, and then you can work on it.

We're a small team. Our capacity to review and integrate external contributions is limited, and we can't commit to responding to every inquiry or pull request.

Bugs and feature requests

Please don't open GitHub issues for user-facing bug reports or feature requests.

We track our work internally and triage inbound requests through the iNaturalist Forum. Filing a GitHub issue is unlikely to result in action, and you're much more likely to get a response — and to hear from other community members with similar experiences — on the Forum.

If you've found a problem in the code, please supply detailed reproduction conditions, cite line numbers, include exceptions / stack traces, etc. If you can't supply this kind of information, we will probably close your issue and suggest you post to the forum links above.

Reporting Security Issues

You should report security issues that require confidential communication to help+security@inaturalist.org. We do not offer any rewards or bounties for reporting security issues, though we may offer to list your name and URL here if we act on your report.


Translations

Translations are handled separately through Crowdin, not through pull requests. If you'd like to help translate iNaturalist into another language, that's the place to start — and it's one of the most impactful ways to contribute to the project.


Code of conduct

All contributors are expected to follow the iNaturalist Community Guidelines, or at least the parts that aren't specific to using iNaturalist as a naturalist.


Questions about the code

If you have a technical question about how something works — you're building an integration, you're curious about an architectural decision, or you've encountered something confusing — you can open a GitHub Discussion. We can't promise a quick response, but discussions are more likely to get attention than issues, and they benefit others who have the same question.

Code contributions

Please keep the following in mind:

  1. Work on existing, unassigned issues (feature requests should go through the Forum)
  2. Leave a comment on the issue you want to work on so we can assign you and other people know not to work on it
  3. Name your branch starting with the issue number and then something descriptive, e.g. 123-login-with-locale-crash
  4. We try to review pull requests as soon as we can, but that might be up to a week or two

Getting Started

  1. Fork the repository
  2. Clone the forked repository to your local machine
  3. Follow the README to set up your dev environment
  4. Create a new branch for the issue you're working on; the branch name should start with the issue number and be concise but descriptive, e.g. 123-login-with-locale-crash
  5. Start coding!

Code Style

  • We use ESLint to enforce our code style; you should have this integrated into your editor / IDE
  • We also have enabled a pre-commit hook to run eslint --fix --quiet on all staged files. This will fix issues that can be fixed automatically and should prevent commits that violate the rules
  • We only have partial TypeScript adoption. It would be nice if new files were in TypeScript and those files were type safe, but it's not a requirement

Commit Style

Please follow this guidance when committing to the main branch, including merge commits from PRs. Atomic commits in branches that don't make it into main can be more freeform.

  1. Try to use the imperative mood, so your message should fill in the blank in, "If applied, this commit will _____"

  2. Describe the impact on the end user if possible, so "Fix broken photo sharing in iOS 18" would be better than "Switch to a fork of photo-sharing-library-x"

  3. Append developer-relevant details on subsequent lines, e.g.

    Fix broken photo sharing in iOS 18
    
    * Switch to fork of photo-sharing-library-x
    * Minor UI touch-ups
    
  4. Include Closes #1234 on a subsequent line if your commit closes issue 1234; that will automatically close the issue on GitHub and helps link commits to the issues they address. Example

    Fix broken photo sharing in iOS 18
    
    Closes #1234
    
  5. Semantic commit labels are fine (e.g. fix: broken photo sharing in iOS 18), but we don't (yet) require them

Submitting Changes

  1. Ensure tests are passing (run npm test). If tests are not passing we will not merge your PR
  2. Ensure your branch is up-to-date with the main branch of the primary repository
  3. Ensure your branch has no merge conflicts with the main branch. We will not merge PRs with conflicts
  4. Create a pull request to the primary repository with your changes

Pull Request Guidelines

  • Give your pull request a clear and descriptive title (e.g. "Remove predictions state on blur and focus in ARCamera") and a comment that includes a reference to the issue number (e.g. "Closes #123" or "Partially addresses #123" in case of an open issue) and maybe a detailed description of the changes you've made
  • Don't include new features or functionality differing from the description in the issue.