- MacOS 10.14 or higher to use Homebrew
- XCode command line tools (Required for Homebrew)
xcode-select --install
- Homebrew
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
- Python3
brew install python3
- Cookie Cutter
brew install cookiecutter
- Python3
sudo apt-get update && sudo apt-get install python3.6
- Cookie Cutter
sudo apt-get install cookiecutter
- Python3
- Download
- ADD PYTHON TO ENVIORNMENT PATH
- Cookie Cutter
pip install --user cookiecutter
-
iOS: XCode(11.3), iOS 13.0+
-
CocoaPods: CocoaPods is a dependency manager for Swift and Objective-C Cocoa projects. It has over 66 thousand libraries and is used in over 3 million apps. CocoaPods can help you scale your projects elegantly.
-
Android: Android Studio(4.0.1),
-
Editor: Android Studio, IntelliJ, Visual Studio Code
- Open terminal at your desired location
- Run
cookiecutter https://github.com/SimformSolutionsPvtLtd/flutter_project_template
to create template * If it asks for "You have .../.cookiecutters/Android_Project_Setup downloaded before. Is it okay to delete and re-download it?" press "yes"
Input name | Description | Default |
---|---|---|
app_name | Application name | App Name |
repo_name | Root Folder name | Repository Name |
bundle_identifier | Bundle ID of project | com.simformsolutions.app |
include_portraitUp_orientation | Include app support for portrait up orientation or not | 1 (y) |
include_landscapeLeft_orientation | Include app support for landscape left orientation or not | 1 (y) |
include_portraitDown_orientation | Include app support for portrait down orientation or not | 1 (y) |
include_landscapeRight_orientation | Include app support for landscape right orientation or not | 1 (y) |
minimum_android_sdk_version | Minimum android SDK support | 21 |
minimum_iOS_sdk_version | Minimum iOS SDK support | 11 |
target_ios_device | ios device support | iPhone/iPod touch |
sentry_dsn_key | Sentry DSN key for crash reporting | Sentry DSN |
repo_link | Repository link to connect project with remote | NA |
launch_studio | Open Android Studio after project is created. Works only for MacOS | 1 (false) |
- retrofit: A composable, cross-platform, Future-based API for making HTTP requests.
- mobx: MobX is a state management library that makes it simple to connect the reactive data of your application with the UI.
- flutter_mobx: Provides the Observer widget that listens to observables and automatically rebuilds on changes.
- provider: A mixture between dependency injection (DI) and state management, built with widgets for widgets.
- logger: Small, easy to use, and extensible logger which prints beautiful logs.
- flutter_svg: Draw SVG (and some Android VectorDrawable (XML)) files on a Flutter Widget.
- flutter_gen: Used to reference the assets safely anywhere in the flutter app.
- very_good_analysis: Linter rules corresponding to the guidelines in very good analysis.
- intl: Used for localization and other date-time utils
- device_preview: Approximate how your app looks and performs on another device.
- MobX to manage the state of the widget with Provider to inject the dependencies of MobX stores to widgets.
- Open set-githooks.bash file and Run it as highlighted in screenshot.
- Install flutter_intl plugin from android studio plugin market-place.
- Run
flutter pub global activate intl_utils
command (required only once). - Hover over any string and click on the light-bulb. Then click on the extract to arb file.
- Generated string can be used with
Str.of(context).stringName
orStr.current.stringName
- Locate and add
.arb
file to git - Tip -: To generate none-generated strings, press enter at the end of the .arb file and save, it will generate all strings.
INTERNET
: Requires for accessing the internet.Camera
: Requires to access and take a picture from the device's camera.Photo lib
: Requires to access a picture from the device's photo lib.
Storage
: Requires for reading files from the storage.Location
: Requires to access the user's location to connect them with location admin for arranging a seminar.
There will be three different product flavors
available for running the project either in development
, uat
, or in production
environment.
- Development - Set the active Build Variant as
"dev"
to run the project in the Development environment. - UAT - Set the active Build Variant as
"uat"
to run the project in the UAT environment. - Production - Set the active Build Variant as
"prod"
to run the project in the Production environment.
productFlavors {
dev {
...
}
uat {
...
}
prod {
...
}
}
We are using App Center for downloading the app for beta testing.
To checkout the beta versions of the application using App Center, you’ll need to receive an invitation email from the developer or get access to a public invitation link, and have a device that you can use to test.
We are using TestFlight to download the app for beta testing.
To test beta versions of apps using TestFlight, you’ll need to receive an invitation email from the developer or get access to a public invitation link, and have a device that you can use to test.
Internal testers Members of the developer’s team in App Store Connect can participate as internal testers and will have access to all builds of the app.
External testers Anyone can participate as an external tester and will have access to builds that the developer makes available to them. A developer can invite you to test with an invitation email or a public invitation link. An Apple ID is not required. If you are part of the developer’s team in App Store Connect, you can be added as an external tester if you aren’t already an internal tester.
Installing a Beta iOS App from an Invitation Email or Public Link
- Install TestFlight on the iOS device that you’ll use for testing.
- Open your invitation email or tap on the public link on your iOS device.
- Tap View in TestFlight or Start Testing; or tap Accept, Install, or Update for the app you want to test.
- Bitrise: [email protected]
- Sentry: [email protected]