First off, thank you for considering contributing to Zwiggy! It's people like you that make Zwiggy such a great tool. We welcome contributions from everyone.
The following is a set of guidelines for contributing to Zwiggy. These are mostly guidelines, not rules. Use your best judgment, and feel free to propose changes to this document in a pull request.
- How to Report a Bug
- Feature Requests
- Setting Up the Development Environment
- Submitting a Pull Request
- Code Review Process
We use GitHub issues to track bugs. If you discover a bug, please follow these steps:
- Check if the bug has already been reported by searching on GitHub under Issues.
- If you're unable to find an open issue addressing the problem, open a new one.
- Use a clear and descriptive title for the issue to identify the problem.
- Describe the exact steps which reproduce the problem in as much detail as possible.
- Provide specific examples to demonstrate the steps. Include links to files or GitHub projects, or copy/pasteable snippets, which you use in those examples.
- Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior.
- Explain which behavior you expected to see instead and why.
- Include screenshots and animated GIFs which show you following the described steps and clearly demonstrate the problem.
We're always looking for suggestions to improve our project. If you have an idea for a new feature:
- Check if the feature has already been suggested by searching on GitHub under Issues.
- If you don't find an existing suggestion, open a new issue.
- Use a clear and descriptive title for the issue to identify the suggestion.
- Provide a detailed description of the suggested enhancement, including specific use cases and potential implementation ideas if you have them.
To set up your development environment for Zwiggy:
- Fork the repository on GitHub.
- Clone your forked repository to your local machine.
- Install Flutter by following the official installation guide.
- Install dependencies by running
flutter pub get
in the project root directory. - Set up Firebase:
- Create a new Firebase project in the Firebase Console.
- Add an Android and iOS app to your Firebase project and follow the setup instructions.
- Download the
google-services.json
(for Android) andGoogleService-Info.plist
(for iOS) files and place them in the appropriate directories in your project.
- Run the app using
flutter run
.
- Create a new branch from
main
for your feature or bug fix. - Make your changes in your branch.
- Follow the Flutter style guide in your code.
- Add or update tests as necessary.
- Ensure all tests pass by running
flutter test
. - Commit your changes using a descriptive commit message.
- Push your branch to your fork on GitHub.
- Create a pull request from your branch to the
main
branch of the original repository. - In the pull request description, clearly describe the problem and solution. Include the relevant issue number if applicable.
The core team looks at pull requests on a regular basis. After feedback has been given, we expect responses within two weeks. After two weeks, we may close the pull request if it isn't showing any activity.
- At least one core team member must approve the pull request before it can be merged.
- If changes are requested, make the required updates and push them to your branch.
- If you disagree with a comment, feel free to reply with your reasoning.
- Once approved, your pull request will be merged by a core team member.
Thank you for contributing to Zwiggy!