Merge branch 'develop' into 'master'
Develop See merge request Cloud_Solution/doctor_app_flutter!70merge-requests/71/head
commit
7f5831335b
@ -0,0 +1,87 @@
|
||||
/*
|
||||
*@author: Ibrahim Albitar
|
||||
*@Date:15/5/2020
|
||||
|
||||
*@param:
|
||||
{"PatientID":1089227,
|
||||
"PatientTypeID":1,
|
||||
"EXuldAPPNO":0,
|
||||
"ProjectID":12,
|
||||
"LanguageID":2,
|
||||
"stamp":"2020-04-01T09:47:19.643Z",
|
||||
"IPAdress":"11.11.11.11",
|
||||
"VersionID":1.2,
|
||||
"Channel":9,
|
||||
"TokenID":"yIwh6wNyUkOeQlJRohWjyw==",
|
||||
"SessionID":"LlBk8lUEJY",
|
||||
"IsLoginForDoctorApp":true,
|
||||
"PatientOutSA":false}
|
||||
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
class InsuranceAprovalsRequest {
|
||||
int exuldAppNO;
|
||||
int patientID;
|
||||
int channel;
|
||||
int projectID;
|
||||
int languageID;
|
||||
String stamp;
|
||||
String ipAdress;
|
||||
double versionID;
|
||||
String tokenID;
|
||||
String sessionID;
|
||||
bool isLoginForDoctorApp;
|
||||
bool patientOutSA;
|
||||
int patientTypeID;
|
||||
|
||||
InsuranceAprovalsRequest(
|
||||
{
|
||||
this.exuldAppNO,
|
||||
this.patientID,
|
||||
this.channel = 9,
|
||||
this.projectID = 12,
|
||||
this.patientTypeID = 1,
|
||||
this.languageID = 2,
|
||||
this.stamp = '2020-04-23T21:01:21.492Z',
|
||||
this.ipAdress = '11.11.11.11',
|
||||
this.versionID = 1.2,
|
||||
this.tokenID = '@dm!n',
|
||||
this.sessionID = 'e29zoooEJ4',
|
||||
this.isLoginForDoctorApp = true,
|
||||
this.patientOutSA = false});
|
||||
|
||||
InsuranceAprovalsRequest.fromJson(Map<String, dynamic> json) {
|
||||
exuldAppNO = json['EXuldAPPNO'];
|
||||
patientID = json['PatientID'];
|
||||
channel = json['Channel'];
|
||||
projectID = json['ProjectID'];
|
||||
patientTypeID = json['PatientTypeID'];
|
||||
languageID = json['LanguageID'];
|
||||
stamp = json['stamp'];
|
||||
ipAdress = json['IPAdress'];
|
||||
versionID = json['VersionID'];
|
||||
tokenID = json['TokenID'];
|
||||
sessionID = json['SessionID'];
|
||||
isLoginForDoctorApp = json['IsLoginForDoctorApp'];
|
||||
patientOutSA = json['PatientOutSA'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['EXuldAPPNO'] = this.exuldAppNO;
|
||||
data['PatientID'] = this.patientID;
|
||||
data['Channel'] = this.channel;
|
||||
data['ProjectID'] = this.projectID;
|
||||
data['PatientTypeID'] = this.patientTypeID;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['stamp'] = this.stamp;
|
||||
data['IPAdress'] = this.ipAdress;
|
||||
data['VersionID'] = this.versionID;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
return data;
|
||||
}
|
||||
}
|
@ -0,0 +1,88 @@
|
||||
|
||||
/*
|
||||
*@author: Ibrahim Albitar
|
||||
*@Date:15/5/2020
|
||||
|
||||
*@param:
|
||||
{"VisitType":3,
|
||||
"AdmissionNo":2020004683,
|
||||
"ProjectID":12,
|
||||
"LanguageID":2,
|
||||
"stamp":"2020-04-01T09:53:50.410Z",
|
||||
"IPAdress":"11.11.11.11",
|
||||
"VersionID":1.2,
|
||||
"Channel":9,
|
||||
"TokenID":"yIwh6wNyUkOeQlJRohWjyw==",
|
||||
"SessionID":"LlBk8lUEJY",
|
||||
"IsLoginForDoctorApp":true,
|
||||
"PatientOutSA":false,
|
||||
"PatientTypeID":1}
|
||||
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
|
||||
class OrdersRequest {
|
||||
int visitType;
|
||||
int admissionNo;
|
||||
int projectID;
|
||||
int languageID;
|
||||
String stamp;
|
||||
String iPAdress;
|
||||
int channel;
|
||||
String tokenID;
|
||||
String sessionID;
|
||||
bool isLoginForDoctorApp;
|
||||
bool patientOutSA;
|
||||
int patientTypeID;
|
||||
double versionID;
|
||||
|
||||
OrdersRequest(
|
||||
{this.visitType ,
|
||||
this.admissionNo,
|
||||
this.projectID = 12,
|
||||
this.stamp = '2020-04-23T21:01:21.492Z',
|
||||
this.languageID = 2,
|
||||
this.iPAdress = '11.11.11.11',
|
||||
this.channel = 9,
|
||||
this.tokenID = '@dm!n',
|
||||
this.sessionID = "LlBk8lUEJY",
|
||||
this.isLoginForDoctorApp = true,
|
||||
this.patientTypeID = 1,
|
||||
this.versionID = 1.2,
|
||||
this.patientOutSA = false});
|
||||
|
||||
OrdersRequest.fromJson(Map<String, dynamic> json) {
|
||||
visitType = json['VisitType'];
|
||||
admissionNo = json['AdmissionNo'];
|
||||
projectID = json['ProjectID'];
|
||||
stamp = json['stamp'];
|
||||
languageID = json['LanguageID'];
|
||||
iPAdress = json['IPAdress'];
|
||||
channel = json['Channel'];
|
||||
tokenID = json['TokenID'];
|
||||
sessionID = json['SessionID'];
|
||||
isLoginForDoctorApp = json['IsLoginForDoctorApp'];
|
||||
patientOutSA = json['PatientOutSA'];
|
||||
patientTypeID = json['PatientTypeID'];
|
||||
versionID = json['VersionID'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['VisitType'] = this.visitType;
|
||||
data['AdmissionNo'] = this.admissionNo;
|
||||
data['ProjectID'] = this.projectID;
|
||||
data['stamp'] = this.stamp;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['IPAdress'] = this.iPAdress;
|
||||
data['Channel'] = this.channel;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
data['PatientTypeID'] = this.patientTypeID;
|
||||
data['VersionID'] = this.versionID;
|
||||
return data;
|
||||
}
|
||||
}
|
@ -0,0 +1,88 @@
|
||||
|
||||
/*
|
||||
*@author: Ibrahim Albitar
|
||||
*@Date:15/5/2020
|
||||
|
||||
*@param:
|
||||
{"VisitType":5,
|
||||
"AdmissionNo":2020004683,
|
||||
"ProjectID":12,
|
||||
"LanguageID":2,
|
||||
"stamp":"2020-04-01T09:41:59.089Z",
|
||||
"IPAdress":"11.11.11.11",
|
||||
"VersionID":1.2,
|
||||
"Channel":9,
|
||||
"TokenID":"yIwh6wNyUkOeQlJRohWjyw==",
|
||||
"SessionID":"LlBk8lUEJY",
|
||||
"IsLoginForDoctorApp":true,
|
||||
"PatientOutSA":false,
|
||||
"PatientTypeID":1}
|
||||
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
|
||||
class ProgressNoteRequest {
|
||||
int visitType;
|
||||
int admissionNo;
|
||||
int projectID;
|
||||
int languageID;
|
||||
String stamp;
|
||||
String iPAdress;
|
||||
int channel;
|
||||
String tokenID;
|
||||
String sessionID;
|
||||
bool isLoginForDoctorApp;
|
||||
bool patientOutSA;
|
||||
int patientTypeID;
|
||||
double versionID;
|
||||
|
||||
ProgressNoteRequest(
|
||||
{this.visitType ,
|
||||
this.admissionNo,
|
||||
this.projectID = 12,
|
||||
this.stamp = '2020-04-23T21:01:21.492Z',
|
||||
this.languageID = 2,
|
||||
this.iPAdress = '11.11.11.11',
|
||||
this.channel = 9,
|
||||
this.tokenID = '@dm!n',
|
||||
this.sessionID = "LlBk8lUEJY",
|
||||
this.isLoginForDoctorApp = true,
|
||||
this.patientTypeID = 1,
|
||||
this.versionID = 1.2,
|
||||
this.patientOutSA = false});
|
||||
|
||||
ProgressNoteRequest.fromJson(Map<String, dynamic> json) {
|
||||
visitType = json['VisitType'];
|
||||
admissionNo = json['AdmissionNo'];
|
||||
projectID = json['ProjectID'];
|
||||
stamp = json['stamp'];
|
||||
languageID = json['LanguageID'];
|
||||
iPAdress = json['IPAdress'];
|
||||
channel = json['Channel'];
|
||||
tokenID = json['TokenID'];
|
||||
sessionID = json['SessionID'];
|
||||
isLoginForDoctorApp = json['IsLoginForDoctorApp'];
|
||||
patientOutSA = json['PatientOutSA'];
|
||||
patientTypeID = json['PatientTypeID'];
|
||||
versionID = json['VersionID'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['VisitType'] = this.visitType;
|
||||
data['AdmissionNo'] = this.admissionNo;
|
||||
data['ProjectID'] = this.projectID;
|
||||
data['stamp'] = this.stamp;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['IPAdress'] = this.iPAdress;
|
||||
data['Channel'] = this.channel;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
data['PatientTypeID'] = this.patientTypeID;
|
||||
data['VersionID'] = this.versionID;
|
||||
return data;
|
||||
}
|
||||
}
|
@ -0,0 +1,151 @@
|
||||
import 'package:doctor_app_flutter/models/patient/insurance_aprovals_request.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/errors/dr_app_embedded_error.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/rounded_container_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
import '../../../config/shared_pref_kay.dart';
|
||||
import '../../../config/size_config.dart';
|
||||
import '../../../models/patient/patiant_info_model.dart';
|
||||
import '../../../providers/patients_provider.dart';
|
||||
import '../../../util/dr_app_shared_pref.dart';
|
||||
import '../../../widgets/shared/app_scaffold_widget.dart';
|
||||
import '../../../widgets/shared/app_texts_widget.dart';
|
||||
import '../../../widgets/shared/dr_app_circular_progress_Indeicator.dart';
|
||||
|
||||
DrAppSharedPreferances sharedPref = new DrAppSharedPreferances();
|
||||
|
||||
/*
|
||||
*@author: ibrahim albitar
|
||||
*@Date:21/5/2020
|
||||
*@param:
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
|
||||
class InsuranceApprovalsScreen extends StatefulWidget {
|
||||
@override
|
||||
_InsuranceApprovalsState createState() => _InsuranceApprovalsState();
|
||||
}
|
||||
|
||||
class _InsuranceApprovalsState extends State<InsuranceApprovalsScreen> {
|
||||
PatientsProvider patientsProv;
|
||||
var _isInit = true;
|
||||
|
||||
/*
|
||||
*@author: ibrahim al bitar
|
||||
*@Date:21/5/2020
|
||||
*@param:
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
getInsuranceApprovalsList(context) async {
|
||||
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||
PatiantInformtion patient = routeArgs['patient'];
|
||||
String token = await sharedPref.getString(TOKEN);
|
||||
String type = await sharedPref.getString(SLECTED_PATIENT_TYPE);
|
||||
|
||||
print(type);
|
||||
InsuranceAprovalsRequest insuranceApprovalsRequest = InsuranceAprovalsRequest(
|
||||
patientID: patient.patientId,
|
||||
projectID: patient.projectId,
|
||||
tokenID: token,
|
||||
patientTypeID: patient.patientType,
|
||||
languageID: 2);
|
||||
patientsProv.getPatientInsuranceApprovals(insuranceApprovalsRequest.toJson());
|
||||
}
|
||||
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
if (_isInit) {
|
||||
patientsProv = Provider.of<PatientsProvider>(context);
|
||||
getInsuranceApprovalsList(context);
|
||||
}
|
||||
_isInit = false;
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return AppScaffold(
|
||||
appBarTitle: "Insurance Approvals",
|
||||
showAppDrawer: false,
|
||||
showBottomBar: false,
|
||||
body: patientsProv.isLoading
|
||||
? DrAppCircularProgressIndeicator()
|
||||
: patientsProv.isError
|
||||
? DrAppEmbeddedError(error: patientsProv.error)
|
||||
: patientsProv.insuranceApporvalsList.length == 0
|
||||
? DrAppEmbeddedError(
|
||||
error: 'You don\'t have any Insurance Approvals')
|
||||
: Container(
|
||||
margin: EdgeInsets.fromLTRB(
|
||||
SizeConfig.realScreenWidth * 0.05,
|
||||
0,
|
||||
SizeConfig.realScreenWidth * 0.05,
|
||||
0),
|
||||
child: ListView.builder(
|
||||
itemCount:
|
||||
patientsProv.insuranceApporvalsList.length,
|
||||
itemBuilder: (BuildContext ctxt, int index) {
|
||||
return RoundedContainer(
|
||||
backgroundColor: Colors.yellow[200],
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
patientsProv
|
||||
.insuranceApporvalsList[index]
|
||||
["ClinicName"]+"-"+patientsProv
|
||||
.insuranceApporvalsList[index]
|
||||
["DoctorName"],
|
||||
marginTop: 10,
|
||||
marginLeft: 10,
|
||||
marginBottom: 5,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
AppText(
|
||||
convertDateFormat(patientsProv
|
||||
.insuranceApporvalsList[index]
|
||||
["ApprovalDate"]),
|
||||
marginLeft: 10,
|
||||
color: Colors.grey[600],
|
||||
),
|
||||
Divider(
|
||||
color: Colors.black,
|
||||
height: 20,
|
||||
thickness: 1,
|
||||
indent: 0,
|
||||
endIndent: 0,
|
||||
),
|
||||
AppText(
|
||||
patientsProv
|
||||
.insuranceApporvalsList[index]
|
||||
["CompanyName"],
|
||||
margin: 10,
|
||||
)
|
||||
],
|
||||
));
|
||||
}),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat(String str) {
|
||||
const start = "/Date(";
|
||||
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)));
|
||||
String newDate = date.year.toString() +
|
||||
"-" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"-" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
}
|
@ -0,0 +1,150 @@
|
||||
import 'package:doctor_app_flutter/models/patient/progress_note_request.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/errors/dr_app_embedded_error.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/rounded_container_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
import '../../../config/shared_pref_kay.dart';
|
||||
import '../../../config/size_config.dart';
|
||||
import '../../../models/patient/patiant_info_model.dart';
|
||||
import '../../../providers/patients_provider.dart';
|
||||
import '../../../util/dr_app_shared_pref.dart';
|
||||
import '../../../widgets/shared/app_scaffold_widget.dart';
|
||||
import '../../../widgets/shared/app_texts_widget.dart';
|
||||
import '../../../widgets/shared/dr_app_circular_progress_Indeicator.dart';
|
||||
|
||||
DrAppSharedPreferances sharedPref = new DrAppSharedPreferances();
|
||||
|
||||
/*
|
||||
*@author: ibrahim albitar
|
||||
*@Date:21/5/2020
|
||||
*@param:
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
|
||||
class PatientsOrdersScreen extends StatefulWidget {
|
||||
@override
|
||||
_PatientsOrdersState createState() => _PatientsOrdersState();
|
||||
}
|
||||
|
||||
class _PatientsOrdersState extends State<PatientsOrdersScreen> {
|
||||
PatientsProvider patientsProv;
|
||||
var _isInit = true;
|
||||
|
||||
/*
|
||||
*@author: ibrahim al bitar
|
||||
*@Date:21/5/2020
|
||||
*@param:
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
getProgressNoteList(context) async {
|
||||
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||
PatiantInformtion patient = routeArgs['patient'];
|
||||
String token = await sharedPref.getString(TOKEN);
|
||||
String type = await sharedPref.getString(SLECTED_PATIENT_TYPE);
|
||||
|
||||
print(type);
|
||||
ProgressNoteRequest progressNoteRequest = ProgressNoteRequest(
|
||||
visitType: 3, // if equal 3 then this will return orders
|
||||
admissionNo: int.parse(patient.admissionNo),
|
||||
projectID: patient.projectId,
|
||||
tokenID: token,
|
||||
patientTypeID: patient.patientType,
|
||||
languageID: 2);
|
||||
patientsProv.getPatientProgressNote(progressNoteRequest.toJson());
|
||||
}
|
||||
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
if (_isInit) {
|
||||
patientsProv = Provider.of<PatientsProvider>(context);
|
||||
getProgressNoteList(context);
|
||||
}
|
||||
_isInit = false;
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return AppScaffold(
|
||||
appBarTitle: "Orders",
|
||||
showAppDrawer: false,
|
||||
showBottomBar: false,
|
||||
body: patientsProv.isLoading
|
||||
? DrAppCircularProgressIndeicator()
|
||||
: patientsProv.isError
|
||||
? DrAppEmbeddedError(error: patientsProv.error)
|
||||
: patientsProv.patientProgressNoteList.length == 0
|
||||
? DrAppEmbeddedError(
|
||||
error: 'You don\'t have any Orders')
|
||||
: Container(
|
||||
margin: EdgeInsets.fromLTRB(
|
||||
SizeConfig.realScreenWidth * 0.05,
|
||||
0,
|
||||
SizeConfig.realScreenWidth * 0.05,
|
||||
0),
|
||||
child: ListView.builder(
|
||||
itemCount:
|
||||
patientsProv.patientProgressNoteList.length,
|
||||
itemBuilder: (BuildContext ctxt, int index) {
|
||||
return RoundedContainer(
|
||||
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
patientsProv
|
||||
.patientProgressNoteList[index]
|
||||
["DoctorName"],
|
||||
marginTop: 10,
|
||||
marginLeft: 10,
|
||||
marginBottom: 5,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
AppText(
|
||||
convertDateFormat(patientsProv
|
||||
.patientProgressNoteList[index]
|
||||
["AssessmentDate"]),
|
||||
marginLeft: 10,
|
||||
color: Colors.grey[600],
|
||||
),
|
||||
Divider(
|
||||
color: Colors.black,
|
||||
height: 20,
|
||||
thickness: 1,
|
||||
indent: 0,
|
||||
endIndent: 0,
|
||||
),
|
||||
AppText(
|
||||
patientsProv
|
||||
.patientProgressNoteList[index]
|
||||
["Notes"],
|
||||
margin: 10,
|
||||
)
|
||||
],
|
||||
));
|
||||
}),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat(String str) {
|
||||
const start = "/Date(";
|
||||
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)));
|
||||
String newDate = date.year.toString() +
|
||||
"-" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"-" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
}
|
@ -0,0 +1,150 @@
|
||||
import 'package:doctor_app_flutter/models/patient/progress_note_request.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/errors/dr_app_embedded_error.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/rounded_container_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
import '../../../config/shared_pref_kay.dart';
|
||||
import '../../../config/size_config.dart';
|
||||
import '../../../models/patient/patiant_info_model.dart';
|
||||
import '../../../providers/patients_provider.dart';
|
||||
import '../../../util/dr_app_shared_pref.dart';
|
||||
import '../../../widgets/shared/app_scaffold_widget.dart';
|
||||
import '../../../widgets/shared/app_texts_widget.dart';
|
||||
import '../../../widgets/shared/dr_app_circular_progress_Indeicator.dart';
|
||||
|
||||
DrAppSharedPreferances sharedPref = new DrAppSharedPreferances();
|
||||
|
||||
/*
|
||||
*@author: ibrahim albitar
|
||||
*@Date:15/5/2020
|
||||
*@param:
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
|
||||
class ProgressNoteScreen extends StatefulWidget {
|
||||
@override
|
||||
_ProgressNoteState createState() => _ProgressNoteState();
|
||||
}
|
||||
|
||||
class _ProgressNoteState extends State<ProgressNoteScreen> {
|
||||
PatientsProvider patientsProv;
|
||||
var _isInit = true;
|
||||
|
||||
/*
|
||||
*@author: ibrahim al bitar
|
||||
*@Date:16/5/2020
|
||||
*@param:
|
||||
*@return:
|
||||
*@desc:
|
||||
*/
|
||||
getProgressNoteList(context) async {
|
||||
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||
PatiantInformtion patient = routeArgs['patient'];
|
||||
String token = await sharedPref.getString(TOKEN);
|
||||
String type = await sharedPref.getString(SLECTED_PATIENT_TYPE);
|
||||
|
||||
print(type);
|
||||
ProgressNoteRequest progressNoteRequest = ProgressNoteRequest(
|
||||
visitType: 5, // if equal 5 then this will return progress note
|
||||
admissionNo: int.parse(patient.admissionNo),
|
||||
projectID: patient.projectId,
|
||||
tokenID: token,
|
||||
patientTypeID: patient.patientType,
|
||||
languageID: 2);
|
||||
patientsProv.getPatientProgressNote(progressNoteRequest.toJson());
|
||||
}
|
||||
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
if (_isInit) {
|
||||
patientsProv = Provider.of<PatientsProvider>(context);
|
||||
getProgressNoteList(context);
|
||||
}
|
||||
_isInit = false;
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return AppScaffold(
|
||||
appBarTitle: "Progress Note",
|
||||
showAppDrawer: false,
|
||||
showBottomBar: false,
|
||||
body: patientsProv.isLoading
|
||||
? DrAppCircularProgressIndeicator()
|
||||
: patientsProv.isError
|
||||
? DrAppEmbeddedError(error: patientsProv.error)
|
||||
: patientsProv.patientProgressNoteList.length == 0
|
||||
? DrAppEmbeddedError(
|
||||
error: 'You don\'t have any Progress Note')
|
||||
: Container(
|
||||
margin: EdgeInsets.fromLTRB(
|
||||
SizeConfig.realScreenWidth * 0.05,
|
||||
0,
|
||||
SizeConfig.realScreenWidth * 0.05,
|
||||
0),
|
||||
child: ListView.builder(
|
||||
itemCount:
|
||||
patientsProv.patientProgressNoteList.length,
|
||||
itemBuilder: (BuildContext ctxt, int index) {
|
||||
return RoundedContainer(
|
||||
backgroundColor: Colors.yellow[200],
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
patientsProv
|
||||
.patientProgressNoteList[index]
|
||||
["DoctorName"],
|
||||
marginTop: 10,
|
||||
marginLeft: 10,
|
||||
marginBottom: 5,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
AppText(
|
||||
convertDateFormat(patientsProv
|
||||
.patientProgressNoteList[index]
|
||||
["AssessmentDate"]),
|
||||
marginLeft: 10,
|
||||
color: Colors.grey[600],
|
||||
),
|
||||
Divider(
|
||||
color: Colors.black,
|
||||
height: 20,
|
||||
thickness: 1,
|
||||
indent: 0,
|
||||
endIndent: 0,
|
||||
),
|
||||
AppText(
|
||||
patientsProv
|
||||
.patientProgressNoteList[index]
|
||||
["Notes"],
|
||||
margin: 10,
|
||||
)
|
||||
],
|
||||
));
|
||||
}),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
convertDateFormat(String str) {
|
||||
const start = "/Date(";
|
||||
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)));
|
||||
String newDate = date.year.toString() +
|
||||
"-" +
|
||||
date.month.toString().padLeft(2, '0') +
|
||||
"-" +
|
||||
date.day.toString().padLeft(2, '0');
|
||||
|
||||
return newDate.toString();
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue