Welcome! Thanks for checking out Expensify.cash and for taking the time to contribute!
This guide is specifically for external contributors. For a general overview of the repo, check out our README located here. The part of the README to pay particular attention to is how to run the app locally using our production API.
You can create as many accounts as needed in order to test your changes directly from expensify.cash. An initial account can be created when logging in for the first time and additional accounts can be invited by entering a valid email or phone in the "Find or start a chat" input then tapping the avatar.
This project and everyone participating in it is governed by the Expensify Code of Conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to contributors@expensify.com.
The best way to ask questions is to join our #expensify-contributors Slack channel. To request an invite to the channel, just email contributors@expensify.com with the subject "Slack Channel Invite" and we'll send you an invite! Please do not create issues to ask questions.
If you've found a vulnerability, please email security@expensify.com with the subject Vulnerability Report
instead of creating an issue.
If you'd like to create a new issue, please first make sure the issue does not exist in the issue list. When creating a new issue, please include all the required information on the issue template.
We are currently managing payment via Upwork. If you'd like to be paid for your contributions, please apply to fix the issue from our Upwork issue list. Each issue in this repo will also link out to the associated Upwork job.
- Before writing any code, please post a proposal of the solution you plan to implement as a comment in the GH issue. This should include a brief technical explanation of the changes you will make.
- Wait for Expensify to review and provide feedback on the proposal within the GH issue, and assign the GH issue to you. Please do not move forward with creating a Pull Request until your proposal is approved
- Fork this repository and create a new branch
‼️ Before you start writing any code ️‼️ , please be aware that we require all commits to be signed. The easiest way to do that is to generate a new GPG key and add it to your Github account. Once you've done that, you can automatically sign all your commits by adding the following to your.gitconfig
:[commit] gpgsign = true [user] email = <Your GH account email> name = <Your Name> signingkey = <your_signing_key> [gpg] program = gpg
- Open a PR. Be sure to fill in all the required information on the PR template.
- An Expensify engineer will be automatically assigned to review your PR
- You will need all checks to pass:
- CLA - You must sign our Contributor License Agreement by following the CLA bot instructions that will be posted on your PR
- Tests - All tests must pass before a merge of a pull request
- Lint - All code must pass lint checks before a merge of a pull request
Upon submission of a PR, please include a numbered list of explicit testing steps for each platform (Web, Desktop, iOS, and Android) to confirm the fix works as expected and there are no regressions.
- If you have made a change and are ready for another review the best way to get your reviewer's attention is to leave a comment that says "Updated" on the PR itself.
- Please do NOT ping individual reviewers in the Slack channel to get their attention and keep the conversation in GitHub whenever possible.
- Patience is a virtue. Reviews can sometimes take place over the course of several days. If your PR has not been addressed after 3 days please leave a comment on the PR. If the PR goes without a response for another day please let us know via Slack.
- Read our official JavaScript and React style guide. Please refer to our Style Guide before asking for a review.
- We have nothing against Prettier or any other automatic style fixers, but we generally don't use them here at Expensify. Do not use Prettier. The style changes these tools enforce don't always align with the ones we recommend and require in our eslint configs and can result in uncessary changes for our reviewers. Ignoring this advice will ultimately make your changes take longer to review as we will ask you to undo any style changes that are not relating to the important changes you are making.