Thank you for your interest in contributing to our Flutter project! We truly appreciate your help in making our app better. Currently, our primary focus is on improving the code quality and addressing technical debt in our 4+ year old codebase, specifically the BLoC architecture. We want to ensure that our app's code is of the highest standard, both for refactored code and new features.
Please note that this is a high-level guide. A comprehensive contributing guide with detailed conventions and architecture will be created.
-
Code Quality: We are dedicated to maintaining a high-quality codebase. Your contributions should aim to improve code readability, maintainability, and performance.
-
BLoC Architecture: All new and refactored code must follow the BLoC architecture pattern. This helps us maintain a consistent structure across the codebase and streamline the review process.
-
Balancing Features and Refactoring: While we value new features, our current focus is on addressing technical debt. As such, we encourage you to focus on refactoring and improving existing code.
There is a folder named lib/generic_blocs
containing files referred to as "blocs." Please note that despite their name, these files do not follow the BLoC architecture. New/refactored features should be created in the lib/packages
folder and follow the BLoC pattern using the bloc
/flutter_bloc
/hydrated_bloc
package.
- Fork the repository: Fork the main repository and create your feature or bugfix branch from the
dev
branch. - Understand the codebase: Spend some time familiarizing yourself with the existing codebase, BLoC architecture, and any conventions followed in the project.
- Open an issue: Before starting any work, open an issue discussing the proposed changes or improvements. This helps avoid duplicate work and ensures that your changes align with the project's goals.
- Start coding: Once you've received feedback on the issue, begin implementing the changes on your branch. Ensure that your code adheres to the BLoC architecture and maintains a high level of quality.
- Test your changes: Make sure to test your changes thoroughly and ensure that they do not introduce new bugs or negatively impact performance.
- Submit a pull request: Once you're satisfied with your changes, submit a pull request to the
dev
branch. Be sure to reference the related issue in the PR description and provide a clear explanation of the changes.
To maintain our focus on code quality and addressing technical debt, we will only approve pull requests that:
- Strictly follow the BLoC architecture.
- Improve code quality, readability, and maintainability.
- Address existing technical debt or introduce new features that align with our current priorities.
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.
As this is just a placeholder guide, please stay tuned for the comprehensive contributing guide with detailed conventions and architecture. In the meantime, feel free to reach out to the maintainers with any questions or concerns. We're excited to have you on board and look forward to your contributions!
To help you get started with BLoC architecture and understand best practices, we've compiled a list of useful resources:
- Official BLoC Documentation: This is the official BLoC library documentation and provides a comprehensive guide on using BLoC in your Flutter projects.
- A Flutter BLoC + Clean Architecture journey: This is a great set of guidelines on when/how to separate blocs. Avoid broad/general mega BLoCs.
- Effective Dart Guide: Google's official guide on Effective Dart provides best practices for writing clean, idiomatic, and efficient Dart code.
- Flutter Best Practices and Tips: A comprehensive list of Flutter best practices and tips curated by the Flutter Community.
- Flutter Style Guide: A style guide for Flutter from the official Flutter repository, which can help you maintain a consistent coding style throughout your project.
- FilledStacks: The FilledStacks YouTube channel offers various tutorials on Flutter development, including videos on BLoC and other state management techniques.
- Reso Coder: The Reso Coder YouTube channel provides high-quality tutorials on various Flutter topics, including the BLoC pattern and clean architecture.
- Flutter.dev blog: The official Flutter blog features articles on Flutter development, including BLoC architecture and best practices.
These resources should help you gain a deeper understanding of BLoC architecture and best practices in Flutter development. As you work on your contributions, don't hesitate to consult these resources and refer back to them for guidance. Good luck, and we look forward to your contributions!