...
This project consists of mainly 3 screens:
- Splash Screen
- Login Screen (bottomsheet)
- Launch Screen (Home - the webview and the Profile - to login and see personal information, Search and About Us, use the same home view)
-
The project is using VIPER architecture where as VIPER stand for
- V = View (where the ui part is handled)
- I = Interactor (where all the interactions i.e. clicks are handled)
- P = Presenter (Where the presenter is hablded for all the business logics)
- E = Entity (Where the models linked to the view and presenter are being handled)
- R = Routes (Where the route/navigation of individual screen are being handled)
-
For state management its using Flutter Riverpod along with Flutter Hooks, there is combined package called as hooks_riverpod
-
For API call its using dio:
-
rest_service.dart file has all the API call methods, and also before calling an API it used the connectivity plugin to check the network availibity.
-
currently for this the API response are mocked, the mock the api resonse, in the reset_service method, have to pass the path for the mock resposne json file. Currentlty all the mock response are added to the assets/mock_response folder.
-
-
The color combination is taken from the website (https://www.dukkantek.com/)
-
For font Google fonts plugin is used and soraTextTheme() is used. The whole app textTheme / font family can be easily cahnged from text_styles.dart file
TextTheme get theme => GoogleFonts.soraTextTheme();
-
Credentials for login:
-
To check the success part use email = [email protected] and password = 123456
-
Apart from the above mentioned combination every other will give failure response.
-
-
Google login works for Android and iOS. (For Android it wont be running on other devices as its in debug mode and requires the development machines SHA1 and SHA256 keys to authenticate).
-
The login details (email and name) are stored in shared preference and on App start the stoage is checked, if the login details are present, it skips the login section and directly goes to the Launch Screen.
-
Most resulable UI(s) are created as seperate components which can be found in global_components folders.
-
String and Widget extensions are used to make the UI creation faster and easier and also to maintain the App style guide.
-
For the bottom navigation bar Cuberto bottom bar is used. (This is my personal package in pub.dev)
- Screen recording of the flow