Merge branch 'development' of https://gitlab.com/Cloud_Solution/doctor_app_flutter into special_clinic
Conflicts: lib/config/config.dartmerge-requests/742/head
commit
c46c339933
@ -0,0 +1,16 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="24dp"
|
||||
android:height="24dp"
|
||||
android:viewportWidth="24"
|
||||
android:viewportHeight="24"
|
||||
android:tint="?attr/colorControlNormal">
|
||||
<path
|
||||
android:fillColor="@android:color/white"
|
||||
android:pathData="M8,8l-2,0l0,9l11,0l0,-2l-9,0z"/>
|
||||
<path
|
||||
android:fillColor="@android:color/white"
|
||||
android:pathData="M22,3H10v10h12V3zM20,11h-8V7h8V11z"/>
|
||||
<path
|
||||
android:fillColor="@android:color/white"
|
||||
android:pathData="M4,12l-2,0l0,9l11,0l0,-2l-9,0z"/>
|
||||
</vector>
|
||||
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<corners android:radius="1000dp"/>
|
||||
|
||||
<solid android:color="@color/green_dark"/>
|
||||
|
||||
</shape>
|
||||
@ -1,327 +0,0 @@
|
||||
PODS:
|
||||
- Alamofire (5.4.3)
|
||||
- barcode_scan_fix (0.0.1):
|
||||
- Flutter
|
||||
- MTBBarcodeScanner
|
||||
- connectivity (0.0.1):
|
||||
- Flutter
|
||||
- Reachability
|
||||
- connectivity_for_web (0.1.0):
|
||||
- Flutter
|
||||
- connectivity_macos (0.0.1):
|
||||
- Flutter
|
||||
- device_info (0.0.1):
|
||||
- Flutter
|
||||
- Firebase/CoreOnly (6.33.0):
|
||||
- FirebaseCore (= 6.10.3)
|
||||
- Firebase/Messaging (6.33.0):
|
||||
- Firebase/CoreOnly
|
||||
- FirebaseMessaging (~> 4.7.0)
|
||||
- firebase_core (0.5.3):
|
||||
- Firebase/CoreOnly (~> 6.33.0)
|
||||
- Flutter
|
||||
- firebase_core_web (0.1.0):
|
||||
- Flutter
|
||||
- firebase_messaging (7.0.3):
|
||||
- Firebase/CoreOnly (~> 6.33.0)
|
||||
- Firebase/Messaging (~> 6.33.0)
|
||||
- firebase_core
|
||||
- Flutter
|
||||
- FirebaseCore (6.10.3):
|
||||
- FirebaseCoreDiagnostics (~> 1.6)
|
||||
- GoogleUtilities/Environment (~> 6.7)
|
||||
- GoogleUtilities/Logger (~> 6.7)
|
||||
- FirebaseCoreDiagnostics (1.7.0):
|
||||
- GoogleDataTransport (~> 7.4)
|
||||
- GoogleUtilities/Environment (~> 6.7)
|
||||
- GoogleUtilities/Logger (~> 6.7)
|
||||
- nanopb (~> 1.30906.0)
|
||||
- FirebaseInstallations (1.7.0):
|
||||
- FirebaseCore (~> 6.10)
|
||||
- GoogleUtilities/Environment (~> 6.7)
|
||||
- GoogleUtilities/UserDefaults (~> 6.7)
|
||||
- PromisesObjC (~> 1.2)
|
||||
- FirebaseInstanceID (4.8.0):
|
||||
- FirebaseCore (~> 6.10)
|
||||
- FirebaseInstallations (~> 1.6)
|
||||
- GoogleUtilities/Environment (~> 6.7)
|
||||
- GoogleUtilities/UserDefaults (~> 6.7)
|
||||
- FirebaseMessaging (4.7.1):
|
||||
- FirebaseCore (~> 6.10)
|
||||
- FirebaseInstanceID (~> 4.7)
|
||||
- GoogleUtilities/AppDelegateSwizzler (~> 6.7)
|
||||
- GoogleUtilities/Environment (~> 6.7)
|
||||
- GoogleUtilities/Reachability (~> 6.7)
|
||||
- GoogleUtilities/UserDefaults (~> 6.7)
|
||||
- Protobuf (>= 3.9.2, ~> 3.9)
|
||||
- Flutter (1.0.0)
|
||||
- flutter_flexible_toast (0.0.1):
|
||||
- Flutter
|
||||
- flutter_inappwebview (0.0.1):
|
||||
- Flutter
|
||||
- flutter_plugin_android_lifecycle (0.0.1):
|
||||
- Flutter
|
||||
- GoogleDataTransport (7.5.1):
|
||||
- nanopb (~> 1.30906.0)
|
||||
- GoogleUtilities/AppDelegateSwizzler (6.7.2):
|
||||
- GoogleUtilities/Environment
|
||||
- GoogleUtilities/Logger
|
||||
- GoogleUtilities/Network
|
||||
- GoogleUtilities/Environment (6.7.2):
|
||||
- PromisesObjC (~> 1.2)
|
||||
- GoogleUtilities/Logger (6.7.2):
|
||||
- GoogleUtilities/Environment
|
||||
- GoogleUtilities/Network (6.7.2):
|
||||
- GoogleUtilities/Logger
|
||||
- "GoogleUtilities/NSData+zlib"
|
||||
- GoogleUtilities/Reachability
|
||||
- "GoogleUtilities/NSData+zlib (6.7.2)"
|
||||
- GoogleUtilities/Reachability (6.7.2):
|
||||
- GoogleUtilities/Logger
|
||||
- GoogleUtilities/UserDefaults (6.7.2):
|
||||
- GoogleUtilities/Logger
|
||||
- hexcolor (0.0.1):
|
||||
- Flutter
|
||||
- imei_plugin (0.0.1):
|
||||
- Flutter
|
||||
- local_auth (0.0.1):
|
||||
- Flutter
|
||||
- maps_launcher (0.0.1):
|
||||
- Flutter
|
||||
- MTBBarcodeScanner (5.0.11)
|
||||
- nanopb (1.30906.0):
|
||||
- nanopb/decode (= 1.30906.0)
|
||||
- nanopb/encode (= 1.30906.0)
|
||||
- nanopb/decode (1.30906.0)
|
||||
- nanopb/encode (1.30906.0)
|
||||
- OpenTok (2.15.3)
|
||||
- path_provider_linux (0.0.1):
|
||||
- Flutter
|
||||
- path_provider_windows (0.0.1):
|
||||
- Flutter
|
||||
- "permission_handler (5.1.0+2)":
|
||||
- Flutter
|
||||
- PromisesObjC (1.2.12)
|
||||
- Protobuf (3.17.0)
|
||||
- Reachability (3.2)
|
||||
- screen (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences_linux (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences_macos (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences_web (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences_windows (0.0.1):
|
||||
- Flutter
|
||||
- speech_to_text (0.0.1):
|
||||
- Flutter
|
||||
- Try
|
||||
- Try (2.1.1)
|
||||
- url_launcher (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_linux (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_macos (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_web (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_windows (0.0.1):
|
||||
- Flutter
|
||||
- video_player (0.0.1):
|
||||
- Flutter
|
||||
- video_player_web (0.0.1):
|
||||
- Flutter
|
||||
- wakelock (0.0.1):
|
||||
- Flutter
|
||||
- webview_flutter (0.0.1):
|
||||
- Flutter
|
||||
|
||||
DEPENDENCIES:
|
||||
- Alamofire (~> 5.2)
|
||||
- barcode_scan_fix (from `.symlinks/plugins/barcode_scan_fix/ios`)
|
||||
- connectivity (from `.symlinks/plugins/connectivity/ios`)
|
||||
- connectivity_for_web (from `.symlinks/plugins/connectivity_for_web/ios`)
|
||||
- connectivity_macos (from `.symlinks/plugins/connectivity_macos/ios`)
|
||||
- device_info (from `.symlinks/plugins/device_info/ios`)
|
||||
- firebase_core (from `.symlinks/plugins/firebase_core/ios`)
|
||||
- firebase_core_web (from `.symlinks/plugins/firebase_core_web/ios`)
|
||||
- firebase_messaging (from `.symlinks/plugins/firebase_messaging/ios`)
|
||||
- Flutter (from `Flutter`)
|
||||
- flutter_flexible_toast (from `.symlinks/plugins/flutter_flexible_toast/ios`)
|
||||
- flutter_inappwebview (from `.symlinks/plugins/flutter_inappwebview/ios`)
|
||||
- flutter_plugin_android_lifecycle (from `.symlinks/plugins/flutter_plugin_android_lifecycle/ios`)
|
||||
- hexcolor (from `.symlinks/plugins/hexcolor/ios`)
|
||||
- imei_plugin (from `.symlinks/plugins/imei_plugin/ios`)
|
||||
- local_auth (from `.symlinks/plugins/local_auth/ios`)
|
||||
- maps_launcher (from `.symlinks/plugins/maps_launcher/ios`)
|
||||
- OpenTok
|
||||
- path_provider_linux (from `.symlinks/plugins/path_provider_linux/ios`)
|
||||
- path_provider_windows (from `.symlinks/plugins/path_provider_windows/ios`)
|
||||
- permission_handler (from `.symlinks/plugins/permission_handler/ios`)
|
||||
- screen (from `.symlinks/plugins/screen/ios`)
|
||||
- shared_preferences (from `.symlinks/plugins/shared_preferences/ios`)
|
||||
- shared_preferences_linux (from `.symlinks/plugins/shared_preferences_linux/ios`)
|
||||
- shared_preferences_macos (from `.symlinks/plugins/shared_preferences_macos/ios`)
|
||||
- shared_preferences_web (from `.symlinks/plugins/shared_preferences_web/ios`)
|
||||
- shared_preferences_windows (from `.symlinks/plugins/shared_preferences_windows/ios`)
|
||||
- speech_to_text (from `.symlinks/plugins/speech_to_text/ios`)
|
||||
- url_launcher (from `.symlinks/plugins/url_launcher/ios`)
|
||||
- url_launcher_linux (from `.symlinks/plugins/url_launcher_linux/ios`)
|
||||
- url_launcher_macos (from `.symlinks/plugins/url_launcher_macos/ios`)
|
||||
- url_launcher_web (from `.symlinks/plugins/url_launcher_web/ios`)
|
||||
- url_launcher_windows (from `.symlinks/plugins/url_launcher_windows/ios`)
|
||||
- video_player (from `.symlinks/plugins/video_player/ios`)
|
||||
- video_player_web (from `.symlinks/plugins/video_player_web/ios`)
|
||||
- wakelock (from `.symlinks/plugins/wakelock/ios`)
|
||||
- webview_flutter (from `.symlinks/plugins/webview_flutter/ios`)
|
||||
|
||||
SPEC REPOS:
|
||||
trunk:
|
||||
- Alamofire
|
||||
- Firebase
|
||||
- FirebaseCore
|
||||
- FirebaseCoreDiagnostics
|
||||
- FirebaseInstallations
|
||||
- FirebaseInstanceID
|
||||
- FirebaseMessaging
|
||||
- GoogleDataTransport
|
||||
- GoogleUtilities
|
||||
- MTBBarcodeScanner
|
||||
- nanopb
|
||||
- OpenTok
|
||||
- PromisesObjC
|
||||
- Protobuf
|
||||
- Reachability
|
||||
- Try
|
||||
|
||||
EXTERNAL SOURCES:
|
||||
barcode_scan_fix:
|
||||
:path: ".symlinks/plugins/barcode_scan_fix/ios"
|
||||
connectivity:
|
||||
:path: ".symlinks/plugins/connectivity/ios"
|
||||
connectivity_for_web:
|
||||
:path: ".symlinks/plugins/connectivity_for_web/ios"
|
||||
connectivity_macos:
|
||||
:path: ".symlinks/plugins/connectivity_macos/ios"
|
||||
device_info:
|
||||
:path: ".symlinks/plugins/device_info/ios"
|
||||
firebase_core:
|
||||
:path: ".symlinks/plugins/firebase_core/ios"
|
||||
firebase_core_web:
|
||||
:path: ".symlinks/plugins/firebase_core_web/ios"
|
||||
firebase_messaging:
|
||||
:path: ".symlinks/plugins/firebase_messaging/ios"
|
||||
Flutter:
|
||||
:path: Flutter
|
||||
flutter_flexible_toast:
|
||||
:path: ".symlinks/plugins/flutter_flexible_toast/ios"
|
||||
flutter_inappwebview:
|
||||
:path: ".symlinks/plugins/flutter_inappwebview/ios"
|
||||
flutter_plugin_android_lifecycle:
|
||||
:path: ".symlinks/plugins/flutter_plugin_android_lifecycle/ios"
|
||||
hexcolor:
|
||||
:path: ".symlinks/plugins/hexcolor/ios"
|
||||
imei_plugin:
|
||||
:path: ".symlinks/plugins/imei_plugin/ios"
|
||||
local_auth:
|
||||
:path: ".symlinks/plugins/local_auth/ios"
|
||||
maps_launcher:
|
||||
:path: ".symlinks/plugins/maps_launcher/ios"
|
||||
path_provider_linux:
|
||||
:path: ".symlinks/plugins/path_provider_linux/ios"
|
||||
path_provider_windows:
|
||||
:path: ".symlinks/plugins/path_provider_windows/ios"
|
||||
permission_handler:
|
||||
:path: ".symlinks/plugins/permission_handler/ios"
|
||||
screen:
|
||||
:path: ".symlinks/plugins/screen/ios"
|
||||
shared_preferences:
|
||||
:path: ".symlinks/plugins/shared_preferences/ios"
|
||||
shared_preferences_linux:
|
||||
:path: ".symlinks/plugins/shared_preferences_linux/ios"
|
||||
shared_preferences_macos:
|
||||
:path: ".symlinks/plugins/shared_preferences_macos/ios"
|
||||
shared_preferences_web:
|
||||
:path: ".symlinks/plugins/shared_preferences_web/ios"
|
||||
shared_preferences_windows:
|
||||
:path: ".symlinks/plugins/shared_preferences_windows/ios"
|
||||
speech_to_text:
|
||||
:path: ".symlinks/plugins/speech_to_text/ios"
|
||||
url_launcher:
|
||||
:path: ".symlinks/plugins/url_launcher/ios"
|
||||
url_launcher_linux:
|
||||
:path: ".symlinks/plugins/url_launcher_linux/ios"
|
||||
url_launcher_macos:
|
||||
:path: ".symlinks/plugins/url_launcher_macos/ios"
|
||||
url_launcher_web:
|
||||
:path: ".symlinks/plugins/url_launcher_web/ios"
|
||||
url_launcher_windows:
|
||||
:path: ".symlinks/plugins/url_launcher_windows/ios"
|
||||
video_player:
|
||||
:path: ".symlinks/plugins/video_player/ios"
|
||||
video_player_web:
|
||||
:path: ".symlinks/plugins/video_player_web/ios"
|
||||
wakelock:
|
||||
:path: ".symlinks/plugins/wakelock/ios"
|
||||
webview_flutter:
|
||||
:path: ".symlinks/plugins/webview_flutter/ios"
|
||||
|
||||
SPEC CHECKSUMS:
|
||||
Alamofire: e447a2774a40c996748296fa2c55112fdbbc42f9
|
||||
barcode_scan_fix: 80dd65de55f27eec6591dd077c8b85f2b79e31f1
|
||||
connectivity: c4130b2985d4ef6fd26f9702e886bd5260681467
|
||||
connectivity_for_web: 2b8584556930d4bd490d82b836bcf45067ce345b
|
||||
connectivity_macos: e2e9731b6b22dda39eb1b128f6969d574460e191
|
||||
device_info: d7d233b645a32c40dfdc212de5cf646ca482f175
|
||||
Firebase: 8db6f2d1b2c5e2984efba4949a145875a8f65fe5
|
||||
firebase_core: 5d6a02f3d85acd5f8321c2d6d62877626a670659
|
||||
firebase_core_web: d501d8b946b60c8af265428ce483b0fff5ad52d1
|
||||
firebase_messaging: 0aea2cd5885b65e19ede58ee3507f485c992cc75
|
||||
FirebaseCore: d889d9e12535b7f36ac8bfbf1713a0836a3012cd
|
||||
FirebaseCoreDiagnostics: 770ac5958e1372ce67959ae4b4f31d8e127c3ac1
|
||||
FirebaseInstallations: 466c7b4d1f58fe16707693091da253726a731ed2
|
||||
FirebaseInstanceID: bd3ffc24367f901a43c063b36c640b345a4a5dd1
|
||||
FirebaseMessaging: 5eca4ef173de76253352511aafef774caa1cba2a
|
||||
Flutter: 0e3d915762c693b495b44d77113d4970485de6ec
|
||||
flutter_flexible_toast: 0547e740cae0c33bb7c51bcd931233f4584e1143
|
||||
flutter_inappwebview: 69dfbac46157b336ffbec19ca6dfd4638c7bf189
|
||||
flutter_plugin_android_lifecycle: dc0b544e129eebb77a6bfb1239d4d1c673a60a35
|
||||
GoogleDataTransport: f56af7caa4ed338dc8e138a5d7c5973e66440833
|
||||
GoogleUtilities: 7f2f5a07f888cdb145101d6042bc4422f57e70b3
|
||||
hexcolor: fdfb9c4258ad96e949c2dbcdf790a62194b8aa89
|
||||
imei_plugin: cb1af7c223ac2d82dcd1457a7137d93d65d2a3cd
|
||||
local_auth: 25938960984c3a7f6e3253e3f8d962fdd16852bd
|
||||
maps_launcher: eae38ee13a9c3f210fa04e04bb4c073fa4c6ed92
|
||||
MTBBarcodeScanner: f453b33c4b7dfe545d8c6484ed744d55671788cb
|
||||
nanopb: 59317e09cf1f1a0af72f12af412d54edf52603fc
|
||||
OpenTok: fde03ecc5ea31fe0a453242847c4ee1f47e1d735
|
||||
path_provider_linux: 4d630dc393e1f20364f3e3b4a2ff41d9674a84e4
|
||||
path_provider_windows: a2b81600c677ac1959367280991971cb9a1edb3b
|
||||
permission_handler: ccb20a9fad0ee9b1314a52b70b76b473c5f8dab0
|
||||
PromisesObjC: 3113f7f76903778cf4a0586bd1ab89329a0b7b97
|
||||
Protobuf: 7327d4444215b5f18e560a97f879ff5503c4581c
|
||||
Reachability: 33e18b67625424e47b6cde6d202dce689ad7af96
|
||||
screen: abd91ca7bf3426e1cc3646d27e9b2358d6bf07b0
|
||||
shared_preferences: af6bfa751691cdc24be3045c43ec037377ada40d
|
||||
shared_preferences_linux: afefbfe8d921e207f01ede8b60373d9e3b566b78
|
||||
shared_preferences_macos: f3f29b71ccbb56bf40c9dd6396c9acf15e214087
|
||||
shared_preferences_web: 141cce0c3ed1a1c5bf2a0e44f52d31eeb66e5ea9
|
||||
shared_preferences_windows: 36b76d6f54e76ead957e60b49e2f124b4cd3e6ae
|
||||
speech_to_text: b43a7d99aef037bd758ed8e45d79bbac035d2dfe
|
||||
Try: 5ef669ae832617b3cee58cb2c6f99fb767a4ff96
|
||||
url_launcher: 6fef411d543ceb26efce54b05a0a40bfd74cbbef
|
||||
url_launcher_linux: ac237cb7a8058736e4aae38bdbcc748a4b394cc0
|
||||
url_launcher_macos: fd7894421cd39320dce5f292fc99ea9270b2a313
|
||||
url_launcher_web: e5527357f037c87560776e36436bf2b0288b965c
|
||||
url_launcher_windows: 683d7c283894db8d1914d3ab2223b20cc1ad95d5
|
||||
video_player: 9cc823b1d9da7e8427ee591e8438bfbcde500e6e
|
||||
video_player_web: da8cadb8274ed4f8dbee8d7171b420dedd437ce7
|
||||
wakelock: 0d4a70faf8950410735e3f61fb15d517c8a6efc4
|
||||
webview_flutter: d2b4d6c66968ad042ad94cbb791f5b72b4678a96
|
||||
|
||||
PODFILE CHECKSUM: d0a3789a37635365b4345e456835ed9d30398217
|
||||
|
||||
COCOAPODS: 1.10.1
|
||||
@ -0,0 +1,4 @@
|
||||
enum PatientType{
|
||||
IN_PATIENT,
|
||||
OUT_PATIENT,
|
||||
}
|
||||
@ -0,0 +1,104 @@
|
||||
class MyReferralPatientRequestModel {
|
||||
int channel;
|
||||
int clinicID;
|
||||
int doctorID;
|
||||
int editedBy;
|
||||
String firstName;
|
||||
String from;
|
||||
String iPAdress;
|
||||
bool isLoginForDoctorApp;
|
||||
int languageID;
|
||||
String lastName;
|
||||
String middleName;
|
||||
int patientID;
|
||||
String patientIdentificationID;
|
||||
String patientMobileNumber;
|
||||
bool patientOutSA;
|
||||
int patientTypeID;
|
||||
int projectID;
|
||||
String sessionID;
|
||||
String stamp;
|
||||
String to;
|
||||
String tokenID;
|
||||
double versionID;
|
||||
String vidaAuthTokenID;
|
||||
|
||||
MyReferralPatientRequestModel(
|
||||
{this.channel,
|
||||
this.clinicID,
|
||||
this.doctorID,
|
||||
this.editedBy,
|
||||
this.firstName,
|
||||
this.from,
|
||||
this.iPAdress,
|
||||
this.isLoginForDoctorApp,
|
||||
this.languageID,
|
||||
this.lastName,
|
||||
this.middleName,
|
||||
this.patientID,
|
||||
this.patientIdentificationID,
|
||||
this.patientMobileNumber,
|
||||
this.patientOutSA,
|
||||
this.patientTypeID,
|
||||
this.projectID,
|
||||
this.sessionID,
|
||||
this.stamp,
|
||||
this.to,
|
||||
this.tokenID,
|
||||
this.versionID,
|
||||
this.vidaAuthTokenID});
|
||||
|
||||
MyReferralPatientRequestModel.fromJson(Map<String, dynamic> json) {
|
||||
channel = json['Channel'];
|
||||
clinicID = json['ClinicID'];
|
||||
doctorID = json['DoctorID'];
|
||||
editedBy = json['EditedBy'];
|
||||
firstName = json['FirstName'];
|
||||
from = json['From'];
|
||||
iPAdress = json['IPAdress'];
|
||||
isLoginForDoctorApp = json['IsLoginForDoctorApp'];
|
||||
languageID = json['LanguageID'];
|
||||
lastName = json['LastName'];
|
||||
middleName = json['MiddleName'];
|
||||
patientID = json['PatientID'];
|
||||
patientIdentificationID = json['PatientIdentificationID'];
|
||||
patientMobileNumber = json['PatientMobileNumber'];
|
||||
patientOutSA = json['PatientOutSA'];
|
||||
patientTypeID = json['PatientTypeID'];
|
||||
projectID = json['ProjectID'];
|
||||
sessionID = json['SessionID'];
|
||||
stamp = json['stamp'];
|
||||
to = json['To'];
|
||||
tokenID = json['TokenID'];
|
||||
versionID = json['VersionID'];
|
||||
vidaAuthTokenID = json['VidaAuthTokenID'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['Channel'] = this.channel;
|
||||
data['ClinicID'] = this.clinicID;
|
||||
data['DoctorID'] = this.doctorID;
|
||||
data['EditedBy'] = this.editedBy;
|
||||
data['FirstName'] = this.firstName;
|
||||
data['From'] = this.from;
|
||||
data['IPAdress'] = this.iPAdress;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['LastName'] = this.lastName;
|
||||
data['MiddleName'] = this.middleName;
|
||||
data['PatientID'] = this.patientID;
|
||||
data['PatientIdentificationID'] = this.patientIdentificationID;
|
||||
data['PatientMobileNumber'] = this.patientMobileNumber;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
data['PatientTypeID'] = this.patientTypeID;
|
||||
data['ProjectID'] = this.projectID;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['stamp'] = this.stamp;
|
||||
data['To'] = this.to;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['VersionID'] = this.versionID;
|
||||
data['VidaAuthTokenID'] = this.vidaAuthTokenID;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,72 @@
|
||||
class AddReferredRemarksRequestModel {
|
||||
int projectID;
|
||||
int admissionNo;
|
||||
int lineItemNo;
|
||||
String referredDoctorRemarks;
|
||||
int editedBy;
|
||||
int referalStatus;
|
||||
bool isLoginForDoctorApp;
|
||||
String iPAdress;
|
||||
bool patientOutSA;
|
||||
String tokenID;
|
||||
int languageID;
|
||||
double versionID;
|
||||
int channel;
|
||||
String sessionID;
|
||||
int deviceTypeID;
|
||||
|
||||
AddReferredRemarksRequestModel(
|
||||
{this.projectID,
|
||||
this.admissionNo,
|
||||
this.lineItemNo,
|
||||
this.referredDoctorRemarks,
|
||||
this.editedBy,
|
||||
this.referalStatus,
|
||||
this.isLoginForDoctorApp,
|
||||
this.iPAdress,
|
||||
this.patientOutSA,
|
||||
this.tokenID,
|
||||
this.languageID,
|
||||
this.versionID,
|
||||
this.channel,
|
||||
this.sessionID,
|
||||
this.deviceTypeID});
|
||||
|
||||
AddReferredRemarksRequestModel.fromJson(Map<String, dynamic> json) {
|
||||
projectID = json['ProjectID'];
|
||||
admissionNo = json['AdmissionNo'];
|
||||
lineItemNo = json['LineItemNo'];
|
||||
referredDoctorRemarks = json['ReferredDoctorRemarks'];
|
||||
editedBy = json['EditedBy'];
|
||||
referalStatus = json['ReferalStatus'];
|
||||
isLoginForDoctorApp = json['IsLoginForDoctorApp'];
|
||||
iPAdress = json['IPAdress'];
|
||||
patientOutSA = json['PatientOutSA'];
|
||||
tokenID = json['TokenID'];
|
||||
languageID = json['LanguageID'];
|
||||
versionID = json['VersionID'];
|
||||
channel = json['Channel'];
|
||||
sessionID = json['SessionID'];
|
||||
deviceTypeID = json['DeviceTypeID'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['ProjectID'] = this.projectID;
|
||||
data['AdmissionNo'] = this.admissionNo;
|
||||
data['LineItemNo'] = this.lineItemNo;
|
||||
data['ReferredDoctorRemarks'] = this.referredDoctorRemarks;
|
||||
data['EditedBy'] = this.editedBy;
|
||||
data['ReferalStatus'] = this.referalStatus;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['IPAdress'] = this.iPAdress;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['VersionID'] = this.versionID;
|
||||
data['Channel'] = this.channel;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['DeviceTypeID'] = this.deviceTypeID;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,12 @@
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class NavigationService {
|
||||
final GlobalKey<NavigatorState> navigatorKey =
|
||||
new GlobalKey<NavigatorState>();
|
||||
Future<dynamic> navigateTo(String routeName) {
|
||||
return navigatorKey.currentState.pushNamed(routeName);
|
||||
}
|
||||
Future<dynamic> pushNamedAndRemoveUntil(String routeName) {
|
||||
return navigatorKey.currentState.pushNamedAndRemoveUntil(routeName,(asd)=>false);
|
||||
}
|
||||
}
|
||||
@ -1,36 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/config.dart';
|
||||
import 'package:doctor_app_flutter/core/service/base/base_service.dart';
|
||||
import 'package:doctor_app_flutter/models/doctor/verify_referral_doctor_remarks.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/my_referral/my_referred_patient_model.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/request_my_referral_patient_model.dart';
|
||||
|
||||
class ReferredPatientService extends BaseService {
|
||||
List<MyReferredPatientModel> _listMyReferredPatientModel = [];
|
||||
|
||||
List<MyReferredPatientModel> get listMyReferredPatientModel =>
|
||||
_listMyReferredPatientModel;
|
||||
|
||||
RequestMyReferralPatientModel _requestMyReferralPatient =
|
||||
RequestMyReferralPatientModel();
|
||||
VerifyReferralDoctorRemarks _verifyreferraldoctorremarks =
|
||||
VerifyReferralDoctorRemarks();
|
||||
|
||||
Future getMyReferredPatient() async {
|
||||
await baseAppClient.post(
|
||||
GET_MY_REFERRED_PATIENT,
|
||||
onSuccess: (dynamic response, int statusCode) {
|
||||
_listMyReferredPatientModel.clear();
|
||||
response['List_MyReferredPatient'].forEach((v) {
|
||||
listMyReferredPatientModel.add(MyReferredPatientModel.fromJson(v));
|
||||
});
|
||||
// print(response['List_MyReferredPatient']);
|
||||
},
|
||||
onFailure: (String error, int statusCode) {
|
||||
hasError = true;
|
||||
super.error = error;
|
||||
},
|
||||
body: _requestMyReferralPatient.toJson(),
|
||||
);
|
||||
}
|
||||
|
||||
}
|
||||
@ -1,24 +0,0 @@
|
||||
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||
import 'package:doctor_app_flutter/core/service/patient/referred_patient_service.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/my_referral/my_referred_patient_model.dart';
|
||||
|
||||
import '../../locator.dart';
|
||||
import 'base_view_model.dart';
|
||||
|
||||
class ReferredPatientViewModel extends BaseViewModel {
|
||||
ReferredPatientService _referralPatientService =
|
||||
locator<ReferredPatientService>();
|
||||
|
||||
List<MyReferredPatientModel> get listMyReferredPatientModel =>
|
||||
_referralPatientService.listMyReferredPatientModel;
|
||||
|
||||
Future getMyReferredPatient() async {
|
||||
setState(ViewState.Busy);
|
||||
await _referralPatientService.getMyReferredPatient();
|
||||
if (_referralPatientService.hasError) {
|
||||
error = _referralPatientService.error;
|
||||
setState(ViewState.Error);
|
||||
} else
|
||||
setState(ViewState.Idle);
|
||||
}
|
||||
}
|
||||
@ -1,56 +1,56 @@
|
||||
class StartCallReq {
|
||||
int vCID;
|
||||
bool isrecall;
|
||||
String tokenID;
|
||||
String generalid;
|
||||
String clincName;
|
||||
int clinicId;
|
||||
String docSpec;
|
||||
String docotrName;
|
||||
int doctorId;
|
||||
String generalid;
|
||||
bool isOutKsa;
|
||||
bool isrecall;
|
||||
String projectName;
|
||||
String docotrName;
|
||||
String clincName;
|
||||
String docSpec;
|
||||
int clinicId;
|
||||
String tokenID;
|
||||
int vCID;
|
||||
|
||||
StartCallReq(
|
||||
{this.vCID,
|
||||
this.isrecall,
|
||||
this.tokenID,
|
||||
this.generalid,
|
||||
this.doctorId,
|
||||
this.isOutKsa,
|
||||
this.projectName,
|
||||
this.docotrName,
|
||||
this.clincName,
|
||||
this.docSpec,
|
||||
this.clinicId});
|
||||
{this.clincName,
|
||||
this.clinicId,
|
||||
this.docSpec,
|
||||
this.docotrName,
|
||||
this.doctorId,
|
||||
this.generalid,
|
||||
this.isOutKsa,
|
||||
this.isrecall,
|
||||
this.projectName,
|
||||
this.tokenID,
|
||||
this.vCID});
|
||||
|
||||
StartCallReq.fromJson(Map<String, dynamic> json) {
|
||||
vCID = json['VC_ID'];
|
||||
isrecall = json['isrecall'];
|
||||
tokenID = json['TokenID'];
|
||||
generalid = json['generalid'];
|
||||
clincName = json['clincName'];
|
||||
clinicId = json['ClinicId'];
|
||||
docSpec = json['Doc_Spec'];
|
||||
docotrName = json['DocotrName'];
|
||||
doctorId = json['DoctorId'];
|
||||
generalid = json['generalid'];
|
||||
isOutKsa = json['IsOutKsa'];
|
||||
isrecall = json['isrecall'];
|
||||
projectName = json['projectName'];
|
||||
docotrName = json['DocotrName'];
|
||||
clincName = json['clincName'];
|
||||
docSpec = json['Doc_Spec'];
|
||||
clinicId = json['ClinicId'];
|
||||
tokenID = json['TokenID'];
|
||||
vCID = json['VC_ID'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['VC_ID'] = this.vCID;
|
||||
data['isrecall'] = this.isrecall;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['generalid'] = this.generalid;
|
||||
data['clincName'] = this.clincName;
|
||||
data['ClinicId'] = this.clinicId;
|
||||
data['Doc_Spec'] = this.docSpec;
|
||||
data['DocotrName'] = this.docotrName;
|
||||
data['DoctorId'] = this.doctorId;
|
||||
data['generalid'] = this.generalid;
|
||||
data['IsOutKsa'] = this.isOutKsa;
|
||||
data['isrecall'] = this.isrecall;
|
||||
data['projectName'] = this.projectName;
|
||||
data['DocotrName'] = this.docotrName;
|
||||
data['clincName'] = this.clincName;
|
||||
data['Doc_Spec'] = this.docSpec;
|
||||
data['ClinicId'] = this.clinicId;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['VC_ID'] = this.vCID;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,119 @@
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/core/model/referral/MyReferralPatientModel.dart';
|
||||
import 'package:doctor_app_flutter/core/viewModel/patient-referral-viewmodel.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/buttons/app_buttons_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
import '../../../../routes.dart';
|
||||
|
||||
class ReplySummeryOnReferralPatient extends StatefulWidget {
|
||||
final MyReferralPatientModel referredPatient;
|
||||
final String doctorReply;
|
||||
|
||||
ReplySummeryOnReferralPatient(this.referredPatient, this.doctorReply);
|
||||
|
||||
@override
|
||||
_ReplySummeryOnReferralPatientState createState() =>
|
||||
_ReplySummeryOnReferralPatientState(this.referredPatient);
|
||||
}
|
||||
|
||||
class _ReplySummeryOnReferralPatientState
|
||||
extends State<ReplySummeryOnReferralPatient> {
|
||||
final MyReferralPatientModel referredPatient;
|
||||
|
||||
_ReplySummeryOnReferralPatientState(this.referredPatient);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return BaseView<PatientReferralViewModel>(
|
||||
builder: (_, model, w) => AppScaffold(
|
||||
baseViewModel: model,
|
||||
isShowAppBar: true,
|
||||
appBarTitle: TranslationBase.of(context).summeryReply,
|
||||
body: Container(
|
||||
child: Column(
|
||||
children: [
|
||||
|
||||
Expanded(
|
||||
child: SingleChildScrollView(
|
||||
child: Container(
|
||||
width: double.infinity,
|
||||
margin:
|
||||
EdgeInsets.symmetric(horizontal: 16, vertical: 16),
|
||||
padding: EdgeInsets.symmetric(
|
||||
horizontal: 16, vertical: 16),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
shape: BoxShape.rectangle,
|
||||
borderRadius: BorderRadius.all(Radius.circular(8)),
|
||||
border: Border.fromBorderSide(BorderSide(
|
||||
color: Colors.white,
|
||||
width: 1.0,
|
||||
)),
|
||||
),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).reply,
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 2.4 * SizeConfig.textMultiplier,
|
||||
color: Color(0XFF2E303A),
|
||||
),
|
||||
AppText(
|
||||
widget.doctorReply ?? '',
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
fontSize: 1.8 * SizeConfig.textMultiplier,
|
||||
color: Color(0XFF2E303A),
|
||||
),
|
||||
SizedBox(
|
||||
height: 8,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
Container(
|
||||
margin:
|
||||
EdgeInsets.symmetric(horizontal: 16, vertical: 16),
|
||||
child: Row(
|
||||
children: [
|
||||
Expanded(
|
||||
child: AppButton(
|
||||
onPressed: () {
|
||||
Navigator.of(context).pop();
|
||||
},
|
||||
title: TranslationBase.of(context).cancel,
|
||||
fontColor: Colors.white,
|
||||
color: Colors.red[600],
|
||||
),
|
||||
),
|
||||
SizedBox(width: 4,),
|
||||
Expanded(
|
||||
child: AppButton(
|
||||
onPressed: () {},
|
||||
title: TranslationBase.of(context).noteConfirm,
|
||||
fontColor: Colors.white,
|
||||
color: Colors.green[600],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
));
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
@ -1,591 +0,0 @@
|
||||
import 'package:doctor_app_flutter/core/viewModel/prescription_view_model.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||
import 'package:doctor_app_flutter/screens/prescription/add_prescription_form.dart';
|
||||
import 'package:doctor_app_flutter/screens/prescription/update_prescription_form.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/patients/profile/patient-page-header-widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class NewPrescriptionScreen extends StatefulWidget {
|
||||
@override
|
||||
_NewPrescriptionScreenState createState() => _NewPrescriptionScreenState();
|
||||
}
|
||||
|
||||
class _NewPrescriptionScreenState extends State<NewPrescriptionScreen> {
|
||||
PersistentBottomSheetController _controller;
|
||||
TextEditingController strengthController = TextEditingController();
|
||||
int testNum = 0;
|
||||
int strengthChar;
|
||||
PatiantInformtion patient;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
}
|
||||
|
||||
Widget build(BuildContext context) {
|
||||
final screenSize = MediaQuery.of(context).size;
|
||||
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||
patient = routeArgs['patient'];
|
||||
return BaseView<PrescriptionViewModel>(
|
||||
onModelReady: (model) => model.getPrescription(mrn: patient.patientId),
|
||||
builder: (BuildContext context, PrescriptionViewModel model, Widget child) => AppScaffold(
|
||||
isShowAppBar: true,
|
||||
appBarTitle: TranslationBase.of(context).prescription,
|
||||
body: NetworkBaseView(
|
||||
baseViewModel: model,
|
||||
child: SingleChildScrollView(
|
||||
child: Container(
|
||||
color: Colors.white,
|
||||
child: Column(
|
||||
children: [
|
||||
PatientPageHeaderWidget(patient),
|
||||
Divider(
|
||||
height: 1.0,
|
||||
thickness: 1.0,
|
||||
color: Colors.grey,
|
||||
),
|
||||
(model.prescriptionList.length != 0)
|
||||
? SizedBox(height: model.prescriptionList[0].rowcount == 0 ? 200.0 : 10.0)
|
||||
: SizedBox(height: 200.0),
|
||||
//model.prescriptionList == null
|
||||
(model.prescriptionList.length != 0)
|
||||
? model.prescriptionList[0].rowcount == 0
|
||||
? Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
||||
children: [
|
||||
InkWell(
|
||||
onTap: () {
|
||||
addPrescriptionForm(context, model, patient, model.prescriptionList);
|
||||
//model.postPrescription();
|
||||
},
|
||||
child: CircleAvatar(
|
||||
radius: 65,
|
||||
backgroundColor: Color(0XFFB8382C),
|
||||
child: CircleAvatar(
|
||||
radius: 60,
|
||||
backgroundColor: Colors.white,
|
||||
child: Icon(
|
||||
Icons.add,
|
||||
color: Colors.black,
|
||||
size: 45.0,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 15.0,
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).noPrescriptionListed,
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.w900,
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).addNow,
|
||||
color: Color(0XFFB8382C),
|
||||
fontWeight: FontWeight.w900,
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
)
|
||||
: Padding(
|
||||
padding: EdgeInsets.all(14.0),
|
||||
child: NetworkBaseView(
|
||||
baseViewModel: model,
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
InkWell(
|
||||
child: Container(
|
||||
height: 50.0,
|
||||
width: 450.0,
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
border: Border.all(color: Colors.grey),
|
||||
borderRadius: BorderRadius.circular(10.0),
|
||||
),
|
||||
child: Padding(
|
||||
padding: EdgeInsets.all(8.0),
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
AppText(
|
||||
' Add more medication',
|
||||
fontWeight: FontWeight.w100,
|
||||
fontSize: 12.5,
|
||||
),
|
||||
Icon(
|
||||
Icons.add,
|
||||
color: Color(0XFFB8382C),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
onTap: () {
|
||||
addPrescriptionForm(context, model, patient, model.prescriptionList);
|
||||
//model.postPrescription();
|
||||
},
|
||||
),
|
||||
SizedBox(
|
||||
height: 10.0,
|
||||
),
|
||||
...List.generate(
|
||||
model.prescriptionList[0].rowcount,
|
||||
(index) => Container(
|
||||
color: Colors.white,
|
||||
child: Column(
|
||||
children: [
|
||||
SizedBox(
|
||||
height: MediaQuery.of(context).size.height * 0.022,
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
// crossAxisAlignment:
|
||||
// CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
color: Colors.white,
|
||||
height: MediaQuery.of(context).size.height * 0.21,
|
||||
width: MediaQuery.of(context).size.width * 0.1,
|
||||
child: Column(
|
||||
children: [
|
||||
AppText(
|
||||
(DateTime.parse(model.prescriptionList[0].entityList[index]
|
||||
.createdOn) !=
|
||||
null
|
||||
? (DateTime.parse(model.prescriptionList[0]
|
||||
.entityList[index].createdOn)
|
||||
.year)
|
||||
.toString()
|
||||
: DateTime.now().year)
|
||||
.toString(),
|
||||
color: Colors.green,
|
||||
fontSize: 13.5,
|
||||
),
|
||||
AppText(
|
||||
AppDateUtils.getMonth(model.prescriptionList[0]
|
||||
.entityList[index].createdOn !=
|
||||
null
|
||||
? (DateTime.parse(model.prescriptionList[0]
|
||||
.entityList[index].createdOn)
|
||||
.month)
|
||||
: DateTime.now().month)
|
||||
.toUpperCase(),
|
||||
color: Colors.green,
|
||||
),
|
||||
AppText(
|
||||
DateTime.parse(
|
||||
model.prescriptionList[0].entityList[index].createdOn)
|
||||
.day
|
||||
.toString(),
|
||||
color: Colors.green,
|
||||
),
|
||||
AppText(
|
||||
AppDateUtils.getTimeFormated(DateTime.parse(model
|
||||
.prescriptionList[0].entityList[index].createdOn))
|
||||
.toString(),
|
||||
color: Colors.green,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
color: Colors.white,
|
||||
// height: MediaQuery.of(
|
||||
// context)
|
||||
// .size
|
||||
// .height *
|
||||
// 0.3499,
|
||||
width: MediaQuery.of(context).size.width * 0.77,
|
||||
child: Column(
|
||||
children: [
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Start Date:',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 14.0,
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
AppDateUtils.getDateFormatted(DateTime.parse(model
|
||||
.prescriptionList[0].entityList[index].startDate)),
|
||||
fontSize: 13.5,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 6.0,
|
||||
),
|
||||
AppText(
|
||||
'Order Type:',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 14.0,
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
model.prescriptionList[0].entityList[index]
|
||||
.orderTypeDescription,
|
||||
fontSize: 13.0,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 5.5,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
Container(
|
||||
color: Colors.white,
|
||||
child: Expanded(
|
||||
child: AppText(
|
||||
model.prescriptionList[0].entityList[index]
|
||||
.medicationName,
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 15.0,
|
||||
),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 5.5,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
Expanded(
|
||||
child: AppText(
|
||||
model.prescriptionList[0].entityList[index].doseDetail,
|
||||
fontSize: 15.0,
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 10.0,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Indication: ',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 17.0,
|
||||
),
|
||||
Expanded(
|
||||
child: RichText(
|
||||
maxLines: 3,
|
||||
overflow: TextOverflow.ellipsis,
|
||||
strutStyle: StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style: TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index]
|
||||
.indication),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'UOM: ',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 17.0,
|
||||
),
|
||||
Expanded(
|
||||
child: RichText(
|
||||
maxLines: 3,
|
||||
overflow: TextOverflow.ellipsis,
|
||||
strutStyle: StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style: TextStyle(color: Colors.black),
|
||||
text: model
|
||||
.prescriptionList[0].entityList[index].uom),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'BOX Quantity: ',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 17.0,
|
||||
),
|
||||
Expanded(
|
||||
child: RichText(
|
||||
maxLines: 3,
|
||||
overflow: TextOverflow.ellipsis,
|
||||
strutStyle: StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style: TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index]
|
||||
.quantity
|
||||
.toString() ==
|
||||
null
|
||||
? ""
|
||||
: model.prescriptionList[0].entityList[index]
|
||||
.quantity
|
||||
.toString()),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'pharmacy Intervention ',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 17.0,
|
||||
),
|
||||
Expanded(
|
||||
child: RichText(
|
||||
maxLines: 3,
|
||||
overflow: TextOverflow.ellipsis,
|
||||
strutStyle: StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style: TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index]
|
||||
.pharmacyInervention ==
|
||||
null
|
||||
? ""
|
||||
: model.prescriptionList[0].entityList[index]
|
||||
.pharmacyInervention
|
||||
.toString()),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(height: 5.0),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'pharmacist Remarks : ',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 15.0,
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
model.prescriptionList[0].entityList[index]
|
||||
.pharmacistRemarks ==
|
||||
null
|
||||
? ""
|
||||
: model.prescriptionList[0].entityList[index]
|
||||
.pharmacistRemarks,
|
||||
fontSize: 15.0),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 20.0,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).doctorName + ": ",
|
||||
fontWeight: FontWeight.w600,
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
model.prescriptionList[0].entityList[index].doctorName,
|
||||
fontWeight: FontWeight.w700,
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 8.0,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Doctor Remarks : ',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 13.0,
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
color: Colors.white,
|
||||
// height: MediaQuery.of(context).size.height *
|
||||
// 0.038,
|
||||
child: RichText(
|
||||
// maxLines:
|
||||
// 2,
|
||||
// overflow:
|
||||
// TextOverflow.ellipsis,
|
||||
strutStyle: StrutStyle(fontSize: 10.0),
|
||||
text: TextSpan(
|
||||
style: TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index]
|
||||
.remarks !=
|
||||
null
|
||||
? model.prescriptionList[0].entityList[index]
|
||||
.remarks
|
||||
: "",
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 10.0,
|
||||
),
|
||||
|
||||
// SizedBox(
|
||||
// height: 40,
|
||||
// ),
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
color: Colors.white,
|
||||
height: MediaQuery.of(context).size.height * 0.16,
|
||||
width: MediaQuery.of(context).size.width * 0.06,
|
||||
child: Column(
|
||||
children: [
|
||||
InkWell(
|
||||
child: Icon(Icons.edit),
|
||||
onTap: () {
|
||||
updatePrescriptionForm(
|
||||
box: model
|
||||
.prescriptionList[0].entityList[index].quantity,
|
||||
uom: model.prescriptionList[0].entityList[index].uom,
|
||||
drugNameGeneric: model.prescriptionList[0]
|
||||
.entityList[index].medicationName,
|
||||
doseUnit: model.prescriptionList[0].entityList[index]
|
||||
.doseDailyUnitID
|
||||
.toString(),
|
||||
doseStreangth: model.prescriptionList[0]
|
||||
.entityList[index].doseDailyQuantity
|
||||
.toString(),
|
||||
duration: model.prescriptionList[0].entityList[index]
|
||||
.doseDurationDays
|
||||
.toString(),
|
||||
startDate: model
|
||||
.prescriptionList[0].entityList[index].startDate
|
||||
.toString(),
|
||||
dose: model.prescriptionList[0].entityList[index].doseTimingID
|
||||
.toString(),
|
||||
frequency: model
|
||||
.prescriptionList[0].entityList[index].frequencyID
|
||||
.toString(),
|
||||
rouat: model.prescriptionList[0].entityList[index].routeID
|
||||
.toString(),
|
||||
patient: patient,
|
||||
drugId: model.prescriptionList[0].entityList[index].medicineCode,
|
||||
drugName: model.prescriptionList[0].entityList[index].medicationName,
|
||||
remarks: model.prescriptionList[0].entityList[index].remarks,
|
||||
model: model,
|
||||
enteredRemarks: model.prescriptionList[0].entityList[index].remarks,
|
||||
context: context);
|
||||
//model.postPrescription();
|
||||
},
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Divider(
|
||||
height: 0,
|
||||
thickness: 1.0,
|
||||
color: Colors.grey,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
)
|
||||
: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
||||
children: [
|
||||
InkWell(
|
||||
onTap: () {
|
||||
addPrescriptionForm(context, model, patient, model.prescriptionList);
|
||||
//model.postPrescription();
|
||||
},
|
||||
child: CircleAvatar(
|
||||
radius: 65,
|
||||
backgroundColor: Color(0XFFB8382C),
|
||||
child: CircleAvatar(
|
||||
radius: 60,
|
||||
backgroundColor: Colors.white,
|
||||
child: Icon(
|
||||
Icons.add,
|
||||
color: Colors.black,
|
||||
size: 45.0,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 15.0,
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).noPrescriptionListed,
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.w900,
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).addNow,
|
||||
color: Color(0XFFB8382C),
|
||||
fontWeight: FontWeight.w900,
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
)),
|
||||
);
|
||||
}
|
||||
|
||||
selectDate(BuildContext context, PrescriptionViewModel model) async {
|
||||
DateTime selectedDate;
|
||||
selectedDate = DateTime.now();
|
||||
final DateTime picked = await showDatePicker(
|
||||
context: context,
|
||||
initialDate: selectedDate,
|
||||
firstDate: DateTime.now().add(Duration(hours: 2)),
|
||||
lastDate: DateTime(2040),
|
||||
initialEntryMode: DatePickerEntryMode.calendar,
|
||||
);
|
||||
if (picked != null && picked != selectedDate) {
|
||||
setState(() {
|
||||
selectedDate = picked;
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,516 +0,0 @@
|
||||
import 'package:doctor_app_flutter/core/viewModel/prescription_view_model.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/patients/profile/patient-page-header-widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class NewPrescriptionHistoryScreen extends StatefulWidget {
|
||||
@override
|
||||
_NewPrescriptionHistoryScreenState createState() =>
|
||||
_NewPrescriptionHistoryScreenState();
|
||||
}
|
||||
|
||||
class _NewPrescriptionHistoryScreenState
|
||||
extends State<NewPrescriptionHistoryScreen> {
|
||||
PersistentBottomSheetController _controller;
|
||||
final _scaffoldKey = GlobalKey<ScaffoldState>();
|
||||
TextEditingController strengthController = TextEditingController();
|
||||
int testNum = 0;
|
||||
int strengthChar;
|
||||
PatiantInformtion patient;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
}
|
||||
|
||||
Widget build(BuildContext context) {
|
||||
final screenSize = MediaQuery.of(context).size;
|
||||
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||
patient = routeArgs['patient'];
|
||||
return BaseView<PrescriptionViewModel>(
|
||||
onModelReady: (model) => model.getPrescription(mrn: patient.patientId),
|
||||
builder:
|
||||
(BuildContext context, PrescriptionViewModel model, Widget child) =>
|
||||
AppScaffold(
|
||||
isShowAppBar: true,
|
||||
appBarTitle: TranslationBase.of(context).prescription,
|
||||
body: NetworkBaseView(
|
||||
baseViewModel: model,
|
||||
child: SingleChildScrollView(
|
||||
child: Container(
|
||||
color: Colors.white,
|
||||
child: Column(
|
||||
children: [
|
||||
PatientPageHeaderWidget(patient),
|
||||
Divider(
|
||||
height: 1.0,
|
||||
thickness: 1.0,
|
||||
color: Colors.grey,
|
||||
),
|
||||
(model.prescriptionList.length != 0)
|
||||
? SizedBox(
|
||||
height:
|
||||
model.prescriptionList[0].rowcount == 0
|
||||
? 200.0
|
||||
: 10.0)
|
||||
: SizedBox(height: 200.0),
|
||||
//model.prescriptionList == null
|
||||
(model.prescriptionList.length != 0)
|
||||
? model.prescriptionList[0].rowcount == 0
|
||||
? Container(
|
||||
child: AppText(
|
||||
'Sorry , Theres no prescriptions for this patient',
|
||||
color: Color(0xFFB9382C),
|
||||
),
|
||||
)
|
||||
: Padding(
|
||||
padding: EdgeInsets.all(14.0),
|
||||
child: NetworkBaseView(
|
||||
baseViewModel: model,
|
||||
child: Column(
|
||||
mainAxisAlignment:
|
||||
MainAxisAlignment.start,
|
||||
children: [
|
||||
...List.generate(
|
||||
model.prescriptionList[0]
|
||||
.rowcount,
|
||||
(index) => Container(
|
||||
color: Colors.white,
|
||||
child: Column(
|
||||
children: [
|
||||
SizedBox(
|
||||
height: MediaQuery.of(
|
||||
context)
|
||||
.size
|
||||
.height *
|
||||
0.022,
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment:
|
||||
MainAxisAlignment
|
||||
.spaceBetween,
|
||||
// crossAxisAlignment:
|
||||
// CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
height: MediaQuery.of(
|
||||
context)
|
||||
.size
|
||||
.height *
|
||||
0.21,
|
||||
width: MediaQuery.of(
|
||||
context)
|
||||
.size
|
||||
.width *
|
||||
0.1,
|
||||
child: Column(
|
||||
children: [
|
||||
AppText(
|
||||
(DateTime.parse(model.prescriptionList[0].entityList[index].createdOn) !=
|
||||
null
|
||||
? (DateTime.parse(model.prescriptionList[0].entityList[index].createdOn).year)
|
||||
.toString()
|
||||
: DateTime.now()
|
||||
.year)
|
||||
.toString(),
|
||||
color: Colors
|
||||
.green,
|
||||
fontSize:
|
||||
13.5,
|
||||
),
|
||||
AppText(
|
||||
AppDateUtils.getMonth(model.prescriptionList[0].entityList[index].createdOn !=
|
||||
null
|
||||
? (DateTime.parse(model.prescriptionList[0].entityList[index].createdOn)
|
||||
.month)
|
||||
: DateTime.now()
|
||||
.month)
|
||||
.toUpperCase(),
|
||||
color: Colors
|
||||
.green,
|
||||
),
|
||||
AppText(
|
||||
DateTime.parse(model
|
||||
.prescriptionList[
|
||||
0]
|
||||
.entityList[
|
||||
index]
|
||||
.createdOn)
|
||||
.day
|
||||
.toString(),
|
||||
color: Colors
|
||||
.green,
|
||||
),
|
||||
AppText(
|
||||
AppDateUtils.getTimeFormated(DateTime.parse(model
|
||||
.prescriptionList[
|
||||
0]
|
||||
.entityList[
|
||||
index]
|
||||
.createdOn))
|
||||
.toString(),
|
||||
color: Colors
|
||||
.green,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
// height: MediaQuery.of(
|
||||
// context)
|
||||
// .size
|
||||
// .height *
|
||||
// 0.3499,
|
||||
width: MediaQuery.of(
|
||||
context)
|
||||
.size
|
||||
.width *
|
||||
0.77,
|
||||
child: Column(
|
||||
children: [
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Start Date:',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
14.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
AppText(
|
||||
AppDateUtils.getDateFormatted(DateTime.parse(model
|
||||
.prescriptionList[0]
|
||||
.entityList[index]
|
||||
.startDate)),
|
||||
fontSize:
|
||||
13.5,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width:
|
||||
6.0,
|
||||
),
|
||||
AppText(
|
||||
'Order Type:',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
14.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
AppText(
|
||||
model
|
||||
.prescriptionList[0]
|
||||
.entityList[index]
|
||||
.orderTypeDescription,
|
||||
fontSize:
|
||||
13.0,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 5.5,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
Container(
|
||||
child:
|
||||
Expanded(
|
||||
child:
|
||||
AppText(
|
||||
model
|
||||
.prescriptionList[0]
|
||||
.entityList[index]
|
||||
.medicationName,
|
||||
fontWeight:
|
||||
FontWeight.w700,
|
||||
fontSize:
|
||||
15.0,
|
||||
),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 5.5,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
Expanded(
|
||||
child:
|
||||
AppText(
|
||||
model
|
||||
.prescriptionList[0]
|
||||
.entityList[index]
|
||||
.doseDetail,
|
||||
fontSize:
|
||||
15.0,
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 10.0,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Indication: ',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
17.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
RichText(
|
||||
maxLines:
|
||||
3,
|
||||
overflow:
|
||||
TextOverflow.ellipsis,
|
||||
strutStyle:
|
||||
StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style:
|
||||
TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index].indication),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'UOM: ',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
17.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
RichText(
|
||||
maxLines:
|
||||
3,
|
||||
overflow:
|
||||
TextOverflow.ellipsis,
|
||||
strutStyle:
|
||||
StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style:
|
||||
TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index].uom),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'BOX Quantity: ',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
17.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
RichText(
|
||||
maxLines:
|
||||
3,
|
||||
overflow:
|
||||
TextOverflow.ellipsis,
|
||||
strutStyle:
|
||||
StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style:
|
||||
TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index].quantity.toString() == null ? "" : model.prescriptionList[0].entityList[index].quantity.toString()),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'pharmacy Intervention ',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
17.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
RichText(
|
||||
maxLines:
|
||||
3,
|
||||
overflow:
|
||||
TextOverflow.ellipsis,
|
||||
strutStyle:
|
||||
StrutStyle(fontSize: 12.0),
|
||||
text: TextSpan(
|
||||
style:
|
||||
TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index].pharmacyInervention == null ? "" : model.prescriptionList[0].entityList[index].pharmacyInervention.toString()),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height:
|
||||
5.0),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'pharmacist Remarks : ',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
15.0,
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
// commening below code because there is an error coming in the model please fix it before pushing it
|
||||
model.prescriptionList[0].entityList[index].pharmacistRemarks == null ? "" : model.prescriptionList[0].entityList[index].pharmacistRemarks,
|
||||
fontSize: 15.0),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 20.0,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context)
|
||||
.doctorName +
|
||||
": ",
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w600,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
AppText(
|
||||
model
|
||||
.prescriptionList[0]
|
||||
.entityList[index]
|
||||
.doctorName,
|
||||
fontWeight:
|
||||
FontWeight.w700,
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 8.0,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Doctor Remarks : ',
|
||||
fontWeight:
|
||||
FontWeight
|
||||
.w700,
|
||||
fontSize:
|
||||
13.0,
|
||||
),
|
||||
Expanded(
|
||||
child:
|
||||
Container(
|
||||
// height: MediaQuery.of(context).size.height *
|
||||
// 0.038,
|
||||
child:
|
||||
RichText(
|
||||
// maxLines:
|
||||
// 2,
|
||||
// overflow:
|
||||
// TextOverflow.ellipsis,
|
||||
strutStyle:
|
||||
StrutStyle(fontSize: 10.0),
|
||||
text:
|
||||
TextSpan(
|
||||
style:
|
||||
TextStyle(color: Colors.black),
|
||||
text: model.prescriptionList[0].entityList[index].remarks != null
|
||||
? model.prescriptionList[0].entityList[index].remarks
|
||||
: "",
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 10.0,
|
||||
),
|
||||
|
||||
// SizedBox(
|
||||
// height: 40,
|
||||
// ),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Divider(
|
||||
height: 0,
|
||||
thickness: 1.0,
|
||||
color: Colors.grey,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
)
|
||||
: Container(
|
||||
child: AppText(
|
||||
'Sorry , theres no prescriptions listed for this patient',
|
||||
color: Color(0xFFB9382C),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
)),
|
||||
);
|
||||
}
|
||||
|
||||
selectDate(BuildContext context, PrescriptionViewModel model) async {
|
||||
DateTime selectedDate;
|
||||
selectedDate = DateTime.now();
|
||||
final DateTime picked = await showDatePicker(
|
||||
context: context,
|
||||
initialDate: selectedDate,
|
||||
firstDate: DateTime.now().add(Duration(hours: 2)),
|
||||
lastDate: DateTime(2040),
|
||||
initialEntryMode: DatePickerEntryMode.calendar,
|
||||
);
|
||||
if (picked != null && picked != selectedDate) {
|
||||
setState(() {
|
||||
selectedDate = picked;
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,59 @@
|
||||
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class ShowTimer extends StatefulWidget {
|
||||
final PatiantInformtion patientInfo;
|
||||
|
||||
|
||||
const ShowTimer({
|
||||
Key key, this.patientInfo,
|
||||
}) : super(key: key);
|
||||
|
||||
@override
|
||||
_ShowTimerState createState() => _ShowTimerState();
|
||||
}
|
||||
|
||||
class _ShowTimerState extends State<ShowTimer> {
|
||||
|
||||
int remainingTime = 600;
|
||||
String displayTime = '';
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
if (displayTime.isEmpty) {
|
||||
startShowTimer();
|
||||
}
|
||||
return AppText(
|
||||
"$displayTime",
|
||||
color: Colors.red,
|
||||
textAlign: TextAlign.start,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 11,
|
||||
);
|
||||
}
|
||||
|
||||
startShowTimer() {
|
||||
// this.remainingTime--;
|
||||
setState(() {
|
||||
displayTime = this.generateShowTimerString();
|
||||
});
|
||||
|
||||
Future.delayed(Duration(seconds: 1), () {
|
||||
if (this.remainingTime > 0) {
|
||||
startShowTimer();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
generateShowTimerString() {
|
||||
DateTime now = DateTime.now();
|
||||
DateTime liveCareDate = DateTime.parse(widget.patientInfo.arrivalTime);
|
||||
String timer = AppDateUtils.differenceBetweenDateAndCurrent(
|
||||
liveCareDate, context, isShowSecond: true, isShowDays: false);
|
||||
|
||||
return timer;
|
||||
}
|
||||
}
|
||||
@ -1,73 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class PatientHeaderWidgetNoAvatar extends StatelessWidget {
|
||||
final PatiantInformtion patient;
|
||||
|
||||
PatientHeaderWidgetNoAvatar(this.patient);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Column(
|
||||
children: [
|
||||
Container(
|
||||
margin: EdgeInsets.all(16),
|
||||
child: Row(
|
||||
children: [
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
AppText(
|
||||
patient.firstName + ' ' + patient.lastName,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: SizeConfig.textMultiplier * 2.2,
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
"VIP",
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: SizeConfig.textMultiplier * 2.2,
|
||||
),
|
||||
SizedBox(
|
||||
width: 8,
|
||||
),
|
||||
AppText(
|
||||
" ${patient.age}",
|
||||
fontWeight: FontWeight.normal,
|
||||
fontSize: SizeConfig.textMultiplier * 2.0,
|
||||
),
|
||||
],
|
||||
),
|
||||
AppText(
|
||||
patient.visitType ?? "",
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: SizeConfig.textMultiplier * 2.0,
|
||||
),
|
||||
AppText(
|
||||
"${patient.companyName != null ? patient.companyName : ""}",
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: SizeConfig.textMultiplier * 2.0,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
Icon(
|
||||
Icons.info_outline,
|
||||
color: Colors.black,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
width: double.infinity,
|
||||
height: 1,
|
||||
color: Color(0xffCCCCCC),
|
||||
),
|
||||
],
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -1,114 +0,0 @@
|
||||
import 'package:doctor_app_flutter/core/enum/master_lookup_key.dart';
|
||||
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||
import 'package:doctor_app_flutter/core/viewModel/project_view_model.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/SOAP/GeneralGetReqForSOAP.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||
import 'package:doctor_app_flutter/screens/patients/profile/profile_screen/patient_profile_screen.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class PatientPageHeaderWidget extends StatelessWidget {
|
||||
|
||||
final PatiantInformtion patient;
|
||||
PatientPageHeaderWidget(this.patient);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
ProjectViewModel projectViewModel = Provider.of(context);
|
||||
|
||||
return BaseView<SOAPViewModel>(
|
||||
onModelReady: (model) async {
|
||||
GeneralGetReqForSOAP generalGetReqForSOAP = GeneralGetReqForSOAP(
|
||||
patientMRN: patient.patientMRN??patient.patientId,
|
||||
doctorID: '',
|
||||
editedBy: '');
|
||||
await model.getPatientAllergy(generalGetReqForSOAP);
|
||||
if (model.allergiesList.length == 0) {
|
||||
await model.getMasterLookup(MasterKeysService.Allergies);
|
||||
}
|
||||
if (model.allergySeverityList.length == 0) {
|
||||
await model.getMasterLookup(MasterKeysService.AllergySeverity);
|
||||
}
|
||||
|
||||
},
|
||||
builder: (_, model, w) => Container(
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
Padding(
|
||||
padding: const EdgeInsets.all(8.0),
|
||||
child: Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
children: <Widget>[
|
||||
AvatarWidget(
|
||||
Icon(
|
||||
patient.genderDescription == "Male"
|
||||
? DoctorApp.male
|
||||
: DoctorApp.female_icon,
|
||||
size: 70,
|
||||
color: Colors.white,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 20,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
SizedBox(
|
||||
height: 5,
|
||||
),
|
||||
AppText(
|
||||
patient.patientDetails.fullName != null ? patient.patientDetails.fullName : patient.firstName,
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).age ,
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
SizedBox(
|
||||
width: 20,
|
||||
),
|
||||
AppText(
|
||||
patient.age.toString(),
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.normal,
|
||||
),
|
||||
],
|
||||
),
|
||||
model.patientAllergiesList.isNotEmpty && model.getAllergicNames(projectViewModel.isArabic)!='' ?AppText(
|
||||
TranslationBase.of(context).allergicTO +" : "+model.getAllergicNames(projectViewModel.isArabic),
|
||||
color: Color(0xFFB9382C),
|
||||
fontWeight: FontWeight.bold,
|
||||
) : AppText(''),
|
||||
],
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
width: double.infinity,
|
||||
height: 1,
|
||||
color: Color(0xffCCCCCC),
|
||||
),
|
||||
SizedBox(
|
||||
width: 20,
|
||||
),
|
||||
],
|
||||
),
|
||||
));
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,556 @@
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/core/viewModel/project_view_model.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
import 'large_avatar.dart';
|
||||
|
||||
class PatientProfileAppBar extends StatelessWidget
|
||||
with PreferredSizeWidget {
|
||||
final PatiantInformtion patient;
|
||||
final double height;
|
||||
final bool isInpatient;
|
||||
final bool isDischargedPatient;
|
||||
final bool isFromLiveCare;
|
||||
|
||||
final String doctorName;
|
||||
final String branch;
|
||||
final DateTime appointmentDate;
|
||||
final String profileUrl;
|
||||
final String invoiceNO;
|
||||
final String orderNo;
|
||||
final bool isPrescriptions;
|
||||
final bool isMedicalFile;
|
||||
final String episode;
|
||||
final String visitDate;
|
||||
final String clinic;
|
||||
final bool isAppointmentHeader;
|
||||
final bool isFromLabResult;
|
||||
|
||||
PatientProfileAppBar(
|
||||
this.patient,
|
||||
{this.height = 0.0,
|
||||
this.isInpatient = false,
|
||||
this.isDischargedPatient = false,
|
||||
this.isFromLiveCare = false,
|
||||
this.doctorName,
|
||||
this.branch,
|
||||
this.appointmentDate,
|
||||
this.profileUrl,
|
||||
this.invoiceNO,
|
||||
this.orderNo,
|
||||
this.isPrescriptions = false,
|
||||
this.clinic,
|
||||
this.isMedicalFile = false,
|
||||
this.episode,
|
||||
this.visitDate,
|
||||
this.isAppointmentHeader = false,
|
||||
this.isFromLabResult = false});
|
||||
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
ProjectViewModel projectViewModel = Provider.of(context);
|
||||
|
||||
int gender = 1;
|
||||
if (patient.patientDetails != null) {
|
||||
gender = patient.patientDetails.gender;
|
||||
} else {
|
||||
gender = patient.gender;
|
||||
}
|
||||
|
||||
return Container(
|
||||
padding: EdgeInsets.only(
|
||||
left: 0,
|
||||
right: 5,
|
||||
bottom: 5,
|
||||
),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
),
|
||||
// height: height == 0
|
||||
// ? isInpatient
|
||||
// ? 215
|
||||
// : isAppointmentHeader
|
||||
// ? 325
|
||||
// : 200
|
||||
// : height,
|
||||
child: Container(
|
||||
padding: EdgeInsets.only(left: 10, right: 10, bottom: 10),
|
||||
margin: EdgeInsets.only(top: 50),
|
||||
child: Column(
|
||||
children: [
|
||||
Container(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Row(children: [
|
||||
IconButton(
|
||||
icon: Icon(Icons.arrow_back_ios),
|
||||
color: Color(0xFF2B353E), //Colors.black,
|
||||
onPressed: () => Navigator.pop(context),
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
patient.firstName != null
|
||||
? (Helpers.capitalize(patient.firstName) +
|
||||
" " +
|
||||
Helpers.capitalize(patient.lastName))
|
||||
: Helpers.capitalize(patient.fullName??patient.patientDetails.fullName),
|
||||
fontSize: SizeConfig.textMultiplier * 1.8,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
color: Color(0xFF2B353E),
|
||||
),
|
||||
),
|
||||
gender == 1
|
||||
? Icon(
|
||||
DoctorApp.male_2,
|
||||
color: Colors.blue,
|
||||
)
|
||||
: Icon(
|
||||
DoctorApp.female_1,
|
||||
color: Colors.pink,
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(horizontal: 4),
|
||||
child: InkWell(
|
||||
onTap: () {
|
||||
launch("tel://" + patient.mobileNumber);
|
||||
},
|
||||
child: Icon(
|
||||
Icons.phone,
|
||||
color: Colors.black87,
|
||||
),
|
||||
),
|
||||
),
|
||||
]),
|
||||
),
|
||||
Row(children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
child: Image.asset(
|
||||
gender == 1
|
||||
? 'assets/images/male_avatar.png'
|
||||
: 'assets/images/female_avatar.png',
|
||||
fit: BoxFit.cover,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 10,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
patient.patientStatusType != null
|
||||
? Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
patient.patientStatusType == 43
|
||||
? AppText(
|
||||
TranslationBase
|
||||
.of(context)
|
||||
.arrivedP,
|
||||
color: Colors.green,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
)
|
||||
: AppText(
|
||||
TranslationBase.of(context).notArrived,
|
||||
color: Colors.red[800],
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
),
|
||||
patient.startTime != null
|
||||
? AppText(
|
||||
patient.startTime != null
|
||||
? patient.startTime
|
||||
: '',
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
color: Color(0xFF2E303A))
|
||||
: SizedBox()
|
||||
],
|
||||
))
|
||||
: SizedBox(),
|
||||
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
RichText(
|
||||
text: TextSpan(
|
||||
style: TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase
|
||||
.of(context)
|
||||
.fileNumber,
|
||||
|
||||
style: TextStyle(
|
||||
fontSize: 10,
|
||||
fontFamily: 'Poppins',
|
||||
color: Color(0xFF575757),
|
||||
fontWeight: FontWeight.w600,
|
||||
|
||||
),),
|
||||
new TextSpan(
|
||||
text: patient.patientId.toString(),
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12, color: Color(0xFF2E303A),)),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
patient.nationalityName ?? patient.nationality?? patient.nationalityId ?? '',
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 12,
|
||||
),
|
||||
patient.nationalityFlagURL != null
|
||||
? ClipRRect(
|
||||
borderRadius: BorderRadius.circular(20.0),
|
||||
child: Image.network(
|
||||
patient.nationalityFlagURL,
|
||||
height: 25,
|
||||
width: 30,
|
||||
errorBuilder: (BuildContext context,
|
||||
Object exception,
|
||||
StackTrace stackTrace) {
|
||||
return Text('No Image');
|
||||
},
|
||||
))
|
||||
: SizedBox()
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase
|
||||
.of(context)
|
||||
.age + " : ",
|
||||
style: TextStyle(fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),)),
|
||||
new TextSpan(
|
||||
text:
|
||||
"${AppDateUtils.getAgeByBirthday(
|
||||
patient.patientDetails != null
|
||||
? patient.patientDetails.dateofBirth ??
|
||||
""
|
||||
: patient.dateofBirth ?? "", context,
|
||||
isServerFormat: !isFromLiveCare)}",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
color: Color(0xFF2E303A),)),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
|
||||
if ( patient.appointmentDate != null && patient.appointmentDate.isNotEmpty)
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
TranslationBase.of(context).appointmentDate +
|
||||
" : ",
|
||||
fontSize: 10,
|
||||
color: Color(0xFF575757),
|
||||
fontWeight: FontWeight.w600,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
SizedBox(
|
||||
width: 3.5,
|
||||
),
|
||||
AppText(
|
||||
AppDateUtils
|
||||
.getDayMonthYearDateFormatted(
|
||||
AppDateUtils.convertStringToDate(
|
||||
patient.appointmentDate))
|
||||
,
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
color: Color(0xFF2E303A),
|
||||
),
|
||||
SizedBox(
|
||||
height: 0.5,
|
||||
)
|
||||
],
|
||||
),
|
||||
if(isFromLabResult)Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: "Result Date: ",
|
||||
style: TextStyle( fontSize: 10,
|
||||
color: Color(0xFF575757),
|
||||
fontWeight: FontWeight.w600,
|
||||
fontFamily: 'Poppins',)),
|
||||
new TextSpan(
|
||||
text:
|
||||
'${AppDateUtils.getDayMonthYearDateFormatted(appointmentDate, isArabic: projectViewModel.isArabic)}',
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700, fontSize: 12)),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
// if(isInpatient)
|
||||
Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
if(patient.admissionDate != null && patient.admissionDate.isNotEmpty)
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: patient.admissionDate == null
|
||||
? ""
|
||||
: TranslationBase.of(context)
|
||||
.admissionDate +
|
||||
" : ",
|
||||
style: TextStyle(fontSize: 10)),
|
||||
new TextSpan(
|
||||
text: patient.admissionDate == null
|
||||
? ""
|
||||
: "${AppDateUtils
|
||||
.getDayMonthYearDateFormatted(
|
||||
(AppDateUtils
|
||||
.getDateTimeFromServerFormat(
|
||||
patient.admissionDate
|
||||
.toString())))}",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
color: Color(0xFF2E303A),)),
|
||||
]))),
|
||||
if (patient.admissionDate != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
"${TranslationBase.of(context).numOfDays}: ",
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757)
|
||||
),
|
||||
if(isDischargedPatient &&
|
||||
patient.dischargeDate != null)
|
||||
AppText(
|
||||
"${AppDateUtils
|
||||
.getDateTimeFromServerFormat(
|
||||
patient.dischargeDate)
|
||||
.difference(AppDateUtils
|
||||
.getDateTimeFromServerFormat(
|
||||
patient.admissionDate))
|
||||
.inDays + 1}",
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
color: Color(0xFF2E303A),
|
||||
)
|
||||
else
|
||||
AppText(
|
||||
"${DateTime
|
||||
.now()
|
||||
.difference(AppDateUtils
|
||||
.getDateTimeFromServerFormat(
|
||||
patient.admissionDate))
|
||||
.inDays + 1}",
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
color: Color(0xFF2E303A),),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
]),
|
||||
if(isAppointmentHeader)
|
||||
Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
width: 30,
|
||||
height: 30,
|
||||
margin: EdgeInsets.only(
|
||||
left: projectViewModel.isArabic ? 10 : 85,
|
||||
right: projectViewModel.isArabic ? 85 : 10,
|
||||
top: 5),
|
||||
decoration: BoxDecoration(
|
||||
shape: BoxShape.rectangle,
|
||||
border: Border(
|
||||
bottom: BorderSide(
|
||||
color: Colors.grey[400], width: 2.5),
|
||||
left: BorderSide(
|
||||
color: Colors.grey[400], width: 2.5),
|
||||
)),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
child: Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Container(
|
||||
child: LargeAvatar(
|
||||
name: doctorName ?? "",
|
||||
url: profileUrl,
|
||||
),
|
||||
width: 25,
|
||||
height: 25,
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
),
|
||||
|
||||
|
||||
Expanded(
|
||||
flex: 5,
|
||||
child: Container(
|
||||
margin: EdgeInsets.all(10),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment
|
||||
.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
'${TranslationBase
|
||||
.of(context)
|
||||
.dr}$doctorName',
|
||||
color: Color(0xFF2E303A),
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 12,
|
||||
),
|
||||
if (orderNo != null &&
|
||||
!isPrescriptions)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText('Order No: ',
|
||||
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),),
|
||||
AppText(orderNo ?? '',
|
||||
fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (invoiceNO != null &&
|
||||
!isPrescriptions)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText('Invoice: ',
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),),
|
||||
AppText(invoiceNO ?? "",
|
||||
fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (branch != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Branch: ',
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),),
|
||||
AppText(branch ?? '',
|
||||
fontSize: 12)
|
||||
],
|
||||
),
|
||||
|
||||
if (clinic != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Clinic: ',
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),),
|
||||
AppText(clinic ?? '',
|
||||
fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (isMedicalFile &&
|
||||
episode != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Episode: ',
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),),
|
||||
AppText(episode ?? '',
|
||||
fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (isMedicalFile &&
|
||||
visitDate != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Visit Date: ',
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),),
|
||||
AppText(visitDate ?? '',
|
||||
fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (!isMedicalFile)
|
||||
Row(
|
||||
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
!isPrescriptions
|
||||
? 'Result Date:'
|
||||
: 'Prescriptions Date ',
|
||||
fontSize: 10, fontWeight: FontWeight.w600,color: Color(0xFF575757),
|
||||
),
|
||||
AppText(
|
||||
'${AppDateUtils
|
||||
.getDayMonthYearDateFormatted(
|
||||
appointmentDate,
|
||||
isArabic: projectViewModel
|
||||
.isArabic)}',
|
||||
fontSize: 12,
|
||||
)
|
||||
],
|
||||
)
|
||||
]),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
@override
|
||||
Size get preferredSize =>
|
||||
Size(double.maxFinite, height == 0
|
||||
? isInpatient ? 160 : isAppointmentHeader ? 290 : 170
|
||||
: height);
|
||||
}
|
||||
@ -1,371 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/config.dart';
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:hexcolor/hexcolor.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
class PatientProfileHeaderNewDesignAppBar extends StatelessWidget
|
||||
with PreferredSizeWidget {
|
||||
final PatiantInformtion patient;
|
||||
final String patientType;
|
||||
final String arrivalType;
|
||||
final double height;
|
||||
final bool isInpatient;
|
||||
final bool isDischargedPatient;
|
||||
final bool isFromLiveCare;
|
||||
|
||||
PatientProfileHeaderNewDesignAppBar(
|
||||
this.patient, this.patientType, this.arrivalType, {this.height = 0.0, this.isInpatient=false, this.isDischargedPatient=false, this.isFromLiveCare = false});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
int gender = 1;
|
||||
if (patient.patientDetails != null) {
|
||||
gender = patient.patientDetails.gender;
|
||||
} else {
|
||||
gender = patient.gender;
|
||||
}
|
||||
return Container(
|
||||
padding: EdgeInsets.only(
|
||||
left: 0,
|
||||
right: 5,
|
||||
bottom: 5,
|
||||
),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
),
|
||||
height: height == 0 ? isInpatient? 215:200 : height,
|
||||
child: Container(
|
||||
padding: EdgeInsets.only(left: 10, right: 10, bottom: 10),
|
||||
margin: EdgeInsets.only(top: 50),
|
||||
child: Column(
|
||||
children: [
|
||||
Container(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Row(children: [
|
||||
IconButton(
|
||||
icon: Icon(Icons.arrow_back_ios),
|
||||
color: Colors.black, //Colors.black,
|
||||
onPressed: () => Navigator.pop(context),
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
patient.firstName != null
|
||||
? (Helpers.capitalize(patient.firstName) +
|
||||
" " +
|
||||
Helpers.capitalize(patient.lastName))
|
||||
: Helpers.capitalize(patient.fullName??patient.patientDetails.fullName),
|
||||
fontSize: SizeConfig.textMultiplier * 1.8,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
),
|
||||
gender == 1
|
||||
? Icon(
|
||||
DoctorApp.male_2,
|
||||
color: Colors.blue,
|
||||
)
|
||||
: Icon(
|
||||
DoctorApp.female_1,
|
||||
color: Colors.pink,
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(horizontal: 4),
|
||||
child: InkWell(
|
||||
onTap: () {
|
||||
launch("tel://" + patient.mobileNumber);
|
||||
},
|
||||
child: Icon(
|
||||
Icons.phone,
|
||||
color: Colors.black87,
|
||||
),
|
||||
),
|
||||
),
|
||||
]),
|
||||
),
|
||||
Row(children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
child: Image.asset(
|
||||
gender == 1
|
||||
? 'assets/images/male_avatar.png'
|
||||
: 'assets/images/female_avatar.png',
|
||||
fit: BoxFit.cover,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 10,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
SERVICES_PATIANT2[int.parse(patientType)] ==
|
||||
"patientArrivalList"
|
||||
? Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
patient.patientStatusType == 43
|
||||
? AppText(
|
||||
TranslationBase.of(context).arrivedP,
|
||||
color: Colors.green,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
)
|
||||
: AppText(
|
||||
TranslationBase.of(context).notArrived,
|
||||
color: Colors.red[800],
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
),
|
||||
arrivalType == '1'|| patient.arrivedOn == null
|
||||
? AppText(
|
||||
patient.startTime != null
|
||||
? patient.startTime
|
||||
: '',
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
)
|
||||
: AppText(
|
||||
patient.arrivedOn != null
|
||||
? AppDateUtils.convertStringToDateFormat(
|
||||
patient.arrivedOn,
|
||||
'MM-dd-yyyy HH:mm')
|
||||
: '',
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
)
|
||||
],
|
||||
))
|
||||
: SizedBox(),
|
||||
if (SERVICES_PATIANT2[int.parse(patientType)] ==
|
||||
"List_MyOutPatient" && !isFromLiveCare)
|
||||
Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
TranslationBase.of(context).appointmentDate +
|
||||
" : ",
|
||||
fontSize: 14,
|
||||
),
|
||||
patient.startTime != null
|
||||
? Container(
|
||||
height: 15,
|
||||
width: 60,
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.circular(25),
|
||||
color: HexColor("#20A169"),
|
||||
),
|
||||
child: AppText(
|
||||
patient.startTime??"",
|
||||
color: Colors.white,
|
||||
fontSize: 1.5 * SizeConfig.textMultiplier,
|
||||
textAlign: TextAlign.center,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
)
|
||||
: SizedBox(),
|
||||
SizedBox(
|
||||
width: 3.5,
|
||||
),
|
||||
Container(
|
||||
child: AppText(
|
||||
convertDateFormat2(
|
||||
patient.appointmentDate ?? ''),
|
||||
fontSize: 1.5 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 0.5,
|
||||
)
|
||||
],
|
||||
),
|
||||
margin: EdgeInsets.only(
|
||||
top: 8,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
RichText(
|
||||
text: TextSpan(
|
||||
style: TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(context).fileNumber,
|
||||
style: TextStyle(
|
||||
fontSize: 12, fontFamily: 'Poppins')),
|
||||
new TextSpan(
|
||||
text: patient.patientId.toString(),
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
patient.nationalityName ?? patient.nationality?? patient.nationalityId ?? '',
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 12,
|
||||
),
|
||||
patient.nationalityFlagURL != null
|
||||
? ClipRRect(
|
||||
borderRadius: BorderRadius.circular(20.0),
|
||||
child: Image.network(
|
||||
patient.nationalityFlagURL,
|
||||
height: 25,
|
||||
width: 30,
|
||||
errorBuilder: (BuildContext context,
|
||||
Object exception,
|
||||
StackTrace stackTrace) {
|
||||
return Text('No Image');
|
||||
},
|
||||
))
|
||||
: SizedBox()
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(context).age+ " : ",
|
||||
style: TextStyle(fontSize: 14)),
|
||||
new TextSpan(
|
||||
text:
|
||||
"${AppDateUtils.getAgeByBirthday(patient.patientDetails != null ? patient.patientDetails.dateofBirth??"" : patient.dateofBirth??"", context,isServerFormat: !isFromLiveCare)}",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700, fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
if(isInpatient)
|
||||
Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize:
|
||||
2.0 * SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: patient.admissionDate == null
|
||||
? ""
|
||||
: TranslationBase.of(context)
|
||||
.admissionDate +
|
||||
" : ",
|
||||
style: TextStyle(fontSize: 14)),
|
||||
new TextSpan(
|
||||
text: patient.admissionDate == null
|
||||
? ""
|
||||
: "${AppDateUtils.convertDateFromServerFormat(patient.admissionDate.toString(), 'yyyy-MM-dd')}",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontSize: 15)),
|
||||
]))),
|
||||
if (patient.admissionDate != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
"${TranslationBase.of(context).numOfDays}: ",
|
||||
fontSize: 15,
|
||||
),
|
||||
if(isDischargedPatient && patient.dischargeDate!=null)
|
||||
AppText(
|
||||
"${AppDateUtils.getDateTimeFromServerFormat(patient.dischargeDate).difference(AppDateUtils.getDateTimeFromServerFormat(patient.admissionDate)).inDays + 1}",
|
||||
fontSize: 15,
|
||||
fontWeight: FontWeight.w700)
|
||||
else
|
||||
AppText(
|
||||
"${DateTime.now().difference(AppDateUtils.getDateTimeFromServerFormat(patient.admissionDate)).inDays + 1}",
|
||||
fontSize: 15,
|
||||
fontWeight: FontWeight.w700),
|
||||
],
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
]),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat2(String str) {
|
||||
String newDate;
|
||||
const start = "/Date(";
|
||||
if (str.isNotEmpty) {
|
||||
const end = "+0300)";
|
||||
|
||||
final startIndex = str.indexOf(start);
|
||||
final endIndex = str.indexOf(end, startIndex + start.length);
|
||||
|
||||
var date = new DateTime.fromMillisecondsSinceEpoch(
|
||||
int.parse(str.substring(startIndex + start.length, endIndex)));
|
||||
newDate = date.year.toString() +
|
||||
"/" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"/" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
}
|
||||
|
||||
return newDate??'';
|
||||
}
|
||||
|
||||
isToday(date) {
|
||||
DateTime tempDate = new DateFormat("yyyy-MM-dd").parse(date);
|
||||
return DateFormat("yyyy-MM-dd").format(tempDate) ==
|
||||
DateFormat("yyyy-MM-dd").format(DateTime.now());
|
||||
}
|
||||
|
||||
myBoxDecoration() {
|
||||
return BoxDecoration(
|
||||
border: Border(
|
||||
top: BorderSide(
|
||||
color: Colors.green,
|
||||
width: 5,
|
||||
),
|
||||
),
|
||||
borderRadius: BorderRadius.circular(10));
|
||||
}
|
||||
|
||||
@override
|
||||
Size get preferredSize => Size(double.maxFinite, 200);
|
||||
}
|
||||
@ -1,316 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/config.dart';
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:hexcolor/hexcolor.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
class PatientProfileHeaderNewDesign extends StatelessWidget {
|
||||
final PatiantInformtion patient;
|
||||
final String patientType;
|
||||
final String arrivalType;
|
||||
final double height;
|
||||
final bool isHaveMargin;
|
||||
|
||||
PatientProfileHeaderNewDesign(
|
||||
this.patient, this.patientType, this.arrivalType,
|
||||
{this.height = 0.0, this.isHaveMargin=true});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
int gender = 1;
|
||||
if (patient.patientDetails != null) {
|
||||
gender = patient.patientDetails.gender;
|
||||
} else {
|
||||
gender = patient.gender;
|
||||
}
|
||||
|
||||
return Container(
|
||||
padding: EdgeInsets.only(
|
||||
left: 0,
|
||||
right: 5,
|
||||
bottom: 5,
|
||||
),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
),
|
||||
height: height == 0 ? 200 : height,
|
||||
child: Container(
|
||||
padding: EdgeInsets.only(left: 10, right: 10, bottom: 10),
|
||||
margin: EdgeInsets.only(top: 50),
|
||||
child: Column(
|
||||
children: [
|
||||
Container(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Row(children: [
|
||||
IconButton(
|
||||
icon: Icon(Icons.arrow_back_ios),
|
||||
color: Colors.black, //Colors.black,
|
||||
onPressed: () => Navigator.pop(context),
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
patient.firstName != null
|
||||
? (Helpers.capitalize(patient.firstName) +
|
||||
" " +
|
||||
Helpers.capitalize(patient.lastName))
|
||||
: Helpers.capitalize(patient.patientDetails.fullName),
|
||||
fontSize: SizeConfig.textMultiplier * 2.2,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
),
|
||||
gender == 1
|
||||
? Icon(
|
||||
DoctorApp.male_2,
|
||||
color: Colors.blue,
|
||||
)
|
||||
: Icon(
|
||||
DoctorApp.female_1,
|
||||
color: Colors.pink,
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(horizontal: 4),
|
||||
child: InkWell(
|
||||
onTap: () {
|
||||
launch("tel://" + patient.mobileNumber);
|
||||
},
|
||||
child: Icon(
|
||||
Icons.phone,
|
||||
color: Colors.black87,
|
||||
),
|
||||
),
|
||||
),
|
||||
]),
|
||||
),
|
||||
Row(children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
child: Image.asset(
|
||||
gender == 1
|
||||
? 'assets/images/male_avatar.png'
|
||||
: 'assets/images/female_avatar.png',
|
||||
fit: BoxFit.cover,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 10,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
SERVICES_PATIANT2[int.parse(patientType)] ==
|
||||
"patientArrivalList"
|
||||
? Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
patient.patientStatusType == 43
|
||||
? AppText(
|
||||
TranslationBase.of(context).arrivedP,
|
||||
color: Colors.green,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
)
|
||||
: AppText(
|
||||
TranslationBase.of(context).notArrived,
|
||||
color: Colors.red[800],
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
),
|
||||
arrivalType == '1' || patient.arrivedOn == null
|
||||
? AppText(
|
||||
patient.startTime != null
|
||||
? patient.startTime
|
||||
: '',
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
)
|
||||
: AppText(
|
||||
AppDateUtils.getDayMonthYearDateFormatted(AppDateUtils.convertStringToDate(patient.arrivedOn)),
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
)
|
||||
],
|
||||
))
|
||||
: SizedBox(),
|
||||
if (SERVICES_PATIANT2[int.parse(patientType)] ==
|
||||
"List_MyOutPatient")
|
||||
Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
TranslationBase.of(context).appointmentDate +
|
||||
" : ",
|
||||
fontSize: 14,
|
||||
),
|
||||
patient.startTime != null
|
||||
? Container(
|
||||
height: 15,
|
||||
width: 60,
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.circular(25),
|
||||
color: HexColor("#20A169"),
|
||||
),
|
||||
child: AppText(
|
||||
patient.startTime ?? "",
|
||||
color: Colors.white,
|
||||
fontSize: 1.5 * SizeConfig.textMultiplier,
|
||||
textAlign: TextAlign.center,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
)
|
||||
: SizedBox(),
|
||||
SizedBox(
|
||||
width: 3.5,
|
||||
),
|
||||
Container(
|
||||
child: AppText(
|
||||
convertDateFormat2(
|
||||
patient.appointmentDate.toString() ?? ''),
|
||||
fontSize: 1.5 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 0.5,
|
||||
)
|
||||
],
|
||||
),
|
||||
margin: EdgeInsets.only(
|
||||
top: 8,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
RichText(
|
||||
text: TextSpan(
|
||||
style: TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(context).fileNumber,
|
||||
style: TextStyle(
|
||||
fontSize: 12, fontFamily: 'Poppins')),
|
||||
new TextSpan(
|
||||
text: patient.patientId.toString(),
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
patient.nationalityName ??
|
||||
patient.nationality ??
|
||||
patient.nationalityId ??
|
||||
'',
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 12,
|
||||
),
|
||||
patient.nationalityFlagURL != null
|
||||
? ClipRRect(
|
||||
borderRadius: BorderRadius.circular(20.0),
|
||||
child: Image.network(
|
||||
patient.nationalityFlagURL,
|
||||
height: 25,
|
||||
width: 30,
|
||||
errorBuilder: (BuildContext context,
|
||||
Object exception,
|
||||
StackTrace stackTrace) {
|
||||
return Text('No Image');
|
||||
},
|
||||
))
|
||||
: SizedBox()
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(context).age + " : ",
|
||||
style: TextStyle(fontSize: 14)),
|
||||
new TextSpan(
|
||||
text:
|
||||
"${AppDateUtils.getAgeByBirthday(patient.patientDetails != null ? patient.patientDetails.dateofBirth ?? "" : patient.dateofBirth ?? "", context)}",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700, fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
]),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat2(String str) {
|
||||
String newDate;
|
||||
const start = "/Date(";
|
||||
if (str.isNotEmpty) {
|
||||
const end = "+0300)";
|
||||
|
||||
final startIndex = str.indexOf(start);
|
||||
final endIndex = str.indexOf(end, startIndex + start.length);
|
||||
|
||||
var date = new DateTime.fromMillisecondsSinceEpoch(
|
||||
int.parse(str.substring(startIndex + start.length, endIndex)));
|
||||
newDate = date.year.toString() +
|
||||
"/" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"/" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
}
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
|
||||
isToday(date) {
|
||||
DateTime tempDate = new DateFormat("yyyy-MM-dd").parse(date);
|
||||
return DateFormat("yyyy-MM-dd").format(tempDate) ==
|
||||
DateFormat("yyyy-MM-dd").format(DateTime.now());
|
||||
}
|
||||
|
||||
myBoxDecoration() {
|
||||
return BoxDecoration(
|
||||
border: Border(
|
||||
top: BorderSide(
|
||||
color: Colors.green,
|
||||
width: 5,
|
||||
),
|
||||
),
|
||||
borderRadius: BorderRadius.circular(10));
|
||||
}
|
||||
}
|
||||
@ -1,242 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
class PatientProfileHeaderNewDesignInPatient extends StatelessWidget {
|
||||
final PatiantInformtion patient;
|
||||
final String patientType;
|
||||
final String arrivalType;
|
||||
final double height;
|
||||
|
||||
PatientProfileHeaderNewDesignInPatient(
|
||||
this.patient, this.patientType, this.arrivalType,
|
||||
{this.height = 0.0});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
int gender = 1;
|
||||
if (patient.patientDetails != null) {
|
||||
gender = patient.patientDetails.gender;
|
||||
} else {
|
||||
gender = patient.gender;
|
||||
}
|
||||
|
||||
return Container(
|
||||
padding: EdgeInsets.only(
|
||||
left: 0,
|
||||
right: 5,
|
||||
bottom: 5,
|
||||
),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
),
|
||||
height: height == 0 ? 200 : height,
|
||||
child: Container(
|
||||
padding: EdgeInsets.only(left: 10, right: 10, bottom: 10),
|
||||
// margin: EdgeInsets.only(top: 50),
|
||||
child: Column(
|
||||
children: [
|
||||
Container(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Row(children: [
|
||||
IconButton(
|
||||
icon: Icon(Icons.arrow_back_ios),
|
||||
color: Colors.black, //Colors.black,
|
||||
onPressed: () => Navigator.pop(context),
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
patient.firstName != null
|
||||
? (Helpers.capitalize(patient.firstName) +
|
||||
" " +
|
||||
Helpers.capitalize(patient.lastName))
|
||||
: Helpers.capitalize(patient.patientDetails.fullName),
|
||||
fontSize: SizeConfig.textMultiplier * 2.2,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
),
|
||||
gender == 1
|
||||
? Icon(
|
||||
DoctorApp.male_2,
|
||||
color: Colors.blue,
|
||||
)
|
||||
: Icon(
|
||||
DoctorApp.female_1,
|
||||
color: Colors.pink,
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(horizontal: 4),
|
||||
child: InkWell(
|
||||
onTap: () {
|
||||
launch("tel://" + patient.mobileNumber);
|
||||
},
|
||||
child: Icon(
|
||||
Icons.phone,
|
||||
color: Colors.black87,
|
||||
),
|
||||
),
|
||||
),
|
||||
]),
|
||||
),
|
||||
Row(children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
child: Image.asset(
|
||||
gender == 1
|
||||
? 'assets/images/male_avatar.png'
|
||||
: 'assets/images/female_avatar.png',
|
||||
fit: BoxFit.cover,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 10,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
TranslationBase.of(context).fileNumber,
|
||||
fontSize: 1.2 * SizeConfig.textMultiplier,
|
||||
),
|
||||
AppText(patient.patientId.toString(),
|
||||
fontSize: 1.4 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.w700),
|
||||
],
|
||||
),
|
||||
if(patient.admissionDate!=null)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
AppDateUtils.convertDateFromServerFormat(
|
||||
patient.admissionDate, "hh:mm a"),
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 1.4 * SizeConfig.textMultiplier,
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
if(patient.admissionDate!=null)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
"${TranslationBase.of(context).admissionDate}: ",
|
||||
fontSize: 1.2 * SizeConfig.textMultiplier,
|
||||
),
|
||||
AppText(
|
||||
AppDateUtils.convertDateFromServerFormat(
|
||||
patient.admissionDate, "dd MMM,yyyy"),
|
||||
fontSize: 1.4 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.w700),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
patient.nationalityName ??
|
||||
patient.nationality ??
|
||||
patient.nationalityId ??
|
||||
'',
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 1.4 * SizeConfig.textMultiplier,
|
||||
),
|
||||
patient.nationalityFlagURL != null
|
||||
? ClipRRect(
|
||||
borderRadius: BorderRadius.circular(20.0),
|
||||
child: Image.network(
|
||||
patient.nationalityFlagURL,
|
||||
height: 25,
|
||||
width: 30,
|
||||
errorBuilder: (BuildContext context,
|
||||
Object exception,
|
||||
StackTrace stackTrace) {
|
||||
return Text('No Image');
|
||||
},
|
||||
))
|
||||
: SizedBox()
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
if(patient.admissionDate!=null)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
"${TranslationBase.of(context).numOfDays}: ",
|
||||
fontSize: 1.2 * SizeConfig.textMultiplier,
|
||||
),
|
||||
AppText(
|
||||
"${DateTime.now().difference(AppDateUtils.getDateTimeFromServerFormat(patient.admissionDate)).inDays + 1}",
|
||||
fontSize: 1.4 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.w700),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
]),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat2(String str) {
|
||||
String newDate;
|
||||
const start = "/Date(";
|
||||
if (str.isNotEmpty) {
|
||||
const end = "+0300)";
|
||||
|
||||
final startIndex = str.indexOf(start);
|
||||
final endIndex = str.indexOf(end, startIndex + start.length);
|
||||
|
||||
var date = new DateTime.fromMillisecondsSinceEpoch(
|
||||
int.parse(str.substring(startIndex + start.length, endIndex)));
|
||||
newDate = date.year.toString() +
|
||||
"/" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"/" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
}
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
|
||||
isToday(date) {
|
||||
DateTime tempDate = new DateFormat("yyyy-MM-dd").parse(date);
|
||||
return DateFormat("yyyy-MM-dd").format(tempDate) ==
|
||||
DateFormat("yyyy-MM-dd").format(DateTime.now());
|
||||
}
|
||||
|
||||
myBoxDecoration() {
|
||||
return BoxDecoration(
|
||||
border: Border(
|
||||
top: BorderSide(
|
||||
color: Colors.green,
|
||||
width: 5,
|
||||
),
|
||||
),
|
||||
borderRadius: BorderRadius.circular(10));
|
||||
}
|
||||
}
|
||||
@ -1,507 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/config.dart';
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/core/viewModel/project_view_model.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:hexcolor/hexcolor.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
import 'large_avatar.dart';
|
||||
|
||||
class PatientProfileHeaderWhitAppointment extends StatelessWidget {
|
||||
|
||||
final PatiantInformtion patient;
|
||||
final String patientType;
|
||||
final String arrivalType;
|
||||
final String doctorName;
|
||||
final String branch;
|
||||
final DateTime appointmentDate;
|
||||
final String profileUrl;
|
||||
final String invoiceNO;
|
||||
final String orderNo;
|
||||
final bool isPrescriptions;
|
||||
final String clinic;
|
||||
PatientProfileHeaderWhitAppointment(
|
||||
{this.patient,
|
||||
this.patientType,
|
||||
this.arrivalType,
|
||||
this.doctorName,
|
||||
this.branch,
|
||||
this.appointmentDate,
|
||||
this.profileUrl,
|
||||
this.invoiceNO,
|
||||
this.orderNo, this.isPrescriptions = false, this.clinic});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
int gender = 1;
|
||||
if (patient.patientDetails != null) {
|
||||
gender = patient.patientDetails.gender;
|
||||
} else {
|
||||
gender = patient.gender;
|
||||
}
|
||||
|
||||
ProjectViewModel projectViewModel = Provider.of(context);
|
||||
return Container(
|
||||
padding: EdgeInsets.only(
|
||||
left: 0, right: 5, bottom: 5, top: 5),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
),
|
||||
//height: 300,
|
||||
child: Container(
|
||||
padding: EdgeInsets.only(left: 10, right: 10, bottom: 10),
|
||||
margin: EdgeInsets.only(top: 50),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Row(children: [
|
||||
IconButton(
|
||||
icon: Icon(Icons.arrow_back_ios),
|
||||
color: Colors.black, //Colors.black,
|
||||
onPressed: () => Navigator.pop(context),
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
patient.firstName != null ?
|
||||
(Helpers.capitalize(patient.firstName) +
|
||||
" " +
|
||||
Helpers.capitalize(
|
||||
patient.lastName)) : Helpers.capitalize(patient.patientDetails.fullName),
|
||||
fontSize: SizeConfig.textMultiplier *2.2,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
),
|
||||
gender == 1
|
||||
? Icon(
|
||||
DoctorApp.male_2,
|
||||
color: Colors.blue,
|
||||
)
|
||||
: Icon(
|
||||
DoctorApp.female_1,
|
||||
color: Colors.pink,
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(horizontal: 4),
|
||||
child: InkWell(
|
||||
onTap: () {
|
||||
launch("tel://" + patient.mobileNumber);
|
||||
},
|
||||
child: Icon(
|
||||
Icons.phone,
|
||||
color: Colors.black87,
|
||||
),
|
||||
),
|
||||
)
|
||||
]),
|
||||
),
|
||||
Row(children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
child: Image.asset(
|
||||
gender == 1
|
||||
? 'assets/images/male_avatar.png'
|
||||
: 'assets/images/female_avatar.png',
|
||||
fit: BoxFit.cover,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 10,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment:
|
||||
CrossAxisAlignment.start,
|
||||
children: [
|
||||
SERVICES_PATIANT2[
|
||||
int.parse(patientType)] ==
|
||||
"patientArrivalList"
|
||||
? Container(
|
||||
child: Row(
|
||||
mainAxisAlignment:
|
||||
MainAxisAlignment
|
||||
.spaceBetween,
|
||||
children: [
|
||||
patient.patientStatusType ==
|
||||
43
|
||||
? AppText(
|
||||
TranslationBase.of(
|
||||
context)
|
||||
.arrivedP,
|
||||
color: Colors.green,
|
||||
fontWeight:
|
||||
FontWeight.bold,
|
||||
fontFamily:
|
||||
'Poppins',
|
||||
fontSize: 12,
|
||||
)
|
||||
: AppText(
|
||||
TranslationBase.of(
|
||||
context)
|
||||
.notArrived,
|
||||
color:
|
||||
Colors.red[800],
|
||||
fontWeight:
|
||||
FontWeight.bold,
|
||||
fontFamily:
|
||||
'Poppins',
|
||||
fontSize: 12,
|
||||
),
|
||||
arrivalType == '1' || patient.arrivedOn == null
|
||||
? AppText(
|
||||
patient.startTime !=
|
||||
null
|
||||
? patient
|
||||
.startTime
|
||||
: '',
|
||||
fontFamily:
|
||||
'Poppins',
|
||||
fontWeight:
|
||||
FontWeight.w600,
|
||||
)
|
||||
: AppText(
|
||||
AppDateUtils.convertStringToDateFormat(
|
||||
patient
|
||||
.arrivedOn,
|
||||
'MM-dd-yyyy HH:mm'),
|
||||
fontFamily:
|
||||
'Poppins',
|
||||
fontWeight:
|
||||
FontWeight.w600,
|
||||
)
|
||||
],
|
||||
))
|
||||
: SizedBox(),
|
||||
if (SERVICES_PATIANT2[
|
||||
int.parse(patientType)] ==
|
||||
"List_MyOutPatient")
|
||||
Container(
|
||||
child: Row(
|
||||
mainAxisAlignment:
|
||||
MainAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
TranslationBase.of(context)
|
||||
.appointmentDate +
|
||||
" : ",
|
||||
fontSize: 14,
|
||||
),
|
||||
patient.startTime != null
|
||||
? Container(
|
||||
height: 15,
|
||||
width: 60,
|
||||
decoration:
|
||||
BoxDecoration(
|
||||
borderRadius:
|
||||
BorderRadius
|
||||
.circular(
|
||||
25),
|
||||
color: HexColor(
|
||||
"#20A169"),
|
||||
),
|
||||
child: AppText(
|
||||
patient.startTime,
|
||||
color: Colors.white,
|
||||
fontSize: 1.5 *
|
||||
SizeConfig
|
||||
.textMultiplier,
|
||||
textAlign: TextAlign
|
||||
.center,
|
||||
fontWeight:
|
||||
FontWeight.bold,
|
||||
),
|
||||
)
|
||||
: SizedBox(),
|
||||
SizedBox(
|
||||
width: 3.5,
|
||||
),
|
||||
Container(
|
||||
child: AppText(
|
||||
convertDateFormat2(patient.appointmentDate.toString()?? ''),
|
||||
fontSize: 1.5 *
|
||||
SizeConfig
|
||||
.textMultiplier,
|
||||
fontWeight:
|
||||
FontWeight.bold,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 0.5,
|
||||
)
|
||||
],
|
||||
),
|
||||
margin: EdgeInsets.only(
|
||||
top: 8,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment:
|
||||
MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
RichText(
|
||||
text: TextSpan(
|
||||
style: TextStyle(
|
||||
fontSize: 1.6 *
|
||||
SizeConfig
|
||||
.textMultiplier,
|
||||
color: Colors.black),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text:
|
||||
TranslationBase.of(
|
||||
context)
|
||||
.fileNumber,
|
||||
style: TextStyle(
|
||||
fontSize: 12,
|
||||
fontFamily:
|
||||
'Poppins')),
|
||||
new TextSpan(
|
||||
text: patient.patientId
|
||||
.toString(),
|
||||
style: TextStyle(
|
||||
fontWeight:
|
||||
FontWeight.w700,
|
||||
fontFamily:
|
||||
'Poppins',
|
||||
fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
patient.nationalityName ??
|
||||
patient.nationality??"",
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 12,
|
||||
),
|
||||
patient.nationality != null
|
||||
? ClipRRect(
|
||||
borderRadius:
|
||||
BorderRadius
|
||||
.circular(
|
||||
20.0),
|
||||
child: Image.network(
|
||||
patient.nationalityFlagURL,
|
||||
height: 25,
|
||||
width: 30,
|
||||
errorBuilder:
|
||||
(BuildContext
|
||||
context,
|
||||
Object
|
||||
exception,
|
||||
StackTrace
|
||||
stackTrace) {
|
||||
return Text(
|
||||
'No Image');
|
||||
},
|
||||
))
|
||||
: SizedBox()
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 1.6 *
|
||||
SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(
|
||||
context)
|
||||
.age +
|
||||
" : ",
|
||||
style: TextStyle(
|
||||
fontSize: 14)),
|
||||
new TextSpan(
|
||||
text:
|
||||
"${AppDateUtils.getAgeByBirthday(patient.patientDetails != null ? patient.patientDetails.dateofBirth ??"": patient.dateofBirth??"", context)}",
|
||||
style: TextStyle(
|
||||
fontWeight:
|
||||
FontWeight.w700,
|
||||
fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
]),
|
||||
Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
width: 30,
|
||||
height: 30,
|
||||
margin: EdgeInsets.only(left: projectViewModel.isArabic?10:85, right: projectViewModel.isArabic?85:10,top: 5),
|
||||
decoration: BoxDecoration(
|
||||
shape: BoxShape.rectangle,
|
||||
border: Border(
|
||||
bottom:BorderSide(color: Colors.grey[400],width: 2.5),
|
||||
left: BorderSide(color: Colors.grey[400],width: 2.5),
|
||||
)
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
child: Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Container(
|
||||
child: LargeAvatar(
|
||||
name: doctorName,
|
||||
url: profileUrl,
|
||||
),
|
||||
width: 25,
|
||||
height: 25,
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
),
|
||||
Expanded(
|
||||
flex: 4,
|
||||
child: Container(
|
||||
margin: EdgeInsets.all(10),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
'${TranslationBase.of(context).dr}.$doctorName',
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.w600,
|
||||
fontSize: 14,
|
||||
),
|
||||
if (orderNo != null && !isPrescriptions)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
'Order No:',
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
AppText(
|
||||
orderNo ?? '',
|
||||
)
|
||||
],
|
||||
),
|
||||
if (invoiceNO != null && !isPrescriptions)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
'Invoice:',
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
AppText(
|
||||
invoiceNO,
|
||||
)
|
||||
],
|
||||
),
|
||||
if(isPrescriptions)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Branch:',
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
AppText(
|
||||
branch?? '',
|
||||
)
|
||||
],
|
||||
),
|
||||
if(isPrescriptions)
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
'Clinic:',
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
AppText(
|
||||
clinic?? '',
|
||||
)
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
!isPrescriptions? 'Result Date:': 'Prescriptions Date',
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
'${AppDateUtils.getDayMonthYearDateFormatted(appointmentDate, isArabic: projectViewModel.isArabic)}',
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
]),
|
||||
),
|
||||
),
|
||||
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat2(String str) {
|
||||
String newDate ="";
|
||||
const start = "/Date(";
|
||||
const end = "+0300)";
|
||||
|
||||
if (str.isNotEmpty) {
|
||||
final startIndex = str.indexOf(start);
|
||||
final endIndex = str.indexOf(end, startIndex + start.length);
|
||||
|
||||
var date = new DateTime.fromMillisecondsSinceEpoch(
|
||||
int.parse(str.substring(startIndex + start.length, endIndex)));
|
||||
newDate = date.year.toString() +
|
||||
"/" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"/" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
}
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
|
||||
isToday(date) {
|
||||
DateTime tempDate = new DateFormat("yyyy-MM-dd").parse(date);
|
||||
return DateFormat("yyyy-MM-dd").format(tempDate) ==
|
||||
DateFormat("yyyy-MM-dd").format(DateTime.now());
|
||||
}
|
||||
|
||||
myBoxDecoration() {
|
||||
return BoxDecoration(
|
||||
border: Border(
|
||||
top: BorderSide(
|
||||
color: Colors.green,
|
||||
width: 5,
|
||||
),
|
||||
),
|
||||
borderRadius: BorderRadius.circular(10));
|
||||
}
|
||||
}
|
||||
@ -1,456 +0,0 @@
|
||||
import 'package:doctor_app_flutter/config/config.dart';
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/core/viewModel/project_view_model.dart';
|
||||
import 'package:doctor_app_flutter/icons_app/doctor_app_icons.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
||||
import 'package:doctor_app_flutter/util/date-utils.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:hexcolor/hexcolor.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
import 'large_avatar.dart';
|
||||
|
||||
class PatientProfileHeaderWhitAppointmentAppBar extends StatelessWidget
|
||||
with PreferredSizeWidget {
|
||||
final PatiantInformtion patient;
|
||||
final String patientType;
|
||||
final String arrivalType;
|
||||
final String doctorName;
|
||||
final String branch;
|
||||
final DateTime appointmentDate;
|
||||
final String profileUrl;
|
||||
final String invoiceNO;
|
||||
final String orderNo;
|
||||
final bool isPrescriptions;
|
||||
final bool isMedicalFile;
|
||||
final String episode;
|
||||
final String vistDate;
|
||||
|
||||
final String clinic;
|
||||
PatientProfileHeaderWhitAppointmentAppBar(
|
||||
{this.patient,
|
||||
this.patientType,
|
||||
this.arrivalType,
|
||||
this.doctorName,
|
||||
this.branch,
|
||||
this.appointmentDate,
|
||||
this.profileUrl,
|
||||
this.invoiceNO,
|
||||
this.orderNo,
|
||||
this.isPrescriptions = false,
|
||||
this.clinic,
|
||||
this.isMedicalFile = false,
|
||||
this.episode,
|
||||
this.vistDate});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
ProjectViewModel projectViewModel = Provider.of(context);
|
||||
int gender = 1;
|
||||
if (patient.patientDetails != null) {
|
||||
gender = patient.patientDetails.gender;
|
||||
} else {
|
||||
gender = patient.gender;
|
||||
}
|
||||
|
||||
return Container(
|
||||
padding: EdgeInsets.only(left: 0, right: 5, bottom: 5, top: 5),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
),
|
||||
//height: 300,
|
||||
child: Container(
|
||||
padding: EdgeInsets.only(left: 10, right: 10, bottom: 10),
|
||||
margin: EdgeInsets.only(top: 50),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Row(children: [
|
||||
IconButton(
|
||||
icon: Icon(Icons.arrow_back_ios),
|
||||
color: Colors.black, //Colors.black,
|
||||
onPressed: () => Navigator.pop(context),
|
||||
),
|
||||
Expanded(
|
||||
child: AppText(
|
||||
patient.firstName != null
|
||||
? (Helpers.capitalize(patient.firstName) +
|
||||
" " +
|
||||
Helpers.capitalize(patient.lastName))
|
||||
: Helpers.capitalize(patient.fullName??patient?.patientDetails?.fullName??""),
|
||||
fontSize: SizeConfig.textMultiplier * 2.2,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
),
|
||||
gender == 1
|
||||
? Icon(
|
||||
DoctorApp.male_2,
|
||||
color: Colors.blue,
|
||||
)
|
||||
: Icon(
|
||||
DoctorApp.female_1,
|
||||
color: Colors.pink,
|
||||
),
|
||||
Container(
|
||||
margin: EdgeInsets.symmetric(horizontal: 4),
|
||||
child: InkWell(
|
||||
onTap: () {
|
||||
launch("tel://" + patient?.mobileNumber??"");
|
||||
},
|
||||
child: Icon(
|
||||
Icons.phone,
|
||||
color: Colors.black87,
|
||||
),
|
||||
),
|
||||
)
|
||||
]),
|
||||
),
|
||||
Row(children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 12.0),
|
||||
child: Container(
|
||||
width: 60,
|
||||
height: 60,
|
||||
child: Image.asset(
|
||||
gender == 1
|
||||
? 'assets/images/male_avatar.png'
|
||||
: 'assets/images/female_avatar.png',
|
||||
fit: BoxFit.cover,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 10,
|
||||
),
|
||||
Expanded(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
SERVICES_PATIANT2[int.parse(patientType)] ==
|
||||
"patientArrivalList"
|
||||
? Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
patient.patientStatusType == 43
|
||||
? AppText(
|
||||
TranslationBase.of(context).arrivedP,
|
||||
color: Colors.green,
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
)
|
||||
: AppText(
|
||||
TranslationBase.of(context).notArrived,
|
||||
color: Colors.red[800],
|
||||
fontWeight: FontWeight.bold,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 12,
|
||||
),
|
||||
arrivalType == '1' || patient.arrivedOn == null
|
||||
? AppText(
|
||||
patient.startTime != null
|
||||
? patient.startTime
|
||||
: '',
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
)
|
||||
: AppText(
|
||||
AppDateUtils.convertStringToDateFormat(
|
||||
patient.arrivedOn,
|
||||
'MM-dd-yyyy HH:mm'),
|
||||
fontFamily: 'Poppins',
|
||||
fontWeight: FontWeight.w600,
|
||||
)
|
||||
],
|
||||
))
|
||||
: SizedBox(),
|
||||
if (SERVICES_PATIANT2[int.parse(patientType)] ==
|
||||
"List_MyOutPatient")
|
||||
Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
TranslationBase.of(context).appointmentDate +
|
||||
" : ",
|
||||
fontSize: 14,
|
||||
),
|
||||
patient.startTime != null
|
||||
? Container(
|
||||
height: 15,
|
||||
width: 60,
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.circular(25),
|
||||
color: HexColor("#20A169"),
|
||||
),
|
||||
child: AppText(
|
||||
patient.startTime ?? "",
|
||||
color: Colors.white,
|
||||
fontSize: 1.5 * SizeConfig.textMultiplier,
|
||||
textAlign: TextAlign.center,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
)
|
||||
: SizedBox(),
|
||||
SizedBox(
|
||||
width: 3.5,
|
||||
),
|
||||
Container(
|
||||
child: AppText(
|
||||
convertDateFormat2(
|
||||
patient.appointmentDate.toString() ?? ''),
|
||||
fontSize: 1.5 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
height: 0.5,
|
||||
)
|
||||
],
|
||||
),
|
||||
margin: EdgeInsets.only(
|
||||
top: 8,
|
||||
),
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
RichText(
|
||||
text: TextSpan(
|
||||
style: TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(context).fileNumber,
|
||||
style: TextStyle(
|
||||
fontSize: 12, fontFamily: 'Poppins')),
|
||||
new TextSpan(
|
||||
text: patient?.patientId?.toString() ?? "",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700,
|
||||
fontFamily: 'Poppins',
|
||||
fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: [
|
||||
AppText(
|
||||
patient.nationalityName ??
|
||||
patient.nationality ??
|
||||
"",
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: 12,
|
||||
),
|
||||
patient.nationality != null
|
||||
? ClipRRect(
|
||||
borderRadius: BorderRadius.circular(20.0),
|
||||
child: Image.network(
|
||||
patient?.nationalityFlagURL??"",
|
||||
height: 25,
|
||||
width: 30,
|
||||
errorBuilder: (BuildContext context,
|
||||
Object exception,
|
||||
StackTrace stackTrace) {
|
||||
return Text('No Image');
|
||||
},
|
||||
))
|
||||
: SizedBox()
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
Container(
|
||||
child: RichText(
|
||||
text: new TextSpan(
|
||||
style: new TextStyle(
|
||||
fontSize: 1.6 * SizeConfig.textMultiplier,
|
||||
color: Colors.black,
|
||||
fontFamily: 'Poppins',
|
||||
),
|
||||
children: <TextSpan>[
|
||||
new TextSpan(
|
||||
text: TranslationBase.of(context).age + " : ",
|
||||
style: TextStyle(fontSize: 14)),
|
||||
new TextSpan(
|
||||
text:
|
||||
"${AppDateUtils.getAgeByBirthday(patient.patientDetails != null ? patient.patientDetails.dateofBirth : patient.dateofBirth, context)}",
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.w700, fontSize: 14)),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
]),
|
||||
Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
Container(
|
||||
width: 30,
|
||||
height: 30,
|
||||
margin: EdgeInsets.only(
|
||||
left: projectViewModel.isArabic ? 10 : 85,
|
||||
right: projectViewModel.isArabic ? 85 : 10,
|
||||
top: 5),
|
||||
decoration: BoxDecoration(
|
||||
shape: BoxShape.rectangle,
|
||||
border: Border(
|
||||
bottom: BorderSide(color: Colors.grey[400], width: 2.5),
|
||||
left: BorderSide(color: Colors.grey[400], width: 2.5),
|
||||
)),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
child: Row(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Container(
|
||||
child: LargeAvatar(
|
||||
name: doctorName ?? "",
|
||||
url: profileUrl,
|
||||
),
|
||||
width: 25,
|
||||
height: 25,
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
),
|
||||
Expanded(
|
||||
flex: 5,
|
||||
child: Container(
|
||||
margin: EdgeInsets.all(10),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
'${TranslationBase.of(context).dr}$doctorName',
|
||||
color: Colors.black,
|
||||
fontWeight: FontWeight.w600,
|
||||
fontSize: 9,
|
||||
),
|
||||
if (orderNo != null && !isPrescriptions)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText('Order No: ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12),
|
||||
AppText(orderNo ?? '', fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (invoiceNO != null && !isPrescriptions)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
AppText('Invoice: ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12),
|
||||
AppText(invoiceNO??"", fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (branch != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Branch: ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12),
|
||||
AppText(branch ?? '', fontSize: 12)
|
||||
],
|
||||
),
|
||||
|
||||
if (clinic != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Clinic: ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12),
|
||||
AppText(clinic ?? '', fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (isMedicalFile && episode != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Episode: ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12),
|
||||
AppText(episode ?? '', fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (isMedicalFile && vistDate != null)
|
||||
Row(
|
||||
children: [
|
||||
AppText('Visit Date: ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12),
|
||||
AppText(vistDate ?? '', fontSize: 12)
|
||||
],
|
||||
),
|
||||
if (!isMedicalFile)
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: AppText(
|
||||
!isPrescriptions
|
||||
? 'Result Date: '
|
||||
: 'Prescriptions Date ',
|
||||
color: Colors.grey[800],
|
||||
fontSize: 12,
|
||||
),
|
||||
),
|
||||
AppText(
|
||||
'${AppDateUtils.getDayMonthYearDateFormatted(appointmentDate, isArabic: projectViewModel.isArabic)}',
|
||||
fontSize: 14,
|
||||
)
|
||||
],
|
||||
)
|
||||
]),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat2(String str) {
|
||||
String newDate = "";
|
||||
const start = "/Date(";
|
||||
const end = "+0300)";
|
||||
|
||||
if (str.isNotEmpty) {
|
||||
final startIndex = str.indexOf(start);
|
||||
final endIndex = str.indexOf(end, startIndex + start.length);
|
||||
|
||||
var date = new DateTime.fromMillisecondsSinceEpoch(
|
||||
int.parse(str.substring(startIndex + start.length, endIndex)));
|
||||
newDate = date.year.toString() +
|
||||
"/" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"/" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
}
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
|
||||
|
||||
|
||||
@override
|
||||
Size get preferredSize => Size(double.maxFinite, 310);
|
||||
}
|
||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue