diff --git a/android/app/build.gradle b/android/app/build.gradle
index dd83ac33ad9f40d8084dd61d315c5eeb2778b7b3..85cd96a3c930e03299120ebbe5ea302926fb476c 100644
--- a/android/app/build.gradle
+++ b/android/app/build.gradle
@@ -44,8 +44,8 @@ android {
     defaultConfig {
         // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
         applicationId "com.example.smf_mobile"
-        minSdkVersion flutter.minSdkVersion
-        targetSdkVersion flutter.targetSdkVersion
+        minSdkVersion 21
+        targetSdkVersion 31
         versionCode flutterVersionCode.toInteger()
         versionName flutterVersionName
     }
diff --git a/android/app/src/main/AndroidManifest.xml b/android/app/src/main/AndroidManifest.xml
index 3d10ea04e1180e72cc1bb6efc6c2661603f7fb4d..a471d0b3a87d369f3d4095470571d75d5dac0c68 100644
--- a/android/app/src/main/AndroidManifest.xml
+++ b/android/app/src/main/AndroidManifest.xml
@@ -1,7 +1,7 @@
 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
     package="com.example.smf_mobile">
    <application
-        android:label="smf_mobile"
+        android:label="UP SMF"
         android:name="${applicationName}"
         android:icon="@mipmap/ic_launcher">
         <activity
diff --git a/android/app/src/main/res/mipmap-hdpi/ic_launcher.png b/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
index db77bb4b7b0906d62b1847e87f15cdcacf6a4f29..51bc4ecdee68288bb2de5df1c250cb3ac997b94d 100644
Binary files a/android/app/src/main/res/mipmap-hdpi/ic_launcher.png and b/android/app/src/main/res/mipmap-hdpi/ic_launcher.png differ
diff --git a/android/app/src/main/res/mipmap-mdpi/ic_launcher.png b/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
index 17987b79bb8a35cc66c3c1fd44f5a5526c1b78be..8c8cd71e97796ccf91dc9ddacdecda453732642f 100644
Binary files a/android/app/src/main/res/mipmap-mdpi/ic_launcher.png and b/android/app/src/main/res/mipmap-mdpi/ic_launcher.png differ
diff --git a/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
index 09d4391482be68e9e4a07fab769b5de337d16eb1..aa0f0db38a5d5d8161267d90da3cd1e4b053706f 100644
Binary files a/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png and b/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png differ
diff --git a/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
index d5f1c8d34e7a88e3f88bea192c3a370d44689c3c..07160d969f338c752d181951baae68413e49c351 100644
Binary files a/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png and b/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png differ
diff --git a/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
index 4d6372eebdb28e45604e46eeda8dd24651419bc0..03ca4fa41fcb3a717d6c10987ce3c5a7dacbb553 100644
Binary files a/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png and b/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png differ
diff --git a/assets/images/logo.png b/assets/images/logo.png
new file mode 100644
index 0000000000000000000000000000000000000000..5f1ee49e1f8752aa29ae20ffb5a1351e09f89a83
Binary files /dev/null and b/assets/images/logo.png differ
diff --git a/assets/images/thumb_up.png b/assets/images/thumb_up.png
new file mode 100644
index 0000000000000000000000000000000000000000..9a0dac32ad95a934f3da1e6b81b5ef9e51ddf35b
Binary files /dev/null and b/assets/images/thumb_up.png differ
diff --git a/assets/launcher/icon.png b/assets/launcher/icon.png
new file mode 100644
index 0000000000000000000000000000000000000000..275d9ad266027529356df93df0097f05ea3e9889
Binary files /dev/null and b/assets/launcher/icon.png differ
diff --git a/ios/Runner.xcodeproj/project.pbxproj b/ios/Runner.xcodeproj/project.pbxproj
index f45f70a4c70acded736b4ec1e9970eafbe42a7f3..98905b151d534660645e8a66c1910156eb126f18 100644
--- a/ios/Runner.xcodeproj/project.pbxproj
+++ b/ios/Runner.xcodeproj/project.pbxproj
@@ -478,4 +478,4 @@
 /* End XCConfigurationList section */
 	};
 	rootObject = 97C146E61CF9000F007C117D /* Project object */;
-}
+}
\ No newline at end of file
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png
index dc9ada4725e9b0ddb1deab583e5b5102493aa332..793ac267d7ac19defde6fa7b77c98a70ebc33e37 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png
index 28c6bf03016f6c994b70f38d1b7346e5831b531f..d093370680001618f67b5a03176e5fae81c1d140 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png
index 2ccbfd967d9697cd4b83225558af2911e9571c9b..8d42cc967dc14a7fd4484365dbae172aaf4bb61e 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png
index f091b6b0bca859a3f474b03065bef75ba58a9e4c..8243ac821d659389e13c3105f334a01ca06db6e1 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png
index 4cde12118dda48d71e01fcb589a74d069c5d7cb5..a6c7ca00fc9429cde7d8d19ce4cb70c5ae23a794 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png
index d0ef06e7edb86cdfe0d15b4b0d98334a86163658..b8f6a954dd3c990703bb93eb441026b1ef73356b 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png
index dcdc2306c28505ebc0b6c3a359c4d252bf626b9f..14b8a67f2f37f5e33118c381998761b0ebc72f2c 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png
index 2ccbfd967d9697cd4b83225558af2911e9571c9b..8d42cc967dc14a7fd4484365dbae172aaf4bb61e 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png
index c8f9ed8f5cee1c98386d13b17e89f719e83555b2..445818e4d9975b90a60b270d81461b00dfa4b198 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png
index a6d6b8609df07bf62e5100a53a01510388bd2b22..eae73eda0bd51ed801e8fad525288108ecbb794e 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png
index a6d6b8609df07bf62e5100a53a01510388bd2b22..eae73eda0bd51ed801e8fad525288108ecbb794e 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png
index 75b2d164a5a98e212cca15ea7bf2ab5de5108680..5a9f1b0b499facfb83d31ced56df130aebd4c47b 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png
index c4df70d39da7941ef3f6dcb7f06a192d8dcb308d..b65f0f351db54531b5466236a27198b305573106 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png
index 6a84f41e14e27f4b11f16f9ee39279ac98f8d5ac..70c2e9d4a39e423979e838368a1c7f52b8127749 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png differ
diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png
index d0e1f58536026aebc4f1f70e481f6993c9ff088d..43982f5a68893e61fa4a33598c15399ffa04868b 100644
Binary files a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png differ
diff --git a/lib/constants/api_endpoints.dart b/lib/constants/api_endpoints.dart
new file mode 100644
index 0000000000000000000000000000000000000000..562473c9b6a68f0de9027df39c36e20a334ae086
--- /dev/null
+++ b/lib/constants/api_endpoints.dart
@@ -0,0 +1,6 @@
+class ApiUrl {
+  static const baseUrl = 'https://smfdev.idc.tarento.com';
+  static const getOtp = '$baseUrl/api/user/requestOTP';
+  static const validateOtp = '$baseUrl/api/signIn';
+  static const getAllApplications = '$baseUrl/api/forms/getAllApplications';
+}
diff --git a/lib/constants/app_constants.dart b/lib/constants/app_constants.dart
new file mode 100644
index 0000000000000000000000000000000000000000..c25c771e795c3a6465b742bd645d0c42dc46e7bd
--- /dev/null
+++ b/lib/constants/app_constants.dart
@@ -0,0 +1,8 @@
+const String appVersion = '1.0';
+const String appName = 'UP SMF';
+
+// class Status {
+//   static const String active = 'active';
+//   static const String completed = 'completed';
+//   static const String deleted = 'deleted';
+// }
diff --git a/lib/constants/app_urls.dart b/lib/constants/app_urls.dart
new file mode 100644
index 0000000000000000000000000000000000000000..4d8e82cd36c1de0099603338fbf3acc3b81bcd80
--- /dev/null
+++ b/lib/constants/app_urls.dart
@@ -0,0 +1,8 @@
+class AppUrl {
+  static const landingPage = '/landing-page';
+  static const loginEmailPage = '/login-email-page';
+  static const loginOtpPage = '/login-otp-page';
+  static const homePage = '/home-page';
+  static const inspectionSummary = '/inspection-summary';
+  static const inspectionCompleted = '/inspection-completed';
+}
diff --git a/lib/constants/color_constants.dart b/lib/constants/color_constants.dart
new file mode 100644
index 0000000000000000000000000000000000000000..322278c81e908d0ef69793e15dfe66984bb7ad89
--- /dev/null
+++ b/lib/constants/color_constants.dart
@@ -0,0 +1,13 @@
+import 'package:flutter/material.dart';
+
+class AppColors {
+  static const scaffoldBackground = Color.fromRGBO(240, 243, 244, 1);
+  static const primaryBlue = Color.fromRGBO(4, 93, 173, 1);
+  static const radioSelected = Color.fromRGBO(0, 116, 182, 0.2);
+  static const primaryGreen = Color.fromRGBO(48, 105, 51, 1);
+  static const black08 = Color.fromRGBO(0, 0, 0, 0.08);
+  static const black16 = Color.fromRGBO(0, 0, 0, 0.16);
+  static const black40 = Color.fromRGBO(0, 0, 0, 0.40);
+  static const black60 = Color.fromRGBO(0, 0, 0, 0.60);
+  static const black87 = Color.fromRGBO(0, 0, 0, 0.87);
+}
diff --git a/lib/landing_page.dart b/lib/landing_page.dart
new file mode 100644
index 0000000000000000000000000000000000000000..801e467972d18d5f7971e8bc4911699fcb00be6a
--- /dev/null
+++ b/lib/landing_page.dart
@@ -0,0 +1,47 @@
+import 'dart:io';
+import 'package:flutter/material.dart';
+import 'package:provider/provider.dart';
+import 'package:smf_mobile/pages/home_page.dart';
+import 'package:smf_mobile/pages/login_email_page.dart';
+import 'package:smf_mobile/repositories/application_repository.dart';
+import 'package:smf_mobile/repositories/login_repository.dart';
+import 'constants/app_constants.dart';
+import 'constants/app_urls.dart';
+import 'constants/color_constants.dart';
+import 'routes.dart';
+
+class LandingPage extends StatefulWidget {
+  static const route = AppUrl.landingPage;
+
+  const LandingPage({Key? key}) : super(key: key);
+  @override
+  _LandingPageState createState() => _LandingPageState();
+}
+
+class _LandingPageState extends State<LandingPage> {
+  final client = HttpClient();
+
+  @override
+  Widget build(BuildContext context) {
+    return MultiProvider(
+        providers: [
+          ChangeNotifierProvider.value(value: LoginRespository()),
+          ChangeNotifierProvider.value(value: ApplicationRespository()),
+        ],
+        child: MaterialApp(
+          title: appName,
+          theme: ThemeData(
+              scaffoldBackgroundColor: AppColors.scaffoldBackground,
+              primaryColor: Colors.white,
+              visualDensity: VisualDensity.adaptivePlatformDensity,
+              dividerColor: AppColors.black08,
+              canvasColor: Colors.white,
+              unselectedWidgetColor: AppColors.black40),
+          debugShowCheckedModeBanner: false,
+          onGenerateRoute: Routes.generateRoute,
+          onUnknownRoute: Routes.errorRoute,
+          home: const LoginEmailPage(),
+          // home: const HomePage(),
+        ));
+  }
+}
diff --git a/lib/main.dart b/lib/main.dart
index 202509be15d8afab8cc0096ea1b9610bd3832dae..3e5d5dac11f3897019b3e0056ee7585a7ac2437c 100644
--- a/lib/main.dart
+++ b/lib/main.dart
@@ -1,115 +1,12 @@
 import 'package:flutter/material.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'landing_page.dart';
 
 void main() {
-  runApp(const MyApp());
-}
-
-class MyApp extends StatelessWidget {
-  const MyApp({Key? key}) : super(key: key);
-
-  // This widget is the root of your application.
-  @override
-  Widget build(BuildContext context) {
-    return MaterialApp(
-      title: 'Flutter Demo',
-      theme: ThemeData(
-        // This is the theme of your application.
-        //
-        // Try running your application with "flutter run". You'll see the
-        // application has a blue toolbar. Then, without quitting the app, try
-        // changing the primarySwatch below to Colors.green and then invoke
-        // "hot reload" (press "r" in the console where you ran "flutter run",
-        // or simply save your changes to "hot reload" in a Flutter IDE).
-        // Notice that the counter didn't reset back to zero; the application
-        // is not restarted.
-        primarySwatch: Colors.blue,
-      ),
-      home: const MyHomePage(title: 'Flutter Demo Home Page'),
-    );
-  }
-}
-
-class MyHomePage extends StatefulWidget {
-  const MyHomePage({Key? key, required this.title}) : super(key: key);
-
-  // This widget is the home page of your application. It is stateful, meaning
-  // that it has a State object (defined below) that contains fields that affect
-  // how it looks.
-
-  // This class is the configuration for the state. It holds the values (in this
-  // case the title) provided by the parent (in this case the App widget) and
-  // used by the build method of the State. Fields in a Widget subclass are
-  // always marked "final".
-
-  final String title;
-
-  @override
-  State<MyHomePage> createState() => _MyHomePageState();
-}
-
-class _MyHomePageState extends State<MyHomePage> {
-  int _counter = 0;
-
-  void _incrementCounter() {
-    setState(() {
-      // This call to setState tells the Flutter framework that something has
-      // changed in this State, which causes it to rerun the build method below
-      // so that the display can reflect the updated values. If we changed
-      // _counter without calling setState(), then the build method would not be
-      // called again, and so nothing would appear to happen.
-      _counter++;
-    });
-  }
-
-  @override
-  Widget build(BuildContext context) {
-    // This method is rerun every time setState is called, for instance as done
-    // by the _incrementCounter method above.
-    //
-    // The Flutter framework has been optimized to make rerunning build methods
-    // fast, so that you can just rebuild anything that needs updating rather
-    // than having to individually change instances of widgets.
-    return Scaffold(
-      appBar: AppBar(
-        // Here we take the value from the MyHomePage object that was created by
-        // the App.build method, and use it to set our appbar title.
-        title: Text(widget.title),
-      ),
-      body: Center(
-        // Center is a layout widget. It takes a single child and positions it
-        // in the middle of the parent.
-        child: Column(
-          // Column is also a layout widget. It takes a list of children and
-          // arranges them vertically. By default, it sizes itself to fit its
-          // children horizontally, and tries to be as tall as its parent.
-          //
-          // Invoke "debug painting" (press "p" in the console, choose the
-          // "Toggle Debug Paint" action from the Flutter Inspector in Android
-          // Studio, or the "Toggle Debug Paint" command in Visual Studio Code)
-          // to see the wireframe for each widget.
-          //
-          // Column has various properties to control how it sizes itself and
-          // how it positions its children. Here we use mainAxisAlignment to
-          // center the children vertically; the main axis here is the vertical
-          // axis because Columns are vertical (the cross axis would be
-          // horizontal).
-          mainAxisAlignment: MainAxisAlignment.center,
-          children: <Widget>[
-            const Text(
-              'You have pushed the button this many times:',
-            ),
-            Text(
-              '$_counter',
-              style: Theme.of(context).textTheme.headline4,
-            ),
-          ],
-        ),
-      ),
-      floatingActionButton: FloatingActionButton(
-        onPressed: _incrementCounter,
-        tooltip: 'Increment',
-        child: const Icon(Icons.add),
-      ), // This trailing comma makes auto-formatting nicer for build methods.
-    );
-  }
+  runApp(MaterialApp(
+    home: const LandingPage(),
+    routes: <String, WidgetBuilder>{
+      AppUrl.landingPage: (BuildContext context) => const LandingPage()
+    },
+  ));
 }
