Skip to content

Latest commit

 

History

History
148 lines (109 loc) · 8 KB

README.md

File metadata and controls

148 lines (109 loc) · 8 KB

Flutter

Flutter Sample App

This application is the Flutter Mobile sample app developed by Adesso Turkey. The primary objective of this project is to create a sample app for Flutter developers. This application consists of a sample architecture and codebase. The application encompasses a range of features, including the display of currently screening movies and TV series, the presentation of nearby movie theaters, and the ability to curate a personalized favorites list through integration with the TMBD movie API.

Screenshots

Android

iOS

Table of Contents

Development

Setup Environment

Flutter Template: You can see how to set up the environment here.

TMDB API Key

To run the application, you need to supply an API key from TMDB. When you get the key, please add the following variable to the .env file in the root of the project.

MAP API Key

To view Google Maps, you need to supply three API keys from Google Web Services. Add these keys to .env file.

.env File

You need to create a file named .env and at root of project. Fill the file accordingly:

# .env
API_KEY= <Your TMDB API Key>
ACCESS_TOKEN= <Access Token>
GOOGLE_PLACES_API_KEY = <Google Places API Key>
GOOGLE_MAP_IOS_API_KEY = <Google Map iOS API Key>
GOOGLE_MAP_ANDROID_API_KEY = <Google Map Android Key>
GOOGLE_PLACES_API_SEARCH_BY_FIELD_MASK = places.displayName,places.formattedAddress,places.location,places.types,places.websiteUri
BASE_URL=https://api.themoviedb.org/3
REQUEST_TOKEN_PATH=/authentication/token/new
MOVIE_PATH=/movie
IMAGE_URL = https://image.tmdb.org/t/p/w500
VIDEO_PATH = /videos
LOGIN_WITH_CREDENTIALS_PATH = /authentication/token/validate_with_login
OPEN_SESSION_PATH= /authentication/session/new
DELETE_SESSION_PATH = /authentication/session
TV_SERIES_PATH = /tv
CREDITS_PATH = /credits
ACCOUNT_PATH = /account/_
FAVORITE_PATH_MOVIES = /favorite/movies
FAVORITE_PATH_TV = /favorite/tv
SEARCH_PATH_MULTI = /search/multi
GENRE_PATH = /genre
FAVORITE_PATH_ADD = /account/_/favorite
GOOGLE_PLACES_API_BASE_URL = https://places.googleapis.com
GOOGLE_PLACES_API_SEARCH_BY_TEXT_PATH = /v1/places:searchText
PERSON_PATH = /person

Architecture

  • BLoC Pattern
  • Localization
  • Configuration
  • Assets
  • Freezed Data Classes

View: Renders UI and delegates user actions to Bloc. Each page is separated as a feature.

Bloc: Manages UI state and retrieves data from the data source asynchronously.

Localization: Holds text for various languages.

Assets: Contains assets like images.

Freezed Data Classes: Data classes are created with Freezed.

Tech Stack

Dependencies

  • auto_route : Declarative routing for Flutter.
  • dio : Powerful HTTP client for Dart.
  • flutter_dotenv : Loads environment variables from a .env file.
  • flutter : Google's UI toolkit for building natively compiled applications for mobile, web, and desktop from a single codebase.
  • flutter_bloc : Implementation of the BLoC pattern for state management.
  • flutter_localizations : Localizations for Flutter's built-in widgets.
  • freezed : Code generation for unions/pattern-matching/copy in Dart.
  • formz : Simplifies form validation.
  • geolocator : Provides geolocation functionalities.

Branching Strategy

Gitflow is a legacy Git workflow that was originally a disruptive and novel strategy for managing Git branches. Gitflow has fallen in popularity in favor of trunk-based workflows, which are now considered best practices for modern continuous software development and DevOps practices. Gitflow can also be challenging to use with CI/CD.

Branch Description
Main In the Git flow workflow, the main branch is used to store code that is release-ready and ready for production.
Develop The develop branch contains pre-production code with recently built features that are currently being tested. It is established at the beginning of a project and maintained during the development process.
Feature You will create a feature branch off the develop branch while working on a new feature, and once it has been finished and carefully reviewed, you will merge your changes into the develop branch.
Hotfix The hotfix branch is utilized in the Git pipeline to swiftly address required changes in your main branch. Your main branch should serve as the base for the hotfix branch, and it should be merged back into both the main and develop branches.
Release The release branch should be used when preparing new production releases. Typically, the work being performed on release branches concerns finishing touches and minor bugs specific to releasing new code, with code that should be addressed separately from the main develop branch.
  • Branch names should start with feature, hotfix, or release according to the purpose of the branch, followed by the ticket ID. For example: feature/SASU-1234_some-issue
  • Pull requests should refer to specific issues with the ticket ID. For example: [SASU-1234] - New feature
  • Merge strategy: Rebase and merge is preferred for maintaining a linear project history.

Join the Crew!

Act now to join our team and become an adessi — enjoy a Great Place to Work!

License

Copyright 2024 adesso Turkey

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.