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.
527 lines
26 KiB
Dart
527 lines
26 KiB
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/admissionRequest/admission-request.dart';
|
|
import 'package:doctor_app_flutter/core/viewModel/patient-admission-request-viewmodel.dart';
|
|
import 'package:doctor_app_flutter/core/viewModel/project_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/patients/profile/patient-profile-header-new-design-app-bar.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/app_scaffold_widget.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/app_texts_widget.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/buttons/app_buttons_widget.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/dialogs/dailog-list-select.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/loader/gif_loader_dialog_utils.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/text_fields/app-textfield-custom.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/text_fields/app-textfield-custom2.dart';
|
|
import 'package:doctor_app_flutter/widgets/shared/text_fields/text_fields_utils.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:hexcolor/hexcolor.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
import '../../../../routes.dart';
|
|
|
|
class AdmissionRequestFirstScreen extends StatefulWidget {
|
|
@override
|
|
_AdmissionRequestThirdScreenState createState() =>
|
|
_AdmissionRequestThirdScreenState();
|
|
}
|
|
|
|
class _AdmissionRequestThirdScreenState
|
|
extends State<AdmissionRequestFirstScreen> {
|
|
final _dietTypeRemarksController = TextEditingController();
|
|
final _sickLeaveCommentsController = TextEditingController();
|
|
final _postMedicalHistoryController = TextEditingController();
|
|
final _postSurgicalHistoryController = TextEditingController();
|
|
|
|
dynamic _selectedClinic;
|
|
dynamic _selectedDoctor;
|
|
dynamic _selectedDietType;
|
|
|
|
bool _isSickLeaveRequired = false;
|
|
bool _patientPregnant = false;
|
|
|
|
String clinicError;
|
|
String doctorError;
|
|
String sickLeaveCommentError;
|
|
String dietTypeError;
|
|
String medicalHistoryError;
|
|
String surgicalHistoryError;
|
|
|
|
final _formKey = GlobalKey<FormState>();
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final routeArgs = ModalRoute.of(context).settings.arguments as Map;
|
|
PatiantInformtion patient = routeArgs['patient'];
|
|
String patientType = routeArgs['patientType'];
|
|
String arrivalType = routeArgs['arrivalType'];
|
|
final screenSize = MediaQuery.of(context).size;
|
|
ProjectViewModel projectViewModel = Provider.of(context);
|
|
|
|
return BaseView<AdmissionRequestViewModel>(
|
|
builder: (_, model, w) => AppScaffold(
|
|
baseViewModel: model,
|
|
isShowAppBar: true,
|
|
appBar: PatientProfileHeaderNewDesignAppBar(
|
|
patient, patientType, arrivalType),
|
|
appBarTitle: TranslationBase.of(context).admissionRequest,
|
|
body: GestureDetector(
|
|
onTap: () {
|
|
FocusScopeNode currentFocus = FocusScope.of(context);
|
|
if (!currentFocus.hasPrimaryFocus) {
|
|
currentFocus.unfocus();
|
|
}
|
|
},
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
Expanded(
|
|
child: SingleChildScrollView(
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
Container(
|
|
margin: EdgeInsets.all(16.0),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
AppText(
|
|
"${TranslationBase.of(context).admission}",
|
|
fontSize: SizeConfig.textMultiplier * 1.6,
|
|
fontWeight: FontWeight.w700,
|
|
color: Color(0xFF2E303A),
|
|
),
|
|
AppText(
|
|
TranslationBase.of(context).request,
|
|
fontSize: SizeConfig.textMultiplier * 3,
|
|
fontWeight: FontWeight.bold,
|
|
color: Color(0xFF2E303A),
|
|
)
|
|
],
|
|
),
|
|
),
|
|
Container(
|
|
margin:
|
|
EdgeInsets.symmetric(vertical: 0, horizontal: 16),
|
|
child: Form(
|
|
key: _formKey,
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
AppText(
|
|
TranslationBase.of(context)
|
|
.specialityAndDoctorDetail,
|
|
color: Color(0xFF2E303A),
|
|
fontSize: SizeConfig.textMultiplier * 1.8,
|
|
fontWeight: FontWeight.w700,
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFieldCustom(
|
|
height: screenSize.height * 0.075,
|
|
hintText: TranslationBase.of(context).clinic,
|
|
isTextFieldHasSuffix: true,
|
|
validationError: clinicError,
|
|
dropDownText: _selectedClinic != null
|
|
? projectViewModel.isArabic
|
|
? _selectedClinic['clinicNameArabic']
|
|
: _selectedClinic['clinicNameEnglish']
|
|
: null,
|
|
enabled: false,
|
|
onClick: model.clinicList != null &&
|
|
model.clinicList.length > 0
|
|
? () {
|
|
openListDialogField(
|
|
projectViewModel.isArabic
|
|
? 'clinicNameArabic'
|
|
: 'clinicNameEnglish',
|
|
'clinicID',
|
|
model.clinicList, (selectedValue) {
|
|
setState(() {
|
|
_selectedClinic = selectedValue;
|
|
});
|
|
});
|
|
}
|
|
: () async {
|
|
GifLoaderDialogUtils.showMyDialog(
|
|
context);
|
|
await model.getClinics().then((_) =>
|
|
GifLoaderDialogUtils.hideDialog(
|
|
context));
|
|
if (model.state == ViewState.Idle &&
|
|
model.clinicList.length > 0) {
|
|
openListDialogField(
|
|
projectViewModel.isArabic
|
|
? 'clinicNameArabic'
|
|
: 'clinicNameEnglish',
|
|
'clinicID',
|
|
model.clinicList,
|
|
(selectedValue) {
|
|
setState(() {
|
|
_selectedClinic = selectedValue;
|
|
});
|
|
});
|
|
} else if (model.state ==
|
|
ViewState.ErrorLocal) {
|
|
DrAppToastMsg.showErrorToast(
|
|
model.error);
|
|
} else {
|
|
DrAppToastMsg.showErrorToast(
|
|
"Empty List");
|
|
}
|
|
},
|
|
),
|
|
SizedBox(
|
|
height: 20,
|
|
),
|
|
AppTextFieldCustom2(
|
|
height: screenSize.height * 0.075,
|
|
hintText: TranslationBase.of(context).doctor,
|
|
isTextFieldHasSuffix: true,
|
|
dropDownText: _selectedDoctor != null
|
|
? _selectedDoctor['DoctorName']
|
|
: null,
|
|
enabled: false,
|
|
validationError: doctorError,
|
|
onClick: _selectedClinic != null
|
|
? model.doctorsList != null &&
|
|
model.doctorsList.length > 0
|
|
? () {
|
|
openListDialogField('DoctorName',
|
|
'DoctorID', model.doctorsList,
|
|
(selectedValue) {
|
|
setState(() {
|
|
_selectedDoctor = selectedValue;
|
|
});
|
|
});
|
|
}
|
|
: () async {
|
|
GifLoaderDialogUtils.showMyDialog(
|
|
context);
|
|
await model
|
|
.getClinicDoctors(
|
|
_selectedClinic['clinicID'])
|
|
.then((_) =>
|
|
GifLoaderDialogUtils
|
|
.hideDialog(context));
|
|
if (model.state == ViewState.Idle &&
|
|
model.doctorsList.length > 0) {
|
|
openListDialogField('DoctorName',
|
|
'DoctorID', model.doctorsList,
|
|
(selectedValue) {
|
|
setState(() {
|
|
_selectedDoctor =
|
|
selectedValue;
|
|
});
|
|
});
|
|
} else if (model.state ==
|
|
ViewState.ErrorLocal) {
|
|
DrAppToastMsg.showErrorToast(
|
|
model.error);
|
|
} else {
|
|
DrAppToastMsg.showErrorToast(
|
|
"Empty List");
|
|
}
|
|
}
|
|
: null,
|
|
),
|
|
Container(
|
|
decoration: TextFieldsUtils.containerBorderDecoration(
|
|
Color(0Xffffffff),
|
|
Color(0xFFEFEFEF)
|
|
),
|
|
child: TextFormField(
|
|
validator: (value) {
|
|
if (value == null || value.isEmpty) {
|
|
return 'Please enter some text';
|
|
}
|
|
return null;
|
|
},
|
|
),
|
|
),
|
|
SizedBox(
|
|
height: 16,
|
|
),
|
|
AppText(
|
|
TranslationBase.of(context).patientDetails,
|
|
fontFamily: 'Poppins',
|
|
fontSize: SizeConfig.textMultiplier * 1.8,
|
|
fontWeight: FontWeight.w700,
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
if (patient.gender != 1)
|
|
CheckboxListTile(
|
|
title: AppText(
|
|
TranslationBase.of(context).patientPregnant,
|
|
fontWeight: FontWeight.normal,
|
|
fontFamily: 'Poppins',
|
|
fontSize: SizeConfig.textMultiplier * 2.0,
|
|
),
|
|
value: _patientPregnant,
|
|
activeColor: HexColor("#D02127"),
|
|
onChanged: (newValue) {
|
|
setState(() {
|
|
_patientPregnant = newValue;
|
|
});
|
|
},
|
|
controlAffinity:
|
|
ListTileControlAffinity.leading,
|
|
contentPadding: EdgeInsets.all(0),
|
|
),
|
|
CheckboxListTile(
|
|
title: AppText(
|
|
TranslationBase.of(context)
|
|
.isSickLeaveRequired,
|
|
fontWeight: FontWeight.normal,
|
|
fontFamily: 'Poppins',
|
|
fontSize: SizeConfig.textMultiplier * 2.0,
|
|
),
|
|
value: _isSickLeaveRequired,
|
|
activeColor: HexColor("#D02127"),
|
|
onChanged: (newValue) {
|
|
setState(() {
|
|
_isSickLeaveRequired = newValue;
|
|
});
|
|
},
|
|
controlAffinity:
|
|
ListTileControlAffinity.leading,
|
|
contentPadding: EdgeInsets.all(0),
|
|
),
|
|
AppTextFieldCustom(
|
|
hintText: TranslationBase.of(context)
|
|
.sickLeaveComments,
|
|
controller: _sickLeaveCommentsController,
|
|
minLines: 2,
|
|
maxLines: 4,
|
|
validationError: sickLeaveCommentError,
|
|
inputType: TextInputType.multiline,
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFieldCustom(
|
|
height: screenSize.height * 0.075,
|
|
hintText: TranslationBase.of(context).dietType,
|
|
isTextFieldHasSuffix: true,
|
|
validationError: dietTypeError,
|
|
dropDownText: _selectedDietType != null
|
|
? _selectedDietType['nameEn']
|
|
: null,
|
|
enabled: false,
|
|
onClick: model.dietTypesList != null &&
|
|
model.dietTypesList.length > 0
|
|
? () {
|
|
openListDialogField(
|
|
'nameEn', 'id', model.dietTypesList,
|
|
(selectedValue) {
|
|
setState(() {
|
|
_selectedDietType = selectedValue;
|
|
});
|
|
});
|
|
}
|
|
: () async {
|
|
GifLoaderDialogUtils.showMyDialog(
|
|
context);
|
|
await model
|
|
.getDietTypes(patient.patientId)
|
|
.then((_) =>
|
|
GifLoaderDialogUtils.hideDialog(
|
|
context));
|
|
if (model.state == ViewState.Idle &&
|
|
model.dietTypesList.length > 0) {
|
|
openListDialogField('nameEn', 'id',
|
|
model.dietTypesList,
|
|
(selectedValue) {
|
|
setState(() {
|
|
_selectedDietType = selectedValue;
|
|
});
|
|
});
|
|
} else if (model.state ==
|
|
ViewState.ErrorLocal) {
|
|
DrAppToastMsg.showErrorToast(
|
|
model.error);
|
|
} else {
|
|
DrAppToastMsg.showErrorToast(
|
|
"Empty List");
|
|
}
|
|
},
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFieldCustom(
|
|
hintText:
|
|
TranslationBase.of(context).dietTypeRemarks,
|
|
controller: _dietTypeRemarksController,
|
|
minLines: 4,
|
|
maxLines: 6,
|
|
inputType: TextInputType.multiline,
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFieldCustom(
|
|
hintText: TranslationBase.of(context)
|
|
.pastMedicalHistory,
|
|
controller: _postMedicalHistoryController,
|
|
minLines: 4,
|
|
maxLines: 6,
|
|
validationError: medicalHistoryError,
|
|
inputType: TextInputType.multiline,
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFieldCustom(
|
|
hintText: TranslationBase.of(context)
|
|
.pastSurgicalHistory,
|
|
controller: _postSurgicalHistoryController,
|
|
minLines: 2,
|
|
maxLines: 4,
|
|
validationError: surgicalHistoryError,
|
|
inputType: TextInputType.multiline,
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
Container(
|
|
margin: EdgeInsets.symmetric(horizontal: 16, vertical: 8),
|
|
child: AppButton(
|
|
title: TranslationBase.of(context).next,
|
|
color: HexColor("#D02127"),
|
|
onPressed: () {
|
|
// Validate returns true if the form is valid, or false otherwise.
|
|
if (_formKey.currentState.validate()) {
|
|
DrAppToastMsg.showErrorToast("all good");
|
|
} else {
|
|
DrAppToastMsg.showErrorToast("not valid");
|
|
}
|
|
|
|
model.admissionRequestData = AdmissionRequest();
|
|
if (_selectedClinic != null &&
|
|
_selectedDoctor != null &&
|
|
_sickLeaveCommentsController.text != "" &&
|
|
_postMedicalHistoryController.text != "" &&
|
|
_postSurgicalHistoryController.text != "") {
|
|
model.admissionRequestData.patientMRN =
|
|
patient.patientMRN;
|
|
model.admissionRequestData.appointmentNo =
|
|
patient.appointmentNo;
|
|
model.admissionRequestData.episodeID = patient.episodeNo;
|
|
model.admissionRequestData.admissionRequestNo = 0;
|
|
|
|
model.admissionRequestData.admitToClinic =
|
|
_selectedClinic['clinicID'];
|
|
model.admissionRequestData.mrpDoctorID =
|
|
_selectedDoctor['DoctorID'];
|
|
|
|
model.admissionRequestData.isPregnant = _patientPregnant;
|
|
model.admissionRequestData.isSickLeaveRequired =
|
|
_isSickLeaveRequired;
|
|
model.admissionRequestData.sickLeaveComments =
|
|
_sickLeaveCommentsController.text;
|
|
model.admissionRequestData.isDietType =
|
|
_selectedDietType != null ? true : false;
|
|
model.admissionRequestData.dietType =
|
|
_selectedDietType != null
|
|
? _selectedDietType['id']
|
|
: 0;
|
|
model.admissionRequestData.dietRemarks =
|
|
_dietTypeRemarksController.text;
|
|
model.admissionRequestData.pastMedicalHistory =
|
|
_postMedicalHistoryController.text;
|
|
model.admissionRequestData.pastSurgicalHistory =
|
|
_postSurgicalHistoryController.text;
|
|
Navigator.of(context)
|
|
.pushNamed(PATIENT_ADMISSION_REQUEST_2, arguments: {
|
|
'patient': patient,
|
|
'patientType': patientType,
|
|
'arrivalType': arrivalType,
|
|
'admission-data': model.admissionRequestData
|
|
});
|
|
} else {
|
|
DrAppToastMsg.showErrorToast(
|
|
TranslationBase.of(context).pleaseFill);
|
|
|
|
setState(() {
|
|
if (_selectedClinic == null) {
|
|
clinicError =
|
|
TranslationBase.of(context).fieldRequired;
|
|
} else {
|
|
clinicError = null;
|
|
}
|
|
if (_selectedDoctor == null) {
|
|
doctorError =
|
|
TranslationBase.of(context).fieldRequired;
|
|
} else {
|
|
doctorError = null;
|
|
}
|
|
if (_sickLeaveCommentsController.text == "") {
|
|
sickLeaveCommentError =
|
|
TranslationBase.of(context).fieldRequired;
|
|
} else {
|
|
sickLeaveCommentError = null;
|
|
}
|
|
if (_selectedDietType == null) {
|
|
dietTypeError =
|
|
TranslationBase.of(context).fieldRequired;
|
|
} else {
|
|
dietTypeError = null;
|
|
}
|
|
if (_postMedicalHistoryController.text == "") {
|
|
medicalHistoryError =
|
|
TranslationBase.of(context).fieldRequired;
|
|
} else {
|
|
medicalHistoryError = null;
|
|
}
|
|
if (_postSurgicalHistoryController.text == "") {
|
|
surgicalHistoryError =
|
|
TranslationBase.of(context).fieldRequired;
|
|
} else {
|
|
surgicalHistoryError = null;
|
|
}
|
|
});
|
|
}
|
|
},
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
void openListDialogField(String attributeName, String attributeValueId,
|
|
List<dynamic> list, Function(dynamic selectedValue) okFunction) {
|
|
ListSelectDialog dialog = ListSelectDialog(
|
|
list: list,
|
|
attributeName: attributeName,
|
|
attributeValueId: attributeValueId,
|
|
usingSearch: true,
|
|
okText: TranslationBase.of(context).ok,
|
|
okFunction: (selectedValue) {
|
|
okFunction(selectedValue);
|
|
},
|
|
);
|
|
showDialog(
|
|
barrierDismissible: false,
|
|
context: context,
|
|
builder: (BuildContext context) {
|
|
return dialog;
|
|
},
|
|
);
|
|
}
|
|
}
|