Hello and thank you for expressing interest in contributing to Forgettable!
Be sure to read the Code of Conduct to ensure our community remains a welcoming environment.
This guide takes you through the workflow you should follow when contributing to our project.
- Create an issue/Assign yourself to an issue
- Issue must be reviewed by at least one person
- Fork the repository
- Clone to local repository
- Create new feature branch
- Push changes to Forked repository
- Create pull request
- Must be reviewed by at least two people
- Success!
Be sure to read the READMEs to get a better understanding of the project. Look through both the Frontend and Backend READMEs as well.
- If you find a problem in our code, or you have an exciting idea for an addition, create a new issue. Be sure to use the provided Issue template.
- Ensure you link to the appropriate dependencies when required e.g. Blocks Issue #78.
- Add the relevant labels. Find more info on the appropriate labels here.
- When you have created your issue, tag an appropriate person in the 'Reviewers' section to get it approved.
- The reviewer will respond with a comment, add the 'approved' label to your issue, and assign you to the issue.
- Now you are free to start working on it.
If you find an existing issue that interests you, express your interest in the comments. Once you are assigned to the issue, you can start working on it.
The 'fork and pull' model is used for this project. Once you have an issue assigned, for the main repository. You will then clone this fork to your local repository. It is also recommended to create a new branch in your local repository to start working on your issue.
- Refer to the coding style guide to ensure our project remains consistent.
- Update local repository to remain up-to-date with the main repository
- Rebase often
- If your code requires testing, ensure all tests pass.
- Create a pull request to be merged to the main repository.
- Ensure a succinct, yet descriptive title is included.
- The description should describe some additional details about the changes made.
- Remember to link the pull request to the issue that it fixes e.g. "Fixes #46"
- The code must also pass the automated test and build in the CI pipeline
- Every pull request must be reviewed by at least two other people.
- Once it is successfully reviewed, it can be merged into the main repository.
- Try to follow the style of the existing code. Look through some existing files to see how variables and functions are named.
- This project uses eslint. Ensure your code follows these formatting rules. (If you are using VSCode, install the eslint extension and ensure any other formatting extension is disabled)
- Ensure Component classes start with a capital letter.
- Each new component should have a dedicated folder. This will contain the main ComponentName.js, ComponentName.module.css, and ComponentName.test.js (if required)
Primary custom labels used throughout the project:
- api - For api related issues
- approved - Used to approve issues
- authentication - For authentication related issues
- backend - Backend related issues
- component - Related to React components
- database - Database related issues
- frontend - Frontend related issues
- frontend-page - Web app page related issues
- initial - For initial set of issues
- search - Search related issues
- testing - Test related issues
Additional labels used
- bug
- documentation
- feature
- set up
- UI/UX