diff --git a/lib/models/application_model.dart b/lib/models/application_model.dart
new file mode 100644
index 0000000000000000000000000000000000000000..2043ad40ae113d888fd905351cb145b928cde454
--- /dev/null
+++ b/lib/models/application_model.dart
@@ -0,0 +1,45 @@
+class Application {
+  final int formId;
+  final String applicationId;
+  final String title;
+  final String email;
+  final String status;
+  final Map dataObject;
+  final String createdDate;
+  final String createdBy;
+
+  const Application({
+    required this.formId,
+    required this.applicationId,
+    required this.title,
+    required this.email,
+    required this.status,
+    required this.dataObject,
+    required this.createdDate,
+    required this.createdBy,
+  });
+
+  factory Application.fromJson(Map<String, dynamic> json) {
+    return Application(
+      formId: json['formId'],
+      applicationId: json['applicationId'],
+      title: json['title'],
+      email: json['email'] ?? '',
+      status: json['status'],
+      dataObject: json['dataObject'],
+      createdDate: json['createdDate'],
+      createdBy: json['createdBy'],
+    );
+  }
+
+  List<Object> get props => [
+        formId,
+        applicationId,
+        title,
+        email,
+        status,
+        dataObject,
+        createdDate,
+        createdBy
+      ];
+}
diff --git a/lib/models/login_model.dart b/lib/models/login_model.dart
new file mode 100644
index 0000000000000000000000000000000000000000..b9228d9d7f1bd7c504a9bb7814b4491c83342757
--- /dev/null
+++ b/lib/models/login_model.dart
@@ -0,0 +1,37 @@
+class Login {
+  final int id;
+  final String username;
+  final String email;
+  final String firstName;
+  final String lastName;
+  final String authToken;
+
+  const Login({
+    required this.id,
+    required this.username,
+    required this.email,
+    required this.firstName,
+    required this.lastName,
+    required this.authToken,
+  });
+
+  factory Login.fromJson(Map<String, dynamic> json) {
+    return Login(
+      id: json['id'],
+      username: json['username'],
+      email: json['emailId'],
+      firstName: json['firstName'],
+      lastName: json['lastName'],
+      authToken: json['authToken'],
+    );
+  }
+
+  List<Object> get props => [
+        id,
+        username,
+        email,
+        firstName,
+        lastName,
+        authToken,
+      ];
+}
diff --git a/lib/pages/application_details_page.dart b/lib/pages/application_details_page.dart
new file mode 100644
index 0000000000000000000000000000000000000000..18da9b1f39e75c80af1f2a83c43714d0e80dc1b6
--- /dev/null
+++ b/lib/pages/application_details_page.dart
@@ -0,0 +1,237 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/pages/inspection_summary.dart';
+import 'package:smf_mobile/widgets/application_field.dart';
+import 'package:smf_mobile/widgets/silverappbar_delegate.dart';
+
+class ApplicationDetailsPage extends StatefulWidget {
+  const ApplicationDetailsPage({
+    Key? key,
+  }) : super(key: key);
+
+  @override
+  _ApplicationDetailsPageState createState() => _ApplicationDetailsPageState();
+}
+
+class _ApplicationDetailsPageState extends State<ApplicationDetailsPage>
+    with SingleTickerProviderStateMixin {
+  final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
+  TabController? _tabController;
+  int _activeTabIndex = 0;
+  final List _tabs = [
+    'General details',
+    'Insurance details',
+    'Training center details',
+    'Upload documents'
+  ];
+
+  @override
+  void initState() {
+    super.initState();
+    _tabController = TabController(vsync: this, length: _tabs.length);
+    _tabController!.addListener(_setActiveTabIndex);
+  }
+
+  void _setActiveTabIndex() {
+    setState(() {
+      _activeTabIndex = _tabController!.index;
+    });
+  }
+
+  @override
+  void dispose() {
+    _tabController?.dispose();
+    super.dispose();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+      key: _scaffoldKey,
+      appBar: AppBar(
+        titleSpacing: 10,
+        elevation: 0,
+        backgroundColor: Colors.white,
+        leading: const BackButton(color: AppColors.black60),
+        title: Text(
+          'Applications title',
+          style: GoogleFonts.lato(
+            color: AppColors.black87,
+            fontSize: 16.0,
+            letterSpacing: 0.12,
+            fontWeight: FontWeight.w600,
+          ),
+        ),
+        // centerTitle: true,
+      ),
+      body: Container(
+        color: Colors.white,
+        child: DefaultTabController(
+            length: _tabs.length,
+            child: SafeArea(
+                minimum: const EdgeInsets.only(top: 5),
+                child: NestedScrollView(
+                    headerSliverBuilder:
+                        (BuildContext context, bool innerBoxIsScrolled) {
+                      return <Widget>[
+                        SliverPersistentHeader(
+                          delegate: SilverAppBarDelegate(
+                            TabBar(
+                              isScrollable: true,
+                              indicator: const BoxDecoration(
+                                border: Border(
+                                  bottom: BorderSide(
+                                    color: AppColors.primaryBlue,
+                                    width: 2.0,
+                                  ),
+                                ),
+                              ),
+                              indicatorColor: Colors.white,
+                              labelPadding: const EdgeInsets.only(top: 0.0),
+                              unselectedLabelColor: AppColors.black60,
+                              labelColor: AppColors.black87,
+                              labelStyle: GoogleFonts.lato(
+                                  color: AppColors.black60,
+                                  fontSize: 14,
+                                  letterSpacing:
+                                      0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                  fontWeight: FontWeight.w700,
+                                  height: 1),
+                              unselectedLabelStyle: const TextStyle(
+                                color: Color.fromRGBO(0, 77, 89, 1),
+                                fontFamily: 'Inter',
+                                fontSize: 14,
+                                letterSpacing:
+                                    0 /*percentages not used in flutter. defaulting to zero*/,
+                                fontWeight: FontWeight.w500,
+                                height: 1,
+                              ),
+                              tabs: [
+                                for (var tabItem in _tabs)
+                                  Container(
+                                    height: MediaQuery.of(context).size.height,
+                                    padding: const EdgeInsets.only(
+                                        left: 15, right: 15),
+                                    child: Tab(
+                                      child: Text(
+                                        tabItem,
+                                      ),
+                                    ),
+                                  ),
+                              ],
+                              controller: _tabController,
+                            ),
+                          ),
+                          pinned: true,
+                          floating: false,
+                        ),
+                      ];
+                    },
+                    body: Container(
+                        padding: const EdgeInsets.only(top: 20),
+                        color: AppColors.scaffoldBackground,
+                        child:
+                            TabBarView(controller: _tabController, children: [
+                          for (var tab in _tabs)
+                            ListView.builder(
+                                shrinkWrap: true,
+                                physics: const NeverScrollableScrollPhysics(),
+                                itemCount: 3,
+                                itemBuilder: (context, i) {
+                                  return const ApplicationField();
+                                })
+                        ]))))),
+      ),
+      bottomNavigationBar: BottomAppBar(
+          elevation: 20,
+          child: Container(
+            height: 60,
+            padding: const EdgeInsets.only(left: 20, right: 20),
+            decoration: BoxDecoration(
+              color: Theme.of(context).primaryColor,
+              borderRadius: const BorderRadius.only(
+                topLeft: Radius.circular(20),
+                topRight: Radius.circular(20),
+              ),
+            ),
+            child: Row(
+              mainAxisAlignment: MainAxisAlignment.spaceBetween,
+              children: [
+                _activeTabIndex > 0
+                    ? InkWell(
+                        onTap: () => _tabController!.index--,
+                        child: Row(
+                          mainAxisAlignment: MainAxisAlignment.spaceAround,
+                          children: [
+                            const Icon(
+                              Icons.arrow_back,
+                              color: AppColors.primaryBlue,
+                            ),
+                            Padding(
+                                padding: const EdgeInsets.only(left: 10),
+                                child: Text(
+                                  'Previous',
+                                  style: GoogleFonts.lato(
+                                    color: AppColors.primaryBlue,
+                                    fontSize: 14.0,
+                                    letterSpacing: 0.12,
+                                    fontWeight: FontWeight.w700,
+                                  ),
+                                )),
+                          ],
+                        ))
+                    : const Center(),
+                _activeTabIndex < _tabs.length - 1
+                    ? InkWell(
+                        onTap: () => _tabController!.index++,
+                        child: Row(
+                          mainAxisAlignment: MainAxisAlignment.spaceBetween,
+                          children: [
+                            Padding(
+                                padding: const EdgeInsets.only(right: 10),
+                                child: Text(
+                                  'Next',
+                                  style: GoogleFonts.lato(
+                                    color: AppColors.primaryBlue,
+                                    fontSize: 14.0,
+                                    letterSpacing: 0.12,
+                                    fontWeight: FontWeight.w700,
+                                  ),
+                                )),
+                            const Icon(
+                              Icons.arrow_forward,
+                              color: AppColors.primaryBlue,
+                            )
+                          ],
+                        ))
+                    : TextButton(
+                        onPressed: () {
+                          Navigator.of(context).pushReplacement(
+                              MaterialPageRoute(
+                                  builder: (context) =>
+                                      const InspectionSummaryPage()));
+                        },
+                        style: TextButton.styleFrom(
+                          // primary: Colors.white,
+                          padding: const EdgeInsets.only(left: 15, right: 15),
+                          backgroundColor: AppColors.primaryBlue,
+                          shape: RoundedRectangleBorder(
+                              borderRadius: BorderRadius.circular(4),
+                              side: const BorderSide(color: AppColors.black16)),
+                        ),
+                        child: Text(
+                          'Inspection completed',
+                          style: GoogleFonts.lato(
+                            color: Colors.white,
+                            fontWeight: FontWeight.w700,
+                            fontSize: 14,
+                          ),
+                        ),
+                      ),
+              ],
+            ),
+          )),
+    );
+  }
+}
diff --git a/lib/pages/error_page.dart b/lib/pages/error_page.dart
new file mode 100644
index 0000000000000000000000000000000000000000..ab7816915e1db9df5f52c23e9532ffd8667f043d
--- /dev/null
+++ b/lib/pages/error_page.dart
@@ -0,0 +1,19 @@
+import 'package:big_tip/big_tip.dart';
+import 'package:flutter/material.dart';
+
+class ErrorPage extends StatelessWidget {
+  const ErrorPage({Key? key}) : super(key: key);
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+      body: BigTip(
+        title: const Text('An error occurred'),
+        subtitle: const Text('This page is not available'),
+        action: const Text('Go back'),
+        actionCallback: () => Navigator.pop(context),
+        child: const Icon(Icons.error_outline),
+      ),
+    );
+  }
+}
diff --git a/lib/pages/home_page.dart b/lib/pages/home_page.dart
new file mode 100644
index 0000000000000000000000000000000000000000..f560f27c25e45f31160f303db011ace0fe3f7599
--- /dev/null
+++ b/lib/pages/home_page.dart
@@ -0,0 +1,156 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:provider/provider.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/models/application_model.dart';
+import 'package:smf_mobile/pages/past_applications.dart';
+import 'package:smf_mobile/repositories/application_repository.dart';
+import 'package:smf_mobile/widgets/application_card.dart';
+
+// import 'dart:developer' as developer;
+
+class HomePage extends StatefulWidget {
+  static const route = AppUrl.homePage;
+
+  const HomePage({Key? key}) : super(key: key);
+  @override
+  _HomePageState createState() => _HomePageState();
+}
+
+class _HomePageState extends State<HomePage> {
+  @override
+  void initState() {
+    super.initState();
+    _getApplications(context);
+  }
+
+  Future<dynamic> _getApplications(context) async {
+    List<Application> applications =
+        await Provider.of<ApplicationRespository>(context, listen: false)
+            .getApplications();
+    return applications;
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+        appBar: AppBar(
+          elevation: 0,
+          leadingWidth: 0,
+          titleSpacing: 20,
+          backgroundColor: Colors.white,
+          title: Text(
+            'Pending applications',
+            style: GoogleFonts.lato(
+              color: AppColors.black87,
+              fontSize: 16.0,
+              letterSpacing: 0.12,
+              fontWeight: FontWeight.w600,
+            ),
+          ),
+          // centerTitle: true,
+        ),
+        // Tab controller
+        body: SingleChildScrollView(
+            child: Container(
+          padding: const EdgeInsets.all(20),
+          decoration: const BoxDecoration(),
+          constraints: BoxConstraints(
+            minHeight: MediaQuery.of(context).size.height - 150,
+          ),
+          child: FutureBuilder(
+            future: _getApplications(context),
+            builder: (context, AsyncSnapshot<dynamic> snapshot) {
+              if (snapshot.hasData && snapshot.data != null) {
+                List<Application> _todaysApplications = snapshot.data;
+
+                return Column(
+                  mainAxisAlignment: MainAxisAlignment.start,
+                  crossAxisAlignment: CrossAxisAlignment.start,
+                  children: [
+                    Container(
+                      width: double.infinity,
+                      margin: const EdgeInsets.only(top: 10, bottom: 20),
+                      child: Text('Today',
+                          style: GoogleFonts.lato(
+                            color: AppColors.black87,
+                            fontSize: 16.0,
+                            letterSpacing: 0.12,
+                            fontWeight: FontWeight.w600,
+                          )),
+                    ),
+                    ListView.builder(
+                      shrinkWrap: true,
+                      physics: const NeverScrollableScrollPhysics(),
+                      itemCount: _todaysApplications.length,
+                      itemBuilder: (context, i) {
+                        return ApplicationCard(
+                            application: _todaysApplications[i]);
+                      },
+                    ),
+                    Container(
+                      width: double.infinity,
+                      margin: const EdgeInsets.only(top: 20, bottom: 20),
+                      child: Text('Upcoming',
+                          style: GoogleFonts.lato(
+                            color: AppColors.black87,
+                            fontSize: 16.0,
+                            letterSpacing: 0.12,
+                            fontWeight: FontWeight.w600,
+                          )),
+                    ),
+                    ListView.builder(
+                      shrinkWrap: true,
+                      physics: const NeverScrollableScrollPhysics(),
+                      itemCount: _todaysApplications.length,
+                      itemBuilder: (context, i) {
+                        return ApplicationCard(
+                            application: _todaysApplications[i]);
+                      },
+                    ),
+                    Container(
+                      height: 50,
+                      width: double.infinity,
+                      margin: const EdgeInsets.only(top: 20),
+                      child: ButtonTheme(
+                        child: OutlinedButton(
+                          onPressed: () {
+                            Navigator.push(
+                              context,
+                              MaterialPageRoute(
+                                  builder: (context) => PastApplications(
+                                      pastApplications: _todaysApplications)),
+                            );
+                          },
+                          style: OutlinedButton.styleFrom(
+                            // primary: Colors.white,
+                            side: const BorderSide(
+                                width: 1, color: AppColors.primaryBlue),
+                            shape: RoundedRectangleBorder(
+                              borderRadius: BorderRadius.circular(4),
+                            ),
+                            // onSurface: Colors.grey,
+                          ),
+                          child: Text(
+                            'View past applications',
+                            style: GoogleFonts.lato(
+                                color: AppColors.primaryBlue,
+                                fontSize: 14,
+                                fontWeight: FontWeight.w700),
+                          ),
+                        ),
+                      ),
+                    )
+                  ],
+                );
+              } else {
+                return const Center(
+                  child: CircularProgressIndicator(),
+                );
+              }
+            },
+          ),
+        )));
+  }
+}
diff --git a/lib/pages/inspection_completed.dart b/lib/pages/inspection_completed.dart
new file mode 100644
index 0000000000000000000000000000000000000000..e43c5d8d43af69ed04c8c6acffd53106362b7ebd
--- /dev/null
+++ b/lib/pages/inspection_completed.dart
@@ -0,0 +1,108 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/pages/home_page.dart';
+
+// import 'dart:developer' as developer;
+
+class InspectionCompletedPage extends StatefulWidget {
+  static const route = AppUrl.inspectionSummary;
+
+  const InspectionCompletedPage({Key? key}) : super(key: key);
+  @override
+  _InspectionCompletedPageState createState() =>
+      _InspectionCompletedPageState();
+}
+
+class _InspectionCompletedPageState extends State<InspectionCompletedPage> {
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+        appBar: AppBar(
+          elevation: 0,
+          leadingWidth: 0,
+          titleSpacing: 20,
+          backgroundColor: Colors.white,
+          title: Text(
+            'Inspection Completed',
+            style: GoogleFonts.lato(
+              color: AppColors.black87,
+              fontSize: 16.0,
+              letterSpacing: 0.12,
+              fontWeight: FontWeight.w600,
+            ),
+          ),
+          // centerTitle: true,
+        ),
+        // Tab controller
+        body: SingleChildScrollView(
+            child: Container(
+                height: MediaQuery.of(context).size.height - 100,
+                padding: const EdgeInsets.all(20),
+                decoration: const BoxDecoration(),
+                child: Align(
+                  alignment: Alignment.center,
+                  child: Column(
+                    mainAxisAlignment: MainAxisAlignment.center,
+                    crossAxisAlignment: CrossAxisAlignment.center,
+                    children: [
+                      Container(
+                        width: 45,
+                        padding: const EdgeInsets.only(top: 10, bottom: 10),
+                        margin: const EdgeInsets.only(bottom: 20),
+                        decoration: const BoxDecoration(
+                          color: AppColors.black08,
+                          borderRadius: BorderRadius.all(Radius.circular(22)),
+                        ),
+                        child: Center(
+                          child: Image.asset(
+                            'assets/images/thumb_up.png',
+                            color: AppColors.primaryGreen,
+                          ),
+                        ),
+                      ),
+                      Padding(
+                          padding: const EdgeInsets.only(bottom: 20),
+                          child: Text(
+                            'Inspection completed',
+                            style: GoogleFonts.lato(
+                              color: AppColors.black87,
+                              fontSize: 20.0,
+                              letterSpacing: 0.12,
+                              fontWeight: FontWeight.w600,
+                            ),
+                          )),
+                      TextButton(
+                        onPressed: () {
+                          Navigator.of(context).pushReplacement(
+                              MaterialPageRoute(
+                                  builder: (context) => const HomePage()));
+                        },
+                        style: TextButton.styleFrom(
+                          // primary: Colors.white,
+                          padding: const EdgeInsets.only(left: 15, right: 15),
+                          backgroundColor: AppColors.primaryBlue,
+                          shape: RoundedRectangleBorder(
+                              borderRadius: BorderRadius.circular(4),
+                              side: const BorderSide(color: AppColors.black16)),
+                        ),
+                        child: Text(
+                          'View pending appllications',
+                          style: GoogleFonts.lato(
+                            color: Colors.white,
+                            fontWeight: FontWeight.w700,
+                            fontSize: 14,
+                          ),
+                        ),
+                      ),
+                    ],
+                  ),
+                ))));
+  }
+}
diff --git a/lib/pages/inspection_summary.dart b/lib/pages/inspection_summary.dart
new file mode 100644
index 0000000000000000000000000000000000000000..399c833cc92b72afabc47fbea3c8c4ff3e23d2e2
--- /dev/null
+++ b/lib/pages/inspection_summary.dart
@@ -0,0 +1,261 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/widgets/people_card.dart';
+
+import 'inspection_completed.dart';
+
+// import 'dart:developer' as developer;
+
+class InspectionSummaryPage extends StatefulWidget {
+  static const route = AppUrl.inspectionSummary;
+
+  const InspectionSummaryPage({Key? key}) : super(key: key);
+  @override
+  _InspectionSummaryPageState createState() => _InspectionSummaryPageState();
+}
+
+class _InspectionSummaryPageState extends State<InspectionSummaryPage> {
+  final List<String> _dropdownItems = [
+    'Select from the list',
+    'Somorjit Phuritshabam',
+    'Shoaib Muhammed'
+  ];
+  String _selectedItem = 'Select from the list';
+
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+        appBar: AppBar(
+          elevation: 0,
+          leadingWidth: 0,
+          titleSpacing: 20,
+          backgroundColor: Colors.white,
+          title: Text(
+            'Inspection Summary',
+            style: GoogleFonts.lato(
+              color: AppColors.black87,
+              fontSize: 16.0,
+              letterSpacing: 0.12,
+              fontWeight: FontWeight.w600,
+            ),
+          ),
+          // centerTitle: true,
+        ),
+        // Tab controller
+        body: SingleChildScrollView(
+            child: Column(children: [
+          Container(
+            // height: MediaQuery.of(context).size.height,
+            margin: const EdgeInsets.all(20),
+            decoration: BoxDecoration(
+              borderRadius: BorderRadius.circular(4),
+              color: Colors.white,
+              boxShadow: const [
+                BoxShadow(
+                    color: AppColors.black16,
+                    offset: Offset(0, 2),
+                    blurRadius: 2)
+              ],
+            ),
+            child: Column(
+              mainAxisAlignment: MainAxisAlignment.start,
+              crossAxisAlignment: CrossAxisAlignment.start,
+              children: [
+                Container(
+                    margin: const EdgeInsets.fromLTRB(20, 30, 20, 15),
+                    child: Text(
+                      'Enter summary of this inspection',
+                      style: GoogleFonts.lato(
+                        color: AppColors.black87,
+                        fontWeight: FontWeight.w700,
+                        fontSize: 14,
+                        letterSpacing: 0.25,
+                      ),
+                    )),
+                Container(
+                  margin: const EdgeInsets.fromLTRB(20, 0, 20, 20),
+                  padding: const EdgeInsets.all(5),
+                  decoration: BoxDecoration(
+                    borderRadius: BorderRadius.circular(4),
+                    border: Border.all(color: AppColors.black16),
+                  ),
+                  child: TextFormField(
+                    // autofocus: true,
+                    // focusNode: _notesFocus,
+                    textCapitalization: TextCapitalization.sentences,
+                    textInputAction: TextInputAction.done,
+                    keyboardType: TextInputType.multiline,
+                    minLines: 10, //Normal textInputField will be displayed
+                    maxLines: 15, // wh
+                    // controller: notesController,
+                    style:
+                        const TextStyle(color: AppColors.black87, fontSize: 14),
+                    decoration: const InputDecoration(
+                      border: InputBorder.none,
+                      hintText: 'Type here',
+                      hintStyle:
+                          TextStyle(fontSize: 14.0, color: AppColors.black60),
+                      contentPadding: EdgeInsets.all(10.0),
+                    ),
+                  ),
+                ),
+                Container(
+                    margin: const EdgeInsets.fromLTRB(20, 10, 20, 15),
+                    child: Text(
+                      'People accopanied you',
+                      style: GoogleFonts.lato(
+                        color: AppColors.black87,
+                        fontWeight: FontWeight.w700,
+                        fontSize: 14,
+                        letterSpacing: 0.25,
+                      ),
+                    )),
+                // Container(
+                //     margin: const EdgeInsets.fromLTRB(20, 0, 20, 20),
+                //     child: Row(children: [
+                //       Container(
+                //           padding: const EdgeInsets.only(right: 10),
+                //           decoration: BoxDecoration(
+                //             color: Colors.white,
+                //             borderRadius: BorderRadius.circular(4),
+                //             border: Border.all(color: AppColors.black16),
+                //           ),
+                //           child: DropdownButton<String>(
+                //             value: _selectedItem,
+                //             icon: const Icon(
+                //               Icons.arrow_drop_down_outlined,
+                //               color: AppColors.black60,
+                //             ),
+                //             iconSize: 20,
+                //             elevation: 16,
+                //             style: const TextStyle(
+                //                 color: AppColors.black60, fontSize: 12),
+                //             underline: Container(),
+                //             selectedItemBuilder: (BuildContext context) {
+                //               return _dropdownItems.map<Widget>((String item) {
+                //                 return Row(
+                //                   children: [
+                //                     Padding(
+                //                         padding: const EdgeInsets.fromLTRB(
+                //                             20.0, 0.0, 20, 0.0),
+                //                         child: Text(
+                //                           item,
+                //                           style: GoogleFonts.lato(
+                //                             color: AppColors.black60,
+                //                             fontSize: 12,
+                //                             fontWeight: FontWeight.w400,
+                //                           ),
+                //                         ))
+                //                   ],
+                //                 );
+                //               }).toList();
+                //             },
+                //             onChanged: (newValue) {
+                //               setState(() {
+                //                 _selectedItem = newValue.toString();
+                //               });
+                //             },
+                //             items: _dropdownItems
+                //                 .map<DropdownMenuItem<String>>((String value) {
+                //               return DropdownMenuItem<String>(
+                //                 value: value,
+                //                 child: Text(value),
+                //               );
+                //             }).toList(),
+                //           )),
+                //       const Spacer(),
+                //       ButtonTheme(
+                //         child: OutlinedButton(
+                //           onPressed: () {
+                //             // Navigator.of(context).pop(false);
+                //           },
+                //           style: OutlinedButton.styleFrom(
+                //             // primary: Colors.white,
+                //             padding: const EdgeInsets.fromLTRB(30, 15, 30, 15),
+                //             side: const BorderSide(
+                //                 width: 1, color: AppColors.primaryBlue),
+                //             shape: RoundedRectangleBorder(
+                //               borderRadius: BorderRadius.circular(4),
+                //             ),
+                //             // onSurface: Colors.grey,
+                //           ),
+                //           child: Text(
+                //             'Add',
+                //             style: GoogleFonts.lato(
+                //                 color: AppColors.primaryBlue,
+                //                 fontSize: 14,
+                //                 fontWeight: FontWeight.w700),
+                //           ),
+                //         ),
+                //       ),
+                //     ])),
+                for (int i = 0; i < 3; i++) const PeopleCard(),
+                const Divider(),
+                Container(
+                  padding: const EdgeInsets.only(left: 10, bottom: 20),
+                  child: Row(
+                    crossAxisAlignment: CrossAxisAlignment.start,
+                    children: <Widget>[
+                      Checkbox(
+                          value: true,
+                          activeColor: AppColors.primaryBlue,
+                          onChanged: (newValue) {
+                            // setState(() {
+                            //   checkBoxValue = newValue;
+                            // });),
+                          }),
+                      Container(
+                          padding: const EdgeInsets.only(top: 10),
+                          width: MediaQuery.of(context).size.width - 120,
+                          child: Text(
+                            'Sunt autem vel illum, qui dolorem aspernari ut calere ignem, nivem esse albam, dulce mel quorum nihil ut ita ruant itaque earum rerum necessitatibus saepe eveniet, ut labore et aperta iudicari ea commodi consequatur? quis autem vel eum iure reprehenderit, qui in liberos atque corrupti.',
+                            style: GoogleFonts.lato(
+                              color: AppColors.black87,
+                              fontSize: 12.0,
+                              letterSpacing: 0.25,
+                              fontWeight: FontWeight.w400,
+                            ),
+                          ))
+                    ],
+                  ),
+                ),
+              ],
+            ),
+          ),
+          Container(
+              margin: const EdgeInsets.only(right: 20, bottom: 20),
+              child: Align(
+                alignment: Alignment.bottomRight,
+                child: TextButton(
+                  onPressed: () {
+                    Navigator.of(context).pushReplacement(MaterialPageRoute(
+                        builder: (context) => const InspectionCompletedPage()));
+                  },
+                  style: TextButton.styleFrom(
+                    // primary: Colors.white,
+                    padding: const EdgeInsets.only(left: 15, right: 15),
+                    backgroundColor: AppColors.primaryBlue,
+                    shape: RoundedRectangleBorder(
+                        borderRadius: BorderRadius.circular(4),
+                        side: const BorderSide(color: AppColors.black16)),
+                  ),
+                  child: Text(
+                    'Submit',
+                    style: GoogleFonts.lato(
+                      color: Colors.white,
+                      fontWeight: FontWeight.w700,
+                      fontSize: 14,
+                    ),
+                  ),
+                ),
+              ))
+        ])));
+  }
+}
diff --git a/lib/pages/login_email_page.dart b/lib/pages/login_email_page.dart
new file mode 100644
index 0000000000000000000000000000000000000000..cb3a6c5022d03365190bd0e5676940185621a27d
--- /dev/null
+++ b/lib/pages/login_email_page.dart
@@ -0,0 +1,252 @@
+import 'package:flutter/material.dart';
+import 'package:flutter/services.dart';
+import 'package:provider/provider.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/pages/login_otp_page.dart';
+import 'package:smf_mobile/repositories/login_repository.dart';
+import 'package:fluttertoast/fluttertoast.dart';
+
+class LoginEmailPage extends StatefulWidget {
+  static const route = AppUrl.loginEmailPage;
+
+  const LoginEmailPage({Key? key}) : super(key: key);
+  @override
+  _LoginEmailPageState createState() => _LoginEmailPageState();
+}
+
+class _LoginEmailPageState extends State<LoginEmailPage> {
+  final TextEditingController _emailController = TextEditingController();
+  final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
+  String _errorMessage = '';
+
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  Future<void> _generateOtp() async {
+    final email = _emailController.text;
+    if (email == '') {
+      Fluttertoast.showToast(
+          msg: 'Please enter email.',
+          // toastLength: Toast.LENGTH_SHORT,
+          gravity: ToastGravity.CENTER,
+          timeInSecForIosWeb: 2,
+          backgroundColor: Colors.red,
+          textColor: Colors.white,
+          fontSize: 16.0);
+      return;
+    }
+    SystemChannels.textInput.invokeMethod('TextInput.hide');
+    try {
+      final responseCode =
+          await Provider.of<LoginRespository>(context, listen: false)
+              .getOtp(email);
+      if (responseCode == 200) {
+        Navigator.of(context).pushReplacement(MaterialPageRoute(
+          builder: (context) => const LoginOtpPage(),
+        ));
+      } else {
+        _errorMessage =
+            Provider.of<LoginRespository>(context, listen: false).errorMessage;
+        Fluttertoast.showToast(
+            msg: _errorMessage,
+            toastLength: Toast.LENGTH_SHORT,
+            gravity: ToastGravity.TOP,
+            timeInSecForIosWeb: 2,
+            backgroundColor: Colors.red,
+            textColor: Colors.white,
+            fontSize: 16.0);
+        // print(_errorMessage);
+      }
+    } catch (err) {
+      throw Exception(err);
+    }
+  }
+
+  @override
+  void dispose() {
+    super.dispose();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+        key: _scaffoldKey,
+        body: SingleChildScrollView(
+          reverse: true,
+          child: SizedBox(
+              width: MediaQuery.of(context).size.width,
+              height: MediaQuery.of(context).size.height,
+              child: Column(
+                children: [
+                  Container(
+                    padding: const EdgeInsets.only(top: 100, bottom: 100),
+                    child: Center(
+                      child: Image.asset(
+                        'assets/images/logo.png',
+                        // width: 50.0,
+                        // height: 50.0,
+                      ),
+                    ),
+                  ),
+                  Container(
+                    padding:
+                        const EdgeInsets.only(left: 40, right: 40, bottom: 40),
+                    margin: const EdgeInsets.only(left: 20, right: 20),
+                    decoration: BoxDecoration(
+                      borderRadius: BorderRadius.circular(4),
+                      color: Colors.white,
+                      boxShadow: const [
+                        BoxShadow(
+                            color: AppColors.black16,
+                            offset: Offset(0, 2),
+                            blurRadius: 2)
+                      ],
+                    ),
+                    child: Column(
+                        crossAxisAlignment: CrossAxisAlignment.start,
+                        children: [
+                          Padding(
+                              padding: const EdgeInsets.only(top: 40),
+                              child: Align(
+                                  alignment: Alignment.center,
+                                  child: Text(
+                                    'Login',
+                                    textAlign: TextAlign.center,
+                                    style: GoogleFonts.lato(
+                                        color: AppColors.black87,
+                                        fontSize: 20,
+                                        letterSpacing:
+                                            0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                        fontWeight: FontWeight.w600,
+                                        height: 1.4),
+                                  ))),
+                          Padding(
+                              padding: const EdgeInsets.only(
+                                top: 50,
+                              ),
+                              child: Text(
+                                'Email Id',
+                                textAlign: TextAlign.left,
+                                style: GoogleFonts.lato(
+                                    color: AppColors.black87,
+                                    fontSize: 16,
+                                    letterSpacing:
+                                        0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                    fontWeight: FontWeight.w400,
+                                    height: 1.4),
+                              )),
+                          Container(
+                            width: double.infinity,
+                            margin: const EdgeInsets.only(
+                              top: 0,
+                            ),
+                            child: Padding(
+                              padding: const EdgeInsets.fromLTRB(0, 5, 0, 30),
+                              child: Column(
+                                crossAxisAlignment: CrossAxisAlignment.start,
+                                children: [
+                                  const SizedBox(height: 10.0),
+                                  Container(
+                                    alignment: Alignment.centerLeft,
+                                    height: 50.0,
+                                    decoration: BoxDecoration(
+                                      borderRadius: BorderRadius.circular(4),
+                                      border:
+                                          Border.all(color: AppColors.black16),
+                                      color: Colors.white,
+                                    ),
+                                    child: Focus(
+                                      child: TextFormField(
+                                        textCapitalization:
+                                            TextCapitalization.none,
+                                        textInputAction: TextInputAction.done,
+                                        controller: _emailController,
+                                        style: GoogleFonts.lato(
+                                            color: AppColors.black40,
+                                            fontSize: 16,
+                                            letterSpacing:
+                                                0 /*percentages not used in flutter. defaulting to zero*/,
+                                            fontWeight: FontWeight.normal,
+                                            height:
+                                                1.5 /*PERCENT not supported*/
+                                            ),
+                                        keyboardType:
+                                            TextInputType.emailAddress,
+                                        decoration: const InputDecoration(
+                                          contentPadding: EdgeInsets.fromLTRB(
+                                              20.0, 0.0, 20.0, 0.0),
+                                          border: InputBorder.none,
+                                          hintText: 'Enter here',
+                                          hintStyle: TextStyle(
+                                              color: AppColors.black40,
+                                              fontSize: 14,
+                                              letterSpacing:
+                                                  0 /*percentages not used in flutter. defaulting to zero*/,
+                                              fontWeight: FontWeight.normal,
+                                              height:
+                                                  1.5 /*PERCENT not supported*/
+                                              ),
+                                          focusedBorder: OutlineInputBorder(
+                                            borderSide: BorderSide(
+                                                color: Colors.transparent,
+                                                width: 2.0),
+                                          ),
+                                        ),
+                                      ),
+                                    ),
+                                  )
+                                ],
+                              ),
+                            ),
+                          ),
+                          Padding(
+                            padding: const EdgeInsets.only(bottom: 80),
+                            child: InkWell(
+                                // ignore: avoid_print
+                                onTap: () => _generateOtp(),
+                                child: SizedBox(
+                                    width:
+                                        MediaQuery.of(context).size.width - 80,
+                                    height: 50,
+                                    child: Stack(children: <Widget>[
+                                      Align(
+                                          alignment: Alignment.bottomCenter,
+                                          child: Container(
+                                              width: MediaQuery.of(context)
+                                                      .size
+                                                      .width -
+                                                  80,
+                                              height: 50,
+                                              decoration: BoxDecoration(
+                                                color: AppColors.primaryBlue,
+                                                borderRadius:
+                                                    BorderRadius.circular(4),
+                                              ))),
+                                      Align(
+                                          alignment: Alignment.center,
+                                          child: Text(
+                                            'GET OTP',
+                                            textAlign: TextAlign.center,
+                                            style: GoogleFonts.lato(
+                                                color: Colors.white,
+                                                fontSize: 17,
+                                                letterSpacing:
+                                                    0 /*percentages not used in flutter. defaulting to zero*/,
+                                                fontWeight: FontWeight.normal,
+                                                height:
+                                                    1.5 /*PERCENT not supported*/
+                                                ),
+                                          )),
+                                    ]))),
+                          ),
+                        ]),
+                  )
+                ],
+              )),
+        ));
+  }
+}
diff --git a/lib/pages/login_otp_page.dart b/lib/pages/login_otp_page.dart
new file mode 100644
index 0000000000000000000000000000000000000000..0580ec67b1ac2f325483f9285ce494cb462f7aed
--- /dev/null
+++ b/lib/pages/login_otp_page.dart
@@ -0,0 +1,264 @@
+import 'package:flutter/material.dart';
+import 'package:provider/provider.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/pages/home_page.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/pages/login_email_page.dart';
+import 'package:otp_text_field/otp_field.dart';
+import 'package:otp_text_field/style.dart';
+import 'package:smf_mobile/repositories/login_repository.dart';
+import 'package:fluttertoast/fluttertoast.dart';
+
+class LoginOtpPage extends StatefulWidget {
+  static const route = AppUrl.loginOtpPage;
+
+  const LoginOtpPage({Key? key}) : super(key: key);
+  @override
+  _LoginOtpPageState createState() => _LoginOtpPageState();
+}
+
+class _LoginOtpPageState extends State<LoginOtpPage> {
+  final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
+  String _errorMessage = '';
+  String _otp = '';
+
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  Future<void> _validateOtp() async {
+    String otp = _otp;
+    // if (otp.length != 6) {
+    //   Fluttertoast.showToast(
+    //       msg: 'Please enter 6 digits.',
+    //       // toastLength: Toast.LENGTH_SHORT,
+    //       gravity: ToastGravity.CENTER,
+    //       timeInSecForIosWeb: 2,
+    //       backgroundColor: Colors.red,
+    //       textColor: Colors.white,
+    //       fontSize: 16.0);
+    //   return;
+    // }
+
+    try {
+      final responseCode =
+          await Provider.of<LoginRespository>(context, listen: false)
+              .validateOtp(otp);
+      if (responseCode == 200) {
+        Navigator.of(context).pushReplacement(MaterialPageRoute(
+          builder: (context) => const HomePage(),
+        ));
+      } else {
+        _errorMessage =
+            Provider.of<LoginRespository>(context, listen: false).errorMessage;
+        Fluttertoast.showToast(
+            msg: _errorMessage,
+            toastLength: Toast.LENGTH_SHORT,
+            gravity: ToastGravity.TOP,
+            timeInSecForIosWeb: 2,
+            backgroundColor: Colors.red,
+            textColor: Colors.white,
+            fontSize: 16.0);
+        // print(_errorMessage);
+      }
+    } catch (err) {
+      throw Exception(err);
+    }
+  }
+
+  @override
+  void dispose() {
+    super.dispose();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+        key: _scaffoldKey,
+        body: SingleChildScrollView(
+          reverse: true,
+          child: SizedBox(
+              width: MediaQuery.of(context).size.width,
+              height: MediaQuery.of(context).size.height,
+              child: Column(
+                children: [
+                  Container(
+                    padding: const EdgeInsets.only(top: 100, bottom: 100),
+                    child: Center(
+                      child: Image.asset(
+                        'assets/images/logo.png',
+                        // width: 50.0,
+                        // height: 50.0,
+                      ),
+                    ),
+                  ),
+                  Container(
+                    padding:
+                        const EdgeInsets.only(left: 40, right: 40, bottom: 40),
+                    margin: const EdgeInsets.only(left: 20, right: 20),
+                    decoration: BoxDecoration(
+                      borderRadius: BorderRadius.circular(4),
+                      color: Colors.white,
+                      boxShadow: const [
+                        BoxShadow(
+                            color: AppColors.black16,
+                            offset: Offset(0, 2),
+                            blurRadius: 2)
+                      ],
+                    ),
+                    child: Column(
+                        crossAxisAlignment: CrossAxisAlignment.start,
+                        children: [
+                          Padding(
+                              padding: const EdgeInsets.only(top: 40),
+                              child: Align(
+                                  alignment: Alignment.center,
+                                  child: Text(
+                                    'Login',
+                                    textAlign: TextAlign.center,
+                                    style: GoogleFonts.lato(
+                                        color: AppColors.black87,
+                                        fontSize: 20,
+                                        letterSpacing:
+                                            0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                        fontWeight: FontWeight.w600,
+                                        height: 1.4),
+                                  ))),
+                          Padding(
+                              padding: const EdgeInsets.only(
+                                top: 50,
+                              ),
+                              child: Text(
+                                'Enter OTP',
+                                textAlign: TextAlign.left,
+                                style: GoogleFonts.lato(
+                                    color: AppColors.black87,
+                                    fontSize: 16,
+                                    letterSpacing:
+                                        0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                    fontWeight: FontWeight.w400,
+                                    height: 1.4),
+                              )),
+                          Container(
+                            width: double.infinity,
+                            margin: const EdgeInsets.only(
+                              top: 0,
+                            ),
+                            child: Padding(
+                              padding: const EdgeInsets.fromLTRB(0, 5, 0, 15),
+                              child: Column(
+                                crossAxisAlignment: CrossAxisAlignment.start,
+                                children: [
+                                  const SizedBox(height: 10.0),
+                                  Container(
+                                    alignment: Alignment.centerLeft,
+                                    height: 40.0,
+                                    margin: const EdgeInsets.only(bottom: 10),
+                                    decoration: BoxDecoration(
+                                      borderRadius: BorderRadius.circular(4),
+                                      // border:
+                                      //     Border.all(color: AppColors.black16),
+                                      color: Colors.white,
+                                    ),
+                                    child: OTPTextField(
+                                      length: 6,
+                                      width: MediaQuery.of(context).size.width,
+                                      fieldWidth: 38,
+                                      style: const TextStyle(fontSize: 14),
+                                      textFieldAlignment:
+                                          MainAxisAlignment.spaceAround,
+                                      fieldStyle: FieldStyle.underline,
+                                      onCompleted: (pin) {
+                                        setState(() {
+                                          _otp = pin;
+                                        });
+                                      },
+                                    ),
+                                  )
+                                ],
+                              ),
+                            ),
+                          ),
+                          Padding(
+                            padding: const EdgeInsets.fromLTRB(0, 0, 0, 30),
+                            child: Text(
+                              'Enter the 6 digit OTP sent to your email address.',
+                              style: GoogleFonts.lato(
+                                  color: AppColors.black60,
+                                  fontSize: 12,
+                                  letterSpacing:
+                                      0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                  fontWeight: FontWeight.w400,
+                                  height: 1.4),
+                            ),
+                          ),
+                          Padding(
+                            padding: const EdgeInsets.only(bottom: 10),
+                            child: InkWell(
+                                // ignore: avoid_print
+                                onTap: () => _validateOtp(),
+                                child: SizedBox(
+                                    width:
+                                        MediaQuery.of(context).size.width - 80,
+                                    height: 50,
+                                    child: Stack(children: <Widget>[
+                                      Align(
+                                          alignment: Alignment.bottomCenter,
+                                          child: Container(
+                                              width: MediaQuery.of(context)
+                                                      .size
+                                                      .width -
+                                                  80,
+                                              height: 50,
+                                              decoration: BoxDecoration(
+                                                color: AppColors.primaryBlue,
+                                                borderRadius:
+                                                    BorderRadius.circular(4),
+                                              ))),
+                                      Align(
+                                          alignment: Alignment.center,
+                                          child: Text(
+                                            'SIGN IN',
+                                            textAlign: TextAlign.center,
+                                            style: GoogleFonts.lato(
+                                                color: Colors.white,
+                                                fontSize: 17,
+                                                letterSpacing:
+                                                    0 /*percentages not used in flutter. defaulting to zero*/,
+                                                fontWeight: FontWeight.normal,
+                                                height:
+                                                    1.5 /*PERCENT not supported*/
+                                                ),
+                                          )),
+                                    ]))),
+                          ),
+                          InkWell(
+                            onTap: () => Navigator.of(context)
+                                .pushReplacement(MaterialPageRoute(
+                              builder: (context) => const LoginEmailPage(),
+                            )),
+                            child: Container(
+                              padding: const EdgeInsets.fromLTRB(0, 10, 0, 10),
+                              width: double.infinity,
+                              child: Text(
+                                'Go back, re-enter the email',
+                                textAlign: TextAlign.center,
+                                style: GoogleFonts.lato(
+                                    color: AppColors.primaryBlue,
+                                    fontSize: 14,
+                                    letterSpacing:
+                                        0.25 /*percentages not used in flutter. defaulting to zero*/,
+                                    fontWeight: FontWeight.w700,
+                                    height: 1.4),
+                              ),
+                            ),
+                          ),
+                        ]),
+                  )
+                ],
+              )),
+        ));
+  }
+}
diff --git a/lib/pages/past_applications.dart b/lib/pages/past_applications.dart
new file mode 100644
index 0000000000000000000000000000000000000000..d4e04cffbc6b2180c7ee3ae8353dbe8502bc58f3
--- /dev/null
+++ b/lib/pages/past_applications.dart
@@ -0,0 +1,62 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/models/application_model.dart';
+import 'package:smf_mobile/widgets/application_card.dart';
+
+class PastApplications extends StatefulWidget {
+  final List<Application> pastApplications;
+  const PastApplications({Key? key, required this.pastApplications})
+      : super(key: key);
+  @override
+  _PastApplicationsState createState() => _PastApplicationsState();
+}
+
+class _PastApplicationsState extends State<PastApplications> {
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return Scaffold(
+        appBar: AppBar(
+          titleSpacing: 10,
+          elevation: 0,
+          backgroundColor: Colors.white,
+          leading: const BackButton(color: AppColors.black60),
+          title: Text(
+            'Past applications',
+            style: GoogleFonts.lato(
+              color: AppColors.black87,
+              fontSize: 16.0,
+              letterSpacing: 0.12,
+              fontWeight: FontWeight.w600,
+            ),
+          ),
+          // centerTitle: true,
+        ),
+        // Tab controller
+        body: SingleChildScrollView(
+            child: Container(
+          padding: const EdgeInsets.all(20),
+          decoration: const BoxDecoration(),
+          child: Column(
+            mainAxisAlignment: MainAxisAlignment.start,
+            crossAxisAlignment: CrossAxisAlignment.start,
+            children: [
+              ListView.builder(
+                shrinkWrap: true,
+                physics: const NeverScrollableScrollPhysics(),
+                itemCount: widget.pastApplications.length,
+                itemBuilder: (context, i) {
+                  return ApplicationCard(
+                      application: widget.pastApplications[i]);
+                },
+              ),
+            ],
+          ),
+        )));
+  }
+}
diff --git a/lib/repositories/application_repository.dart b/lib/repositories/application_repository.dart
new file mode 100644
index 0000000000000000000000000000000000000000..5b7107291e40dab0e6df9dcdc3d5b39093e6bebc
--- /dev/null
+++ b/lib/repositories/application_repository.dart
@@ -0,0 +1,30 @@
+import 'dart:convert';
+import 'package:flutter/widgets.dart';
+import 'package:smf_mobile/models/application_model.dart';
+import 'package:smf_mobile/services/application_service.dart';
+
+class ApplicationRespository with ChangeNotifier {
+  late Map _data;
+  List<Application> _applications = [];
+  String _errorMessage = '';
+
+  Future<dynamic> getApplications() async {
+    try {
+      final request = await ApplicationService.getApplications();
+      _data = json.decode(request.body);
+    } catch (_) {
+      return _;
+    }
+
+    if (_data['statusInfo']['statusCode'] != 200) {
+      _errorMessage = _data['statusInfo']['errorMessage'];
+    } else {
+      _applications = [
+        for (final item in _data['responseData']) Application.fromJson(item)
+      ];
+    }
+    return _applications;
+  }
+
+  String get errorMessage => _errorMessage;
+}
diff --git a/lib/repositories/login_repository.dart b/lib/repositories/login_repository.dart
new file mode 100644
index 0000000000000000000000000000000000000000..b98c877418006daa041cc380b89c25120231a709
--- /dev/null
+++ b/lib/repositories/login_repository.dart
@@ -0,0 +1,57 @@
+import 'dart:convert';
+import 'package:flutter/widgets.dart';
+import 'package:smf_mobile/models/login_model.dart';
+import 'package:flutter_secure_storage/flutter_secure_storage.dart';
+import 'package:smf_mobile/services/login_service.dart';
+
+class LoginRespository with ChangeNotifier {
+  late Map _data;
+  late Login _loginDetails;
+  String _errorMessage = '';
+
+  final _storage = const FlutterSecureStorage();
+
+  Future<dynamic> getOtp(String username) async {
+    try {
+      final request = await LoginService.getOtp(username);
+      _data = json.decode(request.body);
+    } catch (_) {
+      return _;
+    }
+
+    if (_data['statusInfo']['statusCode'] != 200) {
+      _errorMessage = _data['statusInfo']['errorMessage'];
+    } else {
+      _storage.write(key: 'username', value: username);
+    }
+    return _data['statusInfo']['statusCode'];
+  }
+
+  Future<dynamic> validateOtp(String otp) async {
+    try {
+      final username = await _storage.read(key: 'username');
+      final request = await LoginService.validateOtp(username!, otp);
+      _data = json.decode(request.body);
+    } catch (_) {
+      return _;
+    }
+    if (_data['statusInfo']['statusCode'] != 200) {
+      _errorMessage = _data['statusInfo']['errorMessage'];
+    } else {
+      _loginDetails = Login.fromJson(_data['responseData']);
+      _storage.write(key: 'id', value: '${_loginDetails.id}');
+      _storage.write(key: 'username', value: _loginDetails.username);
+      _storage.write(key: 'email', value: _loginDetails.email);
+      _storage.write(key: 'firstName', value: _loginDetails.firstName);
+      _storage.write(key: 'lastName', value: _loginDetails.lastName);
+      _storage.write(key: 'authToken', value: _loginDetails.authToken);
+    }
+    return _data['statusInfo']['statusCode'];
+  }
+
+  Future<void> clearData() async {
+    await _storage.deleteAll();
+  }
+
+  String get errorMessage => _errorMessage;
+}
diff --git a/lib/routes.dart b/lib/routes.dart
new file mode 100644
index 0000000000000000000000000000000000000000..3e49c95529b5b9e6bf2f8b105b1420885884447b
--- /dev/null
+++ b/lib/routes.dart
@@ -0,0 +1,41 @@
+import 'package:flutter/material.dart';
+import 'package:smf_mobile/pages/error_page.dart';
+import 'package:smf_mobile/pages/home_page.dart';
+import 'package:smf_mobile/pages/login_email_page.dart';
+import 'package:smf_mobile/pages/login_otp_page.dart';
+import 'constants/app_urls.dart';
+
+class Routes {
+  static Route<dynamic> generateRoute(RouteSettings routeSettings) {
+    try {
+      // final Map<String, dynamic> args = routeSettings.arguments;
+
+      switch (routeSettings.name) {
+        // case AppUrl.loginPage:
+        //   return MaterialPageRoute(
+        //       settings: routeSettings, builder: (_) => Login());
+        case AppUrl.loginEmailPage:
+          return MaterialPageRoute(
+              settings: routeSettings, builder: (_) => const LoginEmailPage());
+
+        case AppUrl.loginOtpPage:
+          return MaterialPageRoute(
+              settings: routeSettings, builder: (_) => const LoginOtpPage());
+
+        case AppUrl.homePage:
+          return MaterialPageRoute(
+              settings: routeSettings, builder: (_) => const HomePage());
+
+        default:
+          return errorRoute(routeSettings);
+      }
+    } catch (_) {
+      return errorRoute(routeSettings);
+    }
+  }
+
+  static Route<dynamic> errorRoute(RouteSettings routeSettings) {
+    return MaterialPageRoute(
+        settings: routeSettings, builder: (_) => const ErrorPage());
+  }
+}
diff --git a/lib/services/application_service.dart b/lib/services/application_service.dart
new file mode 100644
index 0000000000000000000000000000000000000000..18f185422661fbb476008ff607761b1e523ddc84
--- /dev/null
+++ b/lib/services/application_service.dart
@@ -0,0 +1,23 @@
+import 'dart:convert';
+import 'dart:io';
+import 'package:http/http.dart' as http;
+import 'package:smf_mobile/constants/api_endpoints.dart';
+import 'package:smf_mobile/services/base_service.dart';
+import 'package:flutter_secure_storage/flutter_secure_storage.dart';
+// import 'dart:developer' as developer;
+
+class ApplicationService extends BaseService {
+  ApplicationService(HttpClient client) : super(client);
+
+  static Future<dynamic> getApplications() async {
+    Map requestData = {'searchObjects': []};
+    var body = json.encode(requestData);
+    Map<String, String> headers = BaseService.defaultHeaders;
+    const _storage = FlutterSecureStorage();
+    var authToken = await _storage.read(key: 'authToken');
+    headers['Authorization'] = '$authToken';
+    final response = await http.post(Uri.parse(ApiUrl.getAllApplications),
+        headers: BaseService.defaultHeaders, body: body);
+    return response;
+  }
+}
diff --git a/lib/services/base_service.dart b/lib/services/base_service.dart
new file mode 100644
index 0000000000000000000000000000000000000000..a4cbce9eed8ba1a8c02c8ee9f93256d9569b9f94
--- /dev/null
+++ b/lib/services/base_service.dart
@@ -0,0 +1,10 @@
+import 'dart:io';
+
+abstract class BaseService {
+  final HttpClient client;
+  static Map<String, String> defaultHeaders = {
+    'Accept': 'application/json',
+    'Content-Type': 'application/json; charset=utf-8',
+  };
+  const BaseService(this.client);
+}
diff --git a/lib/services/login_service.dart b/lib/services/login_service.dart
new file mode 100644
index 0000000000000000000000000000000000000000..733b6c862150ff1b138a932151b60c8022d39aad
--- /dev/null
+++ b/lib/services/login_service.dart
@@ -0,0 +1,28 @@
+import 'dart:convert';
+import 'dart:io';
+import 'package:http/http.dart' as http;
+import 'package:smf_mobile/constants/api_endpoints.dart';
+import 'package:smf_mobile/services/base_service.dart';
+// import 'dart:developer' as developer;
+
+class LoginService extends BaseService {
+  LoginService(HttpClient client) : super(client);
+
+  static Future<dynamic> getOtp(String username) async {
+    Map requestData = {
+      'username': username,
+    };
+    var body = json.encode(requestData);
+    final response = await http.post(Uri.parse(ApiUrl.getOtp),
+        headers: BaseService.defaultHeaders, body: body);
+    return response;
+  }
+
+  static Future<dynamic> validateOtp(String username, String otp) async {
+    Map requestData = {'username': username, 'otp': otp};
+    var body = json.encode(requestData);
+    final response = await http.post(Uri.parse(ApiUrl.validateOtp),
+        headers: BaseService.defaultHeaders, body: body);
+    return response;
+  }
+}
diff --git a/lib/widgets/application_card.dart b/lib/widgets/application_card.dart
new file mode 100644
index 0000000000000000000000000000000000000000..9a854b64f47d048f8813d301056d4f93f1f6fd17
--- /dev/null
+++ b/lib/widgets/application_card.dart
@@ -0,0 +1,81 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/app_urls.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+import 'package:smf_mobile/models/application_model.dart';
+import 'package:smf_mobile/pages/application_details_page.dart';
+
+class ApplicationCard extends StatefulWidget {
+  static const route = AppUrl.homePage;
+  final Application application;
+
+  const ApplicationCard({Key? key, required this.application})
+      : super(key: key);
+  @override
+  _ApplicationCardState createState() => _ApplicationCardState();
+}
+
+class _ApplicationCardState extends State<ApplicationCard> {
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    return InkWell(
+        onTap: () => Navigator.push(
+              context,
+              MaterialPageRoute(
+                  builder: (context) => const ApplicationDetailsPage()),
+            ),
+        child: Container(
+          width: double.infinity,
+          margin: const EdgeInsets.only(bottom: 10),
+          padding: const EdgeInsets.all(20),
+          decoration: BoxDecoration(
+            borderRadius: BorderRadius.circular(4),
+            color: Colors.white,
+            boxShadow: const [
+              BoxShadow(
+                  color: AppColors.black16, offset: Offset(0, 2), blurRadius: 2)
+            ],
+          ),
+          child: Column(
+            crossAxisAlignment: CrossAxisAlignment.start,
+            children: [
+              Padding(
+                padding: const EdgeInsets.only(bottom: 10),
+                child: Text(widget.application.title,
+                    style: GoogleFonts.lato(
+                      color: AppColors.black87,
+                      fontSize: 16.0,
+                      letterSpacing: 0.12,
+                      fontWeight: FontWeight.w600,
+                    )),
+              ),
+              Padding(
+                padding: const EdgeInsets.only(bottom: 10),
+                child: Text(widget.application.createdBy,
+                    style: GoogleFonts.lato(
+                      color: AppColors.black60,
+                      fontSize: 14.0,
+                      letterSpacing: 0.12,
+                      fontWeight: FontWeight.w700,
+                    )),
+              ),
+              Padding(
+                padding: const EdgeInsets.only(bottom: 10),
+                child: Text('Scheduled on: ${widget.application.createdDate}',
+                    style: GoogleFonts.lato(
+                      color: AppColors.black60,
+                      fontSize: 14.0,
+                      letterSpacing: 0.12,
+                      fontWeight: FontWeight.w400,
+                    )),
+              )
+            ],
+          ),
+        ));
+  }
+}
diff --git a/lib/widgets/application_field.dart b/lib/widgets/application_field.dart
new file mode 100644
index 0000000000000000000000000000000000000000..ce3777c04e159249184d99f50f623404ff947dfc
--- /dev/null
+++ b/lib/widgets/application_field.dart
@@ -0,0 +1,326 @@
+// ignore_for_file: unnecessary_const
+
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+// import './../../constants.dart';
+
+class ApplicationField extends StatefulWidget {
+  const ApplicationField({
+    Key? key,
+  }) : super(key: key);
+  @override
+  _ApplicationFieldState createState() => _ApplicationFieldState();
+}
+
+class _ApplicationFieldState extends State<ApplicationField> {
+  String _radioValue = 'Correct';
+  final List<String> _options = ['Correct', 'Incorrect'];
+
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  Future _displayCommentDialog() {
+    return showDialog(
+        context: context,
+        builder: (context) => StatefulBuilder(builder: (context, setState) {
+              return Stack(
+                children: [
+                  Align(
+                    alignment: FractionalOffset.center,
+                    child: Container(
+                        decoration: BoxDecoration(
+                            color: Colors.white,
+                            borderRadius: BorderRadius.circular(4)),
+                        height: 330,
+                        width: MediaQuery.of(context).size.width - 40,
+                        child: Padding(
+                          padding: const EdgeInsets.all(20),
+                          child: Column(
+                            crossAxisAlignment: CrossAxisAlignment.start,
+                            children: [
+                              Padding(
+                                  padding: const EdgeInsets.all(0),
+                                  child: Text(
+                                    'Enter the reason for the incorrect selection',
+                                    style: GoogleFonts.lato(
+                                      color: AppColors.black87,
+                                      fontWeight: FontWeight.w700,
+                                      fontSize: 14,
+                                      letterSpacing: 0.25,
+                                    ),
+                                  )),
+                              Container(
+                                margin: const EdgeInsets.only(top: 15),
+                                decoration: BoxDecoration(
+                                  borderRadius: BorderRadius.circular(4),
+                                  border: Border.all(color: AppColors.black16),
+                                ),
+                                child: Material(
+                                  color: Colors.white,
+                                  borderRadius: BorderRadius.circular(8),
+                                  child: Focus(
+                                    child: TextFormField(
+                                      // autofocus: true,
+                                      // focusNode: _notesFocus,
+                                      textCapitalization:
+                                          TextCapitalization.sentences,
+                                      textInputAction: TextInputAction.done,
+                                      keyboardType: TextInputType.multiline,
+                                      minLines:
+                                          10, //Normal textInputField will be displayed
+                                      maxLines: 15, // wh
+                                      // controller: notesController,
+                                      style: const TextStyle(
+                                          color: AppColors.black87,
+                                          fontSize: 14),
+                                      decoration: const InputDecoration(
+                                        border: InputBorder.none,
+                                        hintText: 'Type here',
+                                        hintStyle: TextStyle(
+                                            fontSize: 14.0,
+                                            color: AppColors.black60),
+                                        contentPadding: EdgeInsets.all(10.0),
+                                      ),
+                                    ),
+                                  ),
+                                ),
+                              ),
+                              Container(
+                                  margin: const EdgeInsets.only(top: 15),
+                                  child: Row(
+                                    mainAxisAlignment: MainAxisAlignment.end,
+                                    children: [
+                                      ButtonTheme(
+                                        child: OutlinedButton(
+                                          onPressed: () {
+                                            Navigator.of(context).pop(false);
+                                          },
+                                          style: OutlinedButton.styleFrom(
+                                            // primary: Colors.white,
+                                            side: const BorderSide(
+                                                width: 1,
+                                                color: AppColors.primaryBlue),
+                                            shape: RoundedRectangleBorder(
+                                              borderRadius:
+                                                  BorderRadius.circular(4),
+                                            ),
+                                            // onSurface: Colors.grey,
+                                          ),
+                                          child: Text(
+                                            'Cancel',
+                                            style: GoogleFonts.lato(
+                                                color: AppColors.primaryBlue,
+                                                fontSize: 14,
+                                                fontWeight: FontWeight.w700),
+                                          ),
+                                        ),
+                                      ),
+                                      Padding(
+                                        padding:
+                                            const EdgeInsets.only(left: 10),
+                                        child: TextButton(
+                                          onPressed: () {
+                                            Navigator.of(context).pop(false);
+                                          },
+                                          style: TextButton.styleFrom(
+                                            // primary: Colors.white,
+                                            padding: const EdgeInsets.only(
+                                                left: 15, right: 15),
+                                            backgroundColor:
+                                                AppColors.primaryBlue,
+                                            shape: RoundedRectangleBorder(
+                                                borderRadius:
+                                                    BorderRadius.circular(4),
+                                                side: const BorderSide(
+                                                    color: AppColors.black16)),
+                                          ),
+                                          child: Text(
+                                            'Submit',
+                                            style: GoogleFonts.lato(
+                                              color: Colors.white,
+                                              fontWeight: FontWeight.w700,
+                                              fontSize: 14,
+                                            ),
+                                          ),
+                                        ),
+                                      )
+                                    ],
+                                  ))
+                            ],
+                          ),
+                        )),
+                  ),
+                ],
+              );
+            }));
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    // setState(() {
+    //   _radioValue = widget.answerGiven;
+    // });
+    return SingleChildScrollView(
+        reverse: true,
+        child: Container(
+            margin: const EdgeInsets.fromLTRB(20, 0, 20, 20),
+            child: Column(
+                mainAxisAlignment: MainAxisAlignment.start,
+                crossAxisAlignment: CrossAxisAlignment.start,
+                children: [
+                  Container(
+                    width: double.infinity,
+                    padding: const EdgeInsets.all(20),
+                    decoration: const BoxDecoration(
+                      borderRadius: BorderRadius.only(
+                          topLeft: Radius.circular(4),
+                          topRight: Radius.circular(4)),
+                      color: Colors.white,
+                      boxShadow: [
+                        BoxShadow(
+                            color: AppColors.black16,
+                            offset: Offset(0, 2),
+                            blurRadius: 2)
+                      ],
+                    ),
+                    child: Column(
+                      mainAxisAlignment: MainAxisAlignment.start,
+                      crossAxisAlignment: CrossAxisAlignment.start,
+                      children: [
+                        Padding(
+                          padding: const EdgeInsets.only(top: 5),
+                          child: Text(
+                            'Lorem ipsum dolar sit amet',
+                            style: GoogleFonts.lato(
+                              color: AppColors.black87,
+                              fontSize: 14.0,
+                              letterSpacing: 0.25,
+                              fontWeight: FontWeight.w700,
+                            ),
+                          ),
+                        ),
+                        Container(
+                          margin: const EdgeInsets.only(top: 10),
+                          padding: const EdgeInsets.fromLTRB(15, 10, 15, 10),
+                          width: double.infinity,
+                          decoration: BoxDecoration(
+                            border: Border.all(color: AppColors.black16),
+                          ),
+                          child: Text(
+                            'Lorem ipsum dolar sit amet',
+                            style: GoogleFonts.lato(
+                              color: AppColors.black87,
+                              fontSize: 14.0,
+                              letterSpacing: 0.25,
+                              fontWeight: FontWeight.w400,
+                            ),
+                          ),
+                        )
+                      ],
+                    ),
+                  ),
+                  Container(
+                      width: double.infinity,
+                      padding: const EdgeInsets.all(20),
+                      decoration: const BoxDecoration(
+                        borderRadius: BorderRadius.only(
+                            bottomLeft: Radius.circular(4),
+                            bottomRight: Radius.circular(4)),
+                        color: AppColors.black08,
+                        boxShadow: [
+                          BoxShadow(
+                              color: AppColors.black16,
+                              offset: Offset(0, 1),
+                              blurRadius: 1)
+                        ],
+                      ),
+                      child: SizedBox(
+                          width: double.infinity,
+                          child: Column(
+                            crossAxisAlignment: CrossAxisAlignment.start,
+                            children: [
+                              Container(
+                                  width: MediaQuery.of(context).size.width,
+                                  padding: const EdgeInsets.only(bottom: 10),
+                                  child: Text(
+                                    'Is the given information found correct?',
+                                    style: GoogleFonts.lato(
+                                      color: AppColors.black60,
+                                      fontWeight: FontWeight.w700,
+                                      fontSize: 14.0,
+                                      letterSpacing: 0.25,
+                                    ),
+                                  )),
+                              Container(
+                                  width: MediaQuery.of(context).size.width,
+                                  margin: const EdgeInsets.only(bottom: 0),
+                                  child: Row(
+                                    // alignment: MainAxisAlignment.start,
+                                    children: <Widget>[
+                                      for (int i = 0; i < _options.length; i++)
+                                        Container(
+                                            padding: const EdgeInsets.only(
+                                                right: 15),
+                                            margin: const EdgeInsets.only(
+                                                right: 15),
+                                            decoration: BoxDecoration(
+                                              color: _radioValue == _options[i]
+                                                  ? AppColors.radioSelected
+                                                  : Colors.transparent,
+                                              borderRadius:
+                                                  const BorderRadius.all(
+                                                      Radius.circular(4.0)),
+                                              border: Border.all(
+                                                color:
+                                                    _radioValue == _options[i]
+                                                        ? AppColors.primaryBlue
+                                                        : AppColors.black16,
+                                              ),
+                                            ),
+                                            child: Row(children: [
+                                              Radio(
+                                                value: _options[i],
+                                                groupValue: _radioValue,
+                                                activeColor:
+                                                    AppColors.primaryBlue,
+                                                materialTapTargetSize:
+                                                    MaterialTapTargetSize
+                                                        .shrinkWrap,
+                                                onChanged: (val) {
+                                                  setState(() {
+                                                    _radioValue = _options[i];
+                                                  });
+                                                },
+                                              ),
+                                              Text(
+                                                _options[i],
+                                                style: GoogleFonts.lato(
+                                                  color: AppColors.black87,
+                                                  fontWeight: FontWeight.w400,
+                                                  fontSize: 14.0,
+                                                  letterSpacing: 0.25,
+                                                ),
+                                              ),
+                                            ])),
+                                      const Spacer(),
+                                      Padding(
+                                        padding: const EdgeInsets.only(left: 0),
+                                        child: IconButton(
+                                          onPressed: () =>
+                                              _displayCommentDialog(),
+                                          icon: const Icon(
+                                            Icons.message,
+                                            color: AppColors.black40,
+                                          ),
+                                        ),
+                                      )
+                                    ],
+                                  )),
+                            ],
+                          )))
+                ])));
+  }
+}
diff --git a/lib/widgets/people_card.dart b/lib/widgets/people_card.dart
new file mode 100644
index 0000000000000000000000000000000000000000..e29922cf5c2d3abb32869b9e0f4dbf6b8e039cff
--- /dev/null
+++ b/lib/widgets/people_card.dart
@@ -0,0 +1,76 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+
+class PeopleCard extends StatelessWidget {
+  const PeopleCard({Key? key}) : super(key: key);
+
+  @override
+  Widget build(BuildContext context) {
+    return Container(
+      color: Colors.white,
+      // width: double.infinity,
+      margin: const EdgeInsets.only(left: 20, right: 20, bottom: 10.0),
+      child: Row(
+        mainAxisAlignment: MainAxisAlignment.spaceBetween,
+        children: [
+          Container(
+            width: MediaQuery.of(context).size.width - 80,
+            decoration: BoxDecoration(
+              color: AppColors.black08,
+              borderRadius: BorderRadius.circular(4),
+              // border: Border.all(color: AppColors.black08),
+            ),
+            child: Row(
+              mainAxisAlignment: MainAxisAlignment.start,
+              children: [
+                Padding(
+                  padding: const EdgeInsets.all(15.0),
+                  child: Container(
+                    height: 48,
+                    width: 48,
+                    decoration: const BoxDecoration(
+                      color: AppColors.primaryGreen,
+                      borderRadius: BorderRadius.all(Radius.circular(4.0)),
+                    ),
+                    child: Center(
+                      child: Text('SM',
+                          style: GoogleFonts.lato(color: Colors.white)),
+                    ),
+                  ),
+                ),
+                Row(
+                  mainAxisAlignment: MainAxisAlignment.end,
+                  children: [
+                    Column(
+                      crossAxisAlignment: CrossAxisAlignment.start,
+                      children: [
+                        Text(
+                          'Shoaib Muhammed',
+                          style: GoogleFonts.lato(
+                              color: AppColors.black87,
+                              fontSize: 14.0,
+                              fontWeight: FontWeight.w700),
+                        ),
+                        Padding(
+                          padding: const EdgeInsets.only(top: 10.0),
+                          child: Text(
+                            'Designation',
+                            style: GoogleFonts.lato(
+                                color: AppColors.black60,
+                                fontSize: 14.0,
+                                fontWeight: FontWeight.w400),
+                          ),
+                        ),
+                      ],
+                    ),
+                  ],
+                ),
+              ],
+            ),
+          ),
+        ],
+      ),
+    );
+  }
+}
diff --git a/lib/widgets/radio_question.dart b/lib/widgets/radio_question.dart
new file mode 100644
index 0000000000000000000000000000000000000000..50e59f056c4981e9d9c4df4e0e3ddd9f635f7c56
--- /dev/null
+++ b/lib/widgets/radio_question.dart
@@ -0,0 +1,143 @@
+import 'package:flutter/material.dart';
+import 'package:google_fonts/google_fonts.dart';
+import 'package:smf_mobile/constants/color_constants.dart';
+// import './../../constants.dart';
+
+class RadioQuestion extends StatefulWidget {
+  final String question;
+  final int currentIndex;
+  final String answerGiven;
+  const RadioQuestion({
+    Key? key,
+    required this.question,
+    required this.currentIndex,
+    required this.answerGiven,
+  }) : super(key: key);
+  @override
+  _RadioQuestionState createState() => _RadioQuestionState();
+}
+
+class _RadioQuestionState extends State<RadioQuestion> {
+  int _radioValue = 0;
+  final List<String> _options = ['Correct', 'Incorrect'];
+
+  @override
+  void initState() {
+    super.initState();
+  }
+
+  @override
+  Widget build(BuildContext context) {
+    // setState(() {
+    //   _radioValue = widget.answerGiven;
+    // });
+    return Column(
+      crossAxisAlignment: CrossAxisAlignment.start,
+      children: [
+        Container(
+            width: MediaQuery.of(context).size.width,
+            padding: const EdgeInsets.only(bottom: 10),
+            child: Text(
+              widget.question,
+              style: GoogleFonts.lato(
+                color: AppColors.black60,
+                fontWeight: FontWeight.w700,
+                fontSize: 14.0,
+                letterSpacing: 0.25,
+              ),
+            )),
+        Container(
+            width: MediaQuery.of(context).size.width,
+            margin: const EdgeInsets.only(bottom: 0),
+            child: Row(
+              // alignment: MainAxisAlignment.start,
+              children: <Widget>[
+                Container(
+                    padding: const EdgeInsets.only(right: 15),
+                    margin: const EdgeInsets.only(right: 15),
+                    decoration: BoxDecoration(
+                      color: _radioValue == 1
+                          ? AppColors.radioSelected
+                          : Colors.transparent,
+                      borderRadius:
+                          const BorderRadius.all(Radius.circular(4.0)),
+                      border: Border.all(
+                        color: _radioValue == 1
+                            ? AppColors.primaryBlue
+                            : AppColors.black16,
+                      ),
+                    ),
+                    child: Row(children: [
+                      Radio(
+                        value: 1,
+                        groupValue: _radioValue,
+                        activeColor: AppColors.primaryBlue,
+                        materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
+                        onChanged: (val) {
+                          setState(() {
+                            _radioValue = 1;
+                          });
+                        },
+                      ),
+                      Text(
+                        'Correct',
+                        style: GoogleFonts.lato(
+                          color: AppColors.black87,
+                          fontWeight: FontWeight.w400,
+                          fontSize: 14.0,
+                          letterSpacing: 0.25,
+                        ),
+                      ),
+                    ])),
+                Container(
+                    padding: const EdgeInsets.only(right: 15),
+                    decoration: BoxDecoration(
+                        color: _radioValue == 0
+                            ? AppColors.radioSelected
+                            : Colors.transparent,
+                        borderRadius:
+                            const BorderRadius.all(Radius.circular(4.0)),
+                        border: Border.all(
+                          color: _radioValue == 0
+                              ? AppColors.primaryBlue
+                              : AppColors.black16,
+                        )),
+                    child: Row(children: [
+                      Radio(
+                        value: 0,
+                        groupValue: _radioValue,
+                        activeColor: AppColors.primaryBlue,
+                        materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
+                        onChanged: (val) {
+                          setState(() {
+                            _radioValue = 0;
+                          });
+                        },
+                      ),
+                      Text(
+                        'Incorrect',
+                        style: GoogleFonts.lato(
+                          color: AppColors.black87,
+                          fontWeight: FontWeight.w400,
+                          fontSize: 14.0,
+                          letterSpacing: 0.25,
+                        ),
+                      ),
+                    ])),
+                const Spacer(),
+                Padding(
+                  padding: const EdgeInsets.only(left: 0),
+                  child: IconButton(
+                    onPressed: () => print('hello'),
+                    icon: const Icon(
+                      Icons.message,
+                      color: AppColors.black40,
+                    ),
+                  ),
+                )
+              ],
+            )),
+      ],
+    );
+  }
+}
diff --git a/lib/widgets/silverappbar_delegate.dart b/lib/widgets/silverappbar_delegate.dart
new file mode 100644
index 0000000000000000000000000000000000000000..78db253dbd960dd402451017da506a8235fbae38
--- /dev/null
+++ b/lib/widgets/silverappbar_delegate.dart
@@ -0,0 +1,35 @@
+import 'package:flutter/material.dart';
+
+class SilverAppBarDelegate extends SliverPersistentHeaderDelegate {
+  SilverAppBarDelegate(this._tabBar);
+
+  final TabBar _tabBar;
+
+  @override
+  double get minExtent => _tabBar.preferredSize.height;
+  @override
+  double get maxExtent => _tabBar.preferredSize.height;
+
+  @override
+  Widget build(
+      BuildContext context, double shrinkOffset, bool overlapsContent) {
+    return Container(
+        child: _tabBar,
+        decoration: const BoxDecoration(color: Colors.white, boxShadow: [
+          BoxShadow(
+            color: Color.fromRGBO(0, 0, 0, 0.1),
+            blurRadius: 6.0,
+            spreadRadius: 0,
+            offset: Offset(
+              3,
+              3,
+            ),
+          ),
+        ]));
+  }
+
+  @override
+  bool shouldRebuild(SilverAppBarDelegate oldDelegate) {
+    return false;
+  }
+}
diff --git a/pubspec.lock b/pubspec.lock
index 24f9d15520938169e25e17668c2381e32f5fd856..38a6f9cef0895be3a2df6257e8b166eaf5d33dd3 100644
--- a/pubspec.lock
+++ b/pubspec.lock
@@ -1,6 +1,20 @@
 # Generated by pub
 # See https://dart.dev/tools/pub/glossary#lockfile
 packages:
+  archive:
+    dependency: transitive
+    description:
+      name: archive
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "3.1.11"
+  args:
+    dependency: transitive
+    description:
+      name: args
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.3.0"
   async:
     dependency: transitive
     description:
@@ -8,6 +22,13 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "2.8.2"
+  big_tip:
+    dependency: "direct main"
+    description:
+      name: big_tip
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.0"
   boolean_selector:
     dependency: transitive
     description:
@@ -43,6 +64,13 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "1.15.0"
+  crypto:
+    dependency: transitive
+    description:
+      name: crypto
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "3.0.1"
   cupertino_icons:
     dependency: "direct main"
     description:
@@ -57,11 +85,32 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "1.2.0"
+  ffi:
+    dependency: transitive
+    description:
+      name: ffi
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.1.2"
+  file:
+    dependency: transitive
+    description:
+      name: file
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "6.1.2"
   flutter:
     dependency: "direct main"
     description: flutter
     source: sdk
     version: "0.0.0"
+  flutter_launcher_icons:
+    dependency: "direct main"
+    description:
+      name: flutter_launcher_icons
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "0.9.2"
   flutter_lints:
     dependency: "direct dev"
     description:
@@ -69,11 +118,100 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "1.0.4"
+  flutter_secure_storage:
+    dependency: "direct main"
+    description:
+      name: flutter_secure_storage
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "5.0.2"
+  flutter_secure_storage_linux:
+    dependency: transitive
+    description:
+      name: flutter_secure_storage_linux
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.1.0"
+  flutter_secure_storage_macos:
+    dependency: transitive
+    description:
+      name: flutter_secure_storage_macos
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.1.0"
+  flutter_secure_storage_platform_interface:
+    dependency: transitive
+    description:
+      name: flutter_secure_storage_platform_interface
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.0.0"
+  flutter_secure_storage_web:
+    dependency: transitive
+    description:
+      name: flutter_secure_storage_web
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.0.2"
+  flutter_secure_storage_windows:
+    dependency: transitive
+    description:
+      name: flutter_secure_storage_windows
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.1.2"
   flutter_test:
     dependency: "direct dev"
     description: flutter
     source: sdk
     version: "0.0.0"
+  flutter_web_plugins:
+    dependency: transitive
+    description: flutter
+    source: sdk
+    version: "0.0.0"
+  fluttertoast:
+    dependency: "direct main"
+    description:
+      name: fluttertoast
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "8.0.8"
+  google_fonts:
+    dependency: "direct main"
+    description:
+      name: google_fonts
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.3.1"
+  http:
+    dependency: transitive
+    description:
+      name: http
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "0.13.4"
+  http_parser:
+    dependency: transitive
+    description:
+      name: http_parser
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "4.0.0"
+  image:
+    dependency: transitive
+    description:
+      name: image
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "3.1.1"
+  js:
+    dependency: transitive
+    description:
+      name: js
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "0.6.3"
   lints:
     dependency: transitive
     description:
@@ -102,6 +240,20 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "1.7.0"
+  nested:
+    dependency: transitive
+    description:
+      name: nested
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.0.0"
+  otp_text_field:
+    dependency: "direct main"
+    description:
+      name: otp_text_field
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "1.1.2"
   path:
     dependency: transitive
     description:
@@ -109,6 +261,90 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "1.8.0"
+  path_provider:
+    dependency: transitive
+    description:
+      name: path_provider
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.8"
+  path_provider_android:
+    dependency: transitive
+    description:
+      name: path_provider_android
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.11"
+  path_provider_ios:
+    dependency: transitive
+    description:
+      name: path_provider_ios
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.7"
+  path_provider_linux:
+    dependency: transitive
+    description:
+      name: path_provider_linux
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.1.5"
+  path_provider_macos:
+    dependency: transitive
+    description:
+      name: path_provider_macos
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.5"
+  path_provider_platform_interface:
+    dependency: transitive
+    description:
+      name: path_provider_platform_interface
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.3"
+  path_provider_windows:
+    dependency: transitive
+    description:
+      name: path_provider_windows
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.0.5"
+  petitparser:
+    dependency: transitive
+    description:
+      name: petitparser
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "4.4.0"
+  platform:
+    dependency: transitive
+    description:
+      name: platform
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "3.1.0"
+  plugin_platform_interface:
+    dependency: transitive
+    description:
+      name: plugin_platform_interface
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.1.2"
+  process:
+    dependency: transitive
+    description:
+      name: process
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "4.2.4"
+  provider:
+    dependency: "direct main"
+    description:
+      name: provider
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "6.0.2"
   sky_engine:
     dependency: transitive
     description: flutter
@@ -170,5 +406,34 @@ packages:
       url: "https://pub.dartlang.org"
     source: hosted
     version: "2.1.1"
+  win32:
+    dependency: transitive
+    description:
+      name: win32
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "2.3.11"
+  xdg_directories:
+    dependency: transitive
+    description:
+      name: xdg_directories
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "0.2.0+1"
+  xml:
+    dependency: transitive
+    description:
+      name: xml
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "5.3.1"
+  yaml:
+    dependency: transitive
+    description:
+      name: yaml
+      url: "https://pub.dartlang.org"
+    source: hosted
+    version: "3.1.0"
 sdks:
   dart: ">=2.16.0 <3.0.0"
+  flutter: ">=2.10.0-0"
diff --git a/pubspec.yaml b/pubspec.yaml
index 64c9abd3220e06384c49258a9bc1fb9af7e2a94f..b1c47b1026048c87edc7578494dc3cfee9bfbd60 100644
--- a/pubspec.yaml
+++ b/pubspec.yaml
@@ -34,6 +34,13 @@ dependencies:
   # The following adds the Cupertino Icons font to your application.
   # Use with the CupertinoIcons class for iOS style icons.
   cupertino_icons: ^1.0.2
+  big_tip: ^2.0.0
+  google_fonts: ^2.3.1
+  otp_text_field: ^1.1.2
+  flutter_launcher_icons: ^0.9.2
+  flutter_secure_storage: ^5.0.2
+  provider: ^6.0.2
+  fluttertoast: ^8.0.8
 
 dev_dependencies:
   flutter_test:
@@ -58,9 +65,14 @@ flutter:
   uses-material-design: true
 
   # To add assets to your application, add an assets section, like this:
-  # assets:
-  #   - images/a_dot_burr.jpeg
-  #   - images/a_dot_ham.jpeg
+  assets:
+    - assets/images/
+
+flutter_icons:
+  ios: true
+  android: true
+  image_path_ios: "assets/launcher/icon.png"
+  image_path_android: "assets/launcher/icon.png"
 
   # An image asset can refer to one or more resolution-specific "variants", see
   # https://flutter.dev/assets-and-images/#resolution-aware.
diff --git a/test/widget_test.dart b/test/widget_test.dart
index 4fb4b2c0ea9f49fcbe00a22fcd3a1c0fe4f1aa21..8b7e35c5312be67053b7c74c41aed358a05329ca 100644
--- a/test/widget_test.dart
+++ b/test/widget_test.dart
@@ -8,12 +8,12 @@
 import 'package:flutter/material.dart';
 import 'package:flutter_test/flutter_test.dart';
 
-import 'package:smf_mobile/main.dart';
+// import 'package:smf_mobile/main.dart';
 
 void main() {
   testWidgets('Counter increments smoke test', (WidgetTester tester) async {
     // Build our app and trigger a frame.
-    await tester.pumpWidget(const MyApp());
+    // await tester.pumpWidget(const MyApp());
 
     // Verify that our counter starts at 0.
     expect(find.text('0'), findsOneWidget);
diff --git a/windows/flutter/generated_plugin_registrant.cc b/windows/flutter/generated_plugin_registrant.cc
index 8b6d4680af388f28db8742ef7fb8246e2bb1fffb..0c507538547f58e428ce2941d02b3d53db7bf853 100644
--- a/windows/flutter/generated_plugin_registrant.cc
+++ b/windows/flutter/generated_plugin_registrant.cc
@@ -6,6 +6,9 @@
 
 #include "generated_plugin_registrant.h"
 
+#include <flutter_secure_storage_windows/flutter_secure_storage_windows_plugin.h>
 
 void RegisterPlugins(flutter::PluginRegistry* registry) {
+  FlutterSecureStorageWindowsPluginRegisterWithRegistrar(
+      registry->GetRegistrarForPlugin("FlutterSecureStorageWindowsPlugin"));
 }
diff --git a/windows/flutter/generated_plugins.cmake b/windows/flutter/generated_plugins.cmake
index 4d10c2518654eaadbb431f911a1b24860d5b68c6..69b5ae4f581b86acdee0917371d2e73c106fa325 100644
--- a/windows/flutter/generated_plugins.cmake
+++ b/windows/flutter/generated_plugins.cmake
@@ -3,6 +3,7 @@
 #
 
 list(APPEND FLUTTER_PLUGIN_LIST
+  flutter_secure_storage_windows
 )
 
 set(PLUGIN_BUNDLED_LIBRARIES)