|
|
|
@ -16,10 +16,12 @@ import 'dialogs/master_key_dailog.dart';
|
|
|
|
|
|
|
|
|
|
class MasterKeyCheckboxSearchAllergiesWidget extends StatefulWidget {
|
|
|
|
|
final SOAPViewModel model;
|
|
|
|
|
final Function addSelectedAllergy;
|
|
|
|
|
final Function () addSelectedAllergy;
|
|
|
|
|
final Function(MasterKeyModel) removeAllergy;
|
|
|
|
|
final Function(MySelectedAllergy mySelectedAllergy) addAllergy;
|
|
|
|
|
final bool Function(MasterKeyModel) isServiceSelected;
|
|
|
|
|
final MySelectedAllergy Function(MasterKeyModel) getServiceSelectedAllergy;
|
|
|
|
|
|
|
|
|
|
final List<MasterKeyModel> masterList;
|
|
|
|
|
final String buttonName;
|
|
|
|
|
final String hintSearchText;
|
|
|
|
@ -33,7 +35,8 @@ class MasterKeyCheckboxSearchAllergiesWidget extends StatefulWidget {
|
|
|
|
|
this.addAllergy,
|
|
|
|
|
this.isServiceSelected,
|
|
|
|
|
this.buttonName,
|
|
|
|
|
this.hintSearchText})
|
|
|
|
|
this.hintSearchText,
|
|
|
|
|
this.getServiceSelectedAllergy})
|
|
|
|
|
: super(key: key);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@ -89,13 +92,29 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
child: ListView.builder(
|
|
|
|
|
itemCount: items.length,
|
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
|
TextEditingController remarkController = TextEditingController(text: items[index].remarks);
|
|
|
|
|
TextEditingController severityController = TextEditingController(text: _selectedAllergySeverity!= null ?projectViewModel
|
|
|
|
|
.isArabic
|
|
|
|
|
? _selectedAllergySeverity
|
|
|
|
|
.nameAr
|
|
|
|
|
: _selectedAllergySeverity
|
|
|
|
|
.nameEn: null);
|
|
|
|
|
bool isSelected = widget.isServiceSelected(
|
|
|
|
|
items[index]);
|
|
|
|
|
MySelectedAllergy mySelectedAllergy;
|
|
|
|
|
if (isSelected) {
|
|
|
|
|
mySelectedAllergy = widget
|
|
|
|
|
.getServiceSelectedAllergy(
|
|
|
|
|
items[index]);
|
|
|
|
|
}
|
|
|
|
|
TextEditingController remarkController = TextEditingController(
|
|
|
|
|
text: isSelected ? mySelectedAllergy
|
|
|
|
|
.remark : null);
|
|
|
|
|
TextEditingController severityController = TextEditingController(
|
|
|
|
|
text: isSelected ? mySelectedAllergy
|
|
|
|
|
.selectedAllergySeverity != null
|
|
|
|
|
? projectViewModel
|
|
|
|
|
.isArabic
|
|
|
|
|
? mySelectedAllergy
|
|
|
|
|
.selectedAllergySeverity
|
|
|
|
|
.nameAr
|
|
|
|
|
: mySelectedAllergy
|
|
|
|
|
.selectedAllergySeverity
|
|
|
|
|
.nameEn
|
|
|
|
|
: null : null);
|
|
|
|
|
return Column(
|
|
|
|
|
children: [
|
|
|
|
|
InkWell(
|
|
|
|
@ -104,18 +123,22 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
if (widget.isServiceSelected(
|
|
|
|
|
items[index])) {
|
|
|
|
|
widget
|
|
|
|
|
.removeAllergy(items[index]);
|
|
|
|
|
.removeAllergy(
|
|
|
|
|
items[index]);
|
|
|
|
|
} else {
|
|
|
|
|
// TODO add Allergy
|
|
|
|
|
|
|
|
|
|
MySelectedAllergy
|
|
|
|
|
mySelectedAllergy =
|
|
|
|
|
new MySelectedAllergy(
|
|
|
|
|
selectedAllergy:
|
|
|
|
|
items[index],
|
|
|
|
|
selectedAllergySeverity:
|
|
|
|
|
_selectedAllergySeverity, remark: "fdfdf", isChecked: true);
|
|
|
|
|
widget.addAllergy(mySelectedAllergy);
|
|
|
|
|
mySelectedAllergy =
|
|
|
|
|
new MySelectedAllergy(
|
|
|
|
|
selectedAllergy:
|
|
|
|
|
items[index],
|
|
|
|
|
selectedAllergySeverity:
|
|
|
|
|
_selectedAllergySeverity,
|
|
|
|
|
remark: null,
|
|
|
|
|
isChecked: true);
|
|
|
|
|
widget.addAllergy(
|
|
|
|
|
mySelectedAllergy);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
@ -184,16 +207,9 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
okFunction:
|
|
|
|
|
(selectedValue) {
|
|
|
|
|
setState(() {
|
|
|
|
|
_selectedAllergySeverity =
|
|
|
|
|
mySelectedAllergy
|
|
|
|
|
.selectedAllergySeverity =
|
|
|
|
|
selectedValue;
|
|
|
|
|
|
|
|
|
|
severityController
|
|
|
|
|
.text = projectViewModel
|
|
|
|
|
.isArabic
|
|
|
|
|
? _selectedAllergySeverity
|
|
|
|
|
.nameAr
|
|
|
|
|
: _selectedAllergySeverity
|
|
|
|
|
.nameEn;
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
);
|
|
|
|
@ -209,13 +225,15 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
}
|
|
|
|
|
: null,
|
|
|
|
|
hasLabelText:
|
|
|
|
|
severityController.text !=
|
|
|
|
|
''
|
|
|
|
|
mySelectedAllergy
|
|
|
|
|
.selectedAllergySeverity !=
|
|
|
|
|
null
|
|
|
|
|
? true
|
|
|
|
|
: false,
|
|
|
|
|
showLabelText: true,
|
|
|
|
|
hintText:
|
|
|
|
|
TranslationBase.of(context)
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.selectSeverity,
|
|
|
|
|
fontSize: 13.5,
|
|
|
|
|
readOnly: true,
|
|
|
|
@ -226,7 +244,8 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
controller: severityController,
|
|
|
|
|
validator: (value) {
|
|
|
|
|
if (value == null)
|
|
|
|
|
return TranslationBase.of(
|
|
|
|
|
return TranslationBase
|
|
|
|
|
.of(
|
|
|
|
|
context)
|
|
|
|
|
.emptyMessage;
|
|
|
|
|
else
|
|
|
|
@ -252,7 +271,8 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
? true
|
|
|
|
|
: false,
|
|
|
|
|
showLabelText: true,
|
|
|
|
|
hintText: TranslationBase.of(
|
|
|
|
|
hintText: TranslationBase
|
|
|
|
|
.of(
|
|
|
|
|
context)
|
|
|
|
|
.remarks,
|
|
|
|
|
fontSize: 13.5,
|
|
|
|
@ -260,10 +280,22 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
fontWeight: FontWeight.w600,
|
|
|
|
|
maxLines: 25,
|
|
|
|
|
minLines: 10,
|
|
|
|
|
controller: remarkController,
|
|
|
|
|
initialValue: isSelected
|
|
|
|
|
? mySelectedAllergy
|
|
|
|
|
.remark : '',
|
|
|
|
|
// controller: remarkControlle
|
|
|
|
|
|
|
|
|
|
onChanged: (value) {
|
|
|
|
|
if (isSelected) {
|
|
|
|
|
mySelectedAllergy
|
|
|
|
|
.remark = value;
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
validator: (value) {
|
|
|
|
|
if (value == null)
|
|
|
|
|
return TranslationBase.of(
|
|
|
|
|
return TranslationBase
|
|
|
|
|
.of(
|
|
|
|
|
context)
|
|
|
|
|
.emptyMessage;
|
|
|
|
|
else
|
|
|
|
@ -460,8 +492,7 @@ class _MasterKeyCheckboxSearchAllergiesWidgetState
|
|
|
|
|
),
|
|
|
|
|
if (widget.model.state == ViewState.Idle)
|
|
|
|
|
AppButton(
|
|
|
|
|
title: widget.buttonName ??
|
|
|
|
|
TranslationBase.of(context).addSelectedHistories,
|
|
|
|
|
title: "Add Selected Allergy",
|
|
|
|
|
padding: 10,
|
|
|
|
|
color: Color(0xFF359846),
|
|
|
|
|
onPressed: () {
|
|
|
|
|