/Swaasthy

The only health app you'll ever need. Google Solution Challenge 2021

Primary LanguageDart

Hits

Swaasthy

A Google DSC Solution Challenge submission

.

Swaasthy is an app made to uplift user's health. It contains everything from medicine reminder functionality to make an SOS call to nearby ambulances to getting an appointment with a virtual doc. We believe that this is a revolutionary step necessary in bringing down the death-rate due to delay faced by patients in our country.

Video Submission

You can checkout our video submission demo on youtube by clicking on the thumbnail below.

Project Info

The contents in this project follow the following structure, where all views are containerised into screens.

├───models
|
├───screens
│   ├───auth
│   ├───consult
│   ├───emergency
│   ├───forums
│   ├───home
│   ├───reminder
│   └───stats
|
├───services
│
├───shared_widgets
│
└───utils

Each individual screen in the above, follow this structure

screen
  ├──local_widgets
  └──index.dart

Constants

This project uses 'Product Sans' as it's primary font, with weights of 400 and 600. All the fonts have been pre-imported.

Moreover, here are a few constants which are used throughout the project, and have been added within a CodeRedColors class, use them accordingly.

base            : FAFAFAF
primary         : EE466E
primaryAccent   : bd284b
inactive        : 9E9E9E
primary2        : 6246EE
primary2Accent  : 3a21b8
inputFields     : F3F3F3
medicineCard    : FDA8F3
text            : 000000
textSecondary   : 828282

Designs

All the design/mockups for the app have been added in the designs directory. You can use those for reference.

Description

  • Our solution mainly consists of a Flutter based mobile app. We wanted our solution to reach the masses, that's why we picked flutter as our framework of choice because of its cross-platform capabilities.

  • For the backend, we mostly relied on Firebase, as it was easier to integrate with the flutter app, without any hassle to manage & create instances of our server.

  • For sign-up & authentication, we used Firebase auth. If you're a medical volunteer, we'll ask you to upload an image of your medical ID card and we're using firebase ml kit for verification.

  • For storing the different types of data including user data, posts for the forum, ambulances, insights for the heatmap, doctors, appointments etc. we chose Cloud Firestore because of its robust features and ability to query & filter out documents with ease.

  • For verifying the medical volunteer ID Card Image, we used Firebase ML Kit, specifically the text recognition service.

  • To enable image posting in forums, and to store the volunteer image we used firebase cloud storage.

  • For handling payments, we used Razorpay SDK, which allowed us to accept payments for doctor appointment booking using Google Pay.

  • Adding video-calling for doctors and users was a challenging part, we ended up using agora WebRTC SDK to enable that feature within the app.

  • For the symptom-based disease recognition system, we looked up a lot for a reliable resource and ended up using prepaid service from ApiMedic.

  • For the Google Assistant Action, we used actions SDK with Google Actions builder tool, along with that for hosting an instance for webhooks, we used GCP.

Setup

Clone the repository
git clone https://github.com/ishandeveloper/Google-DSC-Solution-Challenge.git
Move to the desired folder
cd \Google-DSC-Solution-Challenge
To run the app, simply write
flutter run

About

Solving real-life problems is not easy, but at the same time, it's not impossible. Keeping this in mind, a team of four student developers from Chitkara University, Punjab, worked throughout March to solve a concerning problem by leveraging tech.

Our app primarily deals with the health sector. When it comes to saving a life, every millisecond counts! One in 10 patients in India dies on the way to the hospital. And we're here to change to that. We're Swaasthy!

Made with ♥ by

forthebadge

For help getting started with Flutter, view the online documentation, which offers tutorials, samples, guidance on mobile development, and a full API reference.