Skip to content

Latest commit

 

History

History
74 lines (51 loc) · 2.17 KB

README.md

File metadata and controls

74 lines (51 loc) · 2.17 KB

Coverage Status

Ingredients Scanner

Overview

Ingredients Scanner is a cross-platform mobile application designed to scan and interpret the ingredient lists on food labels. It enhances readability and assists users in identifying undesirable ingredients. An app built with Flutter, implementing Clean Architecture and TDD principles.

Features

  • Text Recognition: Utilizes Google ML Kit for text recognition.
  • User Authentication: Powered by Firebase Authentication.
  • User Preferences: Stores user settings using SharedPreferences.
  • Clean Architecture: Adheres to clean architecture principles.
  • TDD Approach: Developed using Test-Driven Development (TDD).

Getting Started

Prerequisites

  • Flutter SDK
  • Firebase account

Installation

  1. Clone the repository:
    git clone https://github.com/spermobak/ingredients_scanner.git
    
  2. Navigate to the project directory:
    cd ingredients_scanner
    
  3. Install dependencies:
    flutter pub get
    
  4. Firebase Setup
  • Follow the Firebase setup guide to add Firebase to your Flutter app.
  • Add your 'google-services.json' (for Android) and 'GoogleService-Info.plist' (for iOS) to the respective directories.

Running the App

  1. Run the app on an emulator or connected device:
    flutter run
    

Architecture

  • Presentation Layer: UI components and state management.
  • Domain Layer: Business logic and use cases.
  • Data Layer: Repository pattern for data handling.

Testing

  • Run unit tests:
    flutter test
    
    

Usage

  • Authenticate users with email/password or social media accounts.
  • Save and manage user preferences locally.
  • Scan product ingredients using the camera.

Contribution

Contributions are welcome! Please create an issue or submit a pull request.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contact

For any queries, please contact alexeybismus@gmail.com.