Merge branch 'development' into feature_admission_request
# Conflicts: # lib/routes.dartmerge-requests/210/head
commit
095a915a89
@ -0,0 +1,60 @@
|
|||||||
|
class GetChiefComplaintResModel {
|
||||||
|
int appointmentNo;
|
||||||
|
String ccdate;
|
||||||
|
String chiefComplaint;
|
||||||
|
String clinicDescription;
|
||||||
|
int clinicID;
|
||||||
|
String currentMedication;
|
||||||
|
int doctorID;
|
||||||
|
String doctorName;
|
||||||
|
int episodeId;
|
||||||
|
String hopi;
|
||||||
|
int patientMRN;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
GetChiefComplaintResModel(
|
||||||
|
{this.appointmentNo,
|
||||||
|
this.ccdate,
|
||||||
|
this.chiefComplaint,
|
||||||
|
this.clinicDescription,
|
||||||
|
this.clinicID,
|
||||||
|
this.currentMedication,
|
||||||
|
this.doctorID,
|
||||||
|
this.doctorName,
|
||||||
|
this.episodeId,
|
||||||
|
this.hopi,
|
||||||
|
this.patientMRN,
|
||||||
|
this.status});
|
||||||
|
|
||||||
|
GetChiefComplaintResModel.fromJson(Map<String, dynamic> json) {
|
||||||
|
appointmentNo = json['appointmentNo'];
|
||||||
|
ccdate = json['ccdate'];
|
||||||
|
chiefComplaint = json['chiefComplaint'];
|
||||||
|
clinicDescription = json['clinicDescription'];
|
||||||
|
clinicID = json['clinicID'];
|
||||||
|
currentMedication = json['currentMedication'];
|
||||||
|
doctorID = json['doctorID'];
|
||||||
|
doctorName = json['doctorName'];
|
||||||
|
episodeId = json['episodeId'];
|
||||||
|
hopi = json['hopi'];
|
||||||
|
patientMRN = json['patientMRN'];
|
||||||
|
status = json['status'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
|
data['appointmentNo'] = this.appointmentNo;
|
||||||
|
data['ccdate'] = this.ccdate;
|
||||||
|
data['chiefComplaint'] = this.chiefComplaint;
|
||||||
|
data['clinicDescription'] = this.clinicDescription;
|
||||||
|
data['clinicID'] = this.clinicID;
|
||||||
|
data['currentMedication'] = this.currentMedication;
|
||||||
|
data['doctorID'] = this.doctorID;
|
||||||
|
data['doctorName'] = this.doctorName;
|
||||||
|
data['episodeId'] = this.episodeId;
|
||||||
|
data['hopi'] = this.hopi;
|
||||||
|
data['patientMRN'] = this.patientMRN;
|
||||||
|
data['status'] = this.status;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,25 @@
|
|||||||
|
class GeneralGetReqForSOAP {
|
||||||
|
int patientMRN;
|
||||||
|
int appointmentNo;
|
||||||
|
int episodeId;
|
||||||
|
String doctorID;
|
||||||
|
|
||||||
|
GeneralGetReqForSOAP(
|
||||||
|
{this.patientMRN, this.appointmentNo, this.episodeId, this.doctorID});
|
||||||
|
|
||||||
|
GeneralGetReqForSOAP.fromJson(Map<String, dynamic> json) {
|
||||||
|
patientMRN = json['PatientMRN'];
|
||||||
|
appointmentNo = json['AppointmentNo'];
|
||||||
|
episodeId = json['EpisodeId'];
|
||||||
|
doctorID = json['DoctorID'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
|
data['PatientMRN'] = this.patientMRN;
|
||||||
|
data['AppointmentNo'] = this.appointmentNo;
|
||||||
|
data['EpisodeId'] = this.episodeId;
|
||||||
|
data['DoctorID'] = this.doctorID;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,148 @@
|
|||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/model/procedure/categories_procedure.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/procedure_View_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
class EntityListCheckboxSearchWidget extends StatefulWidget {
|
||||||
|
final ProcedureViewModel model;
|
||||||
|
final Function addSelectedHistories;
|
||||||
|
final Function(EntityList) removeHistory;
|
||||||
|
final Function(EntityList) addHistory;
|
||||||
|
final bool Function(EntityList) isEntityListSelected;
|
||||||
|
final List<EntityList> masterList;
|
||||||
|
|
||||||
|
EntityListCheckboxSearchWidget(
|
||||||
|
{Key key,
|
||||||
|
this.model,
|
||||||
|
this.addSelectedHistories,
|
||||||
|
this.removeHistory,
|
||||||
|
this.masterList,
|
||||||
|
this.addHistory,
|
||||||
|
this.isEntityListSelected})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_EntityListCheckboxSearchWidgetState createState() => _EntityListCheckboxSearchWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _EntityListCheckboxSearchWidgetState extends State<EntityListCheckboxSearchWidget> {
|
||||||
|
List<EntityList> items = List();
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
items.addAll(widget.masterList);
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Container(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
NetworkBaseView(
|
||||||
|
baseViewModel: widget.model,
|
||||||
|
child: Container(
|
||||||
|
height: MediaQuery.of(context).size.height * 0.5,
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
margin: EdgeInsets.only(top: 15),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(12),
|
||||||
|
color: Colors.white),
|
||||||
|
child: ListView(
|
||||||
|
children: [
|
||||||
|
TextFields(
|
||||||
|
hintText: 'Search ',
|
||||||
|
suffixIcon: EvaIcons.search,
|
||||||
|
onChanged: (value) {
|
||||||
|
filterSearchResults(value);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
SizedBox(height: 15,),
|
||||||
|
Column(
|
||||||
|
children: items.map((historyInfo) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Checkbox(
|
||||||
|
value:
|
||||||
|
widget.isEntityListSelected(historyInfo),
|
||||||
|
activeColor: Colors.red[800],
|
||||||
|
onChanged: (bool newValue) {
|
||||||
|
setState(() {
|
||||||
|
if (widget
|
||||||
|
.isEntityListSelected(historyInfo)) {
|
||||||
|
widget.removeHistory(historyInfo);
|
||||||
|
} else {
|
||||||
|
widget.addHistory(historyInfo);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
Expanded(
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(
|
||||||
|
horizontal: 10, vertical: 0),
|
||||||
|
child: Texts(historyInfo.procedureName,
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color: Colors.black),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
if (widget.model.state == ViewState.Idle)
|
||||||
|
AppButton(//TODO change the button name
|
||||||
|
title: "Add ".toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
widget.addSelectedHistories();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void filterSearchResults(String query) {
|
||||||
|
List<EntityList> dummySearchList = List();
|
||||||
|
dummySearchList.addAll(widget.masterList);
|
||||||
|
if (query.isNotEmpty) {
|
||||||
|
List<EntityList> dummyListData = List();
|
||||||
|
dummySearchList.forEach((item) {
|
||||||
|
if (item.procedureName.toLowerCase().contains(query.toLowerCase()) ) {
|
||||||
|
dummyListData.add(item);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
setState(() {
|
||||||
|
items.clear();
|
||||||
|
items.addAll(dummyListData);
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
setState(() {
|
||||||
|
items.clear();
|
||||||
|
items.addAll(widget.masterList);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,343 @@
|
|||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
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/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_allergy.dart';
|
||||||
|
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||||
|
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_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/dialogs/master_key_dailog.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
|
||||||
|
class UpdateAllergiesWidget extends StatefulWidget {
|
||||||
|
final List<MySelectedAllergy> myAllergiesList;
|
||||||
|
|
||||||
|
UpdateAllergiesWidget({Key key, this.myAllergiesList});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_UpdateAllergiesWidgetState createState() => _UpdateAllergiesWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateAllergiesWidgetState extends State<UpdateAllergiesWidget> {
|
||||||
|
|
||||||
|
TextEditingController remarkController = TextEditingController();
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery.of(context).size;
|
||||||
|
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add Allergies",
|
||||||
|
fontSize: 13.5,
|
||||||
|
onTapTextFields: () {
|
||||||
|
openAllergiesList(context);
|
||||||
|
},
|
||||||
|
readOnly: true,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
suffixIcon: EvaIcons.plusCircleOutline,
|
||||||
|
suffixIconColor: AppGlobal.appPrimaryColor,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
// controller: messageController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 15, right: 15, top: 15),
|
||||||
|
child: Column(
|
||||||
|
children: widget.myAllergiesList.map((selectedAllergy) {
|
||||||
|
return Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Texts(selectedAllergy.selectedAllergy.nameEn.toUpperCase(),
|
||||||
|
variant: "bodyText", bold: true, color: Colors.black),
|
||||||
|
Texts(
|
||||||
|
selectedAllergy.selectedAllergySeverity.nameEn
|
||||||
|
.toUpperCase(),
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color: AppGlobal.appPrimaryColor),
|
||||||
|
InkWell(
|
||||||
|
child: Icon(
|
||||||
|
FontAwesomeIcons.trash,
|
||||||
|
color: Colors.grey,
|
||||||
|
size: 20,
|
||||||
|
),
|
||||||
|
onTap: () => removeAllergy(selectedAllergy),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList()),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
removeAllergy(MySelectedAllergy mySelectedAllergy) {
|
||||||
|
Iterable<MySelectedAllergy> allergy =
|
||||||
|
widget.myAllergiesList.where((element) => mySelectedAllergy == element);
|
||||||
|
|
||||||
|
if (allergy.length > 0)
|
||||||
|
setState(() {
|
||||||
|
widget.myAllergiesList.remove(allergy.first);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
openAllergiesList(BuildContext context) {
|
||||||
|
showModalBottomSheet(
|
||||||
|
backgroundColor: Colors.white,
|
||||||
|
isScrollControlled: true,
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return AddAllergies(
|
||||||
|
addAllergiesFun: (MySelectedAllergy mySelectedAllergy) {
|
||||||
|
setState(() {
|
||||||
|
widget.myAllergiesList.add(mySelectedAllergy);
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
});
|
||||||
|
},);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class AddAllergies extends StatefulWidget {
|
||||||
|
final Function addAllergiesFun;
|
||||||
|
|
||||||
|
const AddAllergies({Key key, this.addAllergiesFun}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_AddAllergiesState createState() => _AddAllergiesState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _AddAllergiesState extends State<AddAllergies> {
|
||||||
|
List<MasterKeyModel> allergiesList;
|
||||||
|
List<MasterKeyModel> allergySeverityList;
|
||||||
|
MasterKeyModel _selectedAllergySeverity;
|
||||||
|
MasterKeyModel _selectedAllergy;
|
||||||
|
TextEditingController remarkController = TextEditingController();
|
||||||
|
|
||||||
|
|
||||||
|
InputDecoration textFieldSelectorDecoration(String hintText,
|
||||||
|
String selectedText, bool isDropDown) {
|
||||||
|
return InputDecoration(
|
||||||
|
focusedBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
enabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
disabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
hintText: selectedText != null ? selectedText : hintText,
|
||||||
|
suffixIcon: isDropDown ? Icon(Icons.arrow_drop_down) : null,
|
||||||
|
hintStyle: TextStyle(
|
||||||
|
fontSize: 14,
|
||||||
|
color: Colors.grey.shade600,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery
|
||||||
|
.of(context)
|
||||||
|
.size;
|
||||||
|
return FractionallySizedBox(
|
||||||
|
heightFactor: 0.7,
|
||||||
|
child: BaseView<SOAPViewModel>(
|
||||||
|
onModelReady: (model) async {
|
||||||
|
if (model.allergiesList.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.Allergies);
|
||||||
|
}
|
||||||
|
if (model.allergySeverityList.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.AllergySeverity);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
builder: (_, model, w) =>
|
||||||
|
AppScaffold(
|
||||||
|
baseViewModel: model,
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
child: Center(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Add Allergy",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
child: InkWell(
|
||||||
|
onTap: model.allergiesList != null
|
||||||
|
? () {
|
||||||
|
MasterKeyDailog dialog = MasterKeyDailog(
|
||||||
|
list: model.allergiesList,
|
||||||
|
okText: TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.ok,
|
||||||
|
okFunction: (MasterKeyModel selectedValue) {
|
||||||
|
setState(() {
|
||||||
|
_selectedAllergy = selectedValue;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
);
|
||||||
|
showDialog(
|
||||||
|
barrierDismissible: false,
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return dialog;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
child: TextField(
|
||||||
|
decoration: textFieldSelectorDecoration(
|
||||||
|
"Select Allergy",
|
||||||
|
_selectedAllergy != null
|
||||||
|
? _selectedAllergy.nameEn
|
||||||
|
: null,
|
||||||
|
true),
|
||||||
|
enabled: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
), Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
child: InkWell(
|
||||||
|
onTap: model.allergySeverityList != null
|
||||||
|
? () {
|
||||||
|
MasterKeyDailog dialog = MasterKeyDailog(
|
||||||
|
list: model.allergySeverityList,
|
||||||
|
okText: TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.ok,
|
||||||
|
okFunction: (selectedValue) {
|
||||||
|
setState(() {
|
||||||
|
_selectedAllergySeverity =
|
||||||
|
selectedValue;
|
||||||
|
// model.getDoctorBranch().then((value) {
|
||||||
|
// _selectedBranch = value;
|
||||||
|
// if (_referTo['id'] == 1) {
|
||||||
|
// model.getClinics(
|
||||||
|
// _selectedBranch['ID']);
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
});
|
||||||
|
},
|
||||||
|
);
|
||||||
|
showDialog(
|
||||||
|
barrierDismissible: false,
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return dialog;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
child: TextField(
|
||||||
|
decoration: textFieldSelectorDecoration(
|
||||||
|
"Select Severity",
|
||||||
|
_selectedAllergySeverity != null
|
||||||
|
? _selectedAllergySeverity.nameEn
|
||||||
|
: null,
|
||||||
|
true),
|
||||||
|
enabled: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left: 0, right: 0, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Remarks",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
maxLines: 25,
|
||||||
|
minLines: 13,
|
||||||
|
controller: remarkController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
), SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
AppButton(
|
||||||
|
title: "Add".toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
MySelectedAllergy mySelectedAllergy = new MySelectedAllergy(
|
||||||
|
remark: remarkController.text,
|
||||||
|
selectedAllergy: _selectedAllergy,
|
||||||
|
selectedAllergySeverity: _selectedAllergySeverity);
|
||||||
|
widget.addAllergiesFun(mySelectedAllergy);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,574 @@
|
|||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/master_lookup_key.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
||||||
|
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
import 'package:hexcolor/hexcolor.dart';
|
||||||
|
|
||||||
|
class UpdateHistoryWidget extends StatefulWidget {
|
||||||
|
final List<MasterKeyModel> myHistoryList;
|
||||||
|
|
||||||
|
const UpdateHistoryWidget({Key key, this.myHistoryList}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_UpdateHistoryWidgetState createState() => _UpdateHistoryWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateHistoryWidgetState extends State<UpdateHistoryWidget>
|
||||||
|
with TickerProviderStateMixin {
|
||||||
|
PageController _controller;
|
||||||
|
int _currentIndex = 0;
|
||||||
|
|
||||||
|
changePageViewIndex(pageIndex) {
|
||||||
|
_controller.jumpToPage(pageIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
_controller = new PageController();
|
||||||
|
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add History",
|
||||||
|
fontSize: 13.5,
|
||||||
|
onTapTextFields: () {
|
||||||
|
openHistoryList(context);
|
||||||
|
},
|
||||||
|
readOnly: true,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
suffixIcon: EvaIcons.plusCircleOutline,
|
||||||
|
suffixIconColor: AppGlobal.appPrimaryColor,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
// controller: messageController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 15, right: 15, top: 15),
|
||||||
|
child: Column(
|
||||||
|
children: widget.myHistoryList.map((myHistory) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Texts(myHistory.nameEn,
|
||||||
|
variant: "bodyText", bold: true, color: Colors.black),
|
||||||
|
InkWell(
|
||||||
|
child: Icon(
|
||||||
|
FontAwesomeIcons.trash,
|
||||||
|
color: Colors.grey,
|
||||||
|
size: 20,
|
||||||
|
),
|
||||||
|
onTap: () => removeHistory(myHistory),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
removeHistory(MasterKeyModel masterKey) {
|
||||||
|
Iterable<MasterKeyModel> history = widget.myHistoryList.where((element) =>
|
||||||
|
masterKey.id == element.id && masterKey.typeId == element.typeId);
|
||||||
|
|
||||||
|
if (history.length > 0)
|
||||||
|
setState(() {
|
||||||
|
widget.myHistoryList.remove(history.first);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
openHistoryList(BuildContext context) {
|
||||||
|
showModalBottomSheet(
|
||||||
|
backgroundColor: Colors.white,
|
||||||
|
isScrollControlled: true,
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return AddHistoryDialog(
|
||||||
|
changePageViewIndex: changePageViewIndex,
|
||||||
|
controller: _controller,
|
||||||
|
myHistoryList: widget.myHistoryList,
|
||||||
|
addSelectedHistories: () {
|
||||||
|
setState(() {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
removeHistory: (masterKey) => removeHistory(masterKey),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class PriorityBar extends StatefulWidget {
|
||||||
|
final Function onTap;
|
||||||
|
|
||||||
|
const PriorityBar({Key key, this.onTap}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_PriorityBarState createState() => _PriorityBarState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _PriorityBarState extends State<PriorityBar> {
|
||||||
|
int _activePriority = 0;
|
||||||
|
|
||||||
|
List<String> _priorities = [
|
||||||
|
"Family",
|
||||||
|
"Surgical/Sports",
|
||||||
|
"Medical",
|
||||||
|
];
|
||||||
|
|
||||||
|
BoxDecoration containerBorderDecoration(
|
||||||
|
Color containerColor, Color borderColor) {
|
||||||
|
return BoxDecoration(
|
||||||
|
color: containerColor,
|
||||||
|
shape: BoxShape.rectangle,
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(6)),
|
||||||
|
border: Border.fromBorderSide(BorderSide(
|
||||||
|
color: borderColor,
|
||||||
|
width: 2.0,
|
||||||
|
)),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery.of(context).size;
|
||||||
|
|
||||||
|
return Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
decoration:
|
||||||
|
containerBorderDecoration(Color(0Xffffffff), Color(0xFFCCCCCC)),
|
||||||
|
child: Row(
|
||||||
|
mainAxisSize: MainAxisSize.max,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||||||
|
children: _priorities.map((item) {
|
||||||
|
bool _isActive = _priorities[_activePriority] == item ? true : false;
|
||||||
|
return Expanded(
|
||||||
|
child: InkWell(
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
decoration: containerBorderDecoration(
|
||||||
|
_isActive ? HexColor("#B8382B") : Colors.white,
|
||||||
|
_isActive ? HexColor("#B8382B") : Colors.white),
|
||||||
|
child: Center(
|
||||||
|
child: Text(
|
||||||
|
item,
|
||||||
|
style: TextStyle(
|
||||||
|
fontSize: 12,
|
||||||
|
color: _isActive
|
||||||
|
? Colors.white
|
||||||
|
: Colors.black, //Colors.black,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
onTap: () {
|
||||||
|
widget.onTap(_priorities.indexOf(item));
|
||||||
|
|
||||||
|
setState(() {
|
||||||
|
_activePriority = _priorities.indexOf(item);
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class AddHistoryDialog extends StatefulWidget {
|
||||||
|
final Function changePageViewIndex;
|
||||||
|
final PageController controller;
|
||||||
|
final List<MasterKeyModel> myHistoryList;
|
||||||
|
final Function addSelectedHistories;
|
||||||
|
final Function (MasterKeyModel) removeHistory;
|
||||||
|
|
||||||
|
const AddHistoryDialog(
|
||||||
|
{Key key, this.changePageViewIndex, this.controller, this.myHistoryList, this.addSelectedHistories, this.removeHistory})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_AddHistoryDialogState createState() => _AddHistoryDialogState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _AddHistoryDialogState extends State<AddHistoryDialog> {
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return FractionallySizedBox(
|
||||||
|
heightFactor: 0.7,
|
||||||
|
child: BaseView<SOAPViewModel>(
|
||||||
|
onModelReady: (model) async {
|
||||||
|
if (model.historyFamilyList.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.HistoryFamily);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
// baseViewModel: model,
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: Center(
|
||||||
|
child: Container(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
PriorityBar(onTap: (activePriority) async {
|
||||||
|
widget.changePageViewIndex(activePriority);
|
||||||
|
if(activePriority ==1) {
|
||||||
|
if (model.historySurgicalList.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.HistorySurgical);
|
||||||
|
await model.getMasterLookup(MasterKeysService.HistorySports);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(activePriority ==2) {
|
||||||
|
if (model.historyMedicalList.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.HistoryMedical);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Expanded(
|
||||||
|
child: PageView(
|
||||||
|
physics: NeverScrollableScrollPhysics(),
|
||||||
|
controller: widget.controller,
|
||||||
|
onPageChanged: (index) {
|
||||||
|
setState(() {
|
||||||
|
// currentIndex = index;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
scrollDirection: Axis.horizontal,
|
||||||
|
children: <Widget>[
|
||||||
|
Container(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
NetworkBaseView(
|
||||||
|
baseViewModel: model,
|
||||||
|
child: Container(
|
||||||
|
height:
|
||||||
|
MediaQuery.of(context).size.height * 0.5,
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
margin: EdgeInsets.only(top: 15),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(12),
|
||||||
|
color: Colors.white),
|
||||||
|
child: ListView(
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
children: model.historyFamilyList
|
||||||
|
.map((historyInfo) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Checkbox(
|
||||||
|
value: isServiceSelected(
|
||||||
|
historyInfo),
|
||||||
|
activeColor:
|
||||||
|
Colors.red[800],
|
||||||
|
onChanged:
|
||||||
|
(bool newValue) {
|
||||||
|
setState(() {
|
||||||
|
if (isServiceSelected(
|
||||||
|
historyInfo
|
||||||
|
)) {
|
||||||
|
widget
|
||||||
|
.removeHistory(
|
||||||
|
historyInfo
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
widget
|
||||||
|
.myHistoryList
|
||||||
|
.add(
|
||||||
|
historyInfo);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
Expanded(
|
||||||
|
child: Padding(
|
||||||
|
padding:
|
||||||
|
const EdgeInsets
|
||||||
|
.symmetric(
|
||||||
|
horizontal: 10,
|
||||||
|
vertical: 0),
|
||||||
|
child: Texts(
|
||||||
|
historyInfo.nameEn,
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color:
|
||||||
|
Colors.black),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
if (model.state == ViewState.Idle)
|
||||||
|
AppButton(
|
||||||
|
title: "Add SELECTED HISTORIES"
|
||||||
|
.toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
widget.addSelectedHistories();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
NetworkBaseView(
|
||||||
|
baseViewModel: model,
|
||||||
|
child: Container(
|
||||||
|
height:
|
||||||
|
MediaQuery.of(context).size.height * 0.5,
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
margin: EdgeInsets.only(top: 15),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(12),
|
||||||
|
color: Colors.white),
|
||||||
|
child: ListView(
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
children: model.mergeHistorySurgicalWithHistorySportList
|
||||||
|
.map((historyInfo) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Checkbox(
|
||||||
|
value: isServiceSelected(
|
||||||
|
historyInfo),
|
||||||
|
activeColor:
|
||||||
|
Colors.red[800],
|
||||||
|
onChanged:
|
||||||
|
(
|
||||||
|
bool newValue) {
|
||||||
|
setState(() {
|
||||||
|
if (isServiceSelected(
|
||||||
|
historyInfo
|
||||||
|
)) {
|
||||||
|
widget
|
||||||
|
.removeHistory(
|
||||||
|
historyInfo
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
widget
|
||||||
|
.myHistoryList
|
||||||
|
.add(
|
||||||
|
historyInfo);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
Expanded(
|
||||||
|
child: Padding(
|
||||||
|
padding:
|
||||||
|
const EdgeInsets
|
||||||
|
.symmetric(
|
||||||
|
horizontal: 10,
|
||||||
|
vertical: 0),
|
||||||
|
child: Texts(
|
||||||
|
historyInfo.nameEn,
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color:
|
||||||
|
Colors.black),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
if (model.state == ViewState.Idle)
|
||||||
|
AppButton(
|
||||||
|
title: "Add SELECTED HISTORIES"
|
||||||
|
.toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
widget.addSelectedHistories();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
NetworkBaseView(
|
||||||
|
baseViewModel: model,
|
||||||
|
child: Container(
|
||||||
|
height:
|
||||||
|
MediaQuery.of(context).size.height * 0.5,
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
margin: EdgeInsets.only(top: 15),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(12),
|
||||||
|
color: Colors.white),
|
||||||
|
child: ListView(
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
children: model.historyMedicalList
|
||||||
|
.map((historyInfo) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Checkbox(
|
||||||
|
value: isServiceSelected(
|
||||||
|
historyInfo),
|
||||||
|
activeColor:
|
||||||
|
Colors.red[800],
|
||||||
|
onChanged:
|
||||||
|
(
|
||||||
|
bool newValue) {
|
||||||
|
setState(() {
|
||||||
|
if (isServiceSelected(
|
||||||
|
historyInfo
|
||||||
|
)) {
|
||||||
|
widget
|
||||||
|
.removeHistory(
|
||||||
|
historyInfo
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
widget
|
||||||
|
.myHistoryList
|
||||||
|
.add(
|
||||||
|
historyInfo);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
Expanded(
|
||||||
|
child: Padding(
|
||||||
|
padding:
|
||||||
|
const EdgeInsets
|
||||||
|
.symmetric(
|
||||||
|
horizontal: 10,
|
||||||
|
vertical: 0),
|
||||||
|
child: Texts(
|
||||||
|
historyInfo.nameEn,
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color:
|
||||||
|
Colors.black),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
if (model.state == ViewState.Idle)
|
||||||
|
AppButton(
|
||||||
|
title: "Add SELECTED HISTORIES"
|
||||||
|
.toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
setState(() {
|
||||||
|
widget.addSelectedHistories();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
isServiceSelected(MasterKeyModel masterKey) {
|
||||||
|
Iterable<MasterKeyModel> history =
|
||||||
|
widget
|
||||||
|
.myHistoryList
|
||||||
|
.where((element) =>
|
||||||
|
masterKey.id == element.id && masterKey.typeId == element.typeId);
|
||||||
|
if (history.length > 0) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,107 @@
|
|||||||
|
|
||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
import 'package:doctor_app_flutter/util/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
|
||||||
|
class UpdateMedication extends StatefulWidget {
|
||||||
|
@override
|
||||||
|
_UpdateMedicationState createState() => _UpdateMedicationState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateMedicationState extends State<UpdateMedication> {
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Current Medications",
|
||||||
|
fontSize: 13.5,
|
||||||
|
onTapTextFields: () {
|
||||||
|
openMedicationsList(context);
|
||||||
|
},
|
||||||
|
readOnly: true,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
suffixIcon: EvaIcons.plusCircleOutline,
|
||||||
|
suffixIconColor: AppGlobal.appPrimaryColor,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
// controller: messageController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 15, right: 15, top: 15),
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Texts('Abdomen Pain',
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color: Colors.black),
|
||||||
|
Icon(
|
||||||
|
FontAwesomeIcons.trash,
|
||||||
|
color: Colors.grey,
|
||||||
|
size: 20,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Texts('Back Pain',
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color: Colors.black),
|
||||||
|
Icon(
|
||||||
|
FontAwesomeIcons.trash,
|
||||||
|
color: Colors.grey,
|
||||||
|
size: 20,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
openMedicationsList(BuildContext context) {
|
||||||
|
showModalBottomSheet(
|
||||||
|
backgroundColor: Colors.white,
|
||||||
|
isScrollControlled: true,
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return FractionallySizedBox(
|
||||||
|
heightFactor: 0.7,
|
||||||
|
child: Container(
|
||||||
|
child: Center(
|
||||||
|
child: Texts("dfdfd"),
|
||||||
|
)),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,405 @@
|
|||||||
|
import 'package:doctor_app_flutter/client/base_app_client.dart';
|
||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_allergy.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/post_allergy_request_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/post_chief_complaint_request_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/post_histories_request_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/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/SOAP/subjective/add_allergies_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/SOAP/subjective/add_history_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/soap_update/subjective/update_allergies_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/soap_update/subjective/update_history_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/expandable-widget-header-body.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
|
||||||
|
class UpdateSubjectivePage extends StatefulWidget {
|
||||||
|
final Function changePageViewIndex;
|
||||||
|
final List<MySelectedAllergy> myAllergiesList;
|
||||||
|
final List<MasterKeyModel> myHistoryList;
|
||||||
|
final PatiantInformtion patientInfo;
|
||||||
|
|
||||||
|
UpdateSubjectivePage(
|
||||||
|
{Key key,
|
||||||
|
this.changePageViewIndex,
|
||||||
|
this.myAllergiesList,
|
||||||
|
this.myHistoryList,
|
||||||
|
this.patientInfo});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_UpdateSubjectivePageState createState() => _UpdateSubjectivePageState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateSubjectivePageState extends State<UpdateSubjectivePage> {
|
||||||
|
bool isChiefExpand = false;
|
||||||
|
bool isHistoryExpand = false;
|
||||||
|
bool isAllergiesExpand = false;
|
||||||
|
TextEditingController illnessController = TextEditingController();
|
||||||
|
TextEditingController complaintsController = TextEditingController();
|
||||||
|
final formKey = GlobalKey<FormState>();
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return BaseView<SOAPViewModel>(
|
||||||
|
// onModelReady: (model) => model.getMasterLookup(MasterKeysService.Allergies),
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
isShowAppBar: false,
|
||||||
|
baseViewModel: model,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
physics: ScrollPhysics(),
|
||||||
|
child: Center(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
HeaderBodyExpandableNotifier(
|
||||||
|
headerWidget: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Texts('CHIEF COMPLAINTS',
|
||||||
|
variant: isChiefExpand ? "bodyText" : '',
|
||||||
|
bold: isChiefExpand ? true : false,
|
||||||
|
color: Colors.black),
|
||||||
|
Icon(
|
||||||
|
FontAwesomeIcons.asterisk,
|
||||||
|
color: AppGlobal.appPrimaryColor,
|
||||||
|
size: 12,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
isChiefExpand = !isChiefExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Icon(
|
||||||
|
isChiefExpand ? EvaIcons.minus : EvaIcons.plus))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bodyWidget: Form(
|
||||||
|
key: formKey,
|
||||||
|
child: Column(children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add Chief Complaints",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
maxLines: 25,
|
||||||
|
minLines: 13,
|
||||||
|
controller: complaintsController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null || value =="")
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else if (value.length < 25)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.chiefComplaintLength;
|
||||||
|
//"";
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "History of Present Illness",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
maxLines: 25,
|
||||||
|
minLines: 13,
|
||||||
|
controller: illnessController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null || value =="")
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
// TODO return it back when we need it.
|
||||||
|
// AddMedication(),
|
||||||
|
]),
|
||||||
|
),
|
||||||
|
isExpand: isChiefExpand,
|
||||||
|
),
|
||||||
|
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
width: double.infinity,
|
||||||
|
height: 1,
|
||||||
|
color: Color(0xffCCCCCC),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
HeaderBodyExpandableNotifier(
|
||||||
|
headerWidget: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Texts('History'.toUpperCase(),
|
||||||
|
variant: isHistoryExpand ? "bodyText" : '',
|
||||||
|
bold: isHistoryExpand ? true : false,
|
||||||
|
color: Colors.black),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
isHistoryExpand = !isHistoryExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Icon(isHistoryExpand
|
||||||
|
? EvaIcons.minus
|
||||||
|
: EvaIcons.plus))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bodyWidget: Column(
|
||||||
|
children: [
|
||||||
|
UpdateHistoryWidget(myHistoryList: widget.myHistoryList)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
isExpand: isHistoryExpand,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
width: double.infinity,
|
||||||
|
height: 1,
|
||||||
|
color: Color(0xffCCCCCC),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
HeaderBodyExpandableNotifier(
|
||||||
|
headerWidget: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Texts('Allergies'.toUpperCase(),
|
||||||
|
variant: isAllergiesExpand ? "bodyText" : '',
|
||||||
|
bold: isAllergiesExpand ? true : false,
|
||||||
|
color: Colors.black),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
isAllergiesExpand = !isAllergiesExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Icon(isAllergiesExpand
|
||||||
|
? EvaIcons.minus
|
||||||
|
: EvaIcons.plus))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bodyWidget:Column(
|
||||||
|
children: [
|
||||||
|
UpdateAllergiesWidget(myAllergiesList: widget.myAllergiesList,),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
,
|
||||||
|
isExpand: isAllergiesExpand,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
width: double.infinity,
|
||||||
|
height: 1,
|
||||||
|
color: Color(0xffCCCCCC),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
AppButton(
|
||||||
|
title: TranslationBase.of(context).next,
|
||||||
|
loading: model.state == ViewState.BusyLocal,
|
||||||
|
onPressed: () async {
|
||||||
|
addSubjectiveInfo(
|
||||||
|
model: model,
|
||||||
|
myAllergiesList: widget.myAllergiesList,
|
||||||
|
myHistoryList: widget.myHistoryList);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
addSubjectiveInfo(
|
||||||
|
{SOAPViewModel model,
|
||||||
|
List<MySelectedAllergy> myAllergiesList,
|
||||||
|
List<MasterKeyModel> myHistoryList}) async {
|
||||||
|
formKey.currentState.save();
|
||||||
|
formKey.currentState.validate();
|
||||||
|
|
||||||
|
|
||||||
|
// if(complaintsController.text.isNotEmpty && illnessController.text.isNotEmpty && complaintsController.text.length>25) {
|
||||||
|
// await postChiefComplaint(model: model);
|
||||||
|
// if (model.state == ViewState.ErrorLocal) {
|
||||||
|
// helpers.showErrorToast(model.error);
|
||||||
|
// } else {
|
||||||
|
// if (myHistoryList.length != 0) {
|
||||||
|
// await postHistories(model: model, myHistoryList: myHistoryList);
|
||||||
|
// if (model.state == ViewState.ErrorLocal) {
|
||||||
|
// helpers.showErrorToast(model.error);
|
||||||
|
// } else {
|
||||||
|
// if (myAllergiesList.length != 0) {
|
||||||
|
// await postAllergy(myAllergiesList: myAllergiesList, model: model);
|
||||||
|
// if (model.state == ViewState.ErrorLocal) {
|
||||||
|
// helpers.showErrorToast(model.error);
|
||||||
|
// } else {
|
||||||
|
// widget.changePageViewIndex(1);
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// widget.changePageViewIndex(1);
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// if (myAllergiesList.length != 0) {
|
||||||
|
// await postAllergy(myAllergiesList: myAllergiesList, model: model);
|
||||||
|
// if (model.state == ViewState.ErrorLocal) {
|
||||||
|
// helpers.showErrorToast(model.error);
|
||||||
|
// } else {
|
||||||
|
// widget.changePageViewIndex(1);
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// widget.changePageViewIndex(1);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// helpers.showErrorToast('Please add required field correctly');
|
||||||
|
// }
|
||||||
|
|
||||||
|
widget.changePageViewIndex(1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
postAllergy(
|
||||||
|
{List<MySelectedAllergy> myAllergiesList, SOAPViewModel model}) async {
|
||||||
|
PostAllergyRequestModel postAllergyRequestModel =
|
||||||
|
new PostAllergyRequestModel();
|
||||||
|
widget.myAllergiesList.forEach((allergy) {
|
||||||
|
if (postAllergyRequestModel.listHisProgNotePatientAllergyDiseaseVM ==
|
||||||
|
null)
|
||||||
|
postAllergyRequestModel.listHisProgNotePatientAllergyDiseaseVM = [];
|
||||||
|
//TODO: make static value dynamic
|
||||||
|
postAllergyRequestModel.listHisProgNotePatientAllergyDiseaseVM
|
||||||
|
.add(ListHisProgNotePatientAllergyDiseaseVM(
|
||||||
|
allergyDiseaseId: allergy.selectedAllergy.id,
|
||||||
|
allergyDiseaseType: allergy.selectedAllergy.typeId,
|
||||||
|
patientMRN: widget.patientInfo.patientMRN,
|
||||||
|
episodeId: widget.patientInfo.episodeNo,
|
||||||
|
appointmentNo: widget.patientInfo.appointmentNo,
|
||||||
|
severity: allergy.selectedAllergySeverity.id,
|
||||||
|
remarks: allergy.remark,
|
||||||
|
createdBy: 1485,
|
||||||
|
//
|
||||||
|
createdOn: DateTime.now().toIso8601String(),//"2020-08-14T20:37:22.780Z",
|
||||||
|
editedBy: 1485,
|
||||||
|
editedOn: DateTime.now().toIso8601String(),//"2020-08-14T20:37:22.780Z",
|
||||||
|
isChecked: false,
|
||||||
|
isUpdatedByNurse: false));
|
||||||
|
});
|
||||||
|
await model.patchAllergy(postAllergyRequestModel);
|
||||||
|
|
||||||
|
if (model.state == ViewState.ErrorLocal) {
|
||||||
|
helpers.showErrorToast(model.error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
postHistories(
|
||||||
|
{List<MasterKeyModel> myHistoryList, SOAPViewModel model}) async {
|
||||||
|
PostHistoriesRequestModel postHistoriesRequestModel =
|
||||||
|
new PostHistoriesRequestModel();
|
||||||
|
widget.myHistoryList.forEach((history) {
|
||||||
|
if (postHistoriesRequestModel.listMedicalHistoryVM == null)
|
||||||
|
postHistoriesRequestModel.listMedicalHistoryVM = [];
|
||||||
|
//TODO: make static value dynamic
|
||||||
|
postHistoriesRequestModel.listMedicalHistoryVM.add(ListMedicalHistoryVM(
|
||||||
|
patientMRN: widget.patientInfo.patientMRN,
|
||||||
|
episodeId: widget.patientInfo.episodeNo,
|
||||||
|
appointmentNo: widget.patientInfo.appointmentNo,
|
||||||
|
remarks: "",
|
||||||
|
historyId: history.id,
|
||||||
|
historyType: history.typeId,
|
||||||
|
isChecked: false,
|
||||||
|
));
|
||||||
|
});
|
||||||
|
await model.patchHistories(postHistoriesRequestModel);
|
||||||
|
|
||||||
|
if (model.state == ViewState.ErrorLocal) {
|
||||||
|
helpers.showErrorToast(model.error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
postChiefComplaint({SOAPViewModel model}) async {
|
||||||
|
formKey.currentState.save();
|
||||||
|
if(formKey.currentState.validate()){
|
||||||
|
PostChiefComplaintRequestModel postChiefComplaintRequestModel =
|
||||||
|
//TODO: make static value dynamic
|
||||||
|
new PostChiefComplaintRequestModel(
|
||||||
|
patientMRN: widget.patientInfo.patientMRN,
|
||||||
|
episodeID: widget.patientInfo.episodeNo,
|
||||||
|
appointmentNo: widget.patientInfo.appointmentNo,
|
||||||
|
chiefComplaint: complaintsController.text,
|
||||||
|
currentMedication: " currentMedication ",
|
||||||
|
hopi: illnessController.text,
|
||||||
|
isLactation: false,
|
||||||
|
ispregnant: false,
|
||||||
|
numberOfWeeks: 22);
|
||||||
|
|
||||||
|
await model.patchChiefComplaint(postChiefComplaintRequestModel);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,706 @@
|
|||||||
|
import 'package:doctor_app_flutter/client/base_app_client.dart';
|
||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/master_lookup_key.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_assement.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/post_assessment_request_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/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_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/dialogs/master_key_dailog.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/expandable-widget-header-body.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
|
||||||
|
class UpdateAssessmentPage extends StatefulWidget {
|
||||||
|
final Function changePageViewIndex;
|
||||||
|
final MySelectedAssessment mySelectedAssessment;
|
||||||
|
final PatiantInformtion patientInfo;
|
||||||
|
|
||||||
|
UpdateAssessmentPage(
|
||||||
|
{Key key, this.changePageViewIndex, this.mySelectedAssessment, this.patientInfo});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_UpdateAssessmentPageState createState() => _UpdateAssessmentPageState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateAssessmentPageState extends State<UpdateAssessmentPage> {
|
||||||
|
bool isAssessmentExpand = false;
|
||||||
|
|
||||||
|
List<dynamic> assessmentList;
|
||||||
|
dynamic _referTo;
|
||||||
|
|
||||||
|
TextEditingController remarksController = TextEditingController();
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery.of(context).size;
|
||||||
|
|
||||||
|
return BaseView<SOAPViewModel>(
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
physics: ScrollPhysics(),
|
||||||
|
child: Center(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
HeaderBodyExpandableNotifier(
|
||||||
|
headerWidget: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Texts('ASSESSMENT',
|
||||||
|
variant:
|
||||||
|
isAssessmentExpand ? "bodyText" : '',
|
||||||
|
bold: isAssessmentExpand ? true : false,
|
||||||
|
color: Colors.black),
|
||||||
|
Icon(
|
||||||
|
FontAwesomeIcons.asterisk,
|
||||||
|
color: AppGlobal.appPrimaryColor,
|
||||||
|
size: 12,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
isAssessmentExpand = !isAssessmentExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Icon(isAssessmentExpand
|
||||||
|
? EvaIcons.minus
|
||||||
|
: EvaIcons.plus))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bodyWidget: Column(children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 5, right: 5, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add ASSESSMENT",
|
||||||
|
fontSize: 13.5,
|
||||||
|
onTapTextFields: () {
|
||||||
|
openAssessmentDialog(context);
|
||||||
|
},
|
||||||
|
readOnly: true,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
suffixIcon: EvaIcons.plusCircleOutline,
|
||||||
|
suffixIconColor: AppGlobal.appPrimaryColor,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
// controller: messageController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
if(widget.mySelectedAssessment != null &&
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.appointmentId !=
|
||||||
|
null && widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisType != null &&
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisCondition != null)
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left: 5, right: 5, top: 15),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment
|
||||||
|
.spaceBetween,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment
|
||||||
|
.start,
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment
|
||||||
|
.start,
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"12".toUpperCase(),
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"DEC".toUpperCase(),
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment
|
||||||
|
.start,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"Appointment #: ",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.appointmentId
|
||||||
|
.toString(),
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisCondition
|
||||||
|
.nameEn,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"Type : ",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisType
|
||||||
|
.nameEn,
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"Doc : ",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Anas Abdullah",
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 6,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 6,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
widget.mySelectedAssessment.remark,
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment
|
||||||
|
.start,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"ICD: ".toUpperCase(),
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"R07.1".toUpperCase(),
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children: [
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
openAssessmentDialog(context);
|
||||||
|
},
|
||||||
|
child: Icon(EvaIcons
|
||||||
|
.edit2Outline),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
]),
|
||||||
|
isExpand: isAssessmentExpand,
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
AppButton(
|
||||||
|
title: TranslationBase.of(context).next,
|
||||||
|
loading: model.state == ViewState.BusyLocal,
|
||||||
|
onPressed: () async {
|
||||||
|
await submitAssessment(model);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
|
||||||
|
submitAssessment(SOAPViewModel model) async {
|
||||||
|
if (widget.mySelectedAssessment.selectedDiagnosisCondition != null &&
|
||||||
|
widget.mySelectedAssessment.selectedDiagnosisType != null) {
|
||||||
|
PatchAssessmentReqModel patchAssessmentReqModel =
|
||||||
|
new PatchAssessmentReqModel(
|
||||||
|
patientMRN: widget.patientInfo.patientMRN,
|
||||||
|
episodeId: widget.patientInfo.episodeNo,
|
||||||
|
appointmentNo: widget.patientInfo.appointmentNo,
|
||||||
|
remarks: widget.mySelectedAssessment.remark,
|
||||||
|
complexDiagnosis: true,
|
||||||
|
conditionId:
|
||||||
|
widget.mySelectedAssessment.selectedDiagnosisCondition.id,
|
||||||
|
diagnosisTypeId:
|
||||||
|
widget.mySelectedAssessment.selectedDiagnosisType.id,
|
||||||
|
icdcode10Id: "1",
|
||||||
|
prevIcdCode10ID: "1"
|
||||||
|
);
|
||||||
|
|
||||||
|
await model.patchAssessment(patchAssessmentReqModel);
|
||||||
|
|
||||||
|
if (model.state == ViewState.ErrorLocal) {
|
||||||
|
helpers.showErrorToast(model.error);
|
||||||
|
} else {
|
||||||
|
widget.changePageViewIndex(3);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
helpers.showErrorToast('Please add required field correctly');
|
||||||
|
}
|
||||||
|
|
||||||
|
widget.changePageViewIndex(3);
|
||||||
|
}
|
||||||
|
|
||||||
|
openAssessmentDialog(BuildContext context) {
|
||||||
|
showModalBottomSheet(
|
||||||
|
backgroundColor: Colors.white,
|
||||||
|
isScrollControlled: true,
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return AddAssessmentDetails(
|
||||||
|
mySelectedAssessment: widget.mySelectedAssessment,
|
||||||
|
addSelectedAssessment: () {
|
||||||
|
setState(() {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class AddAssessmentDetails extends StatefulWidget {
|
||||||
|
final MySelectedAssessment mySelectedAssessment;
|
||||||
|
final Function() addSelectedAssessment;
|
||||||
|
|
||||||
|
const AddAssessmentDetails(
|
||||||
|
{Key key, this.mySelectedAssessment, this.addSelectedAssessment})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_AddAssessmentDetailsState createState() => _AddAssessmentDetailsState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _AddAssessmentDetailsState extends State<AddAssessmentDetails> {
|
||||||
|
// MasterKeyModel _selectedDiagnosisCondition;
|
||||||
|
// MasterKeyModel _selectedDiagnosisType;
|
||||||
|
TextEditingController remarkController = TextEditingController();
|
||||||
|
TextEditingController appointmentIdController = TextEditingController(
|
||||||
|
text: "234567");
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
remarkController.text = widget.mySelectedAssessment.remark??"";
|
||||||
|
final screenSize = MediaQuery
|
||||||
|
.of(context)
|
||||||
|
.size;
|
||||||
|
InputDecoration textFieldSelectorDecoration(String hintText,
|
||||||
|
String selectedText, bool isDropDown) {
|
||||||
|
//TODO: make one Input InputDecoration for all
|
||||||
|
return InputDecoration(
|
||||||
|
focusedBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
enabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
disabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
hintText: selectedText != null ? selectedText : hintText,
|
||||||
|
suffixIcon: isDropDown ? Icon(Icons.arrow_drop_down) : null,
|
||||||
|
hintStyle: TextStyle(
|
||||||
|
fontSize: 14,
|
||||||
|
color: Colors.grey.shade600,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return FractionallySizedBox(
|
||||||
|
heightFactor: 0.75,
|
||||||
|
child: BaseView<SOAPViewModel>(
|
||||||
|
onModelReady: (model) async {
|
||||||
|
if (model.listOfDiagnosisCondition.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.DiagnosisCondition);
|
||||||
|
}
|
||||||
|
if (model.listOfDiagnosisType.length == 0) {
|
||||||
|
await model.getMasterLookup(MasterKeysService.DiagnosisType);
|
||||||
|
}
|
||||||
|
// if (model.listOfICD10.length == 0) {
|
||||||
|
// await model.getMasterLookup(MasterKeysService.ICD10);
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
builder: (_, model, w) =>
|
||||||
|
AppScaffold(
|
||||||
|
baseViewModel: model,
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
child: Center(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Container(
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Add Assessment Details".toUpperCase(),
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left: 0, right: 0, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Appointment Number",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
readOnly: true,
|
||||||
|
controller: appointmentIdController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
child: InkWell(
|
||||||
|
onTap: model.listOfDiagnosisType != null
|
||||||
|
? () {
|
||||||
|
MasterKeyDailog dialog = MasterKeyDailog(
|
||||||
|
isICD: true,
|
||||||
|
list: model.listOfDiagnosisType,
|
||||||
|
selectedValue: widget
|
||||||
|
.mySelectedAssessment
|
||||||
|
.selectedICD,
|
||||||
|
okText: TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.ok,
|
||||||
|
okFunction:
|
||||||
|
(MasterKeyModel selectedValue) {
|
||||||
|
setState(() {
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedICD =
|
||||||
|
selectedValue;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
);
|
||||||
|
showDialog(
|
||||||
|
barrierDismissible: false,
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return dialog;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
child: TextField(
|
||||||
|
decoration: textFieldSelectorDecoration(
|
||||||
|
"Name / ICD",
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedICD !=
|
||||||
|
null
|
||||||
|
? widget.mySelectedAssessment
|
||||||
|
.selectedICD.nameEn
|
||||||
|
: null,
|
||||||
|
true),
|
||||||
|
enabled: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
child: InkWell(
|
||||||
|
onTap: model.listOfDiagnosisCondition !=
|
||||||
|
null
|
||||||
|
? () {
|
||||||
|
MasterKeyDailog dialog = MasterKeyDailog(
|
||||||
|
list: model.listOfDiagnosisCondition,
|
||||||
|
okText: TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.ok,
|
||||||
|
okFunction: (
|
||||||
|
MasterKeyModel selectedValue) {
|
||||||
|
setState(() {
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisCondition =
|
||||||
|
selectedValue;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
);
|
||||||
|
showDialog(
|
||||||
|
barrierDismissible: false,
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return dialog;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
child: TextField(
|
||||||
|
decoration: textFieldSelectorDecoration(
|
||||||
|
"Condition",
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisCondition != null
|
||||||
|
? widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisCondition
|
||||||
|
.nameEn
|
||||||
|
: null,
|
||||||
|
true),
|
||||||
|
enabled: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
height: screenSize.height * 0.070,
|
||||||
|
child: InkWell(
|
||||||
|
onTap: model.listOfDiagnosisType != null
|
||||||
|
? () {
|
||||||
|
MasterKeyDailog dialog = MasterKeyDailog(
|
||||||
|
list: model.listOfDiagnosisType,
|
||||||
|
okText: TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.ok,
|
||||||
|
okFunction: (
|
||||||
|
MasterKeyModel selectedValue) {
|
||||||
|
setState(() {
|
||||||
|
// _selectedDiagnosisType =
|
||||||
|
// selectedValue;
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisType =
|
||||||
|
selectedValue;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
);
|
||||||
|
showDialog(
|
||||||
|
barrierDismissible: false,
|
||||||
|
context: context,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return dialog;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
: null,
|
||||||
|
child: TextField(
|
||||||
|
decoration: textFieldSelectorDecoration(
|
||||||
|
"Type",
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisType != null
|
||||||
|
? widget.mySelectedAssessment
|
||||||
|
.selectedDiagnosisType.nameEn
|
||||||
|
: null,
|
||||||
|
true),
|
||||||
|
enabled: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left: 0, right: 0, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Remarks",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
maxLines: 18,
|
||||||
|
minLines: 5,
|
||||||
|
controller: remarkController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
AppButton(
|
||||||
|
title: "Add".toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
setState(() {
|
||||||
|
widget.mySelectedAssessment.remark =
|
||||||
|
remarkController.text;
|
||||||
|
widget.mySelectedAssessment
|
||||||
|
.appointmentId = int.parse(
|
||||||
|
appointmentIdController.text);
|
||||||
|
|
||||||
|
widget.addSelectedAssessment();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
])),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
))),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class PatchAssessmentReqModel {
|
||||||
|
int patientMRN;
|
||||||
|
int appointmentNo;
|
||||||
|
int episodeId;
|
||||||
|
String icdcode10Id;
|
||||||
|
String prevIcdCode10ID;
|
||||||
|
int conditionId;
|
||||||
|
int diagnosisTypeId;
|
||||||
|
bool complexDiagnosis;
|
||||||
|
String remarks;
|
||||||
|
|
||||||
|
PatchAssessmentReqModel(
|
||||||
|
{this.patientMRN,
|
||||||
|
this.appointmentNo,
|
||||||
|
this.episodeId,
|
||||||
|
this.icdcode10Id,
|
||||||
|
this.prevIcdCode10ID,
|
||||||
|
this.conditionId,
|
||||||
|
this.diagnosisTypeId,
|
||||||
|
this.complexDiagnosis,
|
||||||
|
this.remarks});
|
||||||
|
|
||||||
|
PatchAssessmentReqModel.fromJson(Map<String, dynamic> json) {
|
||||||
|
patientMRN = json['patientMRN'];
|
||||||
|
appointmentNo = json['appointmentNo'];
|
||||||
|
episodeId = json['episodeId'];
|
||||||
|
icdcode10Id = json['icdcode10Id'];
|
||||||
|
prevIcdCode10ID = json['prevIcdCode10ID'];
|
||||||
|
conditionId = json['conditionId'];
|
||||||
|
diagnosisTypeId = json['diagnosisTypeId'];
|
||||||
|
complexDiagnosis = json['complexDiagnosis'];
|
||||||
|
remarks = json['remarks'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
|
data['patientMRN'] = this.patientMRN;
|
||||||
|
data['appointmentNo'] = this.appointmentNo;
|
||||||
|
data['episodeId'] = this.episodeId;
|
||||||
|
data['icdcode10Id'] = this.icdcode10Id;
|
||||||
|
data['prevIcdCode10ID'] = this.prevIcdCode10ID;
|
||||||
|
data['conditionId'] = this.conditionId;
|
||||||
|
data['diagnosisTypeId'] = this.diagnosisTypeId;
|
||||||
|
data['complexDiagnosis'] = this.complexDiagnosis;
|
||||||
|
data['remarks'] = this.remarks;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,580 @@
|
|||||||
|
import 'package:doctor_app_flutter/client/base_app_client.dart';
|
||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/master_lookup_key.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_examination.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/post_physical_exam_request_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/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_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/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/expandable-widget-header-body.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
|
||||||
|
class UpdateObjectivePage extends StatefulWidget {
|
||||||
|
final Function changePageViewIndex;
|
||||||
|
final List<MySelectedExamination> mySelectedExamination;
|
||||||
|
final PatiantInformtion patientInfo;
|
||||||
|
UpdateObjectivePage(
|
||||||
|
{Key key, this.changePageViewIndex, this.mySelectedExamination, this.patientInfo});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_UpdateObjectivePageState createState() => _UpdateObjectivePageState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateObjectivePageState extends State<UpdateObjectivePage> {
|
||||||
|
bool isSysExaminationExpand = false;
|
||||||
|
TextEditingController remarksController = TextEditingController();
|
||||||
|
|
||||||
|
BoxDecoration containerBorderDecoration(
|
||||||
|
Color containerColor, Color borderColor) {
|
||||||
|
return BoxDecoration(
|
||||||
|
color: containerColor,
|
||||||
|
shape: BoxShape.rectangle,
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(6)),
|
||||||
|
border: Border.fromBorderSide(BorderSide(
|
||||||
|
color: borderColor,
|
||||||
|
width: 0.5,
|
||||||
|
)),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery.of(context).size;
|
||||||
|
|
||||||
|
return BaseView<SOAPViewModel>(
|
||||||
|
// onModelReady: (model) => model.getMasterLookup(MasterKeysService.Allergies),
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
physics: ScrollPhysics(),
|
||||||
|
child: Center(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
HeaderBodyExpandableNotifier(
|
||||||
|
headerWidget: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Texts('Physical/System Examination',
|
||||||
|
variant:
|
||||||
|
isSysExaminationExpand ? "bodyText" : '',
|
||||||
|
bold: isSysExaminationExpand ? true : false,
|
||||||
|
color: Colors.black),
|
||||||
|
Icon(
|
||||||
|
FontAwesomeIcons.asterisk,
|
||||||
|
color: AppGlobal.appPrimaryColor,
|
||||||
|
size: 12,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
isSysExaminationExpand =
|
||||||
|
!isSysExaminationExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Icon(isSysExaminationExpand
|
||||||
|
? EvaIcons.minus
|
||||||
|
: EvaIcons.plus))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bodyWidget: Column(children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add Examination",
|
||||||
|
fontSize: 13.5,
|
||||||
|
onTapTextFields: () {
|
||||||
|
openExaminationList(context);
|
||||||
|
},
|
||||||
|
readOnly: true,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
suffixIcon: EvaIcons.plusCircleOutline,
|
||||||
|
suffixIconColor: AppGlobal.appPrimaryColor,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
// controller: messageController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children:
|
||||||
|
widget.mySelectedExamination.map((examination) {
|
||||||
|
return Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left: 15, right: 15, top: 15),
|
||||||
|
child: Column(children: [
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Texts(
|
||||||
|
examination
|
||||||
|
.selectedExamination.nameEn
|
||||||
|
.toUpperCase(),
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color: Colors.black)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 8,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
InkWell(
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
height:
|
||||||
|
screenSize.height *
|
||||||
|
0.070,
|
||||||
|
decoration:
|
||||||
|
containerBorderDecoration(
|
||||||
|
examination
|
||||||
|
.isNormal
|
||||||
|
? Color(
|
||||||
|
0xFF515A5D)
|
||||||
|
: Colors
|
||||||
|
.white,
|
||||||
|
Colors.grey),
|
||||||
|
child: Center(
|
||||||
|
child: Padding(
|
||||||
|
padding:
|
||||||
|
const EdgeInsets
|
||||||
|
.all(8.0),
|
||||||
|
child: Text(
|
||||||
|
"Normal",
|
||||||
|
style: TextStyle(
|
||||||
|
fontSize: 12,
|
||||||
|
color:
|
||||||
|
examination
|
||||||
|
.isNormal
|
||||||
|
? Colors.white
|
||||||
|
: Colors
|
||||||
|
.black,
|
||||||
|
//Colors.black,
|
||||||
|
fontWeight:
|
||||||
|
FontWeight
|
||||||
|
.bold,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
examination.isAbnormal =
|
||||||
|
!examination.isAbnormal;
|
||||||
|
examination.isNormal =
|
||||||
|
!examination.isNormal;
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
SizedBox(
|
||||||
|
width: 12,
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
height:
|
||||||
|
screenSize.height *
|
||||||
|
0.070,
|
||||||
|
decoration:
|
||||||
|
containerBorderDecoration(
|
||||||
|
examination
|
||||||
|
.isAbnormal
|
||||||
|
? Color(
|
||||||
|
0xFF515A5D)
|
||||||
|
: Colors
|
||||||
|
.white,
|
||||||
|
Colors.black),
|
||||||
|
child: Center(
|
||||||
|
child: Padding(
|
||||||
|
padding:
|
||||||
|
const EdgeInsets
|
||||||
|
.all(8.0),
|
||||||
|
child: Text(
|
||||||
|
"Abnormal",
|
||||||
|
style: TextStyle(
|
||||||
|
fontSize: 12,
|
||||||
|
color:
|
||||||
|
examination
|
||||||
|
.isAbnormal
|
||||||
|
? Colors.white
|
||||||
|
: Colors
|
||||||
|
.black,
|
||||||
|
//Colors.black,
|
||||||
|
fontWeight:
|
||||||
|
FontWeight
|
||||||
|
.bold,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
examination.isAbnormal =
|
||||||
|
!examination.isAbnormal;
|
||||||
|
examination.isNormal =
|
||||||
|
!examination.isNormal;
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
|
||||||
|
child: Icon(
|
||||||
|
FontAwesomeIcons.trash,
|
||||||
|
color: Colors.grey,
|
||||||
|
size: 20,
|
||||||
|
),
|
||||||
|
onTap: () => removeExamination(
|
||||||
|
examination.selectedExamination),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Remarks",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
maxLines: 25,
|
||||||
|
minLines: 13,
|
||||||
|
controller: remarksController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
]));
|
||||||
|
}).toList(),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
]),
|
||||||
|
isExpand: isSysExaminationExpand,
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(height: 30,),
|
||||||
|
AppButton(
|
||||||
|
title: TranslationBase.of(context).next,
|
||||||
|
loading: model.state == ViewState.BusyLocal,
|
||||||
|
onPressed: () async {
|
||||||
|
await submitUpdateObjectivePage(model);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
|
||||||
|
submitUpdateObjectivePage(SOAPViewModel model) async {
|
||||||
|
if(widget.mySelectedExamination.isNotEmpty){
|
||||||
|
PostPhysicalExamRequestModel postPhysicalExamRequestModel = new PostPhysicalExamRequestModel();
|
||||||
|
widget.mySelectedExamination.forEach((exam) {
|
||||||
|
if (postPhysicalExamRequestModel.listHisProgNotePhysicalExaminationVM ==
|
||||||
|
null)
|
||||||
|
postPhysicalExamRequestModel.listHisProgNotePhysicalExaminationVM = [];
|
||||||
|
|
||||||
|
postPhysicalExamRequestModel.listHisProgNotePhysicalExaminationVM.add(
|
||||||
|
ListHisProgNotePhysicalExaminationVM(
|
||||||
|
patientMRN: widget.patientInfo.patientMRN,
|
||||||
|
episodeId: widget.patientInfo.episodeNo,
|
||||||
|
appointmentNo: widget.patientInfo.appointmentNo,
|
||||||
|
remarks: exam.remark ?? '',
|
||||||
|
createdBy: 4709,
|
||||||
|
createdOn: DateTime.now().toIso8601String(),
|
||||||
|
editedBy: 4709,
|
||||||
|
editedOn: DateTime.now().toIso8601String(),
|
||||||
|
examId: exam.selectedExamination.id,
|
||||||
|
examType: exam.selectedExamination.typeId,
|
||||||
|
isAbnormal: exam.isAbnormal,
|
||||||
|
isNormal: exam.isNormal,
|
||||||
|
masterDescription: exam.selectedExamination,
|
||||||
|
notExamined: false
|
||||||
|
|
||||||
|
));
|
||||||
|
});
|
||||||
|
|
||||||
|
await model.patchPhysicalExam(postPhysicalExamRequestModel);
|
||||||
|
|
||||||
|
if (model.state == ViewState.ErrorLocal) {
|
||||||
|
helpers.showErrorToast(model.error);
|
||||||
|
} else {
|
||||||
|
widget.changePageViewIndex(2);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
helpers.showErrorToast('Please add required field correctly');
|
||||||
|
}
|
||||||
|
|
||||||
|
widget.changePageViewIndex(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
removeExamination(MasterKeyModel masterKey) {
|
||||||
|
Iterable<MySelectedExamination> history = widget.mySelectedExamination
|
||||||
|
.where(
|
||||||
|
(element) =>
|
||||||
|
masterKey.id == element.selectedExamination.id &&
|
||||||
|
masterKey.typeId == element.selectedExamination.typeId);
|
||||||
|
|
||||||
|
if (history.length > 0)
|
||||||
|
setState(() {
|
||||||
|
widget.mySelectedExamination.remove(history.first);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
openExaminationList(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery
|
||||||
|
.of(context)
|
||||||
|
.size;
|
||||||
|
InputDecoration textFieldSelectorDecoration(String hintText,
|
||||||
|
String selectedText, bool isDropDown) {
|
||||||
|
return InputDecoration(
|
||||||
|
focusedBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
enabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
disabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: Color(0xFFCCCCCC), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
hintText: selectedText != null ? selectedText : hintText,
|
||||||
|
suffixIcon: isDropDown ? Icon(Icons.arrow_drop_down) : null,
|
||||||
|
hintStyle: TextStyle(
|
||||||
|
fontSize: 14,
|
||||||
|
color: Colors.grey.shade600,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
showModalBottomSheet(
|
||||||
|
backgroundColor: Colors.white,
|
||||||
|
isScrollControlled: true,
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return AddExaminationDailog(
|
||||||
|
mySelectedExamination: widget.mySelectedExamination,
|
||||||
|
addSelectedExamination: () {
|
||||||
|
setState(() {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
removeExamination: (masterKey) => removeExamination(masterKey),);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class AddExaminationDailog extends StatefulWidget {
|
||||||
|
final List<MySelectedExamination> mySelectedExamination;
|
||||||
|
final Function addSelectedExamination;
|
||||||
|
final Function (MasterKeyModel) removeExamination;
|
||||||
|
|
||||||
|
const AddExaminationDailog(
|
||||||
|
{Key key, this.mySelectedExamination, this.addSelectedExamination, this.removeExamination})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_AddExaminationDailogState createState() => _AddExaminationDailogState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _AddExaminationDailogState extends State<AddExaminationDailog> {
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return FractionallySizedBox(
|
||||||
|
heightFactor: 0.7,
|
||||||
|
child: BaseView<SOAPViewModel>(
|
||||||
|
onModelReady: (model) async {
|
||||||
|
if (model.physicalExaminationList.length == 0) {
|
||||||
|
await model.getMasterLookup(
|
||||||
|
MasterKeysService.PhysicalExamination);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
builder: (_, model, w) =>
|
||||||
|
AppScaffold(
|
||||||
|
// baseViewModel: model,
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: Center(
|
||||||
|
child: Container(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Examinations",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
NetworkBaseView(
|
||||||
|
baseViewModel: model,
|
||||||
|
child: Container(
|
||||||
|
height:
|
||||||
|
MediaQuery
|
||||||
|
.of(context)
|
||||||
|
.size
|
||||||
|
.height * 0.5,
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
margin: EdgeInsets.only(top: 15),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius
|
||||||
|
.circular(12),
|
||||||
|
color: Colors.white),
|
||||||
|
child: ListView(
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
children: model
|
||||||
|
.physicalExaminationList
|
||||||
|
.map((examinationInfo) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Checkbox(
|
||||||
|
value: isServiceSelected(
|
||||||
|
examinationInfo),
|
||||||
|
activeColor:
|
||||||
|
Colors.red[800],
|
||||||
|
onChanged:
|
||||||
|
(
|
||||||
|
bool newValue) {
|
||||||
|
setState(() {
|
||||||
|
if (isServiceSelected(
|
||||||
|
examinationInfo
|
||||||
|
)) {
|
||||||
|
widget
|
||||||
|
.removeExamination(
|
||||||
|
examinationInfo
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
MySelectedExamination mySelectedExamination = new MySelectedExamination(
|
||||||
|
selectedExamination: examinationInfo
|
||||||
|
);
|
||||||
|
widget
|
||||||
|
.mySelectedExamination
|
||||||
|
.add(
|
||||||
|
mySelectedExamination);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
Expanded(
|
||||||
|
child: Padding(
|
||||||
|
padding:
|
||||||
|
const EdgeInsets
|
||||||
|
.symmetric(
|
||||||
|
horizontal: 10,
|
||||||
|
vertical: 0),
|
||||||
|
child: Texts(
|
||||||
|
examinationInfo
|
||||||
|
.nameEn,
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color:
|
||||||
|
Colors.black),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
if (model.state == ViewState.Idle)
|
||||||
|
AppButton(
|
||||||
|
title: "Add SELECTED Examinations"
|
||||||
|
.toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
widget.addSelectedExamination();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
]),
|
||||||
|
))),
|
||||||
|
)),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
isServiceSelected(MasterKeyModel masterKey) {
|
||||||
|
Iterable<MySelectedExamination> exam =
|
||||||
|
widget
|
||||||
|
.mySelectedExamination
|
||||||
|
.where((element) =>
|
||||||
|
masterKey.id == element.selectedExamination.id &&
|
||||||
|
masterKey.typeId == element.selectedExamination.typeId);
|
||||||
|
if (exam.length > 0) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,347 @@
|
|||||||
|
import 'package:doctor_app_flutter/client/base_app_client.dart';
|
||||||
|
import 'package:doctor_app_flutter/config/config.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/post_progress_note_request_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/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_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/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/expandable-widget-header-body.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
||||||
|
|
||||||
|
class UpdatePlanPage extends StatefulWidget {
|
||||||
|
final Function changePageViewIndex;
|
||||||
|
final PatiantInformtion patientInfo;
|
||||||
|
|
||||||
|
UpdatePlanPage({Key key, this.changePageViewIndex, this.patientInfo});
|
||||||
|
|
||||||
|
@override
|
||||||
|
_UpdatePlanPageState createState() => _UpdatePlanPageState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdatePlanPageState extends State<UpdatePlanPage> {
|
||||||
|
bool isProgressNoteExpand = false;
|
||||||
|
|
||||||
|
List<dynamic> progressNoteList;
|
||||||
|
|
||||||
|
TextEditingController progressNoteController =
|
||||||
|
TextEditingController(text: null);
|
||||||
|
|
||||||
|
BoxDecoration containerBorderDecoration(
|
||||||
|
Color containerColor, Color borderColor) {
|
||||||
|
return BoxDecoration(
|
||||||
|
color: containerColor,
|
||||||
|
shape: BoxShape.rectangle,
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(6)),
|
||||||
|
border: Border.fromBorderSide(BorderSide(
|
||||||
|
color: borderColor,
|
||||||
|
width: 0.5,
|
||||||
|
)),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final screenSize = MediaQuery.of(context).size;
|
||||||
|
|
||||||
|
return BaseView<SOAPViewModel>(
|
||||||
|
// onModelReady: (model) => model.getMasterLookup(MasterKeysService.Allergies),
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
isShowAppBar: false,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
physics: ScrollPhysics(),
|
||||||
|
child: Center(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
HeaderBodyExpandableNotifier(
|
||||||
|
headerWidget: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Texts('Progress Note',
|
||||||
|
variant:
|
||||||
|
isProgressNoteExpand ? "bodyText" : '',
|
||||||
|
bold: isProgressNoteExpand ? true : false,
|
||||||
|
color: Colors.black),
|
||||||
|
Icon(
|
||||||
|
FontAwesomeIcons.asterisk,
|
||||||
|
color: AppGlobal.appPrimaryColor,
|
||||||
|
size: 12,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
setState(() {
|
||||||
|
isProgressNoteExpand =
|
||||||
|
!isProgressNoteExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Icon(isProgressNoteExpand
|
||||||
|
? EvaIcons.minus
|
||||||
|
: EvaIcons.plus))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bodyWidget: Column(children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 10, right: 10, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add Progress Note",
|
||||||
|
fontSize: 13.5,
|
||||||
|
onTapTextFields: () {
|
||||||
|
openProgressNote(context);
|
||||||
|
},
|
||||||
|
readOnly: true,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
suffixIcon: EvaIcons.plusCircleOutline,
|
||||||
|
suffixIconColor: AppGlobal.appPrimaryColor,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
// controller: messageController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
if (progressNoteController.text.isNotEmpty)
|
||||||
|
Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 5, right: 5, top: 15),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.spaceBetween,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Column(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
crossAxisAlignment:
|
||||||
|
CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"12".toUpperCase(),
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"DEC".toUpperCase(),
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment
|
||||||
|
.start,
|
||||||
|
children: [
|
||||||
|
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 6,
|
||||||
|
),
|
||||||
|
Padding(
|
||||||
|
padding: const EdgeInsets.all(0.0),
|
||||||
|
child: Container(
|
||||||
|
width: MediaQuery
|
||||||
|
.of(context)
|
||||||
|
.size
|
||||||
|
.width * 0.6,
|
||||||
|
child: AppText(
|
||||||
|
progressNoteController.text,
|
||||||
|
fontSize: 10,
|
||||||
|
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
), SizedBox(
|
||||||
|
height: 8,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"Created By : ",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Anas Abdullah on 12 De",
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment:
|
||||||
|
MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
AppText(
|
||||||
|
"Edited By : ",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Rahim on 13 Dec",
|
||||||
|
fontSize: 10,
|
||||||
|
color: Colors.grey,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
|
||||||
|
],
|
||||||
|
),
|
||||||
|
Column(
|
||||||
|
children: [
|
||||||
|
InkWell(
|
||||||
|
onTap: () {
|
||||||
|
openProgressNote(context);
|
||||||
|
},
|
||||||
|
child: Icon(EvaIcons.edit2Outline),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
]),
|
||||||
|
isExpand: isProgressNoteExpand,
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(height: 30,),
|
||||||
|
AppButton(
|
||||||
|
title: TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.next,
|
||||||
|
loading: model.state == ViewState.BusyLocal,
|
||||||
|
onPressed: () {
|
||||||
|
|
||||||
|
submitPlan(model);
|
||||||
|
// widget.changePageViewIndex(2);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 30,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),),);
|
||||||
|
}
|
||||||
|
|
||||||
|
submitPlan(SOAPViewModel model) async {
|
||||||
|
if (progressNoteController.text.isNotEmpty) {
|
||||||
|
PostProgressNoteRequestModel postProgressNoteRequestModel = new PostProgressNoteRequestModel(
|
||||||
|
patientMRN: widget.patientInfo.patientMRN,
|
||||||
|
episodeId: widget.patientInfo.episodeNo,
|
||||||
|
appointmentNo: widget.patientInfo.appointmentNo,
|
||||||
|
planNote: progressNoteController.text);
|
||||||
|
|
||||||
|
|
||||||
|
await model.patchProgressNote(postProgressNoteRequestModel);
|
||||||
|
|
||||||
|
if (model.state == ViewState.ErrorLocal) {
|
||||||
|
helpers.showErrorToast(model.error);
|
||||||
|
} else {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
openProgressNote(BuildContext context) {
|
||||||
|
showModalBottomSheet(
|
||||||
|
backgroundColor: Colors.white,
|
||||||
|
isScrollControlled: true,
|
||||||
|
context: context,
|
||||||
|
builder: (context) {
|
||||||
|
return FractionallySizedBox(
|
||||||
|
heightFactor: 0.5,
|
||||||
|
child: Container(
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.9,
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
height: 16,
|
||||||
|
),
|
||||||
|
AppText(
|
||||||
|
"Add Progress Note",
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontSize: 16,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(left: 0, right: 0, top: 15),
|
||||||
|
child: TextFields(
|
||||||
|
hintText: "Add progress note here",
|
||||||
|
fontSize: 13.5,
|
||||||
|
// hintColor: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
maxLines: 16,
|
||||||
|
minLines: 8,
|
||||||
|
controller: progressNoteController,
|
||||||
|
validator: (value) {
|
||||||
|
if (value == null)
|
||||||
|
return TranslationBase
|
||||||
|
.of(context)
|
||||||
|
.emptyMessage;
|
||||||
|
else
|
||||||
|
return null;
|
||||||
|
}),
|
||||||
|
),SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
AppButton(
|
||||||
|
title: "Add".toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
]),
|
||||||
|
)),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,133 @@
|
|||||||
|
import 'package:doctor_app_flutter/core/viewModel/doctor_replay_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_allergy.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_assement.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/my_selected_examination.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/translations_delegate_base.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/SOAP/steps_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/patient-page-header-widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/soap_update/subjective/update_subjective_page.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/soap_update/update_assessment_page.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/soap_update/update_objective_page.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/patients/profile/soap_update/update_plan_page.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
|
||||||
|
class UpdateSoapIndex extends StatefulWidget {
|
||||||
|
final bool isUpdate;
|
||||||
|
|
||||||
|
const UpdateSoapIndex({Key key, this.isUpdate}) : super(key: key);
|
||||||
|
@override
|
||||||
|
_UpdateSoapIndexState createState() => _UpdateSoapIndexState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _UpdateSoapIndexState extends State<UpdateSoapIndex>
|
||||||
|
with TickerProviderStateMixin {
|
||||||
|
PageController _controller;
|
||||||
|
int _currentIndex = 0;
|
||||||
|
List<MySelectedAllergy> myAllergiesList= List();
|
||||||
|
List<MasterKeyModel> myHistoryList = List();
|
||||||
|
List<MySelectedExamination> mySelectedExamination = List();
|
||||||
|
MySelectedAssessment mySelectedAssessment = new MySelectedAssessment();
|
||||||
|
changePageViewIndex(pageIndex) {
|
||||||
|
_controller.jumpToPage(pageIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
// TODO: implement initState
|
||||||
|
_controller = new PageController();
|
||||||
|
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
||||||
|
PatiantInformtion patient = routeArgs['patient'];
|
||||||
|
return BaseView<DoctorReplayViewModel>(
|
||||||
|
builder: (_, model, w) => AppScaffold(
|
||||||
|
baseViewModel: model,
|
||||||
|
appBarTitle: TranslationBase.of(context).healthRecordInformation,
|
||||||
|
body: SingleChildScrollView(
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
decoration:
|
||||||
|
BoxDecoration(boxShadow: <BoxShadow>[], color: Colors.white),
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: <Widget>[
|
||||||
|
PatientPageHeaderWidget(patient),
|
||||||
|
FractionallySizedBox(
|
||||||
|
child: SingleChildScrollView(
|
||||||
|
child: Container(
|
||||||
|
height: MediaQuery.of(context).size.height * 0.75,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
margin: EdgeInsets.only(
|
||||||
|
left:
|
||||||
|
MediaQuery.of(context).size.width * 0.05,
|
||||||
|
right:
|
||||||
|
MediaQuery.of(context).size.width * 0.05),
|
||||||
|
child: StepsWidget(
|
||||||
|
index: _currentIndex,
|
||||||
|
changeCurrentTab: changePageViewIndex,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Expanded(
|
||||||
|
child: PageView(
|
||||||
|
physics: NeverScrollableScrollPhysics(),
|
||||||
|
controller: _controller,
|
||||||
|
onPageChanged: (index) {
|
||||||
|
setState(() {
|
||||||
|
_currentIndex = index;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
scrollDirection: Axis.horizontal,
|
||||||
|
children: <Widget>[
|
||||||
|
UpdateSubjectivePage(
|
||||||
|
changePageViewIndex: changePageViewIndex,
|
||||||
|
myAllergiesList: myAllergiesList,
|
||||||
|
myHistoryList: myHistoryList,
|
||||||
|
patientInfo: patient,
|
||||||
|
),
|
||||||
|
UpdateObjectivePage(
|
||||||
|
changePageViewIndex: changePageViewIndex,
|
||||||
|
mySelectedExamination:
|
||||||
|
mySelectedExamination,
|
||||||
|
patientInfo: patient,
|
||||||
|
),
|
||||||
|
UpdateAssessmentPage(
|
||||||
|
changePageViewIndex: changePageViewIndex,
|
||||||
|
mySelectedAssessment:
|
||||||
|
mySelectedAssessment,
|
||||||
|
patientInfo: patient,
|
||||||
|
),
|
||||||
|
UpdatePlanPage(
|
||||||
|
changePageViewIndex: changePageViewIndex,
|
||||||
|
patientInfo: patient,
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,151 @@
|
|||||||
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
||||||
|
import 'package:doctor_app_flutter/core/viewModel/SOAP_view_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/models/SOAP/master_key_model.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/Text.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/TextFields.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/app_buttons_widget.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/divider_with_spaces_around.dart';
|
||||||
|
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
||||||
|
import 'package:eva_icons_flutter/eva_icons_flutter.dart';
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
class MasterKeyCheckboxSearchWidget extends StatefulWidget {
|
||||||
|
final SOAPViewModel model;
|
||||||
|
final Function addSelectedHistories;
|
||||||
|
final Function(MasterKeyModel) removeHistory;
|
||||||
|
final Function(MasterKeyModel) addHistory;
|
||||||
|
final bool Function(MasterKeyModel) isServiceSelected;
|
||||||
|
final List<MasterKeyModel> masterList;
|
||||||
|
final String buttonName;
|
||||||
|
final String hintSearchText;
|
||||||
|
|
||||||
|
MasterKeyCheckboxSearchWidget(
|
||||||
|
{Key key,
|
||||||
|
this.model,
|
||||||
|
this.addSelectedHistories,
|
||||||
|
this.removeHistory,
|
||||||
|
this.masterList,
|
||||||
|
this.addHistory,
|
||||||
|
this.isServiceSelected, this.buttonName, this.hintSearchText})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_MasterKeyCheckboxSearchWidgetState createState() => _MasterKeyCheckboxSearchWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _MasterKeyCheckboxSearchWidgetState extends State<MasterKeyCheckboxSearchWidget> {
|
||||||
|
List<MasterKeyModel> items = List();
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
items.addAll(widget.masterList);
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Container(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
NetworkBaseView(
|
||||||
|
baseViewModel: widget.model,
|
||||||
|
child: Container(
|
||||||
|
height: MediaQuery.of(context).size.height * 0.5,
|
||||||
|
child: Center(
|
||||||
|
child: Container(
|
||||||
|
margin: EdgeInsets.only(top: 15),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(12),
|
||||||
|
color: Colors.white),
|
||||||
|
child: ListView(
|
||||||
|
children: [
|
||||||
|
TextFields(
|
||||||
|
hintText: widget.hintSearchText??'Search history',
|
||||||
|
suffixIcon: EvaIcons.search,
|
||||||
|
onChanged: (value) {
|
||||||
|
filterSearchResults(value);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
SizedBox(height: 15,),
|
||||||
|
Column(
|
||||||
|
children: items.map((historyInfo) {
|
||||||
|
return Column(
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
Checkbox(
|
||||||
|
value:
|
||||||
|
widget.isServiceSelected(historyInfo),
|
||||||
|
activeColor: Colors.red[800],
|
||||||
|
onChanged: (bool newValue) {
|
||||||
|
setState(() {
|
||||||
|
if (widget
|
||||||
|
.isServiceSelected(historyInfo)) {
|
||||||
|
widget.removeHistory(historyInfo);
|
||||||
|
} else {
|
||||||
|
widget.addHistory(historyInfo);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
Expanded(
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(
|
||||||
|
horizontal: 10, vertical: 0),
|
||||||
|
child: Texts(historyInfo.nameEn,
|
||||||
|
variant: "bodyText",
|
||||||
|
bold: true,
|
||||||
|
color: Colors.black),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DividerWithSpacesAround(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
if (widget.model.state == ViewState.Idle)
|
||||||
|
AppButton(
|
||||||
|
title: widget.buttonName?? "Add SELECTED HISTORIES".toUpperCase(),
|
||||||
|
onPressed: () {
|
||||||
|
widget.addSelectedHistories();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void filterSearchResults(String query) {
|
||||||
|
List<MasterKeyModel> dummySearchList = List();
|
||||||
|
dummySearchList.addAll(widget.masterList);
|
||||||
|
if (query.isNotEmpty) {
|
||||||
|
List<MasterKeyModel> dummyListData = List();
|
||||||
|
dummySearchList.forEach((item) {
|
||||||
|
if (item.nameAr.toLowerCase().contains(query.toLowerCase()) ||
|
||||||
|
item.nameEn.toLowerCase().contains(query.toLowerCase())) {
|
||||||
|
dummyListData.add(item);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
setState(() {
|
||||||
|
items.clear();
|
||||||
|
items.addAll(dummyListData);
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
setState(() {
|
||||||
|
items.clear();
|
||||||
|
items.addAll(widget.masterList);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue