/flutter_advance

A Flutter app for managing products using Clean Architecture and BLoC. It supports local caching with Hive and SQLite, and is structured with separate presentation, domain, and data layers.

Primary LanguageDartApache License 2.0Apache-2.0

Store App with Clean Architecture and BLoC

A Flutter project implementing Clean Architecture principles and BLoC pattern for state management. The project features product management with data persistence using both SQLite and Hive.

Important

Project Purpose : This project serves as a practical example of implementing modern Flutter development practices and showcasing the usage of several important packages:

Featured Packages Showcase

  1. dartz Package Usage

    • Implementing functional programming concepts
    • Using Either for better error handling
    • Example:
    Future<Either<Failure, List<Product>>> getProducts({bool useCache = true});
  2. freezed Package Implementation

    • Creating immutable data classes
    • Pattern matching with sealed unions
    • Example:
    @freezed
    class Product with _$Product {
      const factory Product({
        required String id,
        required String name,
        required int price,
      }) = _Product;
    }
  3. injectable Dependency Injection

    • Automatic dependency injection setup
    • Clean dependency management
    • Example:
    @injectable
    class GetProducts implements UseCase<List<Product>, bool> {
      final ProductRepository repository;
      GetProducts(this.repository);
    }
  4. json_serializable Usage

    • Automated JSON serialization/deserialization
    • Type-safe JSON handling
    • Example:
    @JsonSerializable()
    class Product {
      factory Product.fromJson(Map<String, dynamic> json) => 
        _$ProductFromJson(json);
      Map<String, dynamic> toJson() => _$ProductToJson(this);
    }

Learning Outcomes

  • Understanding functional programming in Dart with dartz
  • Implementing immutable state management using freezed
  • Setting up dependency injection with injectable
  • Managing JSON serialization with json_serializable

Project Structure

The project follows Clean Architecture with the following layer structure:

lib/
  ├── core/
  │   ├── error/
  │   │   └── failures.dart
  │   └── usecases/
  │       └── usecase.dart
  ├── features/
  │   └── product/
  │       ├── domain/
  │       ├── data/
  │       └── presentation/
  └── injection.dart

Core Dependencies

dependencies:
  dartz: ^0.10.1
  flutter_bloc: ^8.1.6
  freezed_annotation: ^2.4.4
  get_it: ^8.0.2
  hive: ^2.2.3
  hive_flutter: ^1.1.0
  injectable: ^2.5.0
  json_annotation: ^4.9.0
  json_serializable: ^6.8.0
  path: ^1.9.0
  path_provider: ^2.1.5
  sqflite: ^2.4.0

dev_dependencies:
  build_runner: ^2.4.13
  freezed: ^2.5.7
  hive_generator: ^2.0.1
  injectable_generator: ^2.6.2

Architecture Layers

1. Domain Layer

This layer contains:

Entities

  • Product: Core product model with fields:
    • id: Unique identifier
    • name: Product name
    • price: Product price
    • stock: Available quantity
    • categories: Product categories
    • createdAt: Creation timestamp

Repositories

  • ProductRepository: Core interface for data operations with methods:
    • getProducts: Retrieve product list
    • saveProduct: Save new product

Use Cases

  • GetProducts: Retrieve list of products
  • SaveProduct: Save new product

2. Data Layer

Data Sources

  • ProductLocalDataSource: Local data source with support for:
    • SQLite: Relational storage
    • Hive: Key-value storage

Repository Implementation

  • ProductRepositoryImpl: Implementation of repository with error handling

3. Presentation Layer

BLoC

  • ProductBloc: State management with events:
    • fetchProducts: Get products list
    • addProduct: Add new product

States:

  • initial: Initial state
  • loading: Loading state
  • loaded: Data loaded state
  • error: Error state

UI

  • ProductListPage: Main page showing products list
  • ProductListItem: Widget for displaying individual product

Dependency Injection

Uses get_it and injectable for dependency injection:

  • DatabaseModule: Database configurations
    • SQLite setup
    • Hive setup

Implementation Details

Error Handling

  • Uses Either from dartz package for error handling
  • Different Failure types for error categorization

State Management

  • Implements flutter_bloc for state management
  • Separation of events and states using freezed

Data Persistence

  • Dual storage system using SQLite and Hive
  • Caching capabilities

Code Generation

Uses the following libraries for code generation:

  • freezed: For data classes
  • injectable: For dependency injection
  • hive_generator: For Hive adapters

Getting Started

  1. Install dependencies:
flutter pub get
  1. Run code generators:
flutter pub run build_runner build
  1. Run the app:
flutter run

Key Features

Clean Architecture Implementation

  • Clear separation of concerns
  • Independent layers
  • Testable code structure
  • Domain-driven design

State Management with BLoC

  • Predictable state changes
  • Separation of UI and business logic
  • Easy testing
  • Reactive programming approach

Data Management

  • Dual storage system
  • Efficient caching
  • Type-safe data handling
  • Error handling at all layers

Dependency Injection

  • Service locator pattern
  • Modular code structure
  • Easy dependency management
  • Auto-generated DI code

Error Handling

  • Comprehensive error types
  • Functional programming approach
  • Type-safe error handling
  • User-friendly error messages

Code Quality

  • Type-safe programming with freezed
  • Clean and maintainable code
  • Following SOLID principles
  • Extensive use of Flutter best practices

Technical Considerations

Database Schema

SQLite table structure for products:

CREATE TABLE products(
  id TEXT PRIMARY KEY,
  name TEXT,
  price REAL,
  stock INTEGER,
  categories TEXT,
  created_at TEXT
)

State Flow

  1. User triggers an action
  2. BLoC receives an event
  3. Use case is executed
  4. Repository handles data operation
  5. State is updated
  6. UI reflects changes

Performance Optimizations

  • Efficient data caching
  • Lazy loading when appropriate
  • Minimal rebuilds in UI
  • Optimized database queries

Contributing

  1. Fork the repository
  2. Create your feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a Pull Request

License

This project is licensed under the Apache License - see the LICENSE file for details.