Merge branch 'master' of https://gitlab.com/Cloud_Solution/doctor_app_flutter into sultan
commit
bde30d93ec
@ -0,0 +1,7 @@
|
||||
/// Sample linear data type.
|
||||
class ChartAxis {
|
||||
final int xAxis;
|
||||
final int yAxis;
|
||||
|
||||
ChartAxis(this.xAxis, this.yAxis);
|
||||
}
|
||||
@ -0,0 +1,124 @@
|
||||
class LabResult {
|
||||
String setupID;
|
||||
int projectID;
|
||||
int orderNo;
|
||||
int lineItemNo;
|
||||
int packageID;
|
||||
int testID;
|
||||
String description;
|
||||
String resultValue;
|
||||
String referenceRange;
|
||||
Null convertedResultValue;
|
||||
Null convertedReferenceRange;
|
||||
Null resultValueFlag;
|
||||
int status;
|
||||
String createdBy;
|
||||
Null createdByN;
|
||||
String createdOn;
|
||||
String editedBy;
|
||||
Null editedByN;
|
||||
String editedOn;
|
||||
String verifiedBy;
|
||||
Null verifiedByN;
|
||||
String verifiedOn;
|
||||
Null patientID;
|
||||
int gender;
|
||||
Null maleInterpretativeData;
|
||||
Null femaleInterpretativeData;
|
||||
String testCode;
|
||||
String statusDescription;
|
||||
|
||||
LabResult(
|
||||
{this.setupID,
|
||||
this.projectID,
|
||||
this.orderNo,
|
||||
this.lineItemNo,
|
||||
this.packageID,
|
||||
this.testID,
|
||||
this.description,
|
||||
this.resultValue,
|
||||
this.referenceRange,
|
||||
this.convertedResultValue,
|
||||
this.convertedReferenceRange,
|
||||
this.resultValueFlag,
|
||||
this.status,
|
||||
this.createdBy,
|
||||
this.createdByN,
|
||||
this.createdOn,
|
||||
this.editedBy,
|
||||
this.editedByN,
|
||||
this.editedOn,
|
||||
this.verifiedBy,
|
||||
this.verifiedByN,
|
||||
this.verifiedOn,
|
||||
this.patientID,
|
||||
this.gender,
|
||||
this.maleInterpretativeData,
|
||||
this.femaleInterpretativeData,
|
||||
this.testCode,
|
||||
this.statusDescription});
|
||||
|
||||
LabResult.fromJson(Map<String, dynamic> json) {
|
||||
setupID = json['SetupID'];
|
||||
projectID = json['ProjectID'];
|
||||
orderNo = json['OrderNo'];
|
||||
lineItemNo = json['LineItemNo'];
|
||||
packageID = json['PackageID'];
|
||||
testID = json['TestID'];
|
||||
description = json['Description'];
|
||||
resultValue = json['ResultValue'];
|
||||
referenceRange = json['ReferenceRange'];
|
||||
convertedResultValue = json['ConvertedResultValue'];
|
||||
convertedReferenceRange = json['ConvertedReferenceRange'];
|
||||
resultValueFlag = json['ResultValueFlag'];
|
||||
status = json['Status'];
|
||||
createdBy = json['CreatedBy'];
|
||||
createdByN = json['CreatedByN'];
|
||||
createdOn = json['CreatedOn'];
|
||||
editedBy = json['EditedBy'];
|
||||
editedByN = json['EditedByN'];
|
||||
editedOn = json['EditedOn'];
|
||||
verifiedBy = json['VerifiedBy'];
|
||||
verifiedByN = json['VerifiedByN'];
|
||||
verifiedOn = json['VerifiedOn'];
|
||||
patientID = json['PatientID'];
|
||||
gender = json['Gender'];
|
||||
maleInterpretativeData = json['MaleInterpretativeData'];
|
||||
femaleInterpretativeData = json['FemaleInterpretativeData'];
|
||||
testCode = json['TestCode'];
|
||||
statusDescription = json['StatusDescription'];
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||
data['SetupID'] = this.setupID;
|
||||
data['ProjectID'] = this.projectID;
|
||||
data['OrderNo'] = this.orderNo;
|
||||
data['LineItemNo'] = this.lineItemNo;
|
||||
data['PackageID'] = this.packageID;
|
||||
data['TestID'] = this.testID;
|
||||
data['Description'] = this.description;
|
||||
data['ResultValue'] = this.resultValue;
|
||||
data['ReferenceRange'] = this.referenceRange;
|
||||
data['ConvertedResultValue'] = this.convertedResultValue;
|
||||
data['ConvertedReferenceRange'] = this.convertedReferenceRange;
|
||||
data['ResultValueFlag'] = this.resultValueFlag;
|
||||
data['Status'] = this.status;
|
||||
data['CreatedBy'] = this.createdBy;
|
||||
data['CreatedByN'] = this.createdByN;
|
||||
data['CreatedOn'] = this.createdOn;
|
||||
data['EditedBy'] = this.editedBy;
|
||||
data['EditedByN'] = this.editedByN;
|
||||
data['EditedOn'] = this.editedOn;
|
||||
data['VerifiedBy'] = this.verifiedBy;
|
||||
data['VerifiedByN'] = this.verifiedByN;
|
||||
data['VerifiedOn'] = this.verifiedOn;
|
||||
data['PatientID'] = this.patientID;
|
||||
data['Gender'] = this.gender;
|
||||
data['MaleInterpretativeData'] = this.maleInterpretativeData;
|
||||
data['FemaleInterpretativeData'] = this.femaleInterpretativeData;
|
||||
data['TestCode'] = this.testCode;
|
||||
data['StatusDescription'] = this.statusDescription;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,68 @@
|
||||
class RequestLabResult {
|
||||
int projectID;
|
||||
String setupID;
|
||||
int orderNo;
|
||||
int invoiceNo;
|
||||
int patientTypeID;
|
||||
int languageID;
|
||||
String stamp;
|
||||
String iPAdress;
|
||||
double versionID;
|
||||
int channel;
|
||||
String tokenID;
|
||||
String sessionID;
|
||||
bool isLoginForDoctorApp;
|
||||
bool patientOutSA;
|
||||
|
||||
RequestLabResult(
|
||||
{this.projectID,
|
||||
this.setupID,
|
||||
this.orderNo,
|
||||
this.invoiceNo,
|
||||
this.patientTypeID,
|
||||
this.languageID,
|
||||
this.stamp,
|
||||
this.iPAdress,
|
||||
this.versionID,
|
||||
this.channel,
|
||||
this.tokenID,
|
||||
this.sessionID,
|
||||
this.isLoginForDoctorApp,
|
||||
this.patientOutSA});
|
||||
|
||||
RequestLabResult.fromJson(Map<String, dynamic> json) {
|
||||
projectID = json['ProjectID'];
|
||||
setupID = json['SetupID'];
|
||||
orderNo = json['OrderNo'];
|
||||
invoiceNo = json['InvoiceNo'];
|
||||
patientTypeID = json['PatientTypeID'];
|
||||
languageID = json['LanguageID'];
|
||||
stamp = json['stamp'];
|
||||
iPAdress = json['IPAdress'];
|
||||
versionID = json['VersionID'];
|
||||
channel = json['Channel'];
|
||||
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['ProjectID'] = this.projectID;
|
||||
data['SetupID'] = this.setupID;
|
||||
data['OrderNo'] = this.orderNo;
|
||||
data['InvoiceNo'] = this.invoiceNo;
|
||||
data['PatientTypeID'] = this.patientTypeID;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['stamp'] = this.stamp;
|
||||
data['IPAdress'] = this.iPAdress;
|
||||
data['VersionID'] = this.versionID;
|
||||
data['Channel'] = this.channel;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,103 @@
|
||||
import 'package:doctor_app_flutter/config/config.dart';
|
||||
|
||||
class VerifyReferralDoctorRemarks {
|
||||
int projectID;
|
||||
String admissionNo;
|
||||
int lineItemNo;
|
||||
String referredDoctorRemarks;
|
||||
int editedBy;
|
||||
int patientID;
|
||||
int referringDoctor;
|
||||
int languageID;
|
||||
String stamp;
|
||||
String iPAdress;
|
||||
double versionID;
|
||||
int channel;
|
||||
String tokenID;
|
||||
String sessionID;
|
||||
bool isLoginForDoctorApp;
|
||||
bool patientOutSA;
|
||||
String firstName;
|
||||
|
||||
String middleName;
|
||||
String lastName;
|
||||
String patientMobileNumber;
|
||||
String patientIdentificationID;
|
||||
|
||||
VerifyReferralDoctorRemarks(
|
||||
{this.projectID,
|
||||
this.admissionNo,
|
||||
this.lineItemNo,
|
||||
this.referredDoctorRemarks,
|
||||
this.editedBy,
|
||||
this.patientID,
|
||||
this.referringDoctor,
|
||||
this.languageID = LANGUAGE_ID,
|
||||
this.stamp = STAMP,
|
||||
this.iPAdress = IP_ADDRESS,
|
||||
this.versionID = VERSION_ID,
|
||||
this.channel= CHANNEL,
|
||||
this.tokenID,
|
||||
this.sessionID = SESSION_ID,
|
||||
this.isLoginForDoctorApp = IS_LOGIN_FOR_DOCTOR_APP,
|
||||
this.patientOutSA = PATIENT_OUT_SA,
|
||||
this.firstName,
|
||||
this.middleName,
|
||||
this.lastName,
|
||||
this.patientMobileNumber,
|
||||
this.patientIdentificationID,
|
||||
});
|
||||
|
||||
VerifyReferralDoctorRemarks.fromJson(Map<String, dynamic> json) {
|
||||
projectID = json['ProjectID'];
|
||||
admissionNo = json['AdmissionNo'];
|
||||
lineItemNo = json['LineItemNo'];
|
||||
referredDoctorRemarks = json['ReferredDoctorRemarks'];
|
||||
editedBy = json['EditedBy'];
|
||||
patientID = json['PatientID'];
|
||||
referringDoctor = json['ReferringDoctor'];
|
||||
languageID = json['LanguageID'];
|
||||
stamp = json['stamp'];
|
||||
iPAdress = json['IPAdress'];
|
||||
versionID = json['VersionID'];
|
||||
channel = json['Channel'];
|
||||
tokenID = json['TokenID'];
|
||||
sessionID = json['SessionID'];
|
||||
isLoginForDoctorApp = json['IsLoginForDoctorApp'];
|
||||
patientOutSA = json['PatientOutSA'];
|
||||
firstName= json["FirstName"];
|
||||
middleName= json["MiddleName"];
|
||||
lastName= json["LastName"];
|
||||
patientMobileNumber= json["PatientMobileNumber"];
|
||||
patientIdentificationID = json["PatientIdentificationID"];
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
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['PatientID'] = this.patientID;
|
||||
data['ReferringDoctor'] = this.referringDoctor;
|
||||
data['LanguageID'] = this.languageID;
|
||||
data['stamp'] = this.stamp;
|
||||
data['IPAdress'] = this.iPAdress;
|
||||
data['VersionID'] = this.versionID;
|
||||
data['Channel'] = this.channel;
|
||||
data['TokenID'] = this.tokenID;
|
||||
data['SessionID'] = this.sessionID;
|
||||
data['IsLoginForDoctorApp'] = this.isLoginForDoctorApp;
|
||||
data['PatientOutSA'] = this.patientOutSA;
|
||||
data['FirstName'] = this.firstName;
|
||||
data['MiddleName'] = this.middleName;
|
||||
data['LastName'] = this.lastName;
|
||||
data['PatientMobileNumber'] = this.patientMobileNumber;
|
||||
data['PatientIdentificationID'] = this.patientIdentificationID;
|
||||
return data;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,86 @@
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/lab_orders_res_model.dart';
|
||||
import 'package:doctor_app_flutter/providers/patients_provider.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/widgets/doctor/lab_result_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/card_with_bgNew_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/dr_app_circular_progress_Indeicator.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/errors/dr_app_embedded_error.dart';
|
||||
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class LabResult extends StatefulWidget {
|
||||
final LabOrdersResModel labOrders;
|
||||
|
||||
LabResult({Key key, this.labOrders});
|
||||
|
||||
@override
|
||||
_LabResultState createState() => _LabResultState();
|
||||
}
|
||||
|
||||
class _LabResultState extends State<LabResult> {
|
||||
PatientsProvider patientsProv;
|
||||
bool _isInit = true;
|
||||
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
if (_isInit) {
|
||||
patientsProv = Provider.of<PatientsProvider>(context);
|
||||
patientsProv.getLabResult(widget.labOrders);
|
||||
// getLabResultOrders(context);
|
||||
}
|
||||
_isInit = false;
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return AppScaffold(
|
||||
appBarTitle: "Lab Orders",
|
||||
showAppDrawer: false,
|
||||
showBottomBar: false,
|
||||
body: patientsProv.isLoading
|
||||
? DrAppCircularProgressIndeicator()
|
||||
: patientsProv.isError
|
||||
? DrAppEmbeddedError(error: patientsProv.error)
|
||||
: patientsProv.labResultList.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(
|
||||
children: <Widget>[
|
||||
CardWithBgWidgetNew(
|
||||
widget: Row(
|
||||
mainAxisAlignment:
|
||||
MainAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
' Invoice No :',
|
||||
fontSize:
|
||||
2 * SizeConfig.textMultiplier,
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
AppText(
|
||||
' ${widget.labOrders.invoiceNo}',
|
||||
fontSize:
|
||||
2 * SizeConfig.textMultiplier,
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
CardWithBgWidgetNew(widget: LabResultWidget(labResult: patientsProv.labResultList,))
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -1,143 +1,180 @@
|
||||
import 'package:charts_flutter/flutter.dart' as charts;
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/lookups/patient_lookup.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/vital_sign_res_model.dart';
|
||||
import 'package:doctor_app_flutter/providers/patients_provider.dart';
|
||||
import 'package:doctor_app_flutter/screens/patients/profile/vital_sign/vital_ding_chart_and_detials.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/charts/app_time_series_chart.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/rounded_container_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class BodyMeasurementsScreen extends StatelessWidget {
|
||||
BodyMeasurementsScreen();
|
||||
List<VitalSignResModel> vitalList;
|
||||
// ;
|
||||
PatientsProvider patientsProv;
|
||||
List<VitalSignResModel> vitalList = [];
|
||||
String pageTitle;
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
_seriesData = List<charts.Series<Pollution, String>>();
|
||||
_seriesPieData = List<charts.Series<Task, String>>();
|
||||
_seriesLineData = List<charts.Series<Sales, int>>();
|
||||
_generateData();
|
||||
return AppScaffold(
|
||||
appBarTitle: 'Body Measurements',
|
||||
body: RoundedContainer(
|
||||
height: SizeConfig.realScreenHeight*0.4,
|
||||
child: Padding(
|
||||
padding: EdgeInsets.all(8.0),
|
||||
child: Container(
|
||||
child: Center(
|
||||
child: Column(
|
||||
children: <Widget>[
|
||||
Text(
|
||||
'Body Mass Index',
|
||||
style: TextStyle(
|
||||
fontSize: 24.0, fontWeight: FontWeight.bold),
|
||||
),
|
||||
Expanded(
|
||||
child: charts.BarChart(
|
||||
_seriesData,
|
||||
animate: true,
|
||||
barGroupingType: charts.BarGroupingType.grouped,
|
||||
// behaviors: [new charts.SeriesLegend()],
|
||||
// primaryMeasureAxis: ,
|
||||
animationDuration: Duration(seconds: 1),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
patientsProv = Provider.of<PatientsProvider>(context);
|
||||
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||
pageTitle = routeArgs['title'];
|
||||
var pageKey = routeArgs['key'];
|
||||
List<Map> VSchart;
|
||||
vitalList = patientsProv.patientVitalSignOrderdSubList;
|
||||
switch (pageKey) {
|
||||
case vitalSignDetails.bodyMeasurements:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'Highet',
|
||||
'title1': 'Date',
|
||||
'title2': 'Cm',
|
||||
'viewKey': 'HeightCm',
|
||||
},
|
||||
{
|
||||
'name': 'Weight Kg',
|
||||
'title1': 'Date',
|
||||
'title2': 'Kg',
|
||||
'viewKey': 'WeightKg',
|
||||
},
|
||||
{
|
||||
'name': 'BodyMassIndex',
|
||||
'title1': 'Date',
|
||||
'title2': 'BodyMass',
|
||||
'viewKey': 'BodyMassIndex',
|
||||
},
|
||||
{
|
||||
'name': 'HeadCircumCm',
|
||||
'title1': 'Date',
|
||||
'title2': 'Cm',
|
||||
'viewKey': 'HeadCircumCm',
|
||||
},
|
||||
{
|
||||
'name': 'Ideal Body Weight (Lbs)',
|
||||
'title1': 'Date',
|
||||
'title2': 'Ideal Weight',
|
||||
'viewKey': 'IdealBodyWeightLbs',
|
||||
},
|
||||
{
|
||||
'name': 'LeanBodyWeightLbs (Lbs)',
|
||||
'title1': 'Date',
|
||||
'title2': 'Lean Weight',
|
||||
'viewKey': 'LeanBodyWeightLbs',
|
||||
}
|
||||
];
|
||||
|
||||
List<charts.Series<Pollution, String>> _seriesData;
|
||||
List<charts.Series<Task, String>> _seriesPieData;
|
||||
List<charts.Series<Sales, int>> _seriesLineData;
|
||||
break;
|
||||
|
||||
_generateData() {
|
||||
var data1 = [
|
||||
new Pollution(1980, 'USA', 40),
|
||||
];
|
||||
|
||||
case vitalSignDetails.temperature:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'Temperature In Celcius',
|
||||
'title1': 'Date',
|
||||
'title2': 'C',
|
||||
'viewKey': 'TemperatureCelcius',
|
||||
},
|
||||
];
|
||||
|
||||
_seriesData.add(
|
||||
charts.Series(
|
||||
domainFn: (Pollution pollution, _) => '',
|
||||
measureFn: (Pollution pollution, _) => pollution.quantity,
|
||||
id: '2017',
|
||||
data: data1,
|
||||
fillPatternFn: (_, __) => charts.FillPatternType.solid,
|
||||
fillColorFn: (Pollution pollution, _) =>
|
||||
charts.ColorUtil.fromDartColor(Color(0xff990099)),
|
||||
),
|
||||
);
|
||||
_seriesData.add(
|
||||
charts.Series(
|
||||
domainFn: (Pollution pollution, _) => '',
|
||||
measureFn: (Pollution pollution, _) => pollution.quantity,
|
||||
id: '2017',
|
||||
data: data1,
|
||||
fillPatternFn: (_, __) => charts.FillPatternType.solid,
|
||||
fillColorFn: (Pollution pollution, _) =>
|
||||
charts.ColorUtil.fromDartColor(Color(0xff990099)),
|
||||
),
|
||||
);
|
||||
_seriesData.add(
|
||||
charts.Series(
|
||||
domainFn: (Pollution pollution, _) => '',
|
||||
measureFn: (Pollution pollution, _) => pollution.quantity,
|
||||
id: '2017',
|
||||
data: data1,
|
||||
fillPatternFn: (_, __) => charts.FillPatternType.solid,
|
||||
fillColorFn: (Pollution pollution, _) =>
|
||||
charts.ColorUtil.fromDartColor(Color(0xff990099)),
|
||||
),
|
||||
);
|
||||
_seriesData.add(
|
||||
charts.Series(
|
||||
domainFn: (Pollution pollution, _) => '',
|
||||
measureFn: (Pollution pollution, _) => pollution.quantity,
|
||||
id: '2017',
|
||||
data: data1,
|
||||
fillPatternFn: (_, __) => charts.FillPatternType.solid,
|
||||
fillColorFn: (Pollution pollution, _) =>
|
||||
charts.ColorUtil.fromDartColor(Color(0xff990099)),
|
||||
),
|
||||
);
|
||||
_seriesData.add(
|
||||
charts.Series(
|
||||
domainFn: (Pollution pollution, _) => '',
|
||||
measureFn: (Pollution pollution, _) => pollution.quantity,
|
||||
id: '2017',
|
||||
data: data1,
|
||||
fillPatternFn: (_, __) => charts.FillPatternType.solid,
|
||||
fillColorFn: (Pollution pollution, _) =>
|
||||
charts.ColorUtil.fromDartColor(Color(0xff990099)),
|
||||
),
|
||||
);
|
||||
|
||||
break;
|
||||
case vitalSignDetails.pulse:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'Pulse Beat Per Minute',
|
||||
'title1': 'Date',
|
||||
'title2': 'Minute',
|
||||
'viewKey': 'PulseBeatPerMinute',
|
||||
},
|
||||
];
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
break;
|
||||
case vitalSignDetails.pespiration:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'Respiration Beat Per Minute',
|
||||
'title1': 'Date',
|
||||
'title2': 'Beat Per Minute',
|
||||
'viewKey': 'RespirationBeatPerMinute',
|
||||
},
|
||||
];
|
||||
|
||||
break;
|
||||
case vitalSignDetails.bloodPressure:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'Blood Pressure Higher',
|
||||
'title1': 'Date',
|
||||
'title2': 'Minute',
|
||||
'viewKey': 'BloodPressureHigher',
|
||||
},
|
||||
{
|
||||
'name': 'Blood Pressure Lower',
|
||||
'title1': 'Date',
|
||||
'title2': 'Minute',
|
||||
'viewKey': 'BloodPressureLower',
|
||||
}
|
||||
];
|
||||
|
||||
break;
|
||||
case vitalSignDetails.oxygenation:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'FIO2',
|
||||
'title1': 'Date',
|
||||
'title2': 'Cm',
|
||||
'viewKey': 'FIO2',
|
||||
},
|
||||
{
|
||||
'name': 'SAO2',
|
||||
'title1': 'Date',
|
||||
'title2': 'Cm',
|
||||
'viewKey': 'SAO2',
|
||||
},
|
||||
];
|
||||
|
||||
class Pollution {
|
||||
String place;
|
||||
int year;
|
||||
int quantity;
|
||||
break;
|
||||
case vitalSignDetails.painScale:
|
||||
VSchart = [
|
||||
{
|
||||
'name': 'PainScore',
|
||||
'title1': 'Date',
|
||||
'title2': 'Cm',
|
||||
'viewKey': 'PainScore',
|
||||
},
|
||||
];
|
||||
|
||||
Pollution(this.year, this.place, this.quantity);
|
||||
break;
|
||||
|
||||
default:
|
||||
}
|
||||
// generateData();
|
||||
return AppScaffold(
|
||||
appBarTitle: pageTitle,
|
||||
body: ListView(
|
||||
children: VSchart.map((chartInfo) {
|
||||
var vitalListTemp = vitalList.where((element) => element.toJson()[chartInfo['viewKey']] != null,);
|
||||
return vitalListTemp.length !=0 ? VitalSingChartAndDetials(
|
||||
vitalList: vitalList,
|
||||
name: chartInfo['name'],
|
||||
title1: chartInfo['title1'],
|
||||
title2: chartInfo['title2'],
|
||||
viewKey: chartInfo['viewKey']) : Container();
|
||||
}).toList(),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
class Task {
|
||||
String task;
|
||||
double taskvalue;
|
||||
Color colorval;
|
||||
class LinearSales {
|
||||
final int year;
|
||||
final int sales;
|
||||
|
||||
Task(this.task, this.taskvalue, this.colorval);
|
||||
LinearSales(this.year, this.sales);
|
||||
}
|
||||
|
||||
class Sales {
|
||||
int yearval;
|
||||
int salesval;
|
||||
/// Sample time series data type.
|
||||
class TimeSeriesSales {
|
||||
final DateTime time;
|
||||
final int sales;
|
||||
|
||||
Sales(this.yearval, this.salesval);
|
||||
TimeSeriesSales(this.time, this.sales);
|
||||
}
|
||||
|
||||
@ -0,0 +1,39 @@
|
||||
import 'package:doctor_app_flutter/models/patient/vital_sign_res_model.dart';
|
||||
import 'package:doctor_app_flutter/widgets/patients/vital_sign_details_wideget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/charts/app_time_series_chart.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
class VitalSingChartAndDetials extends StatelessWidget {
|
||||
VitalSingChartAndDetials({
|
||||
Key key,
|
||||
@required this.vitalList,
|
||||
@required this.name,
|
||||
@required this.viewKey,
|
||||
@required this.title1,
|
||||
@required this.title2,
|
||||
}) : super(key: key);
|
||||
|
||||
final List<VitalSignResModel> vitalList ;
|
||||
final String name;
|
||||
final String viewKey;
|
||||
final String title1;
|
||||
final String title2;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Column(
|
||||
children: <Widget>[
|
||||
AppTimeSeriesChart(
|
||||
vitalList: vitalList,
|
||||
chartName: name,
|
||||
viewKey: viewKey,
|
||||
),
|
||||
VitalSignDetailsWidget(
|
||||
vitalList: vitalList.reversed.toList(),
|
||||
title1: '${title1}',
|
||||
title2: '${title2}',
|
||||
viewKey: '${viewKey}',
|
||||
),
|
||||
],
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,174 @@
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/lab_result.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/card_with_bgNew_widget.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:hexcolor/hexcolor.dart';
|
||||
|
||||
class LabResultWidget extends StatefulWidget {
|
||||
final List<LabResult> labResult;
|
||||
|
||||
LabResultWidget({Key key, this.labResult});
|
||||
|
||||
@override
|
||||
_LabResultWidgetState createState() => _LabResultWidgetState();
|
||||
}
|
||||
|
||||
class _LabResultWidgetState extends State<LabResultWidget> {
|
||||
bool _showDetails = true;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Container(
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceAround,
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
AppText(
|
||||
'General Result',
|
||||
fontSize: 2.5 * SizeConfig.textMultiplier,
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
InkWell(
|
||||
onTap: () {
|
||||
setState(() {
|
||||
_showDetails = !_showDetails;
|
||||
});
|
||||
},
|
||||
child: Icon(_showDetails
|
||||
? Icons.keyboard_arrow_up
|
||||
: Icons.keyboard_arrow_down)),
|
||||
],
|
||||
),
|
||||
Divider(
|
||||
color: Colors.grey,
|
||||
height: 0.5,
|
||||
),
|
||||
!_showDetails
|
||||
? Container()
|
||||
: AnimatedContainer(
|
||||
duration: Duration(microseconds: 200),
|
||||
child: Container(
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.all(Radius.circular(10)),
|
||||
|
||||
),
|
||||
child: Column(
|
||||
children: widget.labResult.map((result) {
|
||||
return Container(
|
||||
decoration: BoxDecoration(
|
||||
borderRadius:
|
||||
BorderRadius.all(Radius.circular(10)),
|
||||
border: Border(
|
||||
bottom: BorderSide(
|
||||
color: Colors.grey, width: 0.5),
|
||||
top: BorderSide(
|
||||
color: Colors.grey, width: 0.5),
|
||||
left: BorderSide(
|
||||
color: Colors.grey, width: 0.5),
|
||||
right: BorderSide(
|
||||
color: Colors.grey, width: 0.5),
|
||||
),
|
||||
),
|
||||
margin: EdgeInsets.only(top: 10),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
color: Hexcolor('#515B5D'),
|
||||
borderRadius: BorderRadius.only(
|
||||
topLeft: Radius.circular(10.0),
|
||||
),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'Description',
|
||||
color: Colors.white,
|
||||
),
|
||||
),
|
||||
height: 60,
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
color: Hexcolor('#515B5D'),
|
||||
child: Center(
|
||||
child: Texts('Value', color: Colors.white),
|
||||
),
|
||||
height: 60),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
color: Hexcolor('#515B5D'),
|
||||
borderRadius: BorderRadius.only(
|
||||
topRight: Radius.circular(10.0),
|
||||
),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts('Range', color: Colors.white),
|
||||
),
|
||||
height: 60),
|
||||
),
|
||||
],
|
||||
),
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.only(
|
||||
bottomLeft: Radius.circular(10.0),
|
||||
),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'${result.description}',
|
||||
color: Colors.grey[800],
|
||||
),
|
||||
),
|
||||
height: 60,
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'${result.resultValue}',
|
||||
color: Colors.grey[800]),
|
||||
),
|
||||
height: 60),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'${result.referenceRange}',
|
||||
color: Colors.grey[800]),
|
||||
),
|
||||
height: 60),
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
);
|
||||
}).toList(),
|
||||
),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,118 @@
|
||||
import 'package:doctor_app_flutter/models/patient/vital_sign_res_model.dart';
|
||||
import 'package:doctor_app_flutter/util/helpers.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:hexcolor/hexcolor.dart';
|
||||
|
||||
class VitalSignDetailsWidget extends StatefulWidget {
|
||||
final List<VitalSignResModel> vitalList;
|
||||
final String title1;
|
||||
final String title2;
|
||||
final String viewKey;
|
||||
|
||||
VitalSignDetailsWidget({Key key, this.vitalList, this.title1, this.title2,this.viewKey});
|
||||
|
||||
@override
|
||||
_VitalSignDetailsWidgetState createState() => _VitalSignDetailsWidgetState();
|
||||
}
|
||||
|
||||
class _VitalSignDetailsWidgetState extends State<VitalSignDetailsWidget> {
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Container(
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.transparent,
|
||||
borderRadius: BorderRadius.only(
|
||||
topLeft: Radius.circular(10.0),
|
||||
),
|
||||
),
|
||||
margin: EdgeInsets.all(20),
|
||||
child: Container(
|
||||
color: Colors.transparent,
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
color: Hexcolor('#515B5D'),
|
||||
borderRadius: BorderRadius.only(
|
||||
topLeft: Radius.circular(10.0),
|
||||
),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts(
|
||||
widget.title1,
|
||||
color: Colors.white,
|
||||
),
|
||||
),
|
||||
height: 60,
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
decoration: BoxDecoration(
|
||||
color: Hexcolor('#515B5D'),
|
||||
borderRadius: BorderRadius.only(
|
||||
topRight: Radius.circular(10.0),
|
||||
),
|
||||
),
|
||||
child: Center(
|
||||
child: Texts(widget.title2, color: Colors.white),
|
||||
),
|
||||
height: 60),
|
||||
),
|
||||
],
|
||||
),
|
||||
Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: widget.vitalList.map((vital) {
|
||||
return Column(
|
||||
children: <Widget>[
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Container(
|
||||
height: 50,
|
||||
color: Colors.white,
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'${Helpers.getWeekDay(vital.vitalSignDate.weekday)}, ${vital.vitalSignDate.day} ${Helpers.getMonth(vital.vitalSignDate.month)}, ${vital.vitalSignDate.year} ',
|
||||
textAlign: TextAlign.center,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(
|
||||
width: 2,
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
height: 50,
|
||||
color: Colors.white,
|
||||
child: Center(
|
||||
child: Texts(
|
||||
'${vital.toJson()[widget.viewKey]}',
|
||||
textAlign: TextAlign.center,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
SizedBox(
|
||||
height: 2,
|
||||
),
|
||||
],
|
||||
);
|
||||
}).toList(),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,34 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:charts_flutter/flutter.dart' as charts;
|
||||
|
||||
class AppLineChart extends StatelessWidget {
|
||||
const AppLineChart({
|
||||
Key key,
|
||||
@required this.seriesList,
|
||||
this.chartTitle,
|
||||
}) : super(key: key);
|
||||
|
||||
final List<charts.Series> seriesList;
|
||||
|
||||
final String chartTitle;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Container(
|
||||
child: Column(
|
||||
children: <Widget>[
|
||||
Text(
|
||||
'Body Mass Index',
|
||||
style: TextStyle(fontSize: 24.0, fontWeight: FontWeight.bold),
|
||||
),
|
||||
Expanded(
|
||||
child: charts.LineChart(seriesList,
|
||||
defaultRenderer: new charts.LineRendererConfig(
|
||||
includeArea: false, stacked: true),
|
||||
animate: true),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,93 @@
|
||||
import 'package:charts_flutter/flutter.dart' as charts;
|
||||
import 'package:doctor_app_flutter/config/size_config.dart';
|
||||
import 'package:doctor_app_flutter/models/patient/vital_sign_res_model.dart';
|
||||
import 'package:doctor_app_flutter/screens/patients/profile/vital_sign/body_measurements_screen.dart';
|
||||
import 'package:doctor_app_flutter/widgets/shared/rounded_container_widget.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class AppTimeSeriesChart extends StatelessWidget {
|
||||
AppTimeSeriesChart(
|
||||
{Key key,
|
||||
@required this.vitalList,
|
||||
@required this.viewKey,
|
||||
this.chartName = ''});
|
||||
|
||||
final List<VitalSignResModel> vitalList;
|
||||
final String chartName;
|
||||
final String viewKey;
|
||||
List<charts.Series> seriesList;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
seriesList = generateData();
|
||||
return RoundedContainer(
|
||||
height: SizeConfig.realScreenHeight * 0.47,
|
||||
child: Column(
|
||||
children: <Widget>[
|
||||
Text(
|
||||
chartName,
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.bold,
|
||||
fontSize: SizeConfig.textMultiplier * 3),
|
||||
),
|
||||
Container(
|
||||
height: SizeConfig.realScreenHeight * 0.37,
|
||||
child: Center(
|
||||
child: Expanded(
|
||||
child: charts.TimeSeriesChart(
|
||||
seriesList,
|
||||
animate: true,
|
||||
behaviors: [
|
||||
new charts.RangeAnnotation(
|
||||
[
|
||||
new charts.RangeAnnotationSegment(
|
||||
DateTime(
|
||||
vitalList[vitalList.length - 1]
|
||||
.vitalSignDate
|
||||
.year,
|
||||
vitalList[vitalList.length - 1]
|
||||
.vitalSignDate
|
||||
.month +
|
||||
3,
|
||||
vitalList[vitalList.length - 1]
|
||||
.vitalSignDate
|
||||
.day),
|
||||
vitalList[0].vitalSignDate,
|
||||
charts.RangeAnnotationAxisType.domain),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
generateData() {
|
||||
final List<TimeSeriesSales> data = [];
|
||||
if (vitalList.length > 0) {
|
||||
vitalList.forEach(
|
||||
(element) {
|
||||
data.add(
|
||||
TimeSeriesSales(
|
||||
new DateTime(element.vitalSignDate.year,
|
||||
element.vitalSignDate.month, element.vitalSignDate.day),
|
||||
element.toJson()[viewKey].toInt(),
|
||||
),
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
return [
|
||||
new charts.Series<TimeSeriesSales, DateTime>(
|
||||
id: 'Sales',
|
||||
domainFn: (TimeSeriesSales sales, _) => sales.time,
|
||||
measureFn: (TimeSeriesSales sales, _) => sales.sales,
|
||||
data: data,
|
||||
)
|
||||
];
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue