Thank you for considering contributing to Affinity Frontend! We welcome contributions from the community and are excited to see what you can bring to the project.
- Code of Conduct
- How to Contribute
- Creating Issues
- Writing Better Comments for Issue Assignment
- Setting Up Your Development Environment
- Making Changes
- Submitting Your Changes
- How to Create Pull Requests
- Time Limit for Assigned Issue
- Gathering Contributor Information
- Style Guide
- Testing
- Documentation
- Contact
Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.
1. Fork the Repository
Fork the repository to your own GitHub account by clicking the "Fork" button on the top right of the repository page.
2. Clone the Repository
Clone the forked repository to your local machine:
git clone https://github.com/your-username/Affinity_frontend.git
cd Affinity_frontend
3. Create a Branch
Create a new branch for your feature or bug fix:
git checkout -b feature/your-feature-name
If you've encountered a bug or have a feature request, you can create an issue in the repository:
1. Clear and Concise Title: Use a descriptive title that summarizes the problem or feature request.
2. Detailed Explanation: Provide a clear description of the problem, steps to reproduce (if applicable), and expected behavior. For feature requests, explain the purpose and benefits.
3. Attachments: Whenever possible, include screenshots, logs, or code snippets that help explain the issue.
4. Use Templates: If issue templates are provided, please use them to ensure that all necessary information is included.
This information will help the maintainers understand the context and prioritize the issue appropriately.
When requesting an issue assignment:
1. Clearly Describe Your Approach: Briefly explain how you intend to solve the issue or add the feature. This helps maintainers assess whether your approach aligns with the project's needs.
2. Be Thoughtful and Constructive: Use professional language, be polite, and ensure that your comments contribute to a positive and collaborative environment.
3. Explain Your Availability: Let the maintainers know if you anticipate any delays in solving the issue, so the maintainers can manage the project timeline efficiently.
- Ensure you have Node.js and npm installed. You can download them from Node.js.
- Install the project dependencies:
npm install
- Start the development server:
npm start
This will start the development server and you can view the application in your browser at http://localhost:3000
.
- Make your changes to the codebase. Ensure that your code follows the project's coding standards.
- If you are adding a new feature, consider adding tests to cover your changes.
- Ensure your code passes all existing tests.
Commit your changes with a descriptive commit message:
git add .
git commit -m "Add feature: your feature description"
Push your changes to your forked repository:
git push origin feature/your-feature-name
To submit your work:
1. Fork the Repository: Ensure your repository is forked and you have created a new branch for your work.
2. Make Changes and Test: Make your changes on the new branch, then ensure that everything is working as expected.
3. Maintain Clean Commit History: Organize your commits meaningfully and squash or rebase them if necessary. Ensure each commit has a clear and descriptive message explaining the changes.
4. Link to the Issue: In the PR description, link the issue you're addressing (if applicable) by referencing the issue number.
5. Submit PR: Go to the original repository and create a pull request from your forked repository. Provide a clear and descriptive title and description for your pull request.
6. Complete any Requested Changes: If maintainers request changes to your PR, complete them as soon as possible.
Once an issue is assigned, contributors will have 1-2 days to work on the issue and submit a pull request.
- If you're unable to meet this deadline, please communicate with the maintainers as soon as possible to request an extension.
- If you fail to submit the PR or communicate delays within the specified timeframe, the issue may be reassigned to someone else.
To properly acknowledge the efforts of all contributors:
1. Collect Information: I will ensure each contributor’s name, GitHub profile link, and the details of their contributions (e.g., bug fixes, features, etc.) are accurately included.
2. Markdown Syntax for Formatting: Contributors will be listed using markdown to create a clean and consistent layout. If appropriate, sections will be created for profiles, images, and descriptions of their contributions.
3. Sorting by Contribution: Contributors may be sorted based on role or type of contribution (e.g., bug fix, feature implementation) for better readability.
The expected outcome is a well-organized CONTRIBUTORS.md
file that acknowledges every contributor's effort while maintaining clarity for visitors of the repository.
- Code Formatting: Ensure your code is properly formatted. We use Prettier for code formatting. You can format your code by running:
npm run format
Ensure that your code passes all tests before submitting your changes. If you're adding new features, consider writing tests for them.
Update documentation as necessary for any changes you make. This includes updating the README.md file and any other relevant documentation files.
If you have any questions or need further assistance, feel free to open an issue or contact the maintainers.
Thank you for your contributions!