You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
334 lines
14 KiB
Dart
334 lines
14 KiB
Dart
import 'package:doctor_app_flutter/client/base_app_client.dart';
|
|
import 'package:doctor_app_flutter/config/size_config.dart';
|
|
import 'package:doctor_app_flutter/core/enum/viewstate.dart';
|
|
import 'package:doctor_app_flutter/core/model/procedure/ControlsModel.dart';
|
|
import 'package:doctor_app_flutter/core/model/procedure/categories_procedure.dart';
|
|
import 'package:doctor_app_flutter/core/model/procedure/post_procedure_req_model.dart';
|
|
import 'package:doctor_app_flutter/core/viewModel/procedure_View_model.dart';
|
|
import 'package:doctor_app_flutter/models/patient/patiant_info_model.dart';
|
|
import 'package:doctor_app_flutter/screens/base/base_view.dart';
|
|
import 'package:doctor_app_flutter/util/dr_app_toast_msg.dart';
|
|
import 'package:doctor_app_flutter/util/translations_delegate_base.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_texts_widget.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/dialogs/dailog-list-select.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/network_base_view.dart';
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'entity_list_checkbox_search_widget.dart';
|
|
|
|
postProcedure(
|
|
{ProcedureViewModel model,
|
|
String remarks,
|
|
String orderType,
|
|
PatiantInformtion patient,
|
|
List<EntityList> entityList}) async {
|
|
PostProcedureReqModel postProcedureReqModel = new PostProcedureReqModel();
|
|
List<Controls> controls = List();
|
|
List<Procedures> controlsProcedure = List();
|
|
|
|
postProcedureReqModel.appointmentNo = patient.appointmentNo;
|
|
|
|
postProcedureReqModel.episodeID = patient.episodeNo;
|
|
postProcedureReqModel.patientMRN = patient.patientMRN;
|
|
entityList.forEach((element) {
|
|
controls.add(
|
|
Controls(code: "remarks", controlValue: remarks.isEmpty ? '' : remarks),
|
|
);
|
|
controls.add(
|
|
Controls(
|
|
code: "ordertype",
|
|
controlValue:
|
|
orderType.toString().isNotEmpty ? orderType.toString() : '1'),
|
|
);
|
|
});
|
|
|
|
entityList.forEach((element) {
|
|
controlsProcedure.add(Procedures(
|
|
category: element.categoryID,
|
|
procedure: element.procedureId,
|
|
controls: controls));
|
|
});
|
|
postProcedureReqModel.procedures = controlsProcedure;
|
|
|
|
await model.postProcedure(postProcedureReqModel, patient.patientMRN);
|
|
|
|
if (model.state == ViewState.ErrorLocal) {
|
|
helpers.showErrorToast(model.error);
|
|
model.getProcedure(mrn: patient.patientMRN);
|
|
} else if (model.state == ViewState.Idle) {
|
|
DrAppToastMsg.showSuccesToast('procedure has been added');
|
|
}
|
|
}
|
|
|
|
void addSelectedProcedure(
|
|
context, ProcedureViewModel model, PatiantInformtion patient) {
|
|
showModalBottomSheet(
|
|
context: context,
|
|
isScrollControlled: true,
|
|
builder: (BuildContext bc) {
|
|
return AddSelectedProcedure(
|
|
model: model,
|
|
patient: patient,
|
|
);
|
|
});
|
|
}
|
|
|
|
class AddSelectedProcedure extends StatefulWidget {
|
|
final ProcedureViewModel model;
|
|
final PatiantInformtion patient;
|
|
|
|
const AddSelectedProcedure({Key key, this.model, this.patient})
|
|
: super(key: key);
|
|
@override
|
|
_AddSelectedProcedureState createState() =>
|
|
_AddSelectedProcedureState(patient: patient, model: model);
|
|
}
|
|
|
|
class _AddSelectedProcedureState extends State<AddSelectedProcedure> {
|
|
int selectedType;
|
|
ProcedureViewModel model;
|
|
PatiantInformtion patient;
|
|
_AddSelectedProcedureState({this.patient, this.model});
|
|
TextEditingController procedureController = TextEditingController();
|
|
TextEditingController remarksController = TextEditingController();
|
|
List<EntityList> entityList = List();
|
|
dynamic selectedCategory;
|
|
setSelectedType(int val) {
|
|
setState(() {
|
|
selectedType = val;
|
|
});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final screenSize = MediaQuery.of(context).size;
|
|
return BaseView<ProcedureViewModel>(
|
|
onModelReady: (model) => model.getCategory(),
|
|
builder: (BuildContext context, ProcedureViewModel model, Widget child) =>
|
|
NetworkBaseView(
|
|
baseViewModel: model,
|
|
child: DraggableScrollableSheet(
|
|
minChildSize: 0.90,
|
|
initialChildSize: 0.95,
|
|
maxChildSize: 1.0,
|
|
builder: (BuildContext context, ScrollController scrollController) {
|
|
return SingleChildScrollView(
|
|
child: Container(
|
|
height: MediaQuery.of(context).size.height * 1.20,
|
|
child: Padding(
|
|
padding: EdgeInsets.all(12.0),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
AppText(
|
|
TranslationBase.of(context)
|
|
.selectProcedures
|
|
.toUpperCase(),
|
|
fontWeight: FontWeight.w900,
|
|
),
|
|
SizedBox(
|
|
height: 10.0,
|
|
),
|
|
Container(
|
|
height: screenSize.height * 0.070,
|
|
child: InkWell(
|
|
onTap: model.categoryList != null &&
|
|
model.categoryList.length > 0
|
|
? () {
|
|
ListSelectDialog dialog = ListSelectDialog(
|
|
list: model.categoryList,
|
|
attributeName: 'categoryName',
|
|
attributeValueId: 'categoryId',
|
|
okText: TranslationBase.of(context).ok,
|
|
okFunction: (selectedValue) {
|
|
setState(() {
|
|
selectedCategory = selectedValue;
|
|
model.getProcedureCategory(
|
|
categoryName: selectedCategory[
|
|
'categoryName'],
|
|
categoryID: selectedCategory[
|
|
'categoryId'] <=
|
|
9
|
|
? "0" +
|
|
selectedCategory[
|
|
'categoryId']
|
|
.toString()
|
|
: selectedCategory[
|
|
'categoryId']
|
|
.toString());
|
|
});
|
|
},
|
|
);
|
|
showDialog(
|
|
barrierDismissible: false,
|
|
context: context,
|
|
builder: (BuildContext context) {
|
|
return dialog;
|
|
},
|
|
);
|
|
//model.getProcedureCategory();
|
|
}
|
|
: null,
|
|
child: TextField(
|
|
decoration: textFieldSelectorDecoration(
|
|
TranslationBase.of(context)
|
|
.procedureCategorise,
|
|
selectedCategory != null
|
|
? selectedCategory['categoryName']
|
|
: null,
|
|
true,
|
|
suffixIcon: Icon(
|
|
Icons.search,
|
|
color: Colors.black,
|
|
)),
|
|
enabled: false,
|
|
),
|
|
),
|
|
),
|
|
if (widget.model.categoriesList.length != 0)
|
|
NetworkBaseView(
|
|
baseViewModel: model,
|
|
child: EntityListCheckboxSearchWidget(
|
|
model: widget.model,
|
|
masterList:
|
|
widget.model.categoriesList[0].entityList,
|
|
removeHistory: (item) {
|
|
setState(() {
|
|
entityList.remove(item);
|
|
});
|
|
},
|
|
addHistory: (history) {
|
|
setState(() {
|
|
entityList.add(history);
|
|
});
|
|
},
|
|
addSelectedHistories: () {
|
|
//TODO build your fun herr
|
|
// widget.addSelectedHistories();
|
|
},
|
|
isEntityListSelected: (master) =>
|
|
isEntityListSelected(master),
|
|
),
|
|
),
|
|
SizedBox(
|
|
height: 15.0,
|
|
),
|
|
Column(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
children: [
|
|
Container(
|
|
child: Row(
|
|
children: [
|
|
AppText(
|
|
TranslationBase.of(context).orderType),
|
|
Radio(
|
|
activeColor: Color(0xFFB9382C),
|
|
value: 1,
|
|
groupValue: selectedType,
|
|
onChanged: (value) {
|
|
setSelectedType(value);
|
|
},
|
|
),
|
|
Text('routine'),
|
|
Radio(
|
|
activeColor: Color(0xFFB9382C),
|
|
groupValue: selectedType,
|
|
value: 0,
|
|
onChanged: (value) {
|
|
setSelectedType(value);
|
|
},
|
|
),
|
|
Text(TranslationBase.of(context).urgent),
|
|
],
|
|
),
|
|
),
|
|
SizedBox(
|
|
height: 15.0,
|
|
),
|
|
TextFields(
|
|
hintText: TranslationBase.of(context).remarks,
|
|
controller: remarksController,
|
|
minLines: 3,
|
|
maxLines: 5,
|
|
),
|
|
SizedBox(
|
|
height: 50.0,
|
|
),
|
|
Container(
|
|
margin: EdgeInsets.all(
|
|
SizeConfig.widthMultiplier * 5),
|
|
child: Wrap(
|
|
alignment: WrapAlignment.center,
|
|
children: <Widget>[
|
|
AppButton(
|
|
title: TranslationBase.of(context)
|
|
.addSelectedProcedures,
|
|
onPressed: () {
|
|
Navigator.pop(context);
|
|
postProcedure(
|
|
orderType: selectedType.toString(),
|
|
entityList: entityList,
|
|
patient: patient,
|
|
model: widget.model,
|
|
remarks: remarksController.text);
|
|
},
|
|
),
|
|
],
|
|
),
|
|
),
|
|
],
|
|
)
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}),
|
|
),
|
|
);
|
|
}
|
|
|
|
bool isEntityListSelected(EntityList masterKey) {
|
|
Iterable<EntityList> history = entityList
|
|
.where((element) => masterKey.procedureId == element.procedureId);
|
|
if (history.length > 0) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
InputDecoration textFieldSelectorDecoration(
|
|
String hintText, String selectedText, bool isDropDown,
|
|
{Icon suffixIcon}) {
|
|
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
|
|
? suffixIcon != null
|
|
? suffixIcon
|
|
: Icon(
|
|
Icons.arrow_drop_down,
|
|
color: Colors.black,
|
|
)
|
|
: null,
|
|
hintStyle: TextStyle(
|
|
fontSize: 14,
|
|
color: Colors.grey.shade600,
|
|
),
|
|
);
|
|
}
|
|
}
|