Skip to content

tomoyanakano/flutter-app-template

Folders and files

NameName
Last commit message
Last commit date

Latest commit

2e4346b Β· Apr 9, 2024

History

59 Commits
Apr 8, 2024
Nov 16, 2023
Apr 8, 2024
Apr 8, 2024
Apr 8, 2024
Nov 16, 2023
Apr 5, 2024
Mar 13, 2024
Nov 16, 2023
Apr 2, 2024
Apr 9, 2024
Nov 17, 2023
Nov 16, 2023
Nov 16, 2023
Apr 2, 2024
Apr 2, 2024
Apr 5, 2024
Apr 5, 2024

Repository files navigation

Blue Heart flutter_app_template

A template for flutter app development with best practices and features.

Rocket Getting Started

Clone the repository

git clone https://github.com/firebase/flutterfire.git

Install dependencies

flutter pub get

Setup Flavors

By editing the dart_defines/dev.json and dart_defines/prod.json files, you can define the environment variables for the app.

{
  "flavor": "dev",
  "appName": "tomoyanakano - dev",
  "appIdSuffix": ".dev",
  "iOSBundleIdentifier": "com.tomoyanakano.dev",
  "androidBundleIdentifier": "com.tomoyanakano.dev",
  "LaunchStoryboardName": "LaunchScreenDev"
}

Generate App Icon

Using flutter_launcher_icons package, you can generate app icons for both iOS and Android.

By editing the flutter_launcher_icons-dev.yaml and flutter_launcher_icons-prod.yaml files, you can define the app icon settings. For more details, see the documentation.

flutter_icons:
  android: true
  ios: true
  image_path: "assets/launcher_icon/dev.png" // icon image path

Run the following command to generate app icons.

flutter pub run flutter_launcher_icons:main

Generate App Launch Storyboard

Using flutter_native_splash package, you can generate launch storyboard for iOS.

By editing the flutter_native_splash-dev.yaml and flutter_native_splash-prod.yaml files, you can define the launch storyboard settings. For more details, see the documentation.

flutter_native_splash:
  color: "#ffffff"
  image: assets/launcher_icon/dev.png // launch storyboard image path

  android_12:
    image: assets/launcher_icon/dev.png // launch storyboard image path
    icon_background_color: "#ffffff" // icon background color

Run the following command to generate launch storyboard.

flutter pub run flutter_native_splash:create --flavors dev,prod  

Integrate with Firebase Fire

This template uses Firebase for backend services. To integrate Firebase with the app, follow the steps below.

  1. Create a new project on Firebase Console.
  2. Add iOS and Android apps to the project.

iOS Setup

  1. Download GoogleService-Info.plist from Firebase Console.
  2. Place the file in the ios/dev or ios/prod directory.

Android Setup

  1. Download google-services.json from Firebase Console.
  2. Place the file in the android/app/src/dev or android/app/src/prod directory.

Build and Run the app

flutter run --dart-define-from-file=dart_defines/dev.json // Develpment environment
flutter run --dart-define-from-file=dart_defines/prod.json // Prod environment

Gear Architecture

Code Structure

This template follows the Clean Architecture pattern for organizing the codebase by using Riverpod.

Loading
graph TD;
    subgraph Presentation
        Widgets
        States
    end
    subgraph UseCase
        Notifier
        Provider
    end
    subgraph Application
        Service
    end
    subgraph Domain
        Model
    end
    subgraph Data
        Repository
        DataSource
    end

    Presentation -->|query| Provider
    Presentation -->|mutate| Notifier
    Provider --> Application
    Notifier --> Application
    Application --> Domain
    Domain --> Data
    Repository --> DataSource

Folder Structure

This Template follows Feature First Structure(Folders-by-Feature) for organizing the codebase. For example, the lib directory is structured as follows:

lib
β”œβ”€β”€ src 
β”‚   β”œβ”€β”€ features 
β”‚   β”‚   β”œβ”€β”€ feature1 
β”‚   β”‚   β”‚   β”œβ”€β”€ data
β”‚   β”‚   β”‚   β”œβ”€β”€ domain
β”‚   β”‚   β”‚   β”œβ”€β”€ presentation
β”‚   β”‚   β”‚   β”œβ”€β”€ providers 
β”‚   β”‚   β”‚   feature2 
β”‚   β”‚   β”‚   β”œβ”€β”€ data
β”‚   β”‚   β”‚   β”œβ”€β”€ domain
β”‚   β”‚   β”‚   β”œβ”€β”€ presentation
β”‚   β”‚   β”‚   β”œβ”€β”€ providers
β”‚   β”œβ”€β”€ common_widgets 
β”‚   β”œβ”€β”€ constants
β”‚   β”œβ”€β”€ extensions
β”‚   β”œβ”€β”€ router
β”‚   β”œβ”€β”€ utilities 

Refer to the Flutter Project Structure / Code with Andrea.

Sparkles Built in Features

  • Authentication
  • Maintenance Mode
  • Force Update
  • Notification
  • Settings

Man TechnologistWoman Technologist Contributing

Feel free to contribute to this project. Any contributions you make are greatly appreciated.

Memo License

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

About

πŸ’™ My Flutter app template

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages