├── linux ├── .gitignore ├── main.cc ├── flutter │ ├── generated_plugin_registrant.cc │ ├── generated_plugin_registrant.h │ ├── generated_plugins.cmake │ └── CMakeLists.txt ├── my_application.h ├── my_application.cc └── CMakeLists.txt ├── ios ├── Flutter │ ├── Debug.xcconfig │ ├── Release.xcconfig │ └── AppFrameworkInfo.plist ├── Runner │ ├── Runner-Bridging-Header.h │ ├── Assets.xcassets │ │ ├── LaunchImage.imageset │ │ │ ├── LaunchImage.png │ │ │ ├── LaunchImage@2x.png │ │ │ ├── LaunchImage@3x.png │ │ │ ├── README.md │ │ │ └── Contents.json │ │ └── AppIcon.appiconset │ │ │ ├── Icon-App-20x20@1x.png │ │ │ ├── Icon-App-20x20@2x.png │ │ │ ├── Icon-App-20x20@3x.png │ │ │ ├── Icon-App-29x29@1x.png │ │ │ ├── Icon-App-29x29@2x.png │ │ │ ├── Icon-App-29x29@3x.png │ │ │ ├── Icon-App-40x40@1x.png │ │ │ ├── Icon-App-40x40@2x.png │ │ │ ├── Icon-App-40x40@3x.png │ │ │ ├── Icon-App-60x60@2x.png │ │ │ ├── Icon-App-60x60@3x.png │ │ │ ├── Icon-App-76x76@1x.png │ │ │ ├── Icon-App-76x76@2x.png │ │ │ ├── Icon-App-1024x1024@1x.png │ │ │ ├── Icon-App-83.5x83.5@2x.png │ │ │ └── Contents.json │ ├── AppDelegate.swift │ ├── Base.lproj │ │ ├── Main.storyboard │ │ └── LaunchScreen.storyboard │ └── Info.plist ├── Runner.xcodeproj │ ├── project.xcworkspace │ │ ├── contents.xcworkspacedata │ │ └── xcshareddata │ │ │ ├── WorkspaceSettings.xcsettings │ │ │ └── IDEWorkspaceChecks.plist │ └── xcshareddata │ │ └── xcschemes │ │ └── Runner.xcscheme ├── Runner.xcworkspace │ ├── contents.xcworkspacedata │ └── xcshareddata │ │ ├── WorkspaceSettings.xcsettings │ │ └── IDEWorkspaceChecks.plist └── .gitignore ├── macos ├── Flutter │ ├── Flutter-Debug.xcconfig │ ├── Flutter-Release.xcconfig │ └── GeneratedPluginRegistrant.swift ├── Runner │ ├── Configs │ │ ├── Debug.xcconfig │ │ ├── Release.xcconfig │ │ ├── Warnings.xcconfig │ │ └── AppInfo.xcconfig │ ├── Assets.xcassets │ │ └── AppIcon.appiconset │ │ │ ├── app_icon_16.png │ │ │ ├── app_icon_32.png │ │ │ ├── app_icon_64.png │ │ │ ├── app_icon_1024.png │ │ │ ├── app_icon_128.png │ │ │ ├── app_icon_256.png │ │ │ ├── app_icon_512.png │ │ │ └── Contents.json │ ├── AppDelegate.swift │ ├── Release.entitlements │ ├── DebugProfile.entitlements │ ├── MainFlutterWindow.swift │ └── Info.plist ├── .gitignore ├── Runner.xcworkspace │ ├── contents.xcworkspacedata │ └── xcshareddata │ │ └── IDEWorkspaceChecks.plist └── Runner.xcodeproj │ ├── project.xcworkspace │ └── xcshareddata │ │ └── IDEWorkspaceChecks.plist │ └── xcshareddata │ └── xcschemes │ └── Runner.xcscheme ├── web ├── favicon.png ├── icons │ ├── Icon-192.png │ ├── Icon-512.png │ ├── Icon-maskable-192.png │ └── Icon-maskable-512.png ├── manifest.json └── index.html ├── Screenshots ├── 1.png ├── 2.png ├── 3.png ├── 4.png ├── 5.png ├── 6.png ├── 7.png ├── 8.png ├── liinux2.png ├── linux1.png ├── linux3.png ├── linux5.png ├── linux6.png └── linux7.png ├── assets ├── Icons │ └── 1024.png ├── images │ └── welcomeImage.png └── contracts │ ├── doctor.json │ └── patient.json ├── android ├── gradle.properties ├── app │ ├── src │ │ ├── main │ │ │ ├── res │ │ │ │ ├── mipmap-hdpi │ │ │ │ │ └── ic_launcher.png │ │ │ │ ├── mipmap-mdpi │ │ │ │ │ └── ic_launcher.png │ │ │ │ ├── mipmap-xhdpi │ │ │ │ │ └── ic_launcher.png │ │ │ │ ├── mipmap-xxhdpi │ │ │ │ │ └── ic_launcher.png │ │ │ │ ├── mipmap-xxxhdpi │ │ │ │ │ └── ic_launcher.png │ │ │ │ ├── drawable │ │ │ │ │ └── launch_background.xml │ │ │ │ ├── drawable-v21 │ │ │ │ │ └── launch_background.xml │ │ │ │ ├── values │ │ │ │ │ └── styles.xml │ │ │ │ └── values-night │ │ │ │ │ └── styles.xml │ │ │ ├── kotlin │ │ │ │ └── com │ │ │ │ │ └── example │ │ │ │ │ └── medrec │ │ │ │ │ └── MainActivity.kt │ │ │ └── AndroidManifest.xml │ │ ├── debug │ │ │ └── AndroidManifest.xml │ │ └── profile │ │ │ └── AndroidManifest.xml │ └── build.gradle ├── gradle │ └── wrapper │ │ └── gradle-wrapper.properties ├── .gitignore ├── settings.gradle └── build.gradle ├── windows ├── runner │ ├── resources │ │ └── app_icon.ico │ ├── resource.h │ ├── utils.h │ ├── runner.exe.manifest │ ├── flutter_window.h │ ├── CMakeLists.txt │ ├── main.cpp │ ├── utils.cpp │ ├── flutter_window.cpp │ ├── Runner.rc │ ├── win32_window.h │ └── win32_window.cpp ├── flutter │ ├── generated_plugin_registrant.cc │ ├── generated_plugin_registrant.h │ ├── generated_plugins.cmake │ └── CMakeLists.txt ├── .gitignore └── CMakeLists.txt ├── lib ├── Utils │ ├── routes.dart │ └── connector.dart ├── main.dart └── Pages │ ├── splash_screen.dart │ ├── view_prescription.dart │ ├── login.dart │ └── patient_home_page.dart ├── solidity_contracts ├── doctor.sol └── patient.sol ├── .gitignore ├── LICENSE ├── test └── widget_test.dart ├── analysis_options.yaml ├── .metadata ├── pubspec.yaml ├── README.md └── pubspec.lock /linux/.gitignore: -------------------------------------------------------------------------------- 1 | flutter/ephemeral 2 | -------------------------------------------------------------------------------- /ios/Flutter/Debug.xcconfig: -------------------------------------------------------------------------------- 1 | #include "Generated.xcconfig" 2 | -------------------------------------------------------------------------------- /ios/Flutter/Release.xcconfig: -------------------------------------------------------------------------------- 1 | #include "Generated.xcconfig" 2 | -------------------------------------------------------------------------------- /ios/Runner/Runner-Bridging-Header.h: -------------------------------------------------------------------------------- 1 | #import "GeneratedPluginRegistrant.h" 2 | -------------------------------------------------------------------------------- /macos/Flutter/Flutter-Debug.xcconfig: -------------------------------------------------------------------------------- 1 | #include "ephemeral/Flutter-Generated.xcconfig" 2 | -------------------------------------------------------------------------------- /web/favicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/web/favicon.png -------------------------------------------------------------------------------- /Screenshots/1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/1.png -------------------------------------------------------------------------------- /Screenshots/2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/2.png -------------------------------------------------------------------------------- /Screenshots/3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/3.png -------------------------------------------------------------------------------- /Screenshots/4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/4.png -------------------------------------------------------------------------------- /Screenshots/5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/5.png -------------------------------------------------------------------------------- /Screenshots/6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/6.png -------------------------------------------------------------------------------- /Screenshots/7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/7.png -------------------------------------------------------------------------------- /Screenshots/8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/8.png -------------------------------------------------------------------------------- /macos/Flutter/Flutter-Release.xcconfig: -------------------------------------------------------------------------------- 1 | #include "ephemeral/Flutter-Generated.xcconfig" 2 | -------------------------------------------------------------------------------- /Screenshots/liinux2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/liinux2.png -------------------------------------------------------------------------------- /Screenshots/linux1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/linux1.png -------------------------------------------------------------------------------- /Screenshots/linux3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/linux3.png -------------------------------------------------------------------------------- /Screenshots/linux5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/linux5.png -------------------------------------------------------------------------------- /Screenshots/linux6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/linux6.png -------------------------------------------------------------------------------- /Screenshots/linux7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/Screenshots/linux7.png -------------------------------------------------------------------------------- /assets/Icons/1024.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/assets/Icons/1024.png -------------------------------------------------------------------------------- /web/icons/Icon-192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/web/icons/Icon-192.png -------------------------------------------------------------------------------- /web/icons/Icon-512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/web/icons/Icon-512.png -------------------------------------------------------------------------------- /assets/images/welcomeImage.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/assets/images/welcomeImage.png -------------------------------------------------------------------------------- /android/gradle.properties: -------------------------------------------------------------------------------- 1 | org.gradle.jvmargs=-Xmx1536M 2 | android.useAndroidX=true 3 | android.enableJetifier=true 4 | -------------------------------------------------------------------------------- /macos/Runner/Configs/Debug.xcconfig: -------------------------------------------------------------------------------- 1 | #include "../../Flutter/Flutter-Debug.xcconfig" 2 | #include "Warnings.xcconfig" 3 | -------------------------------------------------------------------------------- /web/icons/Icon-maskable-192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/web/icons/Icon-maskable-192.png -------------------------------------------------------------------------------- /web/icons/Icon-maskable-512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/web/icons/Icon-maskable-512.png -------------------------------------------------------------------------------- /macos/Runner/Configs/Release.xcconfig: -------------------------------------------------------------------------------- 1 | #include "../../Flutter/Flutter-Release.xcconfig" 2 | #include "Warnings.xcconfig" 3 | -------------------------------------------------------------------------------- /macos/.gitignore: -------------------------------------------------------------------------------- 1 | # Flutter-related 2 | **/Flutter/ephemeral/ 3 | **/Pods/ 4 | 5 | # Xcode-related 6 | **/dgph 7 | **/xcuserdata/ 8 | -------------------------------------------------------------------------------- /windows/runner/resources/app_icon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/windows/runner/resources/app_icon.ico -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/android/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/android/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Abhishekkr3003/MedRec/HEAD/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png -------------------------------------------------------------------------------- /android/app/src/main/kotlin/com/example/medrec/MainActivity.kt: -------------------------------------------------------------------------------- 1 | package com.example.medrec 2 | 3 | import io.flutter.embedding.android.FlutterActivity 4 | 5 | class MainActivity: FlutterActivity() { 6 | } 7 | -------------------------------------------------------------------------------- /linux/main.cc: -------------------------------------------------------------------------------- 1 | #include "my_application.h" 2 | 3 | int main(int argc, char** argv) { 4 | g_autoptr(MyApplication) app = my_application_new(); 5 | return g_application_run(G_APPLICATION(app), argc, argv); 6 | } 7 | -------------------------------------------------------------------------------- /ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata: -------------------------------------------------------------------------------- 1 | 2 | 4 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /ios/Runner.xcworkspace/contents.xcworkspacedata: -------------------------------------------------------------------------------- 1 | 2 | 4 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /macos/Runner.xcworkspace/contents.xcworkspacedata: -------------------------------------------------------------------------------- 1 | 2 | 4 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /linux/flutter/generated_plugin_registrant.cc: -------------------------------------------------------------------------------- 1 | // 2 | // Generated file. Do not edit. 3 | // 4 | 5 | // clang-format off 6 | 7 | #include "generated_plugin_registrant.h" 8 | 9 | 10 | void fl_register_plugins(FlPluginRegistry* registry) { 11 | } 12 | -------------------------------------------------------------------------------- /windows/flutter/generated_plugin_registrant.cc: -------------------------------------------------------------------------------- 1 | // 2 | // Generated file. Do not edit. 3 | // 4 | 5 | // clang-format off 6 | 7 | #include "generated_plugin_registrant.h" 8 | 9 | 10 | void RegisterPlugins(flutter::PluginRegistry* registry) { 11 | } 12 | -------------------------------------------------------------------------------- /macos/Runner/AppDelegate.swift: -------------------------------------------------------------------------------- 1 | import Cocoa 2 | import FlutterMacOS 3 | 4 | @NSApplicationMain 5 | class AppDelegate: FlutterAppDelegate { 6 | override func applicationShouldTerminateAfterLastWindowClosed(_ sender: NSApplication) -> Bool { 7 | return true 8 | } 9 | } 10 | -------------------------------------------------------------------------------- /android/gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | #Fri Jun 23 08:50:38 CEST 2017 2 | distributionBase=GRADLE_USER_HOME 3 | distributionPath=wrapper/dists 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip 7 | -------------------------------------------------------------------------------- /macos/Runner/Release.entitlements: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | com.apple.security.app-sandbox 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | PreviewsEnabled 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | IDEDidComputeMac32BitWarning 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | IDEDidComputeMac32BitWarning 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | PreviewsEnabled 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | IDEDidComputeMac32BitWarning 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | IDEDidComputeMac32BitWarning 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /android/.gitignore: -------------------------------------------------------------------------------- 1 | gradle-wrapper.jar 2 | /.gradle 3 | /captures/ 4 | /gradlew 5 | /gradlew.bat 6 | /local.properties 7 | GeneratedPluginRegistrant.java 8 | 9 | # Remember to never publicly share your keystore. 10 | # See https://flutter.dev/docs/deployment/android#reference-the-keystore-from-the-app 11 | key.properties 12 | **/*.keystore 13 | **/*.jks 14 | -------------------------------------------------------------------------------- /macos/Flutter/GeneratedPluginRegistrant.swift: -------------------------------------------------------------------------------- 1 | // 2 | // Generated file. Do not edit. 3 | // 4 | 5 | import FlutterMacOS 6 | import Foundation 7 | 8 | import path_provider_macos 9 | 10 | func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) { 11 | PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin")) 12 | } 13 | -------------------------------------------------------------------------------- /windows/.gitignore: -------------------------------------------------------------------------------- 1 | flutter/ephemeral/ 2 | 3 | # Visual Studio user-specific files. 4 | *.suo 5 | *.user 6 | *.userosscache 7 | *.sln.docstates 8 | 9 | # Visual Studio build-related files. 10 | x64/ 11 | x86/ 12 | 13 | # Visual Studio cache files 14 | # files ending in .cache can be ignored 15 | *.[Cc]ache 16 | # but keep track of directories ending in .cache 17 | !*.[Cc]ache/ 18 | -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md: -------------------------------------------------------------------------------- 1 | # Launch Screen Assets 2 | 3 | You can customize the launch screen with your own desired assets by replacing the image files in this directory. 4 | 5 | You can also do it by opening your Flutter project's Xcode project with `open ios/Runner.xcworkspace`, selecting `Runner/Assets.xcassets` in the Project Navigator and dropping in the desired images. -------------------------------------------------------------------------------- /linux/flutter/generated_plugin_registrant.h: -------------------------------------------------------------------------------- 1 | // 2 | // Generated file. Do not edit. 3 | // 4 | 5 | // clang-format off 6 | 7 | #ifndef GENERATED_PLUGIN_REGISTRANT_ 8 | #define GENERATED_PLUGIN_REGISTRANT_ 9 | 10 | #include 11 | 12 | // Registers Flutter plugins. 13 | void fl_register_plugins(FlPluginRegistry* registry); 14 | 15 | #endif // GENERATED_PLUGIN_REGISTRANT_ 16 | -------------------------------------------------------------------------------- /windows/flutter/generated_plugin_registrant.h: -------------------------------------------------------------------------------- 1 | // 2 | // Generated file. Do not edit. 3 | // 4 | 5 | // clang-format off 6 | 7 | #ifndef GENERATED_PLUGIN_REGISTRANT_ 8 | #define GENERATED_PLUGIN_REGISTRANT_ 9 | 10 | #include 11 | 12 | // Registers Flutter plugins. 13 | void RegisterPlugins(flutter::PluginRegistry* registry); 14 | 15 | #endif // GENERATED_PLUGIN_REGISTRANT_ 16 | -------------------------------------------------------------------------------- /macos/Runner/DebugProfile.entitlements: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | com.apple.security.app-sandbox 6 | 7 | com.apple.security.cs.allow-jit 8 | 9 | com.apple.security.network.server 10 | 11 | 12 | 13 | -------------------------------------------------------------------------------- /android/app/src/debug/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 3 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /android/app/src/profile/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 3 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /ios/Runner/AppDelegate.swift: -------------------------------------------------------------------------------- 1 | import UIKit 2 | import Flutter 3 | 4 | @UIApplicationMain 5 | @objc class AppDelegate: FlutterAppDelegate { 6 | override func application( 7 | _ application: UIApplication, 8 | didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]? 9 | ) -> Bool { 10 | GeneratedPluginRegistrant.register(with: self) 11 | return super.application(application, didFinishLaunchingWithOptions: launchOptions) 12 | } 13 | } 14 | -------------------------------------------------------------------------------- /linux/my_application.h: -------------------------------------------------------------------------------- 1 | #ifndef FLUTTER_MY_APPLICATION_H_ 2 | #define FLUTTER_MY_APPLICATION_H_ 3 | 4 | #include 5 | 6 | G_DECLARE_FINAL_TYPE(MyApplication, my_application, MY, APPLICATION, 7 | GtkApplication) 8 | 9 | /** 10 | * my_application_new: 11 | * 12 | * Creates a new Flutter-based application. 13 | * 14 | * Returns: a new #MyApplication. 15 | */ 16 | MyApplication* my_application_new(); 17 | 18 | #endif // FLUTTER_MY_APPLICATION_H_ 19 | -------------------------------------------------------------------------------- /macos/Runner/MainFlutterWindow.swift: -------------------------------------------------------------------------------- 1 | import Cocoa 2 | import FlutterMacOS 3 | 4 | class MainFlutterWindow: NSWindow { 5 | override func awakeFromNib() { 6 | let flutterViewController = FlutterViewController.init() 7 | let windowFrame = self.frame 8 | self.contentViewController = flutterViewController 9 | self.setFrame(windowFrame, display: true) 10 | 11 | RegisterGeneratedPlugins(registry: flutterViewController) 12 | 13 | super.awakeFromNib() 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /windows/runner/resource.h: -------------------------------------------------------------------------------- 1 | //{{NO_DEPENDENCIES}} 2 | // Microsoft Visual C++ generated include file. 3 | // Used by Runner.rc 4 | // 5 | #define IDI_APP_ICON 101 6 | 7 | // Next default values for new objects 8 | // 9 | #ifdef APSTUDIO_INVOKED 10 | #ifndef APSTUDIO_READONLY_SYMBOLS 11 | #define _APS_NEXT_RESOURCE_VALUE 102 12 | #define _APS_NEXT_COMMAND_VALUE 40001 13 | #define _APS_NEXT_CONTROL_VALUE 1001 14 | #define _APS_NEXT_SYMED_VALUE 101 15 | #endif 16 | #endif 17 | -------------------------------------------------------------------------------- /android/settings.gradle: -------------------------------------------------------------------------------- 1 | include ':app' 2 | 3 | def localPropertiesFile = new File(rootProject.projectDir, "local.properties") 4 | def properties = new Properties() 5 | 6 | assert localPropertiesFile.exists() 7 | localPropertiesFile.withReader("UTF-8") { reader -> properties.load(reader) } 8 | 9 | def flutterSdkPath = properties.getProperty("flutter.sdk") 10 | assert flutterSdkPath != null, "flutter.sdk not set in local.properties" 11 | apply from: "$flutterSdkPath/packages/flutter_tools/gradle/app_plugin_loader.gradle" 12 | -------------------------------------------------------------------------------- /android/app/src/main/res/drawable/launch_background.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 12 | 13 | -------------------------------------------------------------------------------- /android/app/src/main/res/drawable-v21/launch_background.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 12 | 13 | -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json: -------------------------------------------------------------------------------- 1 | { 2 | "images" : [ 3 | { 4 | "idiom" : "universal", 5 | "filename" : "LaunchImage.png", 6 | "scale" : "1x" 7 | }, 8 | { 9 | "idiom" : "universal", 10 | "filename" : "LaunchImage@2x.png", 11 | "scale" : "2x" 12 | }, 13 | { 14 | "idiom" : "universal", 15 | "filename" : "LaunchImage@3x.png", 16 | "scale" : "3x" 17 | } 18 | ], 19 | "info" : { 20 | "version" : 1, 21 | "author" : "xcode" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /lib/Utils/routes.dart: -------------------------------------------------------------------------------- 1 | import 'package:flutter/material.dart'; 2 | import 'package:medrec/Pages/doctor_home_page.dart'; 3 | import 'package:medrec/Pages/login.dart'; 4 | import 'package:medrec/Pages/patient_home_page.dart'; 5 | 6 | class MyRoutes { 7 | static const String loginPage = "/loginPage"; 8 | static const String doctorHomePage = "/doctorHome"; 9 | static const String patientHomePage = "/patientHome"; 10 | 11 | static final routes = { 12 | loginPage: (context) => const LoginPage(), 13 | doctorHomePage: (context) => const DoctorHomePage(), 14 | patientHomePage: (context) => const PatientHomePage(), 15 | }; 16 | } 17 | -------------------------------------------------------------------------------- /macos/Runner/Configs/Warnings.xcconfig: -------------------------------------------------------------------------------- 1 | WARNING_CFLAGS = -Wall -Wconditional-uninitialized -Wnullable-to-nonnull-conversion -Wmissing-method-return-type -Woverlength-strings 2 | GCC_WARN_UNDECLARED_SELECTOR = YES 3 | CLANG_UNDEFINED_BEHAVIOR_SANITIZER_NULLABILITY = YES 4 | CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE 5 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES 6 | CLANG_WARN_PRAGMA_PACK = YES 7 | CLANG_WARN_STRICT_PROTOTYPES = YES 8 | CLANG_WARN_COMMA = YES 9 | GCC_WARN_STRICT_SELECTOR_MATCH = YES 10 | CLANG_WARN_OBJC_REPEATED_USE_OF_WEAK = YES 11 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES 12 | GCC_WARN_SHADOW = YES 13 | CLANG_WARN_UNREACHABLE_CODE = YES 14 | -------------------------------------------------------------------------------- /macos/Runner/Configs/AppInfo.xcconfig: -------------------------------------------------------------------------------- 1 | // Application-level settings for the Runner target. 2 | // 3 | // This may be replaced with something auto-generated from metadata (e.g., pubspec.yaml) in the 4 | // future. If not, the values below would default to using the project name when this becomes a 5 | // 'flutter create' template. 6 | 7 | // The application's name. By default this is also the title of the Flutter window. 8 | PRODUCT_NAME = medrec 9 | 10 | // The application's bundle identifier 11 | PRODUCT_BUNDLE_IDENTIFIER = com.example.medrec 12 | 13 | // The copyright displayed in application information 14 | PRODUCT_COPYRIGHT = Copyright © 2022 com.example. All rights reserved. 15 | -------------------------------------------------------------------------------- /ios/.gitignore: -------------------------------------------------------------------------------- 1 | **/dgph 2 | *.mode1v3 3 | *.mode2v3 4 | *.moved-aside 5 | *.pbxuser 6 | *.perspectivev3 7 | **/*sync/ 8 | .sconsign.dblite 9 | .tags* 10 | **/.vagrant/ 11 | **/DerivedData/ 12 | Icon? 13 | **/Pods/ 14 | **/.symlinks/ 15 | profile 16 | xcuserdata 17 | **/.generated/ 18 | Flutter/App.framework 19 | Flutter/Flutter.framework 20 | Flutter/Flutter.podspec 21 | Flutter/Generated.xcconfig 22 | Flutter/ephemeral/ 23 | Flutter/app.flx 24 | Flutter/app.zip 25 | Flutter/flutter_assets/ 26 | Flutter/flutter_export_environment.sh 27 | ServiceDefinitions.json 28 | Runner/GeneratedPluginRegistrant.* 29 | 30 | # Exceptions to above rules. 31 | !default.mode1v3 32 | !default.mode2v3 33 | !default.pbxuser 34 | !default.perspectivev3 35 | -------------------------------------------------------------------------------- /android/build.gradle: -------------------------------------------------------------------------------- 1 | buildscript { 2 | ext.kotlin_version = '1.6.10' 3 | repositories { 4 | google() 5 | mavenCentral() 6 | } 7 | 8 | dependencies { 9 | classpath 'com.android.tools.build:gradle:7.1.2' 10 | classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" 11 | } 12 | } 13 | 14 | allprojects { 15 | repositories { 16 | google() 17 | mavenCentral() 18 | } 19 | } 20 | 21 | rootProject.buildDir = '../build' 22 | subprojects { 23 | project.buildDir = "${rootProject.buildDir}/${project.name}" 24 | } 25 | subprojects { 26 | project.evaluationDependsOn(':app') 27 | } 28 | 29 | task clean(type: Delete) { 30 | delete rootProject.buildDir 31 | } 32 | -------------------------------------------------------------------------------- /solidity_contracts/doctor.sol: -------------------------------------------------------------------------------- 1 | // SPDX-License-Identifier: GPL-3.0 2 | pragma solidity >=0.5.0 <0.8.0; 3 | 4 | contract Doctor { 5 | mapping(address => uint256) fee; 6 | mapping(address => bool) isExists; 7 | 8 | function addDoctor(address doc) public { 9 | require(!isExists[doc], "Doctor already exists"); 10 | fee[doc] = 0; 11 | isExists[doc] = true; 12 | } 13 | 14 | function updateFee(address doc, uint256 amount) public { 15 | fee[doc] = amount; 16 | } 17 | 18 | function getFee(address doc) public view returns (uint256) { 19 | return fee[doc]; 20 | } 21 | 22 | function isDoctor(address doc) public view returns (bool) { 23 | return isExists[doc]; 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /windows/runner/utils.h: -------------------------------------------------------------------------------- 1 | #ifndef RUNNER_UTILS_H_ 2 | #define RUNNER_UTILS_H_ 3 | 4 | #include 5 | #include 6 | 7 | // Creates a console for the process, and redirects stdout and stderr to 8 | // it for both the runner and the Flutter library. 9 | void CreateAndAttachConsole(); 10 | 11 | // Takes a null-terminated wchar_t* encoded in UTF-16 and returns a std::string 12 | // encoded in UTF-8. Returns an empty std::string on failure. 13 | std::string Utf8FromUtf16(const wchar_t* utf16_string); 14 | 15 | // Gets the command line arguments passed in as a std::vector, 16 | // encoded in UTF-8. Returns an empty std::vector on failure. 17 | std::vector GetCommandLineArguments(); 18 | 19 | #endif // RUNNER_UTILS_H_ 20 | -------------------------------------------------------------------------------- /linux/flutter/generated_plugins.cmake: -------------------------------------------------------------------------------- 1 | # 2 | # Generated file, do not edit. 3 | # 4 | 5 | list(APPEND FLUTTER_PLUGIN_LIST 6 | ) 7 | 8 | list(APPEND FLUTTER_FFI_PLUGIN_LIST 9 | ) 10 | 11 | set(PLUGIN_BUNDLED_LIBRARIES) 12 | 13 | foreach(plugin ${FLUTTER_PLUGIN_LIST}) 14 | add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/linux plugins/${plugin}) 15 | target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin) 16 | list(APPEND PLUGIN_BUNDLED_LIBRARIES $) 17 | list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries}) 18 | endforeach(plugin) 19 | 20 | foreach(ffi_plugin ${FLUTTER_FFI_PLUGIN_LIST}) 21 | add_subdirectory(flutter/ephemeral/.plugin_symlinks/${ffi_plugin}/linux plugins/${ffi_plugin}) 22 | list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${ffi_plugin}_bundled_libraries}) 23 | endforeach(ffi_plugin) 24 | -------------------------------------------------------------------------------- /windows/flutter/generated_plugins.cmake: -------------------------------------------------------------------------------- 1 | # 2 | # Generated file, do not edit. 3 | # 4 | 5 | list(APPEND FLUTTER_PLUGIN_LIST 6 | ) 7 | 8 | list(APPEND FLUTTER_FFI_PLUGIN_LIST 9 | ) 10 | 11 | set(PLUGIN_BUNDLED_LIBRARIES) 12 | 13 | foreach(plugin ${FLUTTER_PLUGIN_LIST}) 14 | add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/windows plugins/${plugin}) 15 | target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin) 16 | list(APPEND PLUGIN_BUNDLED_LIBRARIES $) 17 | list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries}) 18 | endforeach(plugin) 19 | 20 | foreach(ffi_plugin ${FLUTTER_FFI_PLUGIN_LIST}) 21 | add_subdirectory(flutter/ephemeral/.plugin_symlinks/${ffi_plugin}/windows plugins/${ffi_plugin}) 22 | list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${ffi_plugin}_bundled_libraries}) 23 | endforeach(ffi_plugin) 24 | -------------------------------------------------------------------------------- /ios/Flutter/AppFrameworkInfo.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleExecutable 8 | App 9 | CFBundleIdentifier 10 | io.flutter.flutter.app 11 | CFBundleInfoDictionaryVersion 12 | 6.0 13 | CFBundleName 14 | App 15 | CFBundlePackageType 16 | FMWK 17 | CFBundleShortVersionString 18 | 1.0 19 | CFBundleSignature 20 | ???? 21 | CFBundleVersion 22 | 1.0 23 | MinimumOSVersion 24 | 9.0 25 | 26 | 27 | -------------------------------------------------------------------------------- /windows/runner/runner.exe.manifest: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | PerMonitorV2 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Miscellaneous 2 | *.class 3 | *.log 4 | *.pyc 5 | *.swp 6 | .DS_Store 7 | .atom/ 8 | .buildlog/ 9 | .history 10 | .svn/ 11 | migrate_working_dir/ 12 | 13 | # IntelliJ related 14 | *.iml 15 | *.ipr 16 | *.iws 17 | .idea/ 18 | 19 | # The .vscode folder contains launch configuration and tasks you configure in 20 | # VS Code which you may wish to be included in version control, so this line 21 | # is commented out by default. 22 | #.vscode/ 23 | 24 | # Flutter/Dart/Pub related 25 | **/doc/api/ 26 | **/ios/Flutter/.last_build_id 27 | .dart_tool/ 28 | .flutter-plugins 29 | .flutter-plugins-dependencies 30 | .packages 31 | .pub-cache/ 32 | .pub/ 33 | /build/ 34 | 35 | # Web related 36 | lib/generated_plugin_registrant.dart 37 | 38 | # Symbolication related 39 | app.*.symbols 40 | 41 | # Obfuscation related 42 | app.*.map.json 43 | 44 | # Android Studio will place build artifacts here 45 | /android/app/debug 46 | /android/app/profile 47 | /android/app/release 48 | -------------------------------------------------------------------------------- /lib/main.dart: -------------------------------------------------------------------------------- 1 | import 'package:flutter/material.dart'; 2 | import 'package:flutter/services.dart'; 3 | import 'package:google_fonts/google_fonts.dart'; 4 | import 'Pages/splash_screen.dart'; 5 | import 'Utils/routes.dart'; 6 | 7 | void main() { 8 | SystemChrome.setSystemUIOverlayStyle(const SystemUiOverlayStyle( 9 | statusBarColor: Colors.black, statusBarIconBrightness: Brightness.light)); 10 | runApp(const MyApp()); 11 | } 12 | 13 | class MyApp extends StatelessWidget { 14 | const MyApp({Key? key}) : super(key: key); 15 | 16 | // This widget is the root of your application. 17 | @override 18 | Widget build(BuildContext context) { 19 | return MaterialApp( 20 | debugShowCheckedModeBanner: false, 21 | theme: ThemeData( 22 | textTheme: GoogleFonts.poppinsTextTheme( 23 | Theme.of(context).textTheme, 24 | ), 25 | ), 26 | home: const Splash2(), 27 | routes: MyRoutes.routes, 28 | ); 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /web/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "medrec", 3 | "short_name": "medrec", 4 | "start_url": ".", 5 | "display": "standalone", 6 | "background_color": "#0175C2", 7 | "theme_color": "#0175C2", 8 | "description": "A new Flutter project.", 9 | "orientation": "portrait-primary", 10 | "prefer_related_applications": false, 11 | "icons": [ 12 | { 13 | "src": "icons/Icon-192.png", 14 | "sizes": "192x192", 15 | "type": "image/png" 16 | }, 17 | { 18 | "src": "icons/Icon-512.png", 19 | "sizes": "512x512", 20 | "type": "image/png" 21 | }, 22 | { 23 | "src": "icons/Icon-maskable-192.png", 24 | "sizes": "192x192", 25 | "type": "image/png", 26 | "purpose": "maskable" 27 | }, 28 | { 29 | "src": "icons/Icon-maskable-512.png", 30 | "sizes": "512x512", 31 | "type": "image/png", 32 | "purpose": "maskable" 33 | } 34 | ] 35 | } 36 | -------------------------------------------------------------------------------- /windows/runner/flutter_window.h: -------------------------------------------------------------------------------- 1 | #ifndef RUNNER_FLUTTER_WINDOW_H_ 2 | #define RUNNER_FLUTTER_WINDOW_H_ 3 | 4 | #include 5 | #include 6 | 7 | #include 8 | 9 | #include "win32_window.h" 10 | 11 | // A window that does nothing but host a Flutter view. 12 | class FlutterWindow : public Win32Window { 13 | public: 14 | // Creates a new FlutterWindow hosting a Flutter view running |project|. 15 | explicit FlutterWindow(const flutter::DartProject& project); 16 | virtual ~FlutterWindow(); 17 | 18 | protected: 19 | // Win32Window: 20 | bool OnCreate() override; 21 | void OnDestroy() override; 22 | LRESULT MessageHandler(HWND window, UINT const message, WPARAM const wparam, 23 | LPARAM const lparam) noexcept override; 24 | 25 | private: 26 | // The project to run. 27 | flutter::DartProject project_; 28 | 29 | // The Flutter instance hosted by this window. 30 | std::unique_ptr flutter_controller_; 31 | }; 32 | 33 | #endif // RUNNER_FLUTTER_WINDOW_H_ 34 | -------------------------------------------------------------------------------- /android/app/src/main/res/values/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 9 | 15 | 18 | 19 | -------------------------------------------------------------------------------- /android/app/src/main/res/values-night/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 9 | 15 | 18 | 19 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Abhishek Kumar 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /test/widget_test.dart: -------------------------------------------------------------------------------- 1 | // This is a basic Flutter widget test. 2 | // 3 | // To perform an interaction with a widget in your test, use the WidgetTester 4 | // utility in the flutter_test package. For example, you can send tap and scroll 5 | // gestures. You can also use WidgetTester to find child widgets in the widget 6 | // tree, read text, and verify that the values of widget properties are correct. 7 | 8 | import 'package:flutter/material.dart'; 9 | import 'package:flutter_test/flutter_test.dart'; 10 | 11 | import 'package:medrec/main.dart'; 12 | 13 | void main() { 14 | testWidgets('Counter increments smoke test', (WidgetTester tester) async { 15 | // Build our app and trigger a frame. 16 | await tester.pumpWidget(const MyApp()); 17 | 18 | // Verify that our counter starts at 0. 19 | expect(find.text('0'), findsOneWidget); 20 | expect(find.text('1'), findsNothing); 21 | 22 | // Tap the '+' icon and trigger a frame. 23 | await tester.tap(find.byIcon(Icons.add)); 24 | await tester.pump(); 25 | 26 | // Verify that our counter has incremented. 27 | expect(find.text('0'), findsNothing); 28 | expect(find.text('1'), findsOneWidget); 29 | }); 30 | } 31 | -------------------------------------------------------------------------------- /macos/Runner/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | $(DEVELOPMENT_LANGUAGE) 7 | CFBundleExecutable 8 | $(EXECUTABLE_NAME) 9 | CFBundleIconFile 10 | 11 | CFBundleIdentifier 12 | $(PRODUCT_BUNDLE_IDENTIFIER) 13 | CFBundleInfoDictionaryVersion 14 | 6.0 15 | CFBundleName 16 | $(PRODUCT_NAME) 17 | CFBundlePackageType 18 | APPL 19 | CFBundleShortVersionString 20 | $(FLUTTER_BUILD_NAME) 21 | CFBundleVersion 22 | $(FLUTTER_BUILD_NUMBER) 23 | LSMinimumSystemVersion 24 | $(MACOSX_DEPLOYMENT_TARGET) 25 | NSHumanReadableCopyright 26 | $(PRODUCT_COPYRIGHT) 27 | NSMainNibFile 28 | MainMenu 29 | NSPrincipalClass 30 | NSApplication 31 | 32 | 33 | -------------------------------------------------------------------------------- /windows/runner/CMakeLists.txt: -------------------------------------------------------------------------------- 1 | cmake_minimum_required(VERSION 3.14) 2 | project(runner LANGUAGES CXX) 3 | 4 | # Define the application target. To change its name, change BINARY_NAME in the 5 | # top-level CMakeLists.txt, not the value here, or `flutter run` will no longer 6 | # work. 7 | # 8 | # Any new source files that you add to the application should be added here. 9 | add_executable(${BINARY_NAME} WIN32 10 | "flutter_window.cpp" 11 | "main.cpp" 12 | "utils.cpp" 13 | "win32_window.cpp" 14 | "${FLUTTER_MANAGED_DIR}/generated_plugin_registrant.cc" 15 | "Runner.rc" 16 | "runner.exe.manifest" 17 | ) 18 | 19 | # Apply the standard set of build settings. This can be removed for applications 20 | # that need different build settings. 21 | apply_standard_settings(${BINARY_NAME}) 22 | 23 | # Disable Windows macros that collide with C++ standard library functions. 24 | target_compile_definitions(${BINARY_NAME} PRIVATE "NOMINMAX") 25 | 26 | # Add dependency libraries and include directories. Add any application-specific 27 | # dependencies here. 28 | target_link_libraries(${BINARY_NAME} PRIVATE flutter flutter_wrapper_app) 29 | target_include_directories(${BINARY_NAME} PRIVATE "${CMAKE_SOURCE_DIR}") 30 | 31 | # Run the Flutter tool portions of the build. This must not be removed. 32 | add_dependencies(${BINARY_NAME} flutter_assemble) 33 | -------------------------------------------------------------------------------- /windows/runner/main.cpp: -------------------------------------------------------------------------------- 1 | #include 2 | #include 3 | #include 4 | 5 | #include "flutter_window.h" 6 | #include "utils.h" 7 | 8 | int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev, 9 | _In_ wchar_t *command_line, _In_ int show_command) { 10 | // Attach to console when present (e.g., 'flutter run') or create a 11 | // new console when running with a debugger. 12 | if (!::AttachConsole(ATTACH_PARENT_PROCESS) && ::IsDebuggerPresent()) { 13 | CreateAndAttachConsole(); 14 | } 15 | 16 | // Initialize COM, so that it is available for use in the library and/or 17 | // plugins. 18 | ::CoInitializeEx(nullptr, COINIT_APARTMENTTHREADED); 19 | 20 | flutter::DartProject project(L"data"); 21 | 22 | std::vector command_line_arguments = 23 | GetCommandLineArguments(); 24 | 25 | project.set_dart_entrypoint_arguments(std::move(command_line_arguments)); 26 | 27 | FlutterWindow window(project); 28 | Win32Window::Point origin(10, 10); 29 | Win32Window::Size size(1280, 720); 30 | if (!window.CreateAndShow(L"medrec", origin, size)) { 31 | return EXIT_FAILURE; 32 | } 33 | window.SetQuitOnClose(true); 34 | 35 | ::MSG msg; 36 | while (::GetMessage(&msg, nullptr, 0, 0)) { 37 | ::TranslateMessage(&msg); 38 | ::DispatchMessage(&msg); 39 | } 40 | 41 | ::CoUninitialize(); 42 | return EXIT_SUCCESS; 43 | } 44 | -------------------------------------------------------------------------------- /analysis_options.yaml: -------------------------------------------------------------------------------- 1 | # This file configures the analyzer, which statically analyzes Dart code to 2 | # check for errors, warnings, and lints. 3 | # 4 | # The issues identified by the analyzer are surfaced in the UI of Dart-enabled 5 | # IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be 6 | # invoked from the command line by running `flutter analyze`. 7 | 8 | # The following line activates a set of recommended lints for Flutter apps, 9 | # packages, and plugins designed to encourage good coding practices. 10 | include: package:flutter_lints/flutter.yaml 11 | 12 | linter: 13 | # The lint rules applied to this project can be customized in the 14 | # section below to disable rules from the `package:flutter_lints/flutter.yaml` 15 | # included above or to enable additional rules. A list of all available lints 16 | # and their documentation is published at 17 | # https://dart-lang.github.io/linter/lints/index.html. 18 | # 19 | # Instead of disabling a lint rule for the entire project in the 20 | # section below, it can also be suppressed for a single line of code 21 | # or a specific dart file by using the `// ignore: name_of_lint` and 22 | # `// ignore_for_file: name_of_lint` syntax on the line or in the file 23 | # producing the lint. 24 | rules: 25 | # avoid_print: false # Uncomment to disable the `avoid_print` rule 26 | # prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule 27 | 28 | # Additional information about this file can be found at 29 | # https://dart.dev/guides/language/analysis-options 30 | -------------------------------------------------------------------------------- /macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json: -------------------------------------------------------------------------------- 1 | { 2 | "images" : [ 3 | { 4 | "size" : "16x16", 5 | "idiom" : "mac", 6 | "filename" : "app_icon_16.png", 7 | "scale" : "1x" 8 | }, 9 | { 10 | "size" : "16x16", 11 | "idiom" : "mac", 12 | "filename" : "app_icon_32.png", 13 | "scale" : "2x" 14 | }, 15 | { 16 | "size" : "32x32", 17 | "idiom" : "mac", 18 | "filename" : "app_icon_32.png", 19 | "scale" : "1x" 20 | }, 21 | { 22 | "size" : "32x32", 23 | "idiom" : "mac", 24 | "filename" : "app_icon_64.png", 25 | "scale" : "2x" 26 | }, 27 | { 28 | "size" : "128x128", 29 | "idiom" : "mac", 30 | "filename" : "app_icon_128.png", 31 | "scale" : "1x" 32 | }, 33 | { 34 | "size" : "128x128", 35 | "idiom" : "mac", 36 | "filename" : "app_icon_256.png", 37 | "scale" : "2x" 38 | }, 39 | { 40 | "size" : "256x256", 41 | "idiom" : "mac", 42 | "filename" : "app_icon_256.png", 43 | "scale" : "1x" 44 | }, 45 | { 46 | "size" : "256x256", 47 | "idiom" : "mac", 48 | "filename" : "app_icon_512.png", 49 | "scale" : "2x" 50 | }, 51 | { 52 | "size" : "512x512", 53 | "idiom" : "mac", 54 | "filename" : "app_icon_512.png", 55 | "scale" : "1x" 56 | }, 57 | { 58 | "size" : "512x512", 59 | "idiom" : "mac", 60 | "filename" : "app_icon_1024.png", 61 | "scale" : "2x" 62 | } 63 | ], 64 | "info" : { 65 | "version" : 1, 66 | "author" : "xcode" 67 | } 68 | } 69 | -------------------------------------------------------------------------------- /ios/Runner/Base.lproj/Main.storyboard: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | -------------------------------------------------------------------------------- /android/app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 3 | 7 | 15 | 19 | 23 | 24 | 25 | 26 | 27 | 28 | 30 | 33 | 34 | 35 | -------------------------------------------------------------------------------- /.metadata: -------------------------------------------------------------------------------- 1 | # This file tracks properties of this Flutter project. 2 | # Used by Flutter tool to assess capabilities and perform upgrades etc. 3 | # 4 | # This file should be version controlled. 5 | 6 | version: 7 | revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 8 | channel: stable 9 | 10 | project_type: app 11 | 12 | # Tracks metadata for the flutter migrate command 13 | migration: 14 | platforms: 15 | - platform: root 16 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 17 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 18 | - platform: android 19 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 20 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 21 | - platform: ios 22 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 23 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 24 | - platform: linux 25 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 26 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 27 | - platform: macos 28 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 29 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 30 | - platform: web 31 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 32 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 33 | - platform: windows 34 | create_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 35 | base_revision: fb57da5f945d02ef4f98dfd9409a72b7cce74268 36 | 37 | # User provided section 38 | 39 | # List of Local paths (relative to this file) that should be 40 | # ignored by the migrate tool. 41 | # 42 | # Files that are not part of the templates will be ignored by default. 43 | unmanaged_files: 44 | - 'lib/main.dart' 45 | - 'ios/Runner.xcodeproj/project.pbxproj' 46 | -------------------------------------------------------------------------------- /ios/Runner/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | $(DEVELOPMENT_LANGUAGE) 7 | CFBundleDisplayName 8 | Medrec 9 | CFBundleExecutable 10 | $(EXECUTABLE_NAME) 11 | CFBundleIdentifier 12 | $(PRODUCT_BUNDLE_IDENTIFIER) 13 | CFBundleInfoDictionaryVersion 14 | 6.0 15 | CFBundleName 16 | medrec 17 | CFBundlePackageType 18 | APPL 19 | CFBundleShortVersionString 20 | $(FLUTTER_BUILD_NAME) 21 | CFBundleSignature 22 | ???? 23 | CFBundleVersion 24 | $(FLUTTER_BUILD_NUMBER) 25 | LSRequiresIPhoneOS 26 | 27 | UILaunchStoryboardName 28 | LaunchScreen 29 | UIMainStoryboardFile 30 | Main 31 | UISupportedInterfaceOrientations 32 | 33 | UIInterfaceOrientationPortrait 34 | UIInterfaceOrientationLandscapeLeft 35 | UIInterfaceOrientationLandscapeRight 36 | 37 | UISupportedInterfaceOrientations~ipad 38 | 39 | UIInterfaceOrientationPortrait 40 | UIInterfaceOrientationPortraitUpsideDown 41 | UIInterfaceOrientationLandscapeLeft 42 | UIInterfaceOrientationLandscapeRight 43 | 44 | UIViewControllerBasedStatusBarAppearance 45 | 46 | CADisableMinimumFrameDurationOnPhone 47 | 48 | 49 | 50 | -------------------------------------------------------------------------------- /assets/contracts/doctor.json: -------------------------------------------------------------------------------- 1 | [ 2 | { 3 | "inputs": [ 4 | { 5 | "internalType": "address", 6 | "name": "doc", 7 | "type": "address" 8 | } 9 | ], 10 | "name": "addDoctor", 11 | "outputs": [], 12 | "stateMutability": "nonpayable", 13 | "type": "function" 14 | }, 15 | { 16 | "inputs": [ 17 | { 18 | "internalType": "address", 19 | "name": "doc", 20 | "type": "address" 21 | } 22 | ], 23 | "name": "getFee", 24 | "outputs": [ 25 | { 26 | "internalType": "uint256", 27 | "name": "", 28 | "type": "uint256" 29 | } 30 | ], 31 | "stateMutability": "view", 32 | "type": "function" 33 | }, 34 | { 35 | "inputs": [ 36 | { 37 | "internalType": "address", 38 | "name": "doc", 39 | "type": "address" 40 | } 41 | ], 42 | "name": "isDoctor", 43 | "outputs": [ 44 | { 45 | "internalType": "bool", 46 | "name": "", 47 | "type": "bool" 48 | } 49 | ], 50 | "stateMutability": "view", 51 | "type": "function" 52 | }, 53 | { 54 | "inputs": [ 55 | { 56 | "internalType": "address", 57 | "name": "doc", 58 | "type": "address" 59 | }, 60 | { 61 | "internalType": "uint256", 62 | "name": "amount", 63 | "type": "uint256" 64 | } 65 | ], 66 | "name": "updateFee", 67 | "outputs": [], 68 | "stateMutability": "nonpayable", 69 | "type": "function" 70 | } 71 | ] -------------------------------------------------------------------------------- /solidity_contracts/patient.sol: -------------------------------------------------------------------------------- 1 | // SPDX-License-Identifier: GPL-3.0 2 | pragma solidity >=0.5.0 <0.8.0; 3 | pragma experimental ABIEncoderV2; 4 | 5 | contract Patient { 6 | mapping(address => uint256) patientBalance; 7 | mapping(address => bool) isExists; 8 | mapping(address => string[]) prescriptions; 9 | mapping(address => mapping(address => uint256)) authorized; 10 | 11 | modifier checkExistence(address pat) { 12 | require(isExists[pat], "Patient does not exists"); 13 | _; 14 | } 15 | 16 | function addPatient(address pat) public { 17 | require(!isExists[pat], "Patient already exists"); 18 | patientBalance[pat] = 0; 19 | isExists[pat] = true; 20 | } 21 | 22 | function addAuthorization( 23 | address doc, 24 | address pat, 25 | uint256 fee 26 | ) external payable { 27 | require(authorized[pat][doc] == 0, "Doctor already authorized."); 28 | require(msg.value >= fee, "Amount not sufficient"); 29 | patientBalance[pat] += msg.value; 30 | authorized[pat][doc] = fee; 31 | } 32 | 33 | function viewPrescription(address pat) 34 | public 35 | view 36 | returns (string[] memory) 37 | { 38 | return prescriptions[pat]; 39 | } 40 | 41 | function setPrescription( 42 | string memory presc, 43 | address pat, 44 | address payable doc 45 | ) public { 46 | prescriptions[pat].push(presc); 47 | uint256 charges = authorized[pat][doc]; 48 | patientBalance[pat] -= charges; 49 | authorized[pat][doc] = 0; 50 | doc.transfer(charges); 51 | } 52 | 53 | function isAuthorized(address doc, address pat) public view returns (bool) { 54 | return (authorized[pat][doc] > 0); 55 | } 56 | 57 | function isPatient(address pat) public view returns (bool) { 58 | return isExists[pat]; 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /windows/runner/utils.cpp: -------------------------------------------------------------------------------- 1 | #include "utils.h" 2 | 3 | #include 4 | #include 5 | #include 6 | #include 7 | 8 | #include 9 | 10 | void CreateAndAttachConsole() { 11 | if (::AllocConsole()) { 12 | FILE *unused; 13 | if (freopen_s(&unused, "CONOUT$", "w", stdout)) { 14 | _dup2(_fileno(stdout), 1); 15 | } 16 | if (freopen_s(&unused, "CONOUT$", "w", stderr)) { 17 | _dup2(_fileno(stdout), 2); 18 | } 19 | std::ios::sync_with_stdio(); 20 | FlutterDesktopResyncOutputStreams(); 21 | } 22 | } 23 | 24 | std::vector GetCommandLineArguments() { 25 | // Convert the UTF-16 command line arguments to UTF-8 for the Engine to use. 26 | int argc; 27 | wchar_t** argv = ::CommandLineToArgvW(::GetCommandLineW(), &argc); 28 | if (argv == nullptr) { 29 | return std::vector(); 30 | } 31 | 32 | std::vector command_line_arguments; 33 | 34 | // Skip the first argument as it's the binary name. 35 | for (int i = 1; i < argc; i++) { 36 | command_line_arguments.push_back(Utf8FromUtf16(argv[i])); 37 | } 38 | 39 | ::LocalFree(argv); 40 | 41 | return command_line_arguments; 42 | } 43 | 44 | std::string Utf8FromUtf16(const wchar_t* utf16_string) { 45 | if (utf16_string == nullptr) { 46 | return std::string(); 47 | } 48 | int target_length = ::WideCharToMultiByte( 49 | CP_UTF8, WC_ERR_INVALID_CHARS, utf16_string, 50 | -1, nullptr, 0, nullptr, nullptr); 51 | std::string utf8_string; 52 | if (target_length == 0 || target_length > utf8_string.max_size()) { 53 | return utf8_string; 54 | } 55 | utf8_string.resize(target_length); 56 | int converted_length = ::WideCharToMultiByte( 57 | CP_UTF8, WC_ERR_INVALID_CHARS, utf16_string, 58 | -1, utf8_string.data(), 59 | target_length, nullptr, nullptr); 60 | if (converted_length == 0) { 61 | return std::string(); 62 | } 63 | return utf8_string; 64 | } 65 | -------------------------------------------------------------------------------- /windows/runner/flutter_window.cpp: -------------------------------------------------------------------------------- 1 | #include "flutter_window.h" 2 | 3 | #include 4 | 5 | #include "flutter/generated_plugin_registrant.h" 6 | 7 | FlutterWindow::FlutterWindow(const flutter::DartProject& project) 8 | : project_(project) {} 9 | 10 | FlutterWindow::~FlutterWindow() {} 11 | 12 | bool FlutterWindow::OnCreate() { 13 | if (!Win32Window::OnCreate()) { 14 | return false; 15 | } 16 | 17 | RECT frame = GetClientArea(); 18 | 19 | // The size here must match the window dimensions to avoid unnecessary surface 20 | // creation / destruction in the startup path. 21 | flutter_controller_ = std::make_unique( 22 | frame.right - frame.left, frame.bottom - frame.top, project_); 23 | // Ensure that basic setup of the controller was successful. 24 | if (!flutter_controller_->engine() || !flutter_controller_->view()) { 25 | return false; 26 | } 27 | RegisterPlugins(flutter_controller_->engine()); 28 | SetChildContent(flutter_controller_->view()->GetNativeWindow()); 29 | return true; 30 | } 31 | 32 | void FlutterWindow::OnDestroy() { 33 | if (flutter_controller_) { 34 | flutter_controller_ = nullptr; 35 | } 36 | 37 | Win32Window::OnDestroy(); 38 | } 39 | 40 | LRESULT 41 | FlutterWindow::MessageHandler(HWND hwnd, UINT const message, 42 | WPARAM const wparam, 43 | LPARAM const lparam) noexcept { 44 | // Give Flutter, including plugins, an opportunity to handle window messages. 45 | if (flutter_controller_) { 46 | std::optional result = 47 | flutter_controller_->HandleTopLevelWindowProc(hwnd, message, wparam, 48 | lparam); 49 | if (result) { 50 | return *result; 51 | } 52 | } 53 | 54 | switch (message) { 55 | case WM_FONTCHANGE: 56 | flutter_controller_->engine()->ReloadSystemFonts(); 57 | break; 58 | } 59 | 60 | return Win32Window::MessageHandler(hwnd, message, wparam, lparam); 61 | } 62 | -------------------------------------------------------------------------------- /web/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | medrec 33 | 34 | 35 | 39 | 40 | 41 | 42 | 43 | 57 | 58 | 59 | -------------------------------------------------------------------------------- /lib/Pages/splash_screen.dart: -------------------------------------------------------------------------------- 1 | import 'dart:async'; 2 | 3 | import 'package:flutter/material.dart'; 4 | import 'package:medrec/Utils/routes.dart'; 5 | 6 | class Splash2 extends StatefulWidget { 7 | const Splash2({Key? key}) : super(key: key); 8 | 9 | @override 10 | State createState() => _Splash2State(); 11 | } 12 | 13 | class _Splash2State extends State { 14 | @override 15 | void initState() { 16 | super.initState(); 17 | Timer(const Duration(seconds: 3), 18 | () => Navigator.popAndPushNamed(context, MyRoutes.loginPage)); 19 | } 20 | 21 | @override 22 | Widget build(BuildContext context) { 23 | return Scaffold( 24 | body: Center( 25 | child: Column( 26 | mainAxisAlignment: MainAxisAlignment.center, 27 | children: [ 28 | Container( 29 | margin: const EdgeInsets.all(16), 30 | width: 250, 31 | height: 250, 32 | decoration: BoxDecoration( 33 | color: Colors.white, 34 | borderRadius: BorderRadius.circular(500), 35 | boxShadow: [ 36 | BoxShadow( 37 | color: Colors.grey.withOpacity(0.5), 38 | blurRadius: 50, 39 | offset: const Offset(0, 3), // changes position of shadow 40 | ), 41 | ], 42 | ), 43 | child: Padding( 44 | padding: const EdgeInsets.all(16.0), 45 | child: ClipRRect( 46 | borderRadius: BorderRadius.circular(500), 47 | child: Image.asset( 48 | 'assets/Icons/1024.png', 49 | fit: BoxFit.cover, 50 | ), 51 | ), 52 | ), 53 | ), 54 | const SizedBox( 55 | height: 20, 56 | ), 57 | const Text( 58 | "M E D R E C", 59 | style: TextStyle(fontSize: 50, fontWeight: FontWeight.bold), 60 | ), 61 | Text( 62 | "Manage Your Medical Records", 63 | style: Theme.of(context).textTheme.caption, 64 | ), 65 | ], 66 | ), 67 | ), 68 | ); 69 | } 70 | } 71 | -------------------------------------------------------------------------------- /android/app/build.gradle: -------------------------------------------------------------------------------- 1 | def localProperties = new Properties() 2 | def localPropertiesFile = rootProject.file('local.properties') 3 | if (localPropertiesFile.exists()) { 4 | localPropertiesFile.withReader('UTF-8') { reader -> 5 | localProperties.load(reader) 6 | } 7 | } 8 | 9 | def flutterRoot = localProperties.getProperty('flutter.sdk') 10 | if (flutterRoot == null) { 11 | throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.") 12 | } 13 | 14 | def flutterVersionCode = localProperties.getProperty('flutter.versionCode') 15 | if (flutterVersionCode == null) { 16 | flutterVersionCode = '1' 17 | } 18 | 19 | def flutterVersionName = localProperties.getProperty('flutter.versionName') 20 | if (flutterVersionName == null) { 21 | flutterVersionName = '1.0' 22 | } 23 | 24 | apply plugin: 'com.android.application' 25 | apply plugin: 'kotlin-android' 26 | apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle" 27 | 28 | android { 29 | compileSdkVersion flutter.compileSdkVersion 30 | ndkVersion flutter.ndkVersion 31 | 32 | compileOptions { 33 | sourceCompatibility JavaVersion.VERSION_1_8 34 | targetCompatibility JavaVersion.VERSION_1_8 35 | } 36 | 37 | kotlinOptions { 38 | jvmTarget = '1.8' 39 | } 40 | 41 | sourceSets { 42 | main.java.srcDirs += 'src/main/kotlin' 43 | } 44 | 45 | defaultConfig { 46 | // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). 47 | applicationId "com.example.medrec" 48 | // You can update the following values to match your application needs. 49 | // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-build-configuration. 50 | minSdkVersion flutter.minSdkVersion 51 | targetSdkVersion flutter.targetSdkVersion 52 | versionCode flutterVersionCode.toInteger() 53 | versionName flutterVersionName 54 | } 55 | 56 | buildTypes { 57 | release { 58 | // TODO: Add your own signing config for the release build. 59 | // Signing with the debug keys for now, so `flutter run --release` works. 60 | signingConfig signingConfigs.debug 61 | } 62 | } 63 | } 64 | 65 | flutter { 66 | source '../..' 67 | } 68 | 69 | dependencies { 70 | implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version" 71 | } 72 | -------------------------------------------------------------------------------- /ios/Runner/Base.lproj/LaunchScreen.storyboard: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | -------------------------------------------------------------------------------- /linux/flutter/CMakeLists.txt: -------------------------------------------------------------------------------- 1 | # This file controls Flutter-level build steps. It should not be edited. 2 | cmake_minimum_required(VERSION 3.10) 3 | 4 | set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral") 5 | 6 | # Configuration provided via flutter tool. 7 | include(${EPHEMERAL_DIR}/generated_config.cmake) 8 | 9 | # TODO: Move the rest of this into files in ephemeral. See 10 | # https://github.com/flutter/flutter/issues/57146. 11 | 12 | # Serves the same purpose as list(TRANSFORM ... PREPEND ...), 13 | # which isn't available in 3.10. 14 | function(list_prepend LIST_NAME PREFIX) 15 | set(NEW_LIST "") 16 | foreach(element ${${LIST_NAME}}) 17 | list(APPEND NEW_LIST "${PREFIX}${element}") 18 | endforeach(element) 19 | set(${LIST_NAME} "${NEW_LIST}" PARENT_SCOPE) 20 | endfunction() 21 | 22 | # === Flutter Library === 23 | # System-level dependencies. 24 | find_package(PkgConfig REQUIRED) 25 | pkg_check_modules(GTK REQUIRED IMPORTED_TARGET gtk+-3.0) 26 | pkg_check_modules(GLIB REQUIRED IMPORTED_TARGET glib-2.0) 27 | pkg_check_modules(GIO REQUIRED IMPORTED_TARGET gio-2.0) 28 | 29 | set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/libflutter_linux_gtk.so") 30 | 31 | # Published to parent scope for install step. 32 | set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE) 33 | set(FLUTTER_ICU_DATA_FILE "${EPHEMERAL_DIR}/icudtl.dat" PARENT_SCOPE) 34 | set(PROJECT_BUILD_DIR "${PROJECT_DIR}/build/" PARENT_SCOPE) 35 | set(AOT_LIBRARY "${PROJECT_DIR}/build/lib/libapp.so" PARENT_SCOPE) 36 | 37 | list(APPEND FLUTTER_LIBRARY_HEADERS 38 | "fl_basic_message_channel.h" 39 | "fl_binary_codec.h" 40 | "fl_binary_messenger.h" 41 | "fl_dart_project.h" 42 | "fl_engine.h" 43 | "fl_json_message_codec.h" 44 | "fl_json_method_codec.h" 45 | "fl_message_codec.h" 46 | "fl_method_call.h" 47 | "fl_method_channel.h" 48 | "fl_method_codec.h" 49 | "fl_method_response.h" 50 | "fl_plugin_registrar.h" 51 | "fl_plugin_registry.h" 52 | "fl_standard_message_codec.h" 53 | "fl_standard_method_codec.h" 54 | "fl_string_codec.h" 55 | "fl_value.h" 56 | "fl_view.h" 57 | "flutter_linux.h" 58 | ) 59 | list_prepend(FLUTTER_LIBRARY_HEADERS "${EPHEMERAL_DIR}/flutter_linux/") 60 | add_library(flutter INTERFACE) 61 | target_include_directories(flutter INTERFACE 62 | "${EPHEMERAL_DIR}" 63 | ) 64 | target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}") 65 | target_link_libraries(flutter INTERFACE 66 | PkgConfig::GTK 67 | PkgConfig::GLIB 68 | PkgConfig::GIO 69 | ) 70 | add_dependencies(flutter flutter_assemble) 71 | 72 | # === Flutter tool backend === 73 | # _phony_ is a non-existent file to force this command to run every time, 74 | # since currently there's no way to get a full input/output list from the 75 | # flutter tool. 76 | add_custom_command( 77 | OUTPUT ${FLUTTER_LIBRARY} ${FLUTTER_LIBRARY_HEADERS} 78 | ${CMAKE_CURRENT_BINARY_DIR}/_phony_ 79 | COMMAND ${CMAKE_COMMAND} -E env 80 | ${FLUTTER_TOOL_ENVIRONMENT} 81 | "${FLUTTER_ROOT}/packages/flutter_tools/bin/tool_backend.sh" 82 | ${FLUTTER_TARGET_PLATFORM} ${CMAKE_BUILD_TYPE} 83 | VERBATIM 84 | ) 85 | add_custom_target(flutter_assemble DEPENDS 86 | "${FLUTTER_LIBRARY}" 87 | ${FLUTTER_LIBRARY_HEADERS} 88 | ) 89 | -------------------------------------------------------------------------------- /ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json: -------------------------------------------------------------------------------- 1 | { 2 | "images" : [ 3 | { 4 | "size" : "20x20", 5 | "idiom" : "iphone", 6 | "filename" : "Icon-App-20x20@2x.png", 7 | "scale" : "2x" 8 | }, 9 | { 10 | "size" : "20x20", 11 | "idiom" : "iphone", 12 | "filename" : "Icon-App-20x20@3x.png", 13 | "scale" : "3x" 14 | }, 15 | { 16 | "size" : "29x29", 17 | "idiom" : "iphone", 18 | "filename" : "Icon-App-29x29@1x.png", 19 | "scale" : "1x" 20 | }, 21 | { 22 | "size" : "29x29", 23 | "idiom" : "iphone", 24 | "filename" : "Icon-App-29x29@2x.png", 25 | "scale" : "2x" 26 | }, 27 | { 28 | "size" : "29x29", 29 | "idiom" : "iphone", 30 | "filename" : "Icon-App-29x29@3x.png", 31 | "scale" : "3x" 32 | }, 33 | { 34 | "size" : "40x40", 35 | "idiom" : "iphone", 36 | "filename" : "Icon-App-40x40@2x.png", 37 | "scale" : "2x" 38 | }, 39 | { 40 | "size" : "40x40", 41 | "idiom" : "iphone", 42 | "filename" : "Icon-App-40x40@3x.png", 43 | "scale" : "3x" 44 | }, 45 | { 46 | "size" : "60x60", 47 | "idiom" : "iphone", 48 | "filename" : "Icon-App-60x60@2x.png", 49 | "scale" : "2x" 50 | }, 51 | { 52 | "size" : "60x60", 53 | "idiom" : "iphone", 54 | "filename" : "Icon-App-60x60@3x.png", 55 | "scale" : "3x" 56 | }, 57 | { 58 | "size" : "20x20", 59 | "idiom" : "ipad", 60 | "filename" : "Icon-App-20x20@1x.png", 61 | "scale" : "1x" 62 | }, 63 | { 64 | "size" : "20x20", 65 | "idiom" : "ipad", 66 | "filename" : "Icon-App-20x20@2x.png", 67 | "scale" : "2x" 68 | }, 69 | { 70 | "size" : "29x29", 71 | "idiom" : "ipad", 72 | "filename" : "Icon-App-29x29@1x.png", 73 | "scale" : "1x" 74 | }, 75 | { 76 | "size" : "29x29", 77 | "idiom" : "ipad", 78 | "filename" : "Icon-App-29x29@2x.png", 79 | "scale" : "2x" 80 | }, 81 | { 82 | "size" : "40x40", 83 | "idiom" : "ipad", 84 | "filename" : "Icon-App-40x40@1x.png", 85 | "scale" : "1x" 86 | }, 87 | { 88 | "size" : "40x40", 89 | "idiom" : "ipad", 90 | "filename" : "Icon-App-40x40@2x.png", 91 | "scale" : "2x" 92 | }, 93 | { 94 | "size" : "76x76", 95 | "idiom" : "ipad", 96 | "filename" : "Icon-App-76x76@1x.png", 97 | "scale" : "1x" 98 | }, 99 | { 100 | "size" : "76x76", 101 | "idiom" : "ipad", 102 | "filename" : "Icon-App-76x76@2x.png", 103 | "scale" : "2x" 104 | }, 105 | { 106 | "size" : "83.5x83.5", 107 | "idiom" : "ipad", 108 | "filename" : "Icon-App-83.5x83.5@2x.png", 109 | "scale" : "2x" 110 | }, 111 | { 112 | "size" : "1024x1024", 113 | "idiom" : "ios-marketing", 114 | "filename" : "Icon-App-1024x1024@1x.png", 115 | "scale" : "1x" 116 | } 117 | ], 118 | "info" : { 119 | "version" : 1, 120 | "author" : "xcode" 121 | } 122 | } 123 | -------------------------------------------------------------------------------- /windows/runner/Runner.rc: -------------------------------------------------------------------------------- 1 | // Microsoft Visual C++ generated resource script. 2 | // 3 | #pragma code_page(65001) 4 | #include "resource.h" 5 | 6 | #define APSTUDIO_READONLY_SYMBOLS 7 | ///////////////////////////////////////////////////////////////////////////// 8 | // 9 | // Generated from the TEXTINCLUDE 2 resource. 10 | // 11 | #include "winres.h" 12 | 13 | ///////////////////////////////////////////////////////////////////////////// 14 | #undef APSTUDIO_READONLY_SYMBOLS 15 | 16 | ///////////////////////////////////////////////////////////////////////////// 17 | // English (United States) resources 18 | 19 | #if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU) 20 | LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US 21 | 22 | #ifdef APSTUDIO_INVOKED 23 | ///////////////////////////////////////////////////////////////////////////// 24 | // 25 | // TEXTINCLUDE 26 | // 27 | 28 | 1 TEXTINCLUDE 29 | BEGIN 30 | "resource.h\0" 31 | END 32 | 33 | 2 TEXTINCLUDE 34 | BEGIN 35 | "#include ""winres.h""\r\n" 36 | "\0" 37 | END 38 | 39 | 3 TEXTINCLUDE 40 | BEGIN 41 | "\r\n" 42 | "\0" 43 | END 44 | 45 | #endif // APSTUDIO_INVOKED 46 | 47 | 48 | ///////////////////////////////////////////////////////////////////////////// 49 | // 50 | // Icon 51 | // 52 | 53 | // Icon with lowest ID value placed first to ensure application icon 54 | // remains consistent on all systems. 55 | IDI_APP_ICON ICON "resources\\app_icon.ico" 56 | 57 | 58 | ///////////////////////////////////////////////////////////////////////////// 59 | // 60 | // Version 61 | // 62 | 63 | #ifdef FLUTTER_BUILD_NUMBER 64 | #define VERSION_AS_NUMBER FLUTTER_BUILD_NUMBER 65 | #else 66 | #define VERSION_AS_NUMBER 1,0,0 67 | #endif 68 | 69 | #ifdef FLUTTER_BUILD_NAME 70 | #define VERSION_AS_STRING #FLUTTER_BUILD_NAME 71 | #else 72 | #define VERSION_AS_STRING "1.0.0" 73 | #endif 74 | 75 | VS_VERSION_INFO VERSIONINFO 76 | FILEVERSION VERSION_AS_NUMBER 77 | PRODUCTVERSION VERSION_AS_NUMBER 78 | FILEFLAGSMASK VS_FFI_FILEFLAGSMASK 79 | #ifdef _DEBUG 80 | FILEFLAGS VS_FF_DEBUG 81 | #else 82 | FILEFLAGS 0x0L 83 | #endif 84 | FILEOS VOS__WINDOWS32 85 | FILETYPE VFT_APP 86 | FILESUBTYPE 0x0L 87 | BEGIN 88 | BLOCK "StringFileInfo" 89 | BEGIN 90 | BLOCK "040904e4" 91 | BEGIN 92 | VALUE "CompanyName", "com.example" "\0" 93 | VALUE "FileDescription", "medrec" "\0" 94 | VALUE "FileVersion", VERSION_AS_STRING "\0" 95 | VALUE "InternalName", "medrec" "\0" 96 | VALUE "LegalCopyright", "Copyright (C) 2022 com.example. All rights reserved." "\0" 97 | VALUE "OriginalFilename", "medrec.exe" "\0" 98 | VALUE "ProductName", "medrec" "\0" 99 | VALUE "ProductVersion", VERSION_AS_STRING "\0" 100 | END 101 | END 102 | BLOCK "VarFileInfo" 103 | BEGIN 104 | VALUE "Translation", 0x409, 1252 105 | END 106 | END 107 | 108 | #endif // English (United States) resources 109 | ///////////////////////////////////////////////////////////////////////////// 110 | 111 | 112 | 113 | #ifndef APSTUDIO_INVOKED 114 | ///////////////////////////////////////////////////////////////////////////// 115 | // 116 | // Generated from the TEXTINCLUDE 3 resource. 117 | // 118 | 119 | 120 | ///////////////////////////////////////////////////////////////////////////// 121 | #endif // not APSTUDIO_INVOKED 122 | -------------------------------------------------------------------------------- /assets/contracts/patient.json: -------------------------------------------------------------------------------- 1 | [ 2 | { 3 | "inputs": [ 4 | { 5 | "internalType": "address", 6 | "name": "doc", 7 | "type": "address" 8 | }, 9 | { 10 | "internalType": "address", 11 | "name": "pat", 12 | "type": "address" 13 | }, 14 | { 15 | "internalType": "uint256", 16 | "name": "fee", 17 | "type": "uint256" 18 | } 19 | ], 20 | "name": "addAuthorization", 21 | "outputs": [], 22 | "stateMutability": "payable", 23 | "type": "function" 24 | }, 25 | { 26 | "inputs": [ 27 | { 28 | "internalType": "address", 29 | "name": "pat", 30 | "type": "address" 31 | } 32 | ], 33 | "name": "addPatient", 34 | "outputs": [], 35 | "stateMutability": "nonpayable", 36 | "type": "function" 37 | }, 38 | { 39 | "inputs": [ 40 | { 41 | "internalType": "string", 42 | "name": "presc", 43 | "type": "string" 44 | }, 45 | { 46 | "internalType": "address", 47 | "name": "pat", 48 | "type": "address" 49 | }, 50 | { 51 | "internalType": "address payable", 52 | "name": "doc", 53 | "type": "address" 54 | } 55 | ], 56 | "name": "setPrescription", 57 | "outputs": [], 58 | "stateMutability": "nonpayable", 59 | "type": "function" 60 | }, 61 | { 62 | "inputs": [ 63 | { 64 | "internalType": "address", 65 | "name": "doc", 66 | "type": "address" 67 | }, 68 | { 69 | "internalType": "address", 70 | "name": "pat", 71 | "type": "address" 72 | } 73 | ], 74 | "name": "isAuthorized", 75 | "outputs": [ 76 | { 77 | "internalType": "bool", 78 | "name": "", 79 | "type": "bool" 80 | } 81 | ], 82 | "stateMutability": "view", 83 | "type": "function" 84 | }, 85 | { 86 | "inputs": [ 87 | { 88 | "internalType": "address", 89 | "name": "pat", 90 | "type": "address" 91 | } 92 | ], 93 | "name": "isPatient", 94 | "outputs": [ 95 | { 96 | "internalType": "bool", 97 | "name": "", 98 | "type": "bool" 99 | } 100 | ], 101 | "stateMutability": "view", 102 | "type": "function" 103 | }, 104 | { 105 | "inputs": [ 106 | { 107 | "internalType": "address", 108 | "name": "pat", 109 | "type": "address" 110 | } 111 | ], 112 | "name": "viewPrescription", 113 | "outputs": [ 114 | { 115 | "internalType": "string[]", 116 | "name": "", 117 | "type": "string[]" 118 | } 119 | ], 120 | "stateMutability": "view", 121 | "type": "function" 122 | } 123 | ] -------------------------------------------------------------------------------- /ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme: -------------------------------------------------------------------------------- 1 | 2 | 5 | 8 | 9 | 15 | 21 | 22 | 23 | 24 | 25 | 30 | 31 | 37 | 38 | 39 | 40 | 41 | 42 | 52 | 54 | 60 | 61 | 62 | 63 | 69 | 71 | 77 | 78 | 79 | 80 | 82 | 83 | 86 | 87 | 88 | -------------------------------------------------------------------------------- /macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme: -------------------------------------------------------------------------------- 1 | 2 | 5 | 8 | 9 | 15 | 21 | 22 | 23 | 24 | 25 | 30 | 31 | 37 | 38 | 39 | 40 | 41 | 42 | 52 | 54 | 60 | 61 | 62 | 63 | 69 | 71 | 77 | 78 | 79 | 80 | 82 | 83 | 86 | 87 | 88 | -------------------------------------------------------------------------------- /windows/runner/win32_window.h: -------------------------------------------------------------------------------- 1 | #ifndef RUNNER_WIN32_WINDOW_H_ 2 | #define RUNNER_WIN32_WINDOW_H_ 3 | 4 | #include 5 | 6 | #include 7 | #include 8 | #include 9 | 10 | // A class abstraction for a high DPI-aware Win32 Window. Intended to be 11 | // inherited from by classes that wish to specialize with custom 12 | // rendering and input handling 13 | class Win32Window { 14 | public: 15 | struct Point { 16 | unsigned int x; 17 | unsigned int y; 18 | Point(unsigned int x, unsigned int y) : x(x), y(y) {} 19 | }; 20 | 21 | struct Size { 22 | unsigned int width; 23 | unsigned int height; 24 | Size(unsigned int width, unsigned int height) 25 | : width(width), height(height) {} 26 | }; 27 | 28 | Win32Window(); 29 | virtual ~Win32Window(); 30 | 31 | // Creates and shows a win32 window with |title| and position and size using 32 | // |origin| and |size|. New windows are created on the default monitor. Window 33 | // sizes are specified to the OS in physical pixels, hence to ensure a 34 | // consistent size to will treat the width height passed in to this function 35 | // as logical pixels and scale to appropriate for the default monitor. Returns 36 | // true if the window was created successfully. 37 | bool CreateAndShow(const std::wstring& title, 38 | const Point& origin, 39 | const Size& size); 40 | 41 | // Release OS resources associated with window. 42 | void Destroy(); 43 | 44 | // Inserts |content| into the window tree. 45 | void SetChildContent(HWND content); 46 | 47 | // Returns the backing Window handle to enable clients to set icon and other 48 | // window properties. Returns nullptr if the window has been destroyed. 49 | HWND GetHandle(); 50 | 51 | // If true, closing this window will quit the application. 52 | void SetQuitOnClose(bool quit_on_close); 53 | 54 | // Return a RECT representing the bounds of the current client area. 55 | RECT GetClientArea(); 56 | 57 | protected: 58 | // Processes and route salient window messages for mouse handling, 59 | // size change and DPI. Delegates handling of these to member overloads that 60 | // inheriting classes can handle. 61 | virtual LRESULT MessageHandler(HWND window, 62 | UINT const message, 63 | WPARAM const wparam, 64 | LPARAM const lparam) noexcept; 65 | 66 | // Called when CreateAndShow is called, allowing subclass window-related 67 | // setup. Subclasses should return false if setup fails. 68 | virtual bool OnCreate(); 69 | 70 | // Called when Destroy is called. 71 | virtual void OnDestroy(); 72 | 73 | private: 74 | friend class WindowClassRegistrar; 75 | 76 | // OS callback called by message pump. Handles the WM_NCCREATE message which 77 | // is passed when the non-client area is being created and enables automatic 78 | // non-client DPI scaling so that the non-client area automatically 79 | // responsponds to changes in DPI. All other messages are handled by 80 | // MessageHandler. 81 | static LRESULT CALLBACK WndProc(HWND const window, 82 | UINT const message, 83 | WPARAM const wparam, 84 | LPARAM const lparam) noexcept; 85 | 86 | // Retrieves a class instance pointer for |window| 87 | static Win32Window* GetThisFromHandle(HWND const window) noexcept; 88 | 89 | bool quit_on_close_ = false; 90 | 91 | // window handle for top level window. 92 | HWND window_handle_ = nullptr; 93 | 94 | // window handle for hosted content. 95 | HWND child_content_ = nullptr; 96 | }; 97 | 98 | #endif // RUNNER_WIN32_WINDOW_H_ 99 | -------------------------------------------------------------------------------- /pubspec.yaml: -------------------------------------------------------------------------------- 1 | name: medrec 2 | description: A new Flutter project. 3 | 4 | # The following line prevents the package from being accidentally published to 5 | # pub.dev using `flutter pub publish`. This is preferred for private packages. 6 | publish_to: "none" # Remove this line if you wish to publish to pub.dev 7 | 8 | # The following defines the version and build number for your application. 9 | # A version number is three numbers separated by dots, like 1.2.43 10 | # followed by an optional build number separated by a +. 11 | # Both the version and the builder number may be overridden in flutter 12 | # build by specifying --build-name and --build-number, respectively. 13 | # In Android, build-name is used as versionName while build-number used as versionCode. 14 | # Read more about Android versioning at https://developer.android.com/studio/publish/versioning 15 | # In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion. 16 | # Read more about iOS versioning at 17 | # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html 18 | version: 1.0.0+1 19 | 20 | environment: 21 | sdk: ">=2.17.1 <3.0.0" 22 | 23 | # Dependencies specify other packages that your package needs in order to work. 24 | # To automatically upgrade your package dependencies to the latest versions 25 | # consider running `flutter pub upgrade --major-versions`. Alternatively, 26 | # dependencies can be manually updated by changing the version numbers below to 27 | # the latest version available on pub.dev. To see which dependencies have newer 28 | # versions available, run `flutter pub outdated`. 29 | dependencies: 30 | cupertino_icons: ^1.0.2 31 | flutter: 32 | sdk: flutter 33 | fluttertoast: ^8.0.9 34 | font_awesome_flutter: ^10.1.0 35 | google_fonts: ^3.0.1 36 | web3dart: ^2.3.5 37 | 38 | dev_dependencies: 39 | # The "flutter_lints" package below contains a set of recommended lints to 40 | # encourage good coding practices. The lint set provided by the package is 41 | # activated in the `analysis_options.yaml` file located at the root of your 42 | # package. See that file for information about deactivating specific lint 43 | # rules and activating additional ones. 44 | flutter_lints: ^2.0.0 45 | flutter_test: 46 | sdk: flutter 47 | 48 | # For information on the generic Dart part of this file, see the 49 | # following page: https://dart.dev/tools/pub/pubspec 50 | # The following section is specific to Flutter packages. 51 | flutter: 52 | # The following line ensures that the Material Icons font is 53 | # included with your application, so that you can use the icons in 54 | # the material Icons class. 55 | uses-material-design: true 56 | 57 | # To add assets to your application, add an assets section, like this: 58 | assets: 59 | - assets/images/ 60 | - assets/Icons/ 61 | - assets/contracts/ 62 | 63 | # An image asset can refer to one or more resolution-specific "variants", see 64 | # https://flutter.dev/assets-and-images/#resolution-aware 65 | # For details regarding adding assets from package dependencies, see 66 | # https://flutter.dev/assets-and-images/#from-packages 67 | # To add custom fonts to your application, add a fonts section here, 68 | # in this "flutter" section. Each entry in this list should have a 69 | # "family" key with the font family name, and a "fonts" key with a 70 | # list giving the asset and other descriptors for the font. For 71 | # example: 72 | # fonts: 73 | # - family: Schyler 74 | # fonts: 75 | # - asset: fonts/Schyler-Regular.ttf 76 | # - asset: fonts/Schyler-Italic.ttf 77 | # style: italic 78 | # - family: Trajan Pro 79 | # fonts: 80 | # - asset: fonts/TrajanPro.ttf 81 | # - asset: fonts/TrajanPro_Bold.ttf 82 | # weight: 700 83 | # 84 | # For details regarding fonts from package dependencies, 85 | # see https://flutter.dev/custom-fonts/#from-packages 86 | -------------------------------------------------------------------------------- /windows/flutter/CMakeLists.txt: -------------------------------------------------------------------------------- 1 | # This file controls Flutter-level build steps. It should not be edited. 2 | cmake_minimum_required(VERSION 3.14) 3 | 4 | set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral") 5 | 6 | # Configuration provided via flutter tool. 7 | include(${EPHEMERAL_DIR}/generated_config.cmake) 8 | 9 | # TODO: Move the rest of this into files in ephemeral. See 10 | # https://github.com/flutter/flutter/issues/57146. 11 | set(WRAPPER_ROOT "${EPHEMERAL_DIR}/cpp_client_wrapper") 12 | 13 | # === Flutter Library === 14 | set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/flutter_windows.dll") 15 | 16 | # Published to parent scope for install step. 17 | set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE) 18 | set(FLUTTER_ICU_DATA_FILE "${EPHEMERAL_DIR}/icudtl.dat" PARENT_SCOPE) 19 | set(PROJECT_BUILD_DIR "${PROJECT_DIR}/build/" PARENT_SCOPE) 20 | set(AOT_LIBRARY "${PROJECT_DIR}/build/windows/app.so" PARENT_SCOPE) 21 | 22 | list(APPEND FLUTTER_LIBRARY_HEADERS 23 | "flutter_export.h" 24 | "flutter_windows.h" 25 | "flutter_messenger.h" 26 | "flutter_plugin_registrar.h" 27 | "flutter_texture_registrar.h" 28 | ) 29 | list(TRANSFORM FLUTTER_LIBRARY_HEADERS PREPEND "${EPHEMERAL_DIR}/") 30 | add_library(flutter INTERFACE) 31 | target_include_directories(flutter INTERFACE 32 | "${EPHEMERAL_DIR}" 33 | ) 34 | target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}.lib") 35 | add_dependencies(flutter flutter_assemble) 36 | 37 | # === Wrapper === 38 | list(APPEND CPP_WRAPPER_SOURCES_CORE 39 | "core_implementations.cc" 40 | "standard_codec.cc" 41 | ) 42 | list(TRANSFORM CPP_WRAPPER_SOURCES_CORE PREPEND "${WRAPPER_ROOT}/") 43 | list(APPEND CPP_WRAPPER_SOURCES_PLUGIN 44 | "plugin_registrar.cc" 45 | ) 46 | list(TRANSFORM CPP_WRAPPER_SOURCES_PLUGIN PREPEND "${WRAPPER_ROOT}/") 47 | list(APPEND CPP_WRAPPER_SOURCES_APP 48 | "flutter_engine.cc" 49 | "flutter_view_controller.cc" 50 | ) 51 | list(TRANSFORM CPP_WRAPPER_SOURCES_APP PREPEND "${WRAPPER_ROOT}/") 52 | 53 | # Wrapper sources needed for a plugin. 54 | add_library(flutter_wrapper_plugin STATIC 55 | ${CPP_WRAPPER_SOURCES_CORE} 56 | ${CPP_WRAPPER_SOURCES_PLUGIN} 57 | ) 58 | apply_standard_settings(flutter_wrapper_plugin) 59 | set_target_properties(flutter_wrapper_plugin PROPERTIES 60 | POSITION_INDEPENDENT_CODE ON) 61 | set_target_properties(flutter_wrapper_plugin PROPERTIES 62 | CXX_VISIBILITY_PRESET hidden) 63 | target_link_libraries(flutter_wrapper_plugin PUBLIC flutter) 64 | target_include_directories(flutter_wrapper_plugin PUBLIC 65 | "${WRAPPER_ROOT}/include" 66 | ) 67 | add_dependencies(flutter_wrapper_plugin flutter_assemble) 68 | 69 | # Wrapper sources needed for the runner. 70 | add_library(flutter_wrapper_app STATIC 71 | ${CPP_WRAPPER_SOURCES_CORE} 72 | ${CPP_WRAPPER_SOURCES_APP} 73 | ) 74 | apply_standard_settings(flutter_wrapper_app) 75 | target_link_libraries(flutter_wrapper_app PUBLIC flutter) 76 | target_include_directories(flutter_wrapper_app PUBLIC 77 | "${WRAPPER_ROOT}/include" 78 | ) 79 | add_dependencies(flutter_wrapper_app flutter_assemble) 80 | 81 | # === Flutter tool backend === 82 | # _phony_ is a non-existent file to force this command to run every time, 83 | # since currently there's no way to get a full input/output list from the 84 | # flutter tool. 85 | set(PHONY_OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/_phony_") 86 | set_source_files_properties("${PHONY_OUTPUT}" PROPERTIES SYMBOLIC TRUE) 87 | add_custom_command( 88 | OUTPUT ${FLUTTER_LIBRARY} ${FLUTTER_LIBRARY_HEADERS} 89 | ${CPP_WRAPPER_SOURCES_CORE} ${CPP_WRAPPER_SOURCES_PLUGIN} 90 | ${CPP_WRAPPER_SOURCES_APP} 91 | ${PHONY_OUTPUT} 92 | COMMAND ${CMAKE_COMMAND} -E env 93 | ${FLUTTER_TOOL_ENVIRONMENT} 94 | "${FLUTTER_ROOT}/packages/flutter_tools/bin/tool_backend.bat" 95 | windows-x64 $ 96 | VERBATIM 97 | ) 98 | add_custom_target(flutter_assemble DEPENDS 99 | "${FLUTTER_LIBRARY}" 100 | ${FLUTTER_LIBRARY_HEADERS} 101 | ${CPP_WRAPPER_SOURCES_CORE} 102 | ${CPP_WRAPPER_SOURCES_PLUGIN} 103 | ${CPP_WRAPPER_SOURCES_APP} 104 | ) 105 | -------------------------------------------------------------------------------- /linux/my_application.cc: -------------------------------------------------------------------------------- 1 | #include "my_application.h" 2 | 3 | #include 4 | #ifdef GDK_WINDOWING_X11 5 | #include 6 | #endif 7 | 8 | #include "flutter/generated_plugin_registrant.h" 9 | 10 | struct _MyApplication { 11 | GtkApplication parent_instance; 12 | char** dart_entrypoint_arguments; 13 | }; 14 | 15 | G_DEFINE_TYPE(MyApplication, my_application, GTK_TYPE_APPLICATION) 16 | 17 | // Implements GApplication::activate. 18 | static void my_application_activate(GApplication* application) { 19 | MyApplication* self = MY_APPLICATION(application); 20 | GtkWindow* window = 21 | GTK_WINDOW(gtk_application_window_new(GTK_APPLICATION(application))); 22 | 23 | // Use a header bar when running in GNOME as this is the common style used 24 | // by applications and is the setup most users will be using (e.g. Ubuntu 25 | // desktop). 26 | // If running on X and not using GNOME then just use a traditional title bar 27 | // in case the window manager does more exotic layout, e.g. tiling. 28 | // If running on Wayland assume the header bar will work (may need changing 29 | // if future cases occur). 30 | gboolean use_header_bar = TRUE; 31 | #ifdef GDK_WINDOWING_X11 32 | GdkScreen* screen = gtk_window_get_screen(window); 33 | if (GDK_IS_X11_SCREEN(screen)) { 34 | const gchar* wm_name = gdk_x11_screen_get_window_manager_name(screen); 35 | if (g_strcmp0(wm_name, "GNOME Shell") != 0) { 36 | use_header_bar = FALSE; 37 | } 38 | } 39 | #endif 40 | if (use_header_bar) { 41 | GtkHeaderBar* header_bar = GTK_HEADER_BAR(gtk_header_bar_new()); 42 | gtk_widget_show(GTK_WIDGET(header_bar)); 43 | gtk_header_bar_set_title(header_bar, "medrec"); 44 | gtk_header_bar_set_show_close_button(header_bar, TRUE); 45 | gtk_window_set_titlebar(window, GTK_WIDGET(header_bar)); 46 | } else { 47 | gtk_window_set_title(window, "medrec"); 48 | } 49 | 50 | gtk_window_set_default_size(window, 1280, 720); 51 | gtk_widget_show(GTK_WIDGET(window)); 52 | 53 | g_autoptr(FlDartProject) project = fl_dart_project_new(); 54 | fl_dart_project_set_dart_entrypoint_arguments(project, self->dart_entrypoint_arguments); 55 | 56 | FlView* view = fl_view_new(project); 57 | gtk_widget_show(GTK_WIDGET(view)); 58 | gtk_container_add(GTK_CONTAINER(window), GTK_WIDGET(view)); 59 | 60 | fl_register_plugins(FL_PLUGIN_REGISTRY(view)); 61 | 62 | gtk_widget_grab_focus(GTK_WIDGET(view)); 63 | } 64 | 65 | // Implements GApplication::local_command_line. 66 | static gboolean my_application_local_command_line(GApplication* application, gchar*** arguments, int* exit_status) { 67 | MyApplication* self = MY_APPLICATION(application); 68 | // Strip out the first argument as it is the binary name. 69 | self->dart_entrypoint_arguments = g_strdupv(*arguments + 1); 70 | 71 | g_autoptr(GError) error = nullptr; 72 | if (!g_application_register(application, nullptr, &error)) { 73 | g_warning("Failed to register: %s", error->message); 74 | *exit_status = 1; 75 | return TRUE; 76 | } 77 | 78 | g_application_activate(application); 79 | *exit_status = 0; 80 | 81 | return TRUE; 82 | } 83 | 84 | // Implements GObject::dispose. 85 | static void my_application_dispose(GObject* object) { 86 | MyApplication* self = MY_APPLICATION(object); 87 | g_clear_pointer(&self->dart_entrypoint_arguments, g_strfreev); 88 | G_OBJECT_CLASS(my_application_parent_class)->dispose(object); 89 | } 90 | 91 | static void my_application_class_init(MyApplicationClass* klass) { 92 | G_APPLICATION_CLASS(klass)->activate = my_application_activate; 93 | G_APPLICATION_CLASS(klass)->local_command_line = my_application_local_command_line; 94 | G_OBJECT_CLASS(klass)->dispose = my_application_dispose; 95 | } 96 | 97 | static void my_application_init(MyApplication* self) {} 98 | 99 | MyApplication* my_application_new() { 100 | return MY_APPLICATION(g_object_new(my_application_get_type(), 101 | "application-id", APPLICATION_ID, 102 | "flags", G_APPLICATION_NON_UNIQUE, 103 | nullptr)); 104 | } 105 | -------------------------------------------------------------------------------- /windows/CMakeLists.txt: -------------------------------------------------------------------------------- 1 | # Project-level configuration. 2 | cmake_minimum_required(VERSION 3.14) 3 | project(medrec LANGUAGES CXX) 4 | 5 | # The name of the executable created for the application. Change this to change 6 | # the on-disk name of your application. 7 | set(BINARY_NAME "medrec") 8 | 9 | # Explicitly opt in to modern CMake behaviors to avoid warnings with recent 10 | # versions of CMake. 11 | cmake_policy(SET CMP0063 NEW) 12 | 13 | # Define build configuration option. 14 | get_property(IS_MULTICONFIG GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG) 15 | if(IS_MULTICONFIG) 16 | set(CMAKE_CONFIGURATION_TYPES "Debug;Profile;Release" 17 | CACHE STRING "" FORCE) 18 | else() 19 | if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) 20 | set(CMAKE_BUILD_TYPE "Debug" CACHE 21 | STRING "Flutter build mode" FORCE) 22 | set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS 23 | "Debug" "Profile" "Release") 24 | endif() 25 | endif() 26 | # Define settings for the Profile build mode. 27 | set(CMAKE_EXE_LINKER_FLAGS_PROFILE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}") 28 | set(CMAKE_SHARED_LINKER_FLAGS_PROFILE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE}") 29 | set(CMAKE_C_FLAGS_PROFILE "${CMAKE_C_FLAGS_RELEASE}") 30 | set(CMAKE_CXX_FLAGS_PROFILE "${CMAKE_CXX_FLAGS_RELEASE}") 31 | 32 | # Use Unicode for all projects. 33 | add_definitions(-DUNICODE -D_UNICODE) 34 | 35 | # Compilation settings that should be applied to most targets. 36 | # 37 | # Be cautious about adding new options here, as plugins use this function by 38 | # default. In most cases, you should add new options to specific targets instead 39 | # of modifying this function. 40 | function(APPLY_STANDARD_SETTINGS TARGET) 41 | target_compile_features(${TARGET} PUBLIC cxx_std_17) 42 | target_compile_options(${TARGET} PRIVATE /W4 /WX /wd"4100") 43 | target_compile_options(${TARGET} PRIVATE /EHsc) 44 | target_compile_definitions(${TARGET} PRIVATE "_HAS_EXCEPTIONS=0") 45 | target_compile_definitions(${TARGET} PRIVATE "$<$:_DEBUG>") 46 | endfunction() 47 | 48 | # Flutter library and tool build rules. 49 | set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter") 50 | add_subdirectory(${FLUTTER_MANAGED_DIR}) 51 | 52 | # Application build; see runner/CMakeLists.txt. 53 | add_subdirectory("runner") 54 | 55 | # Generated plugin build rules, which manage building the plugins and adding 56 | # them to the application. 57 | include(flutter/generated_plugins.cmake) 58 | 59 | 60 | # === Installation === 61 | # Support files are copied into place next to the executable, so that it can 62 | # run in place. This is done instead of making a separate bundle (as on Linux) 63 | # so that building and running from within Visual Studio will work. 64 | set(BUILD_BUNDLE_DIR "$") 65 | # Make the "install" step default, as it's required to run. 66 | set(CMAKE_VS_INCLUDE_INSTALL_TO_DEFAULT_BUILD 1) 67 | if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) 68 | set(CMAKE_INSTALL_PREFIX "${BUILD_BUNDLE_DIR}" CACHE PATH "..." FORCE) 69 | endif() 70 | 71 | set(INSTALL_BUNDLE_DATA_DIR "${CMAKE_INSTALL_PREFIX}/data") 72 | set(INSTALL_BUNDLE_LIB_DIR "${CMAKE_INSTALL_PREFIX}") 73 | 74 | install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}" 75 | COMPONENT Runtime) 76 | 77 | install(FILES "${FLUTTER_ICU_DATA_FILE}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" 78 | COMPONENT Runtime) 79 | 80 | install(FILES "${FLUTTER_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" 81 | COMPONENT Runtime) 82 | 83 | if(PLUGIN_BUNDLED_LIBRARIES) 84 | install(FILES "${PLUGIN_BUNDLED_LIBRARIES}" 85 | DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" 86 | COMPONENT Runtime) 87 | endif() 88 | 89 | # Fully re-copy the assets directory on each build to avoid having stale files 90 | # from a previous install. 91 | set(FLUTTER_ASSET_DIR_NAME "flutter_assets") 92 | install(CODE " 93 | file(REMOVE_RECURSE \"${INSTALL_BUNDLE_DATA_DIR}/${FLUTTER_ASSET_DIR_NAME}\") 94 | " COMPONENT Runtime) 95 | install(DIRECTORY "${PROJECT_BUILD_DIR}/${FLUTTER_ASSET_DIR_NAME}" 96 | DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" COMPONENT Runtime) 97 | 98 | # Install the AOT library on non-Debug builds only. 99 | install(FILES "${AOT_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" 100 | CONFIGURATIONS Profile;Release 101 | COMPONENT Runtime) 102 | -------------------------------------------------------------------------------- /linux/CMakeLists.txt: -------------------------------------------------------------------------------- 1 | # Project-level configuration. 2 | cmake_minimum_required(VERSION 3.10) 3 | project(runner LANGUAGES CXX) 4 | 5 | # The name of the executable created for the application. Change this to change 6 | # the on-disk name of your application. 7 | set(BINARY_NAME "medrec") 8 | # The unique GTK application identifier for this application. See: 9 | # https://wiki.gnome.org/HowDoI/ChooseApplicationID 10 | set(APPLICATION_ID "com.example.medrec") 11 | 12 | # Explicitly opt in to modern CMake behaviors to avoid warnings with recent 13 | # versions of CMake. 14 | cmake_policy(SET CMP0063 NEW) 15 | 16 | # Load bundled libraries from the lib/ directory relative to the binary. 17 | set(CMAKE_INSTALL_RPATH "$ORIGIN/lib") 18 | 19 | # Root filesystem for cross-building. 20 | if(FLUTTER_TARGET_PLATFORM_SYSROOT) 21 | set(CMAKE_SYSROOT ${FLUTTER_TARGET_PLATFORM_SYSROOT}) 22 | set(CMAKE_FIND_ROOT_PATH ${CMAKE_SYSROOT}) 23 | set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) 24 | set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY) 25 | set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) 26 | set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) 27 | endif() 28 | 29 | # Define build configuration options. 30 | if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) 31 | set(CMAKE_BUILD_TYPE "Debug" CACHE 32 | STRING "Flutter build mode" FORCE) 33 | set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS 34 | "Debug" "Profile" "Release") 35 | endif() 36 | 37 | # Compilation settings that should be applied to most targets. 38 | # 39 | # Be cautious about adding new options here, as plugins use this function by 40 | # default. In most cases, you should add new options to specific targets instead 41 | # of modifying this function. 42 | function(APPLY_STANDARD_SETTINGS TARGET) 43 | target_compile_features(${TARGET} PUBLIC cxx_std_14) 44 | target_compile_options(${TARGET} PRIVATE -Wall -Werror) 45 | target_compile_options(${TARGET} PRIVATE "$<$>:-O3>") 46 | target_compile_definitions(${TARGET} PRIVATE "$<$>:NDEBUG>") 47 | endfunction() 48 | 49 | # Flutter library and tool build rules. 50 | set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter") 51 | add_subdirectory(${FLUTTER_MANAGED_DIR}) 52 | 53 | # System-level dependencies. 54 | find_package(PkgConfig REQUIRED) 55 | pkg_check_modules(GTK REQUIRED IMPORTED_TARGET gtk+-3.0) 56 | 57 | add_definitions(-DAPPLICATION_ID="${APPLICATION_ID}") 58 | 59 | # Define the application target. To change its name, change BINARY_NAME above, 60 | # not the value here, or `flutter run` will no longer work. 61 | # 62 | # Any new source files that you add to the application should be added here. 63 | add_executable(${BINARY_NAME} 64 | "main.cc" 65 | "my_application.cc" 66 | "${FLUTTER_MANAGED_DIR}/generated_plugin_registrant.cc" 67 | ) 68 | 69 | # Apply the standard set of build settings. This can be removed for applications 70 | # that need different build settings. 71 | apply_standard_settings(${BINARY_NAME}) 72 | 73 | # Add dependency libraries. Add any application-specific dependencies here. 74 | target_link_libraries(${BINARY_NAME} PRIVATE flutter) 75 | target_link_libraries(${BINARY_NAME} PRIVATE PkgConfig::GTK) 76 | 77 | # Run the Flutter tool portions of the build. This must not be removed. 78 | add_dependencies(${BINARY_NAME} flutter_assemble) 79 | 80 | # Only the install-generated bundle's copy of the executable will launch 81 | # correctly, since the resources must in the right relative locations. To avoid 82 | # people trying to run the unbundled copy, put it in a subdirectory instead of 83 | # the default top-level location. 84 | set_target_properties(${BINARY_NAME} 85 | PROPERTIES 86 | RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/intermediates_do_not_run" 87 | ) 88 | 89 | # Generated plugin build rules, which manage building the plugins and adding 90 | # them to the application. 91 | include(flutter/generated_plugins.cmake) 92 | 93 | 94 | # === Installation === 95 | # By default, "installing" just makes a relocatable bundle in the build 96 | # directory. 97 | set(BUILD_BUNDLE_DIR "${PROJECT_BINARY_DIR}/bundle") 98 | if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT) 99 | set(CMAKE_INSTALL_PREFIX "${BUILD_BUNDLE_DIR}" CACHE PATH "..." FORCE) 100 | endif() 101 | 102 | # Start with a clean build bundle directory every time. 103 | install(CODE " 104 | file(REMOVE_RECURSE \"${BUILD_BUNDLE_DIR}/\") 105 | " COMPONENT Runtime) 106 | 107 | set(INSTALL_BUNDLE_DATA_DIR "${CMAKE_INSTALL_PREFIX}/data") 108 | set(INSTALL_BUNDLE_LIB_DIR "${CMAKE_INSTALL_PREFIX}/lib") 109 | 110 | install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}" 111 | COMPONENT Runtime) 112 | 113 | install(FILES "${FLUTTER_ICU_DATA_FILE}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" 114 | COMPONENT Runtime) 115 | 116 | install(FILES "${FLUTTER_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" 117 | COMPONENT Runtime) 118 | 119 | foreach(bundled_library ${PLUGIN_BUNDLED_LIBRARIES}) 120 | install(FILES "${bundled_library}" 121 | DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" 122 | COMPONENT Runtime) 123 | endforeach(bundled_library) 124 | 125 | # Fully re-copy the assets directory on each build to avoid having stale files 126 | # from a previous install. 127 | set(FLUTTER_ASSET_DIR_NAME "flutter_assets") 128 | install(CODE " 129 | file(REMOVE_RECURSE \"${INSTALL_BUNDLE_DATA_DIR}/${FLUTTER_ASSET_DIR_NAME}\") 130 | " COMPONENT Runtime) 131 | install(DIRECTORY "${PROJECT_BUILD_DIR}/${FLUTTER_ASSET_DIR_NAME}" 132 | DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" COMPONENT Runtime) 133 | 134 | # Install the AOT library on non-Debug builds only. 135 | if(NOT CMAKE_BUILD_TYPE MATCHES "Debug") 136 | install(FILES "${AOT_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}" 137 | COMPONENT Runtime) 138 | endif() 139 | -------------------------------------------------------------------------------- /windows/runner/win32_window.cpp: -------------------------------------------------------------------------------- 1 | #include "win32_window.h" 2 | 3 | #include 4 | 5 | #include "resource.h" 6 | 7 | namespace { 8 | 9 | constexpr const wchar_t kWindowClassName[] = L"FLUTTER_RUNNER_WIN32_WINDOW"; 10 | 11 | // The number of Win32Window objects that currently exist. 12 | static int g_active_window_count = 0; 13 | 14 | using EnableNonClientDpiScaling = BOOL __stdcall(HWND hwnd); 15 | 16 | // Scale helper to convert logical scaler values to physical using passed in 17 | // scale factor 18 | int Scale(int source, double scale_factor) { 19 | return static_cast(source * scale_factor); 20 | } 21 | 22 | // Dynamically loads the |EnableNonClientDpiScaling| from the User32 module. 23 | // This API is only needed for PerMonitor V1 awareness mode. 24 | void EnableFullDpiSupportIfAvailable(HWND hwnd) { 25 | HMODULE user32_module = LoadLibraryA("User32.dll"); 26 | if (!user32_module) { 27 | return; 28 | } 29 | auto enable_non_client_dpi_scaling = 30 | reinterpret_cast( 31 | GetProcAddress(user32_module, "EnableNonClientDpiScaling")); 32 | if (enable_non_client_dpi_scaling != nullptr) { 33 | enable_non_client_dpi_scaling(hwnd); 34 | FreeLibrary(user32_module); 35 | } 36 | } 37 | 38 | } // namespace 39 | 40 | // Manages the Win32Window's window class registration. 41 | class WindowClassRegistrar { 42 | public: 43 | ~WindowClassRegistrar() = default; 44 | 45 | // Returns the singleton registar instance. 46 | static WindowClassRegistrar* GetInstance() { 47 | if (!instance_) { 48 | instance_ = new WindowClassRegistrar(); 49 | } 50 | return instance_; 51 | } 52 | 53 | // Returns the name of the window class, registering the class if it hasn't 54 | // previously been registered. 55 | const wchar_t* GetWindowClass(); 56 | 57 | // Unregisters the window class. Should only be called if there are no 58 | // instances of the window. 59 | void UnregisterWindowClass(); 60 | 61 | private: 62 | WindowClassRegistrar() = default; 63 | 64 | static WindowClassRegistrar* instance_; 65 | 66 | bool class_registered_ = false; 67 | }; 68 | 69 | WindowClassRegistrar* WindowClassRegistrar::instance_ = nullptr; 70 | 71 | const wchar_t* WindowClassRegistrar::GetWindowClass() { 72 | if (!class_registered_) { 73 | WNDCLASS window_class{}; 74 | window_class.hCursor = LoadCursor(nullptr, IDC_ARROW); 75 | window_class.lpszClassName = kWindowClassName; 76 | window_class.style = CS_HREDRAW | CS_VREDRAW; 77 | window_class.cbClsExtra = 0; 78 | window_class.cbWndExtra = 0; 79 | window_class.hInstance = GetModuleHandle(nullptr); 80 | window_class.hIcon = 81 | LoadIcon(window_class.hInstance, MAKEINTRESOURCE(IDI_APP_ICON)); 82 | window_class.hbrBackground = 0; 83 | window_class.lpszMenuName = nullptr; 84 | window_class.lpfnWndProc = Win32Window::WndProc; 85 | RegisterClass(&window_class); 86 | class_registered_ = true; 87 | } 88 | return kWindowClassName; 89 | } 90 | 91 | void WindowClassRegistrar::UnregisterWindowClass() { 92 | UnregisterClass(kWindowClassName, nullptr); 93 | class_registered_ = false; 94 | } 95 | 96 | Win32Window::Win32Window() { 97 | ++g_active_window_count; 98 | } 99 | 100 | Win32Window::~Win32Window() { 101 | --g_active_window_count; 102 | Destroy(); 103 | } 104 | 105 | bool Win32Window::CreateAndShow(const std::wstring& title, 106 | const Point& origin, 107 | const Size& size) { 108 | Destroy(); 109 | 110 | const wchar_t* window_class = 111 | WindowClassRegistrar::GetInstance()->GetWindowClass(); 112 | 113 | const POINT target_point = {static_cast(origin.x), 114 | static_cast(origin.y)}; 115 | HMONITOR monitor = MonitorFromPoint(target_point, MONITOR_DEFAULTTONEAREST); 116 | UINT dpi = FlutterDesktopGetDpiForMonitor(monitor); 117 | double scale_factor = dpi / 96.0; 118 | 119 | HWND window = CreateWindow( 120 | window_class, title.c_str(), WS_OVERLAPPEDWINDOW | WS_VISIBLE, 121 | Scale(origin.x, scale_factor), Scale(origin.y, scale_factor), 122 | Scale(size.width, scale_factor), Scale(size.height, scale_factor), 123 | nullptr, nullptr, GetModuleHandle(nullptr), this); 124 | 125 | if (!window) { 126 | return false; 127 | } 128 | 129 | return OnCreate(); 130 | } 131 | 132 | // static 133 | LRESULT CALLBACK Win32Window::WndProc(HWND const window, 134 | UINT const message, 135 | WPARAM const wparam, 136 | LPARAM const lparam) noexcept { 137 | if (message == WM_NCCREATE) { 138 | auto window_struct = reinterpret_cast(lparam); 139 | SetWindowLongPtr(window, GWLP_USERDATA, 140 | reinterpret_cast(window_struct->lpCreateParams)); 141 | 142 | auto that = static_cast(window_struct->lpCreateParams); 143 | EnableFullDpiSupportIfAvailable(window); 144 | that->window_handle_ = window; 145 | } else if (Win32Window* that = GetThisFromHandle(window)) { 146 | return that->MessageHandler(window, message, wparam, lparam); 147 | } 148 | 149 | return DefWindowProc(window, message, wparam, lparam); 150 | } 151 | 152 | LRESULT 153 | Win32Window::MessageHandler(HWND hwnd, 154 | UINT const message, 155 | WPARAM const wparam, 156 | LPARAM const lparam) noexcept { 157 | switch (message) { 158 | case WM_DESTROY: 159 | window_handle_ = nullptr; 160 | Destroy(); 161 | if (quit_on_close_) { 162 | PostQuitMessage(0); 163 | } 164 | return 0; 165 | 166 | case WM_DPICHANGED: { 167 | auto newRectSize = reinterpret_cast(lparam); 168 | LONG newWidth = newRectSize->right - newRectSize->left; 169 | LONG newHeight = newRectSize->bottom - newRectSize->top; 170 | 171 | SetWindowPos(hwnd, nullptr, newRectSize->left, newRectSize->top, newWidth, 172 | newHeight, SWP_NOZORDER | SWP_NOACTIVATE); 173 | 174 | return 0; 175 | } 176 | case WM_SIZE: { 177 | RECT rect = GetClientArea(); 178 | if (child_content_ != nullptr) { 179 | // Size and position the child window. 180 | MoveWindow(child_content_, rect.left, rect.top, rect.right - rect.left, 181 | rect.bottom - rect.top, TRUE); 182 | } 183 | return 0; 184 | } 185 | 186 | case WM_ACTIVATE: 187 | if (child_content_ != nullptr) { 188 | SetFocus(child_content_); 189 | } 190 | return 0; 191 | } 192 | 193 | return DefWindowProc(window_handle_, message, wparam, lparam); 194 | } 195 | 196 | void Win32Window::Destroy() { 197 | OnDestroy(); 198 | 199 | if (window_handle_) { 200 | DestroyWindow(window_handle_); 201 | window_handle_ = nullptr; 202 | } 203 | if (g_active_window_count == 0) { 204 | WindowClassRegistrar::GetInstance()->UnregisterWindowClass(); 205 | } 206 | } 207 | 208 | Win32Window* Win32Window::GetThisFromHandle(HWND const window) noexcept { 209 | return reinterpret_cast( 210 | GetWindowLongPtr(window, GWLP_USERDATA)); 211 | } 212 | 213 | void Win32Window::SetChildContent(HWND content) { 214 | child_content_ = content; 215 | SetParent(content, window_handle_); 216 | RECT frame = GetClientArea(); 217 | 218 | MoveWindow(content, frame.left, frame.top, frame.right - frame.left, 219 | frame.bottom - frame.top, true); 220 | 221 | SetFocus(child_content_); 222 | } 223 | 224 | RECT Win32Window::GetClientArea() { 225 | RECT frame; 226 | GetClientRect(window_handle_, &frame); 227 | return frame; 228 | } 229 | 230 | HWND Win32Window::GetHandle() { 231 | return window_handle_; 232 | } 233 | 234 | void Win32Window::SetQuitOnClose(bool quit_on_close) { 235 | quit_on_close_ = quit_on_close; 236 | } 237 | 238 | bool Win32Window::OnCreate() { 239 | // No-op; provided for subclasses. 240 | return true; 241 | } 242 | 243 | void Win32Window::OnDestroy() { 244 | // No-op; provided for subclasses. 245 | } 246 | -------------------------------------------------------------------------------- /lib/Utils/connector.dart: -------------------------------------------------------------------------------- 1 | import 'package:fluttertoast/fluttertoast.dart'; 2 | import 'package:web3dart/web3dart.dart'; 3 | import 'package:flutter/services.dart'; 4 | import 'package:http/http.dart'; 5 | 6 | class Connector { 7 | static late EthereumAddress address; 8 | static late String key; 9 | static String blockchainUrl = 10 | "https://rinkeby.infura.io/v3/e88563d8f10a486a888e8660c887eec4"; 11 | 12 | static Client httpClient = Client(); 13 | static Web3Client ethClient = Web3Client(blockchainUrl, httpClient); 14 | 15 | static Future getContractPatient() async { 16 | String abiFilePatient = 17 | await rootBundle.loadString("assets/contracts/patient.json"); 18 | String contractAddress = "0xc291a6B782129256A8b6f947220cbde49ec52Dc4"; 19 | final contractPatient = DeployedContract( 20 | ContractAbi.fromJson(abiFilePatient, "Patient"), 21 | EthereumAddress.fromHex(contractAddress)); 22 | 23 | return contractPatient; 24 | } 25 | 26 | static Future getContractDoctor() async { 27 | String abiFileDoctor = 28 | await rootBundle.loadString("assets/contracts/doctor.json"); 29 | String contractAddress = "0xa717BfAEdFA4Fd2C0e02E3BF21dC87DAF4D76C23"; 30 | final contractDoctor = DeployedContract( 31 | ContractAbi.fromJson(abiFileDoctor, "Doctor"), 32 | EthereumAddress.fromHex(contractAddress)); 33 | return contractDoctor; 34 | } 35 | 36 | static Future isDoctorExists(EthereumAddress address) async { 37 | final contract = await getContractDoctor(); 38 | final result = await ethClient.call( 39 | contract: contract, 40 | function: contract.function("isDoctor"), 41 | params: [address]); 42 | return result[0]; 43 | } 44 | 45 | static Future isPatientExists(EthereumAddress address) async { 46 | final contract = await getContractPatient(); 47 | final result = await ethClient.call( 48 | contract: contract, 49 | function: contract.function("isPatient"), 50 | params: [address]); 51 | return result[0]; 52 | } 53 | 54 | static Future getFee(EthereumAddress address) async { 55 | final contract = await getContractDoctor(); 56 | final result = await ethClient.call( 57 | contract: contract, 58 | function: contract.function("getFee"), 59 | params: [address]); 60 | return result[0].toString(); 61 | } 62 | 63 | static Future isAuthorized( 64 | EthereumAddress doc, EthereumAddress pat) async { 65 | final contract = await getContractPatient(); 66 | final result = await ethClient.call( 67 | contract: contract, 68 | function: contract.function("isAuthorized"), 69 | params: [doc, pat]); 70 | return result[0]; 71 | } 72 | 73 | static Future getPresc(EthereumAddress address) async { 74 | final contract = await getContractPatient(); 75 | final result = await ethClient.call( 76 | contract: contract, 77 | function: contract.function("viewPrescription"), 78 | params: [address]); 79 | return result[0]; 80 | } 81 | 82 | static Future logInDoctor(String address, String privateKey) async { 83 | EthereumAddress addr = EthereumAddress.fromHex(address); 84 | bool result = await isDoctorExists(addr); 85 | if (result == true) return true; 86 | Credentials key = EthPrivateKey.fromHex(privateKey); 87 | 88 | //obtain our contract from abi in json file 89 | final contract = await getContractDoctor(); 90 | 91 | // extract function from json file 92 | final function = contract.function("addDoctor"); 93 | 94 | //send transaction using the our private key, function and contract 95 | await ethClient.sendTransaction( 96 | key, 97 | Transaction.callContract( 98 | contract: contract, function: function, parameters: [addr]), 99 | chainId: 4, 100 | ); 101 | //set a 40 seconds delay to allow the transaction to be verified before trying to retrieve the balance 102 | await Future.delayed(const Duration(seconds: 40), () {}); 103 | result = await isDoctorExists(addr); 104 | return result; 105 | } 106 | 107 | static Future logInPatient(String address, String privateKey) async { 108 | // print("here2"); 109 | EthereumAddress addr = EthereumAddress.fromHex(address); 110 | bool result = await isPatientExists(addr); 111 | // print("here3"); 112 | if (result == true) return true; 113 | Credentials key = EthPrivateKey.fromHex(privateKey); 114 | // print("here4"); 115 | //obtain our contract from abi in json file 116 | final contract = await getContractPatient(); 117 | 118 | // extract function from json file 119 | final function = contract.function("addPatient"); 120 | 121 | //send transaction using the our private key, function and contract 122 | await ethClient.sendTransaction( 123 | key, 124 | Transaction.callContract( 125 | contract: contract, function: function, parameters: [addr]), 126 | chainId: 4, 127 | ); 128 | //set a 40 seconds delay to allow the transaction to be verified before trying to retrieve the balance 129 | await Future.delayed(const Duration(seconds: 40), () {}); 130 | result = await isPatientExists(addr); 131 | return result; 132 | } 133 | 134 | static Future updateDoctorFee( 135 | EthereumAddress address, String privateKey, String amount) async { 136 | Credentials key = EthPrivateKey.fromHex(privateKey); 137 | 138 | //obtain our contract from abi in json file 139 | final contract = await getContractDoctor(); 140 | 141 | // extract function from json file 142 | final function = contract.function("updateFee"); 143 | 144 | //send transaction using the our private key, function and contract 145 | // print("here2"); 146 | await ethClient.sendTransaction( 147 | key, 148 | Transaction.callContract( 149 | contract: contract, 150 | function: function, 151 | parameters: [address, BigInt.parse(amount)]), 152 | chainId: 4); 153 | // print("here3"); 154 | //set a 40 seconds delay to allow the transaction to be verified before trying to retrieve the balance 155 | await Future.delayed(const Duration(seconds: 40), () {}); 156 | // print("here4"); 157 | String result = await getFee(address); 158 | return result; 159 | } 160 | 161 | static Future addAuthorization( 162 | EthereumAddress doc, EthereumAddress pat, String privateKey) async { 163 | bool result = await isAuthorized(doc, pat); 164 | if (result) return true; 165 | String fee = await getFee(doc); 166 | 167 | Credentials key = EthPrivateKey.fromHex(privateKey); 168 | 169 | //obtain our contract from abi in json file 170 | final contract = await getContractPatient(); 171 | 172 | // extract function from json file 173 | final function = contract.function("addAuthorization"); 174 | 175 | //send transaction using the our private key, function and contract 176 | await ethClient.sendTransaction( 177 | key, 178 | Transaction.callContract( 179 | value: EtherAmount.fromUnitAndValue(EtherUnit.wei, fee), 180 | contract: contract, 181 | function: function, 182 | parameters: [doc, pat, BigInt.parse(fee)]), 183 | chainId: 4); 184 | //set a 40 seconds delay to allow the transaction to be verified before trying to retrieve the balance 185 | await Future.delayed(const Duration(seconds: 40), () {}); 186 | result = await isAuthorized(doc, pat); 187 | return result; 188 | } 189 | 190 | static Future setPresc(EthereumAddress doc, EthereumAddress pat, 191 | String privateKey, String prescription) async { 192 | if (await isAuthorized(doc, pat)) { 193 | Credentials key = EthPrivateKey.fromHex(privateKey); 194 | 195 | //obtain our contract from abi in json file 196 | final contract = await getContractPatient(); 197 | 198 | // extract function from json file 199 | final function = contract.function("setPrescription"); 200 | 201 | //send transaction using the our private key, function and contract 202 | await ethClient.sendTransaction( 203 | key, 204 | Transaction.callContract( 205 | contract: contract, 206 | function: function, 207 | parameters: [prescription, pat, doc]), 208 | chainId: 4); 209 | } else { 210 | Fluttertoast.showToast(msg: "You are not authorized"); 211 | } 212 | } 213 | } 214 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |
2 | 3 | # MedRec 4 | 5 |
6 | 7 | Medical records need innovation. Patients leave data scattered across various jurisdictions as life events take them away from one provider’s data to another. In doing so, they lose easy access to past data, as the provider, not the patient, generally retains primary stewardship. Patients thus interact with records in a broken manner that reflects the nature of how these records are managed. Patients with a huge medical history across many hospitals should not have to keep their history in the form of huge Patients and providers may face significant hurdles in initiating data retrieval and sharing due to economic incentives that encourage “health information blocking”. In the age of online banking and social media, patients are increasingly willing, able and desirous of managing their data on the web and on the go. This work explores a blockchain structure with its backend based on a Rinkeby Test network using Ethereum for its data storage and a smart contract for its data logic. Medical Records are data with sensitive information, and hence using DAPPS with smart contracts ensures safety features essential such as Zero Downtime (i.e. the data associated with a patient is always ready to be fetched and updated), Privacy (A Patient's data should be secured and of limited accessibility to only the people closely associated with the patient), Complete data integrity (The data must not be changed by someone in no authority to do so). This MedRec blockchain implementation seeks to solve this vast fragmentation of patient data by bringing it together and organizing it in the form of a ledger while providing it with the benefits provided by blockchain and DAPPs. 8 | 9 | Hence, by implementing Medical records on the blockchain we achieve the following features which by other means could only be partially fulfilled or not fulfilled at all. 10 | 11 | 1. Non-Repudiation of Medical Records, i.e. once the prescription is received by a patient from a doctor, the transaction is stored digitally on the blockchain signed by the private keys of both the patient and the doctor, hence if either party refuses to claim the ownership of the transaction, it can be easily detected using the public key of both. 12 | 2. Only the authorized doctor can suggest a prescription that is to be added to the patient records. 13 | 3. The integrity that the prescription once added cannot be modified by any of the parties involved, i.e. the doctor, the patient or an attacker trying to harass the patient. 14 | 4. Automated transactions using smart contracts i.e. Once the patient authorizes a doctor to suggest a prescription, money is automatically transferred from the patient’s wallet to the patient contract and once the doctor sends a prescription, the money is transferred from the patient contract to the doctor’s wallet. The prescription to be sent is based on the mutual trust between the doctor and the patient and is not regulated by the application. 15 | 16 | 5. The contracts were created with vulnerabilities like Re-entrancy, transaction ordering, value underflow-overflow etc. in mind hence the application is safe to use under such circumstances if they shall prevail. 17 | 18 | 19 |
20 | 21 | ## Contents 22 | 23 | [Download APK](#Download-APK) • [How to Use](#how-to-use) • [Screenshots on Android](#screenshots-on-Android) • [Screenshots on Linux](#screenshots-on-Linux) • [Libraries & Tools Used](#libraries--tools-used) • [Folder Structure](#folder-structure) • [Routes](#routes) • [Main](#main) • [Contracts](#Solidity-Contracts) 24 | 25 |
26 | 27 | 28 | ## Download APK 29 | You can download the latest installable version of MedRec for Android from `Releases` or using this link: [MedRec.apk](https://github.com/Abhishekkr3003/MedRec/releases/download/v1.0.0/MedRec.apk) 30 | 31 | 32 | ## How to Use 33 | 34 | Steps working for Android, IOS, MacOS, Windows, Linux and Web. 35 | 36 | **Step 1:** 37 | 38 | Download or clone this repo by using the link below: 39 | 40 | ``` 41 | https://github.com/Abhishekkr3003/MedRec.git 42 | ``` 43 | 44 | **Step 2:** 45 | 46 | Go to project root and execute the following command in console to get the required dependencies (make sure you have flutter installed successfully): 47 | 48 | ``` 49 | flutter pub get 50 | ``` 51 | 52 | **Step 3:** 53 | 54 | Connect your device and run: 55 | 56 | ``` 57 | flutter run 58 | ``` 59 | 60 | 61 | ## Screenshots on Android 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 |
79 | 80 | ## Screenshots on Linux 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 100 | 101 | 102 |
103 | 104 | 105 | ## Libraries & Tools Used 106 | 107 | * [web3dart](https://github.com/xclud/web3dart) 108 | * [http](https://github.com/dart-lang/http) 109 | * [Cupertino_Icons](https://github.com/flutter/packages/tree/master/third_party/packages/cupertino_icons) 110 | * [font_awesome_flutter](https://github.com/fluttercommunity/font_awesome_flutter) 111 | * [FlutterToast](https://github.com/PonnamKarthik/FlutterToast) 112 | * [Google Fonts](https://github.com/material-foundation/google-fonts-flutter/) 113 | 114 | ## Folder Structure 115 | Here is the core folder structure which flutter provides. 116 | 117 | ``` 118 | flutter-app/ 119 | |- android 120 | |- assets 121 | |- build 122 | |- ios 123 | |- lib 124 | |- test 125 | |- linux 126 | |- macos 127 | |- test 128 | |- web 129 | |- windows 130 | ``` 131 | 132 | Here is the folder structure we have been using in this project 133 | 134 | ``` 135 | assets/ 136 | |- contracts/ 137 | |- doctor.json 138 | |- patient.json 139 | |- Icons/ 140 | |- 1024.png 141 | |-images 142 | |-welcomeImage.png 143 | 144 | lib/ 145 | |- Pages/ 146 | |- doctor_home_page.dart 147 | |- login.dart 148 | |- patient_home_page.dart 149 | |- splash_screen.dart 150 | |- view_prescription.dart 151 | 152 | |- Utils/ 153 | |- routes.dart 154 | |- routes.dart 155 | 156 | |- main.dart 157 | ``` 158 | 159 | ## Routes 160 | 161 | This file contains all the routes for your application. 162 | 163 | ```dart 164 | import 'package:flutter/material.dart'; 165 | import 'package:medrec/Pages/doctor_home_page.dart'; 166 | import 'package:medrec/Pages/login.dart'; 167 | import 'package:medrec/Pages/patient_home_page.dart'; 168 | 169 | class MyRoutes { 170 | static const String loginPage = "/loginPage"; 171 | static const String doctorHomePage = "/doctorHome"; 172 | static const String patientHomePage = "/patientHome"; 173 | 174 | static final routes = { 175 | loginPage: (context) => const LoginPage(), 176 | doctorHomePage: (context) => const DoctorHomePage(), 177 | patientHomePage: (context) => const PatientHomePage(), 178 | }; 179 | } 180 | 181 | ``` 182 | 183 | ## Main 184 | 185 | This is the starting point of the application. All the application level configurations are defined in this file i.e, theme, routes, title, orientation etc. 186 | 187 | ```dart 188 | import 'package:flutter/material.dart'; 189 | import 'package:flutter/services.dart'; 190 | import 'package:google_fonts/google_fonts.dart'; 191 | import 'Pages/splash_screen.dart'; 192 | import 'Utils/routes.dart'; 193 | 194 | void main() { 195 | SystemChrome.setSystemUIOverlayStyle(const SystemUiOverlayStyle( 196 | statusBarColor: Colors.black, statusBarIconBrightness: Brightness.light)); 197 | runApp(const MyApp()); 198 | } 199 | 200 | class MyApp extends StatelessWidget { 201 | const MyApp({Key? key}) : super(key: key); 202 | 203 | @override 204 | Widget build(BuildContext context) { 205 | return MaterialApp( 206 | debugShowCheckedModeBanner: false, 207 | theme: ThemeData( 208 | textTheme: GoogleFonts.poppinsTextTheme( 209 | Theme.of(context).textTheme, 210 | ), 211 | ), 212 | home: const Splash2(), 213 | routes: MyRoutes.routes, 214 | ); 215 | } 216 | } 217 | 218 | ``` 219 | 220 | ## Solidity Contracts 221 | [Doctor](https://github.com/Abhishekkr3003/MedRec/blob/main/solidity_contracts/doctor.sol) 222 | 223 | 224 | [Patient](https://github.com/Abhishekkr3003/MedRec/blob/main/solidity_contracts/patient.sol) 225 | 226 | -------------------------------------------------------------------------------- /lib/Pages/view_prescription.dart: -------------------------------------------------------------------------------- 1 | import 'package:flutter/cupertino.dart'; 2 | import 'package:flutter/material.dart'; 3 | import 'package:font_awesome_flutter/font_awesome_flutter.dart'; 4 | 5 | class ViewPrescription extends StatelessWidget { 6 | final int index; 7 | final List record; 8 | const ViewPrescription({ 9 | Key? key, 10 | required this.index, 11 | required this.record, 12 | }) : super(key: key); 13 | 14 | @override 15 | Widget build(BuildContext context) { 16 | return Scaffold( 17 | backgroundColor: Colors.white, 18 | body: SafeArea( 19 | child: SingleChildScrollView( 20 | child: Padding( 21 | padding: const EdgeInsets.all(16.0), 22 | child: Column( 23 | mainAxisAlignment: MainAxisAlignment.center, 24 | crossAxisAlignment: CrossAxisAlignment.start, 25 | children: [ 26 | Row( 27 | mainAxisAlignment: MainAxisAlignment.spaceBetween, 28 | children: [ 29 | SizedBox( 30 | width: MediaQuery.of(context).size.width - 100, 31 | child: Text( 32 | "Record #$index", 33 | style: const TextStyle( 34 | fontSize: 50, fontWeight: FontWeight.bold), 35 | ), 36 | ), 37 | IconButton( 38 | onPressed: () => Navigator.pop(context), 39 | icon: const Icon(CupertinoIcons.chevron_back), 40 | iconSize: 40, 41 | ) 42 | ], 43 | ), 44 | Row( 45 | mainAxisAlignment: MainAxisAlignment.start, 46 | children: [ 47 | const Icon( 48 | FontAwesomeIcons.clock, 49 | size: 15, 50 | color: Colors.grey, 51 | ), 52 | const SizedBox( 53 | width: 10, 54 | ), 55 | Text( 56 | record[0], 57 | style: Theme.of(context).textTheme.caption, 58 | ), 59 | ], 60 | ), 61 | Row( 62 | mainAxisAlignment: MainAxisAlignment.start, 63 | children: [ 64 | const Icon( 65 | FontAwesomeIcons.userDoctor, 66 | size: 15, 67 | color: Colors.grey, 68 | ), 69 | const SizedBox( 70 | width: 10, 71 | ), 72 | SizedBox( 73 | width: MediaQuery.of(context).size.width - 100, 74 | // height: 30, 75 | child: Text( 76 | record[1], 77 | style: Theme.of(context).textTheme.caption, 78 | ), 79 | ), 80 | ], 81 | ), 82 | const Divider( 83 | thickness: 2, 84 | ), 85 | Center( 86 | child: Container( 87 | width: 200, 88 | height: 50, 89 | padding: const EdgeInsets.all(8), 90 | child: Row( 91 | mainAxisAlignment: MainAxisAlignment.center, 92 | children: const [ 93 | Icon( 94 | FontAwesomeIcons.noteSticky, 95 | color: Colors.black, 96 | size: 25, 97 | ), 98 | Padding( 99 | padding: EdgeInsets.all(8.0), 100 | child: VerticalDivider( 101 | color: Colors.black, 102 | thickness: 1, 103 | ), 104 | ), 105 | Text( 106 | 'Notes', 107 | style: TextStyle( 108 | fontSize: 20, 109 | fontWeight: FontWeight.bold, 110 | color: Colors.black), 111 | ), 112 | ], 113 | ), 114 | ), 115 | ), 116 | Padding( 117 | padding: const EdgeInsets.all(8.0), 118 | child: Center( 119 | child: Text( 120 | record[2], 121 | textAlign: TextAlign.justify, 122 | ), 123 | ), 124 | ), 125 | const Divider( 126 | thickness: 2, 127 | ), 128 | Center( 129 | child: Container( 130 | width: 200, 131 | height: 50, 132 | padding: const EdgeInsets.all(8), 133 | child: Row( 134 | mainAxisAlignment: MainAxisAlignment.center, 135 | children: const [ 136 | Icon( 137 | FontAwesomeIcons.scaleBalanced, 138 | color: Colors.black, 139 | size: 25, 140 | ), 141 | Padding( 142 | padding: EdgeInsets.all(8.0), 143 | child: VerticalDivider( 144 | color: Colors.black, 145 | thickness: 1, 146 | ), 147 | ), 148 | Text( 149 | 'Vitals', 150 | style: TextStyle( 151 | fontSize: 20, 152 | fontWeight: FontWeight.bold, 153 | color: Colors.black), 154 | ), 155 | ], 156 | ), 157 | ), 158 | ), 159 | Padding( 160 | padding: const EdgeInsets.all(8.0), 161 | child: Center( 162 | child: Text( 163 | record[3], 164 | textAlign: TextAlign.justify, 165 | ), 166 | ), 167 | ), 168 | const Divider( 169 | thickness: 2, 170 | ), 171 | Center( 172 | child: Container( 173 | width: 200, 174 | height: 50, 175 | padding: const EdgeInsets.all(8), 176 | child: Row( 177 | mainAxisAlignment: MainAxisAlignment.center, 178 | children: const [ 179 | Icon( 180 | FontAwesomeIcons.tablets, 181 | color: Colors.black, 182 | size: 25, 183 | ), 184 | Padding( 185 | padding: EdgeInsets.all(8.0), 186 | child: VerticalDivider( 187 | color: Colors.black, 188 | thickness: 1, 189 | ), 190 | ), 191 | Text( 192 | 'Medicines', 193 | style: TextStyle( 194 | fontSize: 20, 195 | fontWeight: FontWeight.bold, 196 | color: Colors.black), 197 | ), 198 | ], 199 | ), 200 | ), 201 | ), 202 | Padding( 203 | padding: const EdgeInsets.all(8.0), 204 | child: Center( 205 | child: Text( 206 | record[4], 207 | textAlign: TextAlign.justify, 208 | ), 209 | ), 210 | ), 211 | const Divider( 212 | thickness: 2, 213 | ), 214 | Center( 215 | child: Container( 216 | width: 200, 217 | height: 50, 218 | padding: const EdgeInsets.all(8), 219 | child: Row( 220 | mainAxisAlignment: MainAxisAlignment.center, 221 | children: const [ 222 | Icon( 223 | FontAwesomeIcons.message, 224 | color: Colors.black, 225 | size: 25, 226 | ), 227 | Padding( 228 | padding: EdgeInsets.all(8.0), 229 | child: VerticalDivider( 230 | color: Colors.black, 231 | thickness: 1, 232 | ), 233 | ), 234 | Text( 235 | 'Advice', 236 | style: TextStyle( 237 | fontSize: 20, 238 | fontWeight: FontWeight.bold, 239 | color: Colors.black), 240 | ), 241 | ], 242 | ), 243 | ), 244 | ), 245 | Padding( 246 | padding: const EdgeInsets.all(8.0), 247 | child: Center( 248 | child: Text( 249 | record[5], 250 | textAlign: TextAlign.justify, 251 | ), 252 | ), 253 | ) 254 | ]), 255 | ), 256 | ))); 257 | } 258 | } 259 | -------------------------------------------------------------------------------- /lib/Pages/login.dart: -------------------------------------------------------------------------------- 1 | import 'package:flutter/cupertino.dart'; 2 | import 'package:flutter/material.dart'; 3 | import 'package:fluttertoast/fluttertoast.dart'; 4 | import 'package:google_fonts/google_fonts.dart'; 5 | import 'package:font_awesome_flutter/font_awesome_flutter.dart'; 6 | import 'package:medrec/Utils/connector.dart'; 7 | import 'package:medrec/Utils/routes.dart'; 8 | import 'package:web3dart/web3dart.dart'; 9 | 10 | bool adding = false; 11 | 12 | class LoginPage extends StatefulWidget { 13 | const LoginPage({Key? key}) : super(key: key); 14 | 15 | @override 16 | _LoginPageState createState() => _LoginPageState(); 17 | } 18 | 19 | class _LoginPageState extends State { 20 | TextEditingController address = TextEditingController(); 21 | TextEditingController privateKey = TextEditingController(); 22 | TextEditingController role = TextEditingController(); 23 | final _formKey = GlobalKey(); 24 | 25 | _showPicker() { 26 | showModalBottomSheet( 27 | context: context, 28 | shape: const RoundedRectangleBorder( 29 | borderRadius: BorderRadius.vertical(top: Radius.circular(5.0))), 30 | builder: (BuildContext bc) { 31 | return SafeArea( 32 | child: Wrap( 33 | children: [ 34 | const Padding( 35 | padding: EdgeInsets.fromLTRB(16, 8, 8, 8), 36 | child: Text( 37 | "Roles", 38 | style: TextStyle(fontSize: 40, fontWeight: FontWeight.bold), 39 | ), 40 | ), 41 | ListTile( 42 | leading: const Icon( 43 | CupertinoIcons.person_alt_circle, 44 | color: Colors.black, 45 | ), 46 | title: const Text( 47 | 'Patient', 48 | style: 49 | TextStyle(fontSize: 20, fontWeight: FontWeight.bold), 50 | ), 51 | onTap: () { 52 | role.text = "Patient"; 53 | setState(() {}); 54 | Navigator.pop(context); 55 | }), 56 | ListTile( 57 | leading: const Icon( 58 | FontAwesomeIcons.userDoctor, 59 | color: Colors.black, 60 | ), 61 | title: const Text( 62 | 'Doctor', 63 | style: 64 | TextStyle(fontSize: 20, fontWeight: FontWeight.bold), 65 | ), 66 | onTap: () { 67 | role.text = "Doctor"; 68 | setState(() {}); 69 | Navigator.pop(context); 70 | }) 71 | ], 72 | ), 73 | ); 74 | }); 75 | } 76 | 77 | void moveToHome() async { 78 | bool result; 79 | if (_formKey.currentState!.validate()) { 80 | adding = true; 81 | setState(() {}); 82 | if (role.text == "Patient") { 83 | try { 84 | result = await Connector.logInPatient(address.text, privateKey.text); 85 | if (!result) { 86 | Fluttertoast.showToast(msg: "Wrong credentials"); 87 | setState(() { 88 | adding = false; 89 | }); 90 | } else { 91 | Fluttertoast.showToast(msg: "Login Success"); 92 | Connector.address = EthereumAddress.fromHex(address.text); 93 | Connector.key = privateKey.text; 94 | await Navigator.pushReplacementNamed( 95 | context, MyRoutes.patientHomePage); 96 | } 97 | } catch (e) { 98 | // print("here"); 99 | // print(e); 100 | Fluttertoast.showToast( 101 | msg: "Oops! Something went wrong. Try Again..."); 102 | // print('Error creating user: $e'); 103 | setState(() { 104 | adding = false; 105 | }); 106 | } 107 | adding = false; 108 | } else if (role.text == "Doctor") { 109 | try { 110 | result = await Connector.logInPatient(address.text, privateKey.text); 111 | if (!result) { 112 | Fluttertoast.showToast(msg: "Wrong credentials"); 113 | setState(() { 114 | adding = false; 115 | }); 116 | } else { 117 | Fluttertoast.showToast(msg: "Login Success"); 118 | Connector.address = EthereumAddress.fromHex(address.text); 119 | Connector.key = privateKey.text; 120 | await Navigator.pushReplacementNamed( 121 | context, MyRoutes.doctorHomePage); 122 | } 123 | } catch (e) { 124 | Fluttertoast.showToast( 125 | msg: "Oops! Something went wrong. Try Again..."); 126 | // print('Error creating user: $e'); 127 | setState(() { 128 | adding = false; 129 | }); 130 | } 131 | adding = false; 132 | } 133 | } 134 | } 135 | 136 | @override 137 | Widget build(BuildContext context) { 138 | return Material( 139 | color: Theme.of(context).canvasColor, 140 | child: Scaffold( 141 | body: SafeArea( 142 | child: SingleChildScrollView( 143 | child: Form( 144 | key: _formKey, 145 | child: Column( 146 | mainAxisAlignment: MainAxisAlignment.start, 147 | crossAxisAlignment: CrossAxisAlignment.start, 148 | children: [ 149 | Padding( 150 | padding: const EdgeInsets.fromLTRB(0, 0, 0, 16), 151 | child: Center( 152 | child: ClipRRect( 153 | borderRadius: const BorderRadius.only( 154 | bottomLeft: Radius.circular(100), 155 | bottomRight: Radius.circular(100)), 156 | child: SizedBox( 157 | width: MediaQuery.of(context).size.width, 158 | height: MediaQuery.of(context).size.height / 3, 159 | child: Image.asset( 160 | "assets/images/welcomeImage.png", 161 | fit: BoxFit.cover, 162 | ), 163 | ), 164 | ), 165 | ), 166 | ), 167 | const SizedBox( 168 | height: 20.0, 169 | ), 170 | Center( 171 | child: Text( 172 | "Sign-In", 173 | style: GoogleFonts.lato( 174 | fontSize: 50, fontWeight: FontWeight.bold), 175 | ), 176 | ), 177 | Padding( 178 | padding: const EdgeInsets.fromLTRB(32, 32, 32, 32), 179 | child: CupertinoFormSection( 180 | backgroundColor: Colors.transparent, 181 | children: [ 182 | CupertinoFormRow( 183 | //padding: EdgeInsets.only(left: 0), 184 | child: CupertinoTextFormFieldRow( 185 | style: GoogleFonts.poppins(), 186 | controller: address, 187 | placeholder: "Enter your Etherium Address", 188 | prefix: Text( 189 | "Address ", 190 | style: Theme.of(context).textTheme.caption, 191 | ), 192 | padding: const EdgeInsets.only(left: 0), 193 | keyboardType: TextInputType.emailAddress, 194 | validator: (value) { 195 | if (value!.isEmpty) { 196 | return "Address can't be empty"; 197 | } 198 | return null; 199 | }, 200 | ), 201 | ), 202 | CupertinoFormRow( 203 | //padding: EdgeInsets.only(left: 0), 204 | child: CupertinoTextFormFieldRow( 205 | style: GoogleFonts.poppins(), 206 | controller: privateKey, 207 | placeholder: "Enter your private key", 208 | prefix: Text( 209 | "Key ", 210 | style: Theme.of(context).textTheme.caption, 211 | ), 212 | padding: const EdgeInsets.only(left: 0), 213 | keyboardType: TextInputType.emailAddress, 214 | validator: (value) { 215 | if (value!.isEmpty) { 216 | return "Key can't be empty"; 217 | } 218 | return null; 219 | }, 220 | ), 221 | ), 222 | CupertinoTextFormFieldRow( 223 | style: GoogleFonts.poppins(), 224 | controller: role, 225 | onTap: _showPicker, 226 | placeholder: "Tap to Show Roles", 227 | validator: (value) { 228 | if (value!.isEmpty) { 229 | return "Role can't be empty"; 230 | } 231 | return null; 232 | }, 233 | decoration: const BoxDecoration(color: Colors.white), 234 | prefix: Text( 235 | "Role ", 236 | style: Theme.of(context).textTheme.caption, 237 | ), 238 | readOnly: true, 239 | ), 240 | ], 241 | ), 242 | ), 243 | Padding( 244 | padding: EdgeInsets.all(32), 245 | child: adding 246 | ? const Center( 247 | child: Padding( 248 | padding: EdgeInsets.only(top: 40), 249 | child: CupertinoActivityIndicator( 250 | radius: 20, 251 | ), 252 | ), 253 | ) 254 | : Center( 255 | child: Container( 256 | width: 60, 257 | height: 60, 258 | decoration: BoxDecoration( 259 | color: Colors.black, 260 | borderRadius: BorderRadius.circular(50), 261 | boxShadow: [ 262 | BoxShadow( 263 | color: Colors.grey.withOpacity(0.5), 264 | blurRadius: 7, 265 | offset: const Offset( 266 | 0, 3), // changes position of shadow 267 | ), 268 | ], 269 | ), 270 | child: IconButton( 271 | onPressed: () => moveToHome(), 272 | icon: const Icon(Icons.send_outlined), 273 | iconSize: 40, 274 | color: Colors.white, 275 | ), 276 | ), 277 | ), 278 | ) 279 | ], 280 | ), 281 | ), 282 | ), 283 | ), 284 | ), 285 | ); 286 | } 287 | } 288 | -------------------------------------------------------------------------------- /pubspec.lock: -------------------------------------------------------------------------------- 1 | # Generated by pub 2 | # See https://dart.dev/tools/pub/glossary#lockfile 3 | packages: 4 | _fe_analyzer_shared: 5 | dependency: transitive 6 | description: 7 | name: _fe_analyzer_shared 8 | url: "https://pub.dartlang.org" 9 | source: hosted 10 | version: "40.0.0" 11 | analyzer: 12 | dependency: transitive 13 | description: 14 | name: analyzer 15 | url: "https://pub.dartlang.org" 16 | source: hosted 17 | version: "4.1.0" 18 | args: 19 | dependency: transitive 20 | description: 21 | name: args 22 | url: "https://pub.dartlang.org" 23 | source: hosted 24 | version: "2.0.0" 25 | async: 26 | dependency: transitive 27 | description: 28 | name: async 29 | url: "https://pub.dartlang.org" 30 | source: hosted 31 | version: "2.8.2" 32 | boolean_selector: 33 | dependency: transitive 34 | description: 35 | name: boolean_selector 36 | url: "https://pub.dartlang.org" 37 | source: hosted 38 | version: "2.1.0" 39 | build: 40 | dependency: transitive 41 | description: 42 | name: build 43 | url: "https://pub.dartlang.org" 44 | source: hosted 45 | version: "2.3.0" 46 | build_config: 47 | dependency: transitive 48 | description: 49 | name: build_config 50 | url: "https://pub.dartlang.org" 51 | source: hosted 52 | version: "1.0.0" 53 | built_collection: 54 | dependency: transitive 55 | description: 56 | name: built_collection 57 | url: "https://pub.dartlang.org" 58 | source: hosted 59 | version: "5.1.1" 60 | built_value: 61 | dependency: transitive 62 | description: 63 | name: built_value 64 | url: "https://pub.dartlang.org" 65 | source: hosted 66 | version: "8.3.2" 67 | characters: 68 | dependency: transitive 69 | description: 70 | name: characters 71 | url: "https://pub.dartlang.org" 72 | source: hosted 73 | version: "1.2.0" 74 | charcode: 75 | dependency: transitive 76 | description: 77 | name: charcode 78 | url: "https://pub.dartlang.org" 79 | source: hosted 80 | version: "1.3.1" 81 | checked_yaml: 82 | dependency: transitive 83 | description: 84 | name: checked_yaml 85 | url: "https://pub.dartlang.org" 86 | source: hosted 87 | version: "2.0.1" 88 | clock: 89 | dependency: transitive 90 | description: 91 | name: clock 92 | url: "https://pub.dartlang.org" 93 | source: hosted 94 | version: "1.1.0" 95 | code_builder: 96 | dependency: transitive 97 | description: 98 | name: code_builder 99 | url: "https://pub.dartlang.org" 100 | source: hosted 101 | version: "4.1.0" 102 | collection: 103 | dependency: transitive 104 | description: 105 | name: collection 106 | url: "https://pub.dartlang.org" 107 | source: hosted 108 | version: "1.16.0" 109 | convert: 110 | dependency: transitive 111 | description: 112 | name: convert 113 | url: "https://pub.dartlang.org" 114 | source: hosted 115 | version: "3.0.1" 116 | crypto: 117 | dependency: transitive 118 | description: 119 | name: crypto 120 | url: "https://pub.dartlang.org" 121 | source: hosted 122 | version: "3.0.2" 123 | cupertino_icons: 124 | dependency: "direct main" 125 | description: 126 | name: cupertino_icons 127 | url: "https://pub.dartlang.org" 128 | source: hosted 129 | version: "1.0.4" 130 | dart_style: 131 | dependency: transitive 132 | description: 133 | name: dart_style 134 | url: "https://pub.dartlang.org" 135 | source: hosted 136 | version: "2.2.3" 137 | fake_async: 138 | dependency: transitive 139 | description: 140 | name: fake_async 141 | url: "https://pub.dartlang.org" 142 | source: hosted 143 | version: "1.3.0" 144 | ffi: 145 | dependency: transitive 146 | description: 147 | name: ffi 148 | url: "https://pub.dartlang.org" 149 | source: hosted 150 | version: "1.2.1" 151 | file: 152 | dependency: transitive 153 | description: 154 | name: file 155 | url: "https://pub.dartlang.org" 156 | source: hosted 157 | version: "6.1.2" 158 | fixnum: 159 | dependency: transitive 160 | description: 161 | name: fixnum 162 | url: "https://pub.dartlang.org" 163 | source: hosted 164 | version: "1.0.1" 165 | flutter: 166 | dependency: "direct main" 167 | description: flutter 168 | source: sdk 169 | version: "0.0.0" 170 | flutter_lints: 171 | dependency: "direct dev" 172 | description: 173 | name: flutter_lints 174 | url: "https://pub.dartlang.org" 175 | source: hosted 176 | version: "2.0.1" 177 | flutter_test: 178 | dependency: "direct dev" 179 | description: flutter 180 | source: sdk 181 | version: "0.0.0" 182 | flutter_web_plugins: 183 | dependency: transitive 184 | description: flutter 185 | source: sdk 186 | version: "0.0.0" 187 | fluttertoast: 188 | dependency: "direct main" 189 | description: 190 | name: fluttertoast 191 | url: "https://pub.dartlang.org" 192 | source: hosted 193 | version: "8.0.9" 194 | font_awesome_flutter: 195 | dependency: "direct main" 196 | description: 197 | name: font_awesome_flutter 198 | url: "https://pub.dartlang.org" 199 | source: hosted 200 | version: "10.1.0" 201 | glob: 202 | dependency: transitive 203 | description: 204 | name: glob 205 | url: "https://pub.dartlang.org" 206 | source: hosted 207 | version: "2.0.2" 208 | google_fonts: 209 | dependency: "direct main" 210 | description: 211 | name: google_fonts 212 | url: "https://pub.dartlang.org" 213 | source: hosted 214 | version: "3.0.1" 215 | http: 216 | dependency: transitive 217 | description: 218 | name: http 219 | url: "https://pub.dartlang.org" 220 | source: hosted 221 | version: "0.13.4" 222 | http_parser: 223 | dependency: transitive 224 | description: 225 | name: http_parser 226 | url: "https://pub.dartlang.org" 227 | source: hosted 228 | version: "4.0.1" 229 | js: 230 | dependency: transitive 231 | description: 232 | name: js 233 | url: "https://pub.dartlang.org" 234 | source: hosted 235 | version: "0.6.4" 236 | json_annotation: 237 | dependency: transitive 238 | description: 239 | name: json_annotation 240 | url: "https://pub.dartlang.org" 241 | source: hosted 242 | version: "4.5.0" 243 | json_rpc_2: 244 | dependency: transitive 245 | description: 246 | name: json_rpc_2 247 | url: "https://pub.dartlang.org" 248 | source: hosted 249 | version: "3.0.1" 250 | lints: 251 | dependency: transitive 252 | description: 253 | name: lints 254 | url: "https://pub.dartlang.org" 255 | source: hosted 256 | version: "2.0.0" 257 | logging: 258 | dependency: transitive 259 | description: 260 | name: logging 261 | url: "https://pub.dartlang.org" 262 | source: hosted 263 | version: "1.0.2" 264 | matcher: 265 | dependency: transitive 266 | description: 267 | name: matcher 268 | url: "https://pub.dartlang.org" 269 | source: hosted 270 | version: "0.12.11" 271 | material_color_utilities: 272 | dependency: transitive 273 | description: 274 | name: material_color_utilities 275 | url: "https://pub.dartlang.org" 276 | source: hosted 277 | version: "0.1.4" 278 | meta: 279 | dependency: transitive 280 | description: 281 | name: meta 282 | url: "https://pub.dartlang.org" 283 | source: hosted 284 | version: "1.7.0" 285 | package_config: 286 | dependency: transitive 287 | description: 288 | name: package_config 289 | url: "https://pub.dartlang.org" 290 | source: hosted 291 | version: "2.0.2" 292 | path: 293 | dependency: transitive 294 | description: 295 | name: path 296 | url: "https://pub.dartlang.org" 297 | source: hosted 298 | version: "1.8.1" 299 | path_provider: 300 | dependency: transitive 301 | description: 302 | name: path_provider 303 | url: "https://pub.dartlang.org" 304 | source: hosted 305 | version: "2.0.10" 306 | path_provider_android: 307 | dependency: transitive 308 | description: 309 | name: path_provider_android 310 | url: "https://pub.dartlang.org" 311 | source: hosted 312 | version: "2.0.14" 313 | path_provider_ios: 314 | dependency: transitive 315 | description: 316 | name: path_provider_ios 317 | url: "https://pub.dartlang.org" 318 | source: hosted 319 | version: "2.0.9" 320 | path_provider_linux: 321 | dependency: transitive 322 | description: 323 | name: path_provider_linux 324 | url: "https://pub.dartlang.org" 325 | source: hosted 326 | version: "2.1.6" 327 | path_provider_macos: 328 | dependency: transitive 329 | description: 330 | name: path_provider_macos 331 | url: "https://pub.dartlang.org" 332 | source: hosted 333 | version: "2.0.6" 334 | path_provider_platform_interface: 335 | dependency: transitive 336 | description: 337 | name: path_provider_platform_interface 338 | url: "https://pub.dartlang.org" 339 | source: hosted 340 | version: "2.0.4" 341 | path_provider_windows: 342 | dependency: transitive 343 | description: 344 | name: path_provider_windows 345 | url: "https://pub.dartlang.org" 346 | source: hosted 347 | version: "2.0.6" 348 | platform: 349 | dependency: transitive 350 | description: 351 | name: platform 352 | url: "https://pub.dartlang.org" 353 | source: hosted 354 | version: "3.1.0" 355 | plugin_platform_interface: 356 | dependency: transitive 357 | description: 358 | name: plugin_platform_interface 359 | url: "https://pub.dartlang.org" 360 | source: hosted 361 | version: "2.1.2" 362 | pointycastle: 363 | dependency: transitive 364 | description: 365 | name: pointycastle 366 | url: "https://pub.dartlang.org" 367 | source: hosted 368 | version: "3.6.0" 369 | process: 370 | dependency: transitive 371 | description: 372 | name: process 373 | url: "https://pub.dartlang.org" 374 | source: hosted 375 | version: "4.2.4" 376 | pub_semver: 377 | dependency: transitive 378 | description: 379 | name: pub_semver 380 | url: "https://pub.dartlang.org" 381 | source: hosted 382 | version: "2.1.1" 383 | pubspec_parse: 384 | dependency: transitive 385 | description: 386 | name: pubspec_parse 387 | url: "https://pub.dartlang.org" 388 | source: hosted 389 | version: "1.2.0" 390 | sky_engine: 391 | dependency: transitive 392 | description: flutter 393 | source: sdk 394 | version: "0.0.99" 395 | source_span: 396 | dependency: transitive 397 | description: 398 | name: source_span 399 | url: "https://pub.dartlang.org" 400 | source: hosted 401 | version: "1.8.2" 402 | stack_trace: 403 | dependency: transitive 404 | description: 405 | name: stack_trace 406 | url: "https://pub.dartlang.org" 407 | source: hosted 408 | version: "1.10.0" 409 | stream_channel: 410 | dependency: transitive 411 | description: 412 | name: stream_channel 413 | url: "https://pub.dartlang.org" 414 | source: hosted 415 | version: "2.1.0" 416 | stream_transform: 417 | dependency: transitive 418 | description: 419 | name: stream_transform 420 | url: "https://pub.dartlang.org" 421 | source: hosted 422 | version: "2.0.0" 423 | string_scanner: 424 | dependency: transitive 425 | description: 426 | name: string_scanner 427 | url: "https://pub.dartlang.org" 428 | source: hosted 429 | version: "1.1.0" 430 | term_glyph: 431 | dependency: transitive 432 | description: 433 | name: term_glyph 434 | url: "https://pub.dartlang.org" 435 | source: hosted 436 | version: "1.2.0" 437 | test_api: 438 | dependency: transitive 439 | description: 440 | name: test_api 441 | url: "https://pub.dartlang.org" 442 | source: hosted 443 | version: "0.4.9" 444 | typed_data: 445 | dependency: transitive 446 | description: 447 | name: typed_data 448 | url: "https://pub.dartlang.org" 449 | source: hosted 450 | version: "1.3.1" 451 | uuid: 452 | dependency: transitive 453 | description: 454 | name: uuid 455 | url: "https://pub.dartlang.org" 456 | source: hosted 457 | version: "3.0.6" 458 | vector_math: 459 | dependency: transitive 460 | description: 461 | name: vector_math 462 | url: "https://pub.dartlang.org" 463 | source: hosted 464 | version: "2.1.2" 465 | watcher: 466 | dependency: transitive 467 | description: 468 | name: watcher 469 | url: "https://pub.dartlang.org" 470 | source: hosted 471 | version: "1.0.1" 472 | web3dart: 473 | dependency: "direct main" 474 | description: 475 | name: web3dart 476 | url: "https://pub.dartlang.org" 477 | source: hosted 478 | version: "2.3.5" 479 | win32: 480 | dependency: transitive 481 | description: 482 | name: win32 483 | url: "https://pub.dartlang.org" 484 | source: hosted 485 | version: "2.6.1" 486 | xdg_directories: 487 | dependency: transitive 488 | description: 489 | name: xdg_directories 490 | url: "https://pub.dartlang.org" 491 | source: hosted 492 | version: "0.2.0+1" 493 | yaml: 494 | dependency: transitive 495 | description: 496 | name: yaml 497 | url: "https://pub.dartlang.org" 498 | source: hosted 499 | version: "3.1.1" 500 | sdks: 501 | dart: ">=2.17.1 <3.0.0" 502 | flutter: ">=2.10.0-0" 503 | -------------------------------------------------------------------------------- /lib/Pages/patient_home_page.dart: -------------------------------------------------------------------------------- 1 | import 'package:flutter/cupertino.dart'; 2 | import 'package:flutter/material.dart'; 3 | import 'package:fluttertoast/fluttertoast.dart'; 4 | import 'package:font_awesome_flutter/font_awesome_flutter.dart'; 5 | import 'package:medrec/Pages/view_prescription.dart'; 6 | import 'package:medrec/Utils/connector.dart'; 7 | import 'package:medrec/Utils/routes.dart'; 8 | import 'package:web3dart/credentials.dart'; 9 | 10 | class PatientHomePage extends StatefulWidget { 11 | const PatientHomePage({Key? key}) : super(key: key); 12 | 13 | @override 14 | State createState() => _PatientHomePageState(); 15 | } 16 | 17 | class _PatientHomePageState extends State { 18 | TextEditingController doctorAddress = TextEditingController(); 19 | bool showLoading = true; 20 | List> prescriptions = []; 21 | void setAuthorization() async { 22 | if (doctorAddress.text.length < 40) { 23 | Fluttertoast.showToast(msg: "Wrong Address"); 24 | return; 25 | } 26 | bool isAuthorized = await Connector.addAuthorization( 27 | EthereumAddress.fromHex(doctorAddress.text), 28 | Connector.address, 29 | Connector.key); 30 | if (!isAuthorized) { 31 | Fluttertoast.showToast(msg: "Authorization Failed"); 32 | } else { 33 | Fluttertoast.showToast( 34 | msg: "Doctor is now authorized to give you prescription."); 35 | doctorAddress.clear(); 36 | } 37 | } 38 | 39 | void getPrescriptions() async { 40 | setState(() { 41 | showLoading = true; 42 | }); 43 | List result = await Connector.getPresc(Connector.address); 44 | for (var element in result) { 45 | prescriptions.add(element.toString().split('#')); 46 | } 47 | prescriptions = prescriptions.reversed.toList(); 48 | setState(() { 49 | showLoading = false; 50 | }); 51 | } 52 | 53 | _showPickerAuthorization() { 54 | showModalBottomSheet( 55 | isScrollControlled: true, 56 | shape: const RoundedRectangleBorder( 57 | borderRadius: BorderRadius.vertical(top: Radius.circular(25.0))), 58 | context: context, 59 | builder: (BuildContext bc) { 60 | return SingleChildScrollView( 61 | child: Padding( 62 | padding: MediaQuery.of(context).viewInsets, 63 | child: Column( 64 | mainAxisSize: MainAxisSize.min, 65 | children: [ 66 | const Text( 67 | "Authorize Doctor", 68 | style: TextStyle(fontSize: 30, fontWeight: FontWeight.bold), 69 | ), 70 | CupertinoFormSection(children: [ 71 | CupertinoFormRow( 72 | //padding: EdgeInsets.only(left: 0), 73 | child: CupertinoTextFormFieldRow( 74 | controller: doctorAddress, 75 | // obscureText: true, 76 | placeholder: "Enter Doctor's Address", 77 | // prefix: "Email".text.make(), 78 | padding: const EdgeInsets.only(left: 0), 79 | keyboardType: TextInputType.emailAddress, 80 | validator: (value) { 81 | if (value!.isEmpty) { 82 | return "Address can't be empty"; 83 | } 84 | return null; 85 | }, 86 | prefix: Text( 87 | 'Address | ', 88 | style: Theme.of(context).textTheme.caption, 89 | ), 90 | ), 91 | ), 92 | InkWell( 93 | onTap: () async { 94 | setAuthorization(); 95 | Navigator.pop(context); 96 | doctorAddress.clear(); 97 | }, 98 | child: const SizedBox( 99 | height: 50, 100 | child: Center( 101 | child: Text( 102 | "Submit", 103 | style: TextStyle( 104 | fontSize: 20, 105 | ), 106 | ), 107 | ))) 108 | ]) 109 | ], 110 | ), 111 | ), 112 | ); 113 | }); 114 | } 115 | 116 | @override 117 | void initState() { 118 | getPrescriptions(); 119 | super.initState(); 120 | } 121 | 122 | @override 123 | Widget build(BuildContext context) { 124 | return Scaffold( 125 | floatingActionButton: InkWell( 126 | onTap: () => _showPickerAuthorization(), 127 | child: Container( 128 | width: (MediaQuery.of(context).size.width / 1.5), 129 | height: 50, 130 | decoration: BoxDecoration( 131 | color: Colors.black, 132 | borderRadius: BorderRadius.circular(50), 133 | boxShadow: [ 134 | BoxShadow( 135 | color: Colors.grey.withOpacity(0.5), 136 | blurRadius: 7, 137 | offset: const Offset(0, 3), // changes position of shadow 138 | ), 139 | ], 140 | ), 141 | child: Padding( 142 | padding: const EdgeInsets.all(8.0), 143 | child: Row( 144 | mainAxisAlignment: MainAxisAlignment.center, 145 | children: const [ 146 | Icon( 147 | FontAwesomeIcons.userDoctor, 148 | color: Colors.white, 149 | size: 20, 150 | ), 151 | Padding( 152 | padding: EdgeInsets.all(8.0), 153 | child: VerticalDivider( 154 | color: Colors.white, 155 | thickness: 1, 156 | ), 157 | ), 158 | Text( 159 | 'Authorize Doctor', 160 | style: TextStyle( 161 | // fontSize: 20, 162 | fontWeight: FontWeight.bold, 163 | color: Colors.white), 164 | ), 165 | ], 166 | ), 167 | ), 168 | ), 169 | ), 170 | backgroundColor: Colors.white, 171 | body: SafeArea( 172 | child: SingleChildScrollView( 173 | child: Column( 174 | mainAxisAlignment: MainAxisAlignment.start, 175 | crossAxisAlignment: CrossAxisAlignment.start, 176 | children: [ 177 | Container( 178 | width: MediaQuery.of(context).size.width, 179 | height: MediaQuery.of(context).size.height / 8, 180 | padding: const EdgeInsets.all(8), 181 | decoration: const BoxDecoration( 182 | color: Colors.black, 183 | borderRadius: BorderRadius.only( 184 | topLeft: Radius.circular(0), 185 | bottomLeft: Radius.circular(50), 186 | topRight: Radius.circular(0), 187 | bottomRight: Radius.circular(50), 188 | ), 189 | ), 190 | child: Row( 191 | crossAxisAlignment: CrossAxisAlignment.center, 192 | mainAxisAlignment: MainAxisAlignment.center, 193 | children: const [ 194 | Icon( 195 | CupertinoIcons.person_circle, 196 | color: Colors.white, 197 | size: 40, 198 | ), 199 | VerticalDivider( 200 | color: Colors.white, 201 | // thickness: 5, 202 | ), 203 | Center( 204 | child: Text( 205 | 'Patient Panel', 206 | style: TextStyle( 207 | fontSize: 40, 208 | fontWeight: FontWeight.bold, 209 | color: Colors.white), 210 | ), 211 | ), 212 | ], 213 | ), 214 | ), 215 | Padding( 216 | padding: const EdgeInsets.fromLTRB(8, 16, 8, 16), 217 | child: Row( 218 | mainAxisAlignment: MainAxisAlignment.center, 219 | children: [ 220 | Container( 221 | width: MediaQuery.of(context).size.width * 0.7, 222 | padding: const EdgeInsets.all(16), 223 | decoration: BoxDecoration( 224 | color: Colors.green.shade50, 225 | borderRadius: BorderRadius.circular(20), 226 | boxShadow: [ 227 | BoxShadow( 228 | color: Colors.grey.withOpacity(0.5), 229 | blurRadius: 7, 230 | offset: const Offset( 231 | 0, 3), // changes position of shadow 232 | ), 233 | ], 234 | ), 235 | child: Center( 236 | child: Text( 237 | Connector.address.toString(), 238 | style: TextStyle( 239 | fontSize: 240 | (MediaQuery.of(context).size.width * 0.02), 241 | fontWeight: FontWeight.bold, 242 | color: Colors.green), 243 | ), 244 | ), 245 | ), 246 | const SizedBox( 247 | width: 10, 248 | ), 249 | InkWell( 250 | onTap: () { 251 | Connector.key = ""; 252 | Navigator.popAndPushNamed(context, MyRoutes.loginPage); 253 | }, 254 | child: Container( 255 | width: MediaQuery.of(context).size.width * 0.2, 256 | padding: const EdgeInsets.all(16), 257 | decoration: BoxDecoration( 258 | color: Colors.red.shade50, 259 | borderRadius: BorderRadius.circular(20), 260 | boxShadow: [ 261 | BoxShadow( 262 | color: Colors.grey.withOpacity(0.5), 263 | blurRadius: 7, 264 | offset: const Offset( 265 | 0, 3), // changes position of shadow 266 | ), 267 | ], 268 | ), 269 | child: Center( 270 | child: Text( 271 | "Logout", 272 | style: TextStyle( 273 | fontSize: 274 | (MediaQuery.of(context).size.width * 0.02), 275 | // fontWeight: FontWeight.bold, 276 | color: Colors.red), 277 | ), 278 | ), 279 | ), 280 | ), 281 | ], 282 | ), 283 | ), 284 | Center( 285 | child: Container( 286 | width: MediaQuery.of(context).size.width, 287 | height: 50, 288 | padding: const EdgeInsets.all(8), 289 | child: Row( 290 | mainAxisAlignment: MainAxisAlignment.center, 291 | children: const [ 292 | Icon( 293 | FontAwesomeIcons.timeline, 294 | color: Colors.black, 295 | size: 25, 296 | ), 297 | Padding( 298 | padding: EdgeInsets.all(8.0), 299 | child: VerticalDivider( 300 | color: Colors.black, 301 | thickness: 1, 302 | ), 303 | ), 304 | Text( 305 | 'Medical History', 306 | style: TextStyle( 307 | fontSize: 20, 308 | fontWeight: FontWeight.bold, 309 | color: Colors.black), 310 | ), 311 | ], 312 | ), 313 | ), 314 | ), 315 | (showLoading == false && prescriptions.isNotEmpty) 316 | ? ListView.builder( 317 | itemCount: prescriptions.length, 318 | shrinkWrap: true, 319 | itemBuilder: (BuildContext context, int index) { 320 | return InkWell( 321 | onTap: () async { 322 | await Navigator.push( 323 | context, 324 | MaterialPageRoute( 325 | builder: (context) => ViewPrescription( 326 | index: index + 1, 327 | record: prescriptions[index]))); 328 | }, 329 | child: Padding( 330 | padding: const EdgeInsets.fromLTRB(16, 8, 16, 8), 331 | child: Container( 332 | // margin: EdgeInsets.all(16), 333 | // height: 100, 334 | padding: const EdgeInsets.all(16), 335 | decoration: BoxDecoration( 336 | color: Colors.white, 337 | borderRadius: BorderRadius.circular(15), 338 | boxShadow: [ 339 | BoxShadow( 340 | color: Colors.grey.withOpacity(0.5), 341 | blurRadius: 7, 342 | offset: const Offset( 343 | 0, 3), // changes position of shadow 344 | ), 345 | ], 346 | ), 347 | child: Row( 348 | children: [ 349 | Padding( 350 | padding: 351 | const EdgeInsets.only(right: 8.0), 352 | child: ClipRRect( 353 | borderRadius: BorderRadius.circular(5), 354 | child: Container( 355 | color: Colors.black, 356 | child: Text( 357 | " ${index + 1} ", 358 | style: const TextStyle( 359 | color: Colors.white, 360 | ), 361 | ), 362 | ), 363 | ), 364 | ), 365 | const VerticalDivider( 366 | thickness: 2, 367 | ), 368 | Column( 369 | crossAxisAlignment: 370 | CrossAxisAlignment.start, 371 | children: [ 372 | Row( 373 | mainAxisAlignment: 374 | MainAxisAlignment.start, 375 | children: [ 376 | const Icon( 377 | FontAwesomeIcons.clock, 378 | size: 15, 379 | // color: Colors.grey, 380 | ), 381 | const SizedBox( 382 | width: 10, 383 | ), 384 | Text( 385 | prescriptions[index][0], 386 | // style: 387 | // Theme.of(context).textTheme.caption, 388 | ), 389 | ], 390 | ), 391 | Row( 392 | mainAxisAlignment: 393 | MainAxisAlignment.start, 394 | children: [ 395 | const Icon( 396 | FontAwesomeIcons.userDoctor, 397 | size: 15, 398 | color: Colors.grey, 399 | ), 400 | const SizedBox( 401 | width: 10, 402 | ), 403 | SizedBox( 404 | width: MediaQuery.of(context) 405 | .size 406 | .width - 407 | 150, 408 | // height: 30, 409 | child: Text( 410 | prescriptions[index][1], 411 | style: Theme.of(context) 412 | .textTheme 413 | .caption, 414 | ), 415 | ), 416 | ], 417 | ), 418 | ], 419 | ) 420 | ], 421 | )), 422 | ), 423 | ); 424 | }, 425 | ) 426 | : showLoading == true 427 | ? const Center( 428 | child: Padding( 429 | padding: EdgeInsets.only(top: 40), 430 | child: CupertinoActivityIndicator( 431 | radius: 20, 432 | ), 433 | ), 434 | ) 435 | : const Padding( 436 | padding: EdgeInsets.only(top: 32.0, left: 16), 437 | child: Text( 438 | "No Medical History!", 439 | style: TextStyle( 440 | fontSize: 70, 441 | fontWeight: FontWeight.bold, 442 | color: Colors.grey), 443 | ), 444 | ), 445 | ], 446 | ), 447 | ), 448 | ), 449 | ); 450 | } 451 | } 452 | --------------------------------------------------------------------------------