|
|
@ -124,260 +124,240 @@ class _PatientSearchScreenState extends State<PatientSearchScreen> {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
child: AppScaffold(
|
|
|
|
child: AppScaffold(
|
|
|
|
appBarTitle: TranslationBase.of(context).searchPatient,
|
|
|
|
appBarTitle: TranslationBase.of(context).searchPatient,
|
|
|
|
isShowAppBar: false,
|
|
|
|
isShowAppBar: true,
|
|
|
|
body: ListView(
|
|
|
|
body: Column(
|
|
|
|
children: <Widget>[
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
|
|
RoundedContainer(
|
|
|
|
children: [
|
|
|
|
child: Column(
|
|
|
|
RoundedContainer(
|
|
|
|
children: <Widget>[
|
|
|
|
showBorder: false,
|
|
|
|
Column(
|
|
|
|
child: Column(
|
|
|
|
children: <Widget>[
|
|
|
|
children: <Widget>[
|
|
|
|
// Container(
|
|
|
|
Column(
|
|
|
|
// child: Icon(
|
|
|
|
children: <Widget>[
|
|
|
|
// DoctorApp.search_patient_1,
|
|
|
|
// Container(
|
|
|
|
// size: 100,
|
|
|
|
// child: Icon(
|
|
|
|
// color: Colors.black,
|
|
|
|
// DoctorApp.search_patient_1,
|
|
|
|
// ),
|
|
|
|
// size: 100,
|
|
|
|
// margin: EdgeInsets.only(top: 10),
|
|
|
|
// color: Colors.black,
|
|
|
|
// ),
|
|
|
|
// ),
|
|
|
|
// Padding(
|
|
|
|
// margin: EdgeInsets.only(top: 10),
|
|
|
|
// padding: const EdgeInsets.only(top: 12.0),
|
|
|
|
// ),
|
|
|
|
// child: AppText(
|
|
|
|
// Padding(
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// padding: const EdgeInsets.only(top: 12.0),
|
|
|
|
// .searchPatientImageCaptionTitle
|
|
|
|
// child: AppText(
|
|
|
|
// .toUpperCase(),
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// fontWeight: FontWeight.bold,
|
|
|
|
// .searchPatientImageCaptionTitle
|
|
|
|
// fontSize: SizeConfig.heightMultiplier * 2.5,
|
|
|
|
// .toUpperCase(),
|
|
|
|
// ),
|
|
|
|
// fontWeight: FontWeight.bold,
|
|
|
|
// ),
|
|
|
|
// fontSize: SizeConfig.heightMultiplier * 2.5,
|
|
|
|
// Padding(
|
|
|
|
// ),
|
|
|
|
// padding: const EdgeInsets.only(top: 5.0),
|
|
|
|
// ),
|
|
|
|
// child: AppText(
|
|
|
|
// Padding(
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// padding: const EdgeInsets.only(top: 5.0),
|
|
|
|
// .searchPatientImageCaptionBody,
|
|
|
|
// child: AppText(
|
|
|
|
// fontSize: SizeConfig.heightMultiplier * 2,
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// ),
|
|
|
|
// .searchPatientImageCaptionBody,
|
|
|
|
// )
|
|
|
|
// fontSize: SizeConfig.heightMultiplier * 2,
|
|
|
|
],
|
|
|
|
// ),
|
|
|
|
),
|
|
|
|
// )
|
|
|
|
Container(
|
|
|
|
],
|
|
|
|
padding: EdgeInsets.all(15),
|
|
|
|
),
|
|
|
|
width: SizeConfig.screenWidth * 1,
|
|
|
|
Container(
|
|
|
|
child: Form(
|
|
|
|
padding: EdgeInsets.all(15),
|
|
|
|
key: _formKey,
|
|
|
|
width: SizeConfig.screenWidth * 1,
|
|
|
|
autovalidate: _autoValidate,
|
|
|
|
child: Form(
|
|
|
|
child: Column(
|
|
|
|
key: _formKey,
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
autovalidate: _autoValidate,
|
|
|
|
children: <Widget>[
|
|
|
|
child: Column(
|
|
|
|
SizedBox(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
height: 15,
|
|
|
|
children: <Widget>[
|
|
|
|
),
|
|
|
|
SizedBox(
|
|
|
|
if (_selectedType != '7')
|
|
|
|
height: 15,
|
|
|
|
Container(
|
|
|
|
),
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
if (_selectedType != '7')
|
|
|
|
borderRadius:
|
|
|
|
Container(
|
|
|
|
BorderRadius.all(Radius.circular(6.0)),
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
border: Border.all(
|
|
|
|
borderRadius:
|
|
|
|
width: 1.0, color: HexColor("#CCCCCC"))),
|
|
|
|
BorderRadius.all(Radius.circular(6.0)),
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
border: Border.all(
|
|
|
|
child: AppTextFormField(
|
|
|
|
width: 1.0,
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
.patpatientIDMobilenationalientID,
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
borderColor: Colors.white,
|
|
|
|
child: AppTextFormField(
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
textInputAction: TextInputAction.done,
|
|
|
|
.patpatientIDMobilenationalientID,
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
focusNode: _nodeText1,
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
onSaved: (value) {
|
|
|
|
textInputAction: TextInputAction.done,
|
|
|
|
if (value != null && value != '') {
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
if (value.length == 10 &&
|
|
|
|
focusNode: _nodeText1,
|
|
|
|
(value[0] == '2' || value[0] == '1')) {
|
|
|
|
onSaved: (value) {
|
|
|
|
_patientSearchFormValues
|
|
|
|
if (value != null && value != '') {
|
|
|
|
.IdentificationNo = value;
|
|
|
|
if (value.length == 10 &&
|
|
|
|
_patientSearchFormValues.Searchtype = 2;
|
|
|
|
(value[0] == '2' ||
|
|
|
|
_patientSearchFormValues.setPatientID = 0;
|
|
|
|
value[0] == '1')) {
|
|
|
|
} else if ((value.length == 10 ||
|
|
|
|
_patientSearchFormValues
|
|
|
|
value.length == 9) &&
|
|
|
|
.IdentificationNo = value;
|
|
|
|
((value[0] == '0' && value[1] == '5') ||
|
|
|
|
_patientSearchFormValues.Searchtype = 2;
|
|
|
|
value[0] == '5')) {
|
|
|
|
_patientSearchFormValues.setPatientID =
|
|
|
|
_patientSearchFormValues.MobileNo = value;
|
|
|
|
0;
|
|
|
|
_patientSearchFormValues.Searchtype = 0;
|
|
|
|
} else if ((value.length == 10 ||
|
|
|
|
} else {
|
|
|
|
value.length == 9) &&
|
|
|
|
_patientSearchFormValues.setPatientID =
|
|
|
|
((value[0] == '0' &&
|
|
|
|
int.parse(value);
|
|
|
|
value[1] == '5') ||
|
|
|
|
_patientSearchFormValues.Searchtype = 1;
|
|
|
|
value[0] == '5')) {
|
|
|
|
|
|
|
|
_patientSearchFormValues.MobileNo =
|
|
|
|
|
|
|
|
value;
|
|
|
|
|
|
|
|
_patientSearchFormValues.Searchtype = 0;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
_patientSearchFormValues.setPatientID =
|
|
|
|
|
|
|
|
int.parse(value);
|
|
|
|
|
|
|
|
_patientSearchFormValues.Searchtype = 1;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// else{
|
|
|
|
// else{
|
|
|
|
|
|
|
|
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
// value == null || value == ''
|
|
|
|
// value == null || value == ''
|
|
|
|
// ? _patientSearchFormValues.setPatientID =
|
|
|
|
// ? _patientSearchFormValues.setPatientID =
|
|
|
|
// 0
|
|
|
|
// 0
|
|
|
|
// : _patientSearchFormValues.setPatientID =
|
|
|
|
// : _patientSearchFormValues.setPatientID =
|
|
|
|
// int.parse(value);
|
|
|
|
// int.parse(value);
|
|
|
|
|
|
|
|
|
|
|
|
// if (value != null &&
|
|
|
|
// if (value != null &&
|
|
|
|
// value.toString().trim().isEmpty) {
|
|
|
|
// value.toString().trim().isEmpty) {
|
|
|
|
// _patientSearchFormValues.setPatientID = 0;
|
|
|
|
// _patientSearchFormValues.setPatientID = 0;
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
SizedBox(
|
|
|
|
// Row(
|
|
|
|
height: 10,
|
|
|
|
// mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
),
|
|
|
|
// children: [
|
|
|
|
// Row(
|
|
|
|
// InkWell(
|
|
|
|
// mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
// child: this.isView == false
|
|
|
|
// children: [
|
|
|
|
// ? AppText(
|
|
|
|
// InkWell(
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// child: this.isView == false
|
|
|
|
// .searchWithOther,
|
|
|
|
// ? AppText(
|
|
|
|
// color: Colors.red,
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// fontWeight: FontWeight.bold,
|
|
|
|
// .searchWithOther,
|
|
|
|
// )
|
|
|
|
// color: Colors.red,
|
|
|
|
// : AppText(
|
|
|
|
// fontWeight: FontWeight.bold,
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// )
|
|
|
|
// .hideOtherCriteria,
|
|
|
|
// : AppText(
|
|
|
|
// color: Colors.red,
|
|
|
|
// TranslationBase.of(context)
|
|
|
|
// fontWeight: FontWeight.bold),
|
|
|
|
// .hideOtherCriteria,
|
|
|
|
// onTap: () {
|
|
|
|
// color: Colors.red,
|
|
|
|
// setState(() {
|
|
|
|
// fontWeight: FontWeight.bold),
|
|
|
|
// this.isView = !this.isView;
|
|
|
|
// onTap: () {
|
|
|
|
// });
|
|
|
|
// setState(() {
|
|
|
|
// },
|
|
|
|
// this.isView = !this.isView;
|
|
|
|
// )
|
|
|
|
// });
|
|
|
|
// ],
|
|
|
|
// },
|
|
|
|
// ),
|
|
|
|
// )
|
|
|
|
isView == true
|
|
|
|
// ],
|
|
|
|
? Column(children: [
|
|
|
|
// ),
|
|
|
|
SizedBox(
|
|
|
|
isView == true
|
|
|
|
height: 10,
|
|
|
|
? Column(children: [
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
height: 65.0,
|
|
|
|
|
|
|
|
decoration: ShapeDecoration(
|
|
|
|
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
|
|
|
|
side: BorderSide(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
style: BorderStyle.solid,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC")),
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
width: double.infinity,
|
|
|
|
Container(
|
|
|
|
child: Padding(
|
|
|
|
height: 65.0,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
decoration: ShapeDecoration(
|
|
|
|
top: SizeConfig.widthMultiplier * 0.9,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
bottom:
|
|
|
|
side: BorderSide(
|
|
|
|
SizeConfig.widthMultiplier * 0.9,
|
|
|
|
width: 1.0,
|
|
|
|
right: SizeConfig.widthMultiplier * 3,
|
|
|
|
style: BorderStyle.solid,
|
|
|
|
left: SizeConfig.widthMultiplier * 3),
|
|
|
|
color: HexColor("#CCCCCC")),
|
|
|
|
child: Row(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
mainAxisSize: MainAxisSize.max,
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
children: <Widget>[
|
|
|
|
),
|
|
|
|
Expanded(
|
|
|
|
),
|
|
|
|
// add Expanded to have your dropdown button fill remaining space
|
|
|
|
width: double.infinity,
|
|
|
|
child: DropdownButtonHideUnderline(
|
|
|
|
child: Padding(
|
|
|
|
child: DropdownButton(
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
isExpanded: true,
|
|
|
|
top: SizeConfig.widthMultiplier *
|
|
|
|
value: _selectedType,
|
|
|
|
0.9,
|
|
|
|
iconSize: 25,
|
|
|
|
bottom: SizeConfig.widthMultiplier *
|
|
|
|
elevation: 16,
|
|
|
|
0.9,
|
|
|
|
selectedItemBuilder:
|
|
|
|
right:
|
|
|
|
(BuildContext context) {
|
|
|
|
SizeConfig.widthMultiplier * 3,
|
|
|
|
return PATIENT_TYPE_Des.map(
|
|
|
|
left:
|
|
|
|
|
|
|
|
SizeConfig.widthMultiplier * 3),
|
|
|
|
|
|
|
|
child: Row(
|
|
|
|
|
|
|
|
mainAxisSize: MainAxisSize.max,
|
|
|
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
|
|
|
Expanded(
|
|
|
|
|
|
|
|
// add Expanded to have your dropdown button fill remaining space
|
|
|
|
|
|
|
|
child:
|
|
|
|
|
|
|
|
DropdownButtonHideUnderline(
|
|
|
|
|
|
|
|
child: DropdownButton(
|
|
|
|
|
|
|
|
isExpanded: true,
|
|
|
|
|
|
|
|
value: _selectedType,
|
|
|
|
|
|
|
|
iconSize: 25,
|
|
|
|
|
|
|
|
elevation: 16,
|
|
|
|
|
|
|
|
selectedItemBuilder:
|
|
|
|
|
|
|
|
(BuildContext context) {
|
|
|
|
|
|
|
|
return PATIENT_TYPE_Des.map(
|
|
|
|
|
|
|
|
(item) {
|
|
|
|
|
|
|
|
return Row(
|
|
|
|
|
|
|
|
mainAxisSize:
|
|
|
|
|
|
|
|
MainAxisSize.max,
|
|
|
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
|
|
|
!projectsProvider
|
|
|
|
|
|
|
|
.isArabic
|
|
|
|
|
|
|
|
? AppText(
|
|
|
|
|
|
|
|
item['text'],
|
|
|
|
|
|
|
|
fontSize: SizeConfig
|
|
|
|
|
|
|
|
.textMultiplier *
|
|
|
|
|
|
|
|
2.1,
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
: AppText(
|
|
|
|
|
|
|
|
item['text_ar'],
|
|
|
|
|
|
|
|
fontSize: SizeConfig
|
|
|
|
|
|
|
|
.textMultiplier *
|
|
|
|
|
|
|
|
2.1,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}).toList();
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
onChanged: (String newValue) =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
setState(() {
|
|
|
|
|
|
|
|
_selectedType = newValue;
|
|
|
|
|
|
|
|
selectedPatientType =
|
|
|
|
|
|
|
|
int.parse(
|
|
|
|
|
|
|
|
_selectedType);
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
items: PATIENT_TYPE_Des.map(
|
|
|
|
(item) {
|
|
|
|
(item) {
|
|
|
|
return Row(
|
|
|
|
!projectsProvider.isArabic
|
|
|
|
mainAxisSize:
|
|
|
|
? itemText = item['text']
|
|
|
|
MainAxisSize.max,
|
|
|
|
: itemText =
|
|
|
|
children: <Widget>[
|
|
|
|
item['text_ar'];
|
|
|
|
!projectsProvider.isArabic
|
|
|
|
return DropdownMenuItem(
|
|
|
|
? AppText(
|
|
|
|
child: Text(
|
|
|
|
item['text'],
|
|
|
|
itemText,
|
|
|
|
fontSize: SizeConfig
|
|
|
|
textAlign: TextAlign.end,
|
|
|
|
.textMultiplier *
|
|
|
|
),
|
|
|
|
2.1,
|
|
|
|
value: item['val'],
|
|
|
|
)
|
|
|
|
|
|
|
|
: AppText(
|
|
|
|
|
|
|
|
item['text_ar'],
|
|
|
|
|
|
|
|
fontSize: SizeConfig
|
|
|
|
|
|
|
|
.textMultiplier *
|
|
|
|
|
|
|
|
2.1,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}).toList();
|
|
|
|
}).toList(),
|
|
|
|
},
|
|
|
|
)),
|
|
|
|
onChanged: (String newValue) => {
|
|
|
|
),
|
|
|
|
setState(() {
|
|
|
|
],
|
|
|
|
_selectedType = newValue;
|
|
|
|
),
|
|
|
|
selectedPatientType =
|
|
|
|
|
|
|
|
int.parse(_selectedType);
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
items:
|
|
|
|
|
|
|
|
PATIENT_TYPE_Des.map((item) {
|
|
|
|
|
|
|
|
!projectsProvider.isArabic
|
|
|
|
|
|
|
|
? itemText = item['text']
|
|
|
|
|
|
|
|
: itemText =
|
|
|
|
|
|
|
|
item['text_ar'];
|
|
|
|
|
|
|
|
return DropdownMenuItem(
|
|
|
|
|
|
|
|
child: Text(
|
|
|
|
|
|
|
|
itemText,
|
|
|
|
|
|
|
|
textAlign: TextAlign.end,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
value: item['val'],
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}).toList(),
|
|
|
|
|
|
|
|
)),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
SizedBox(
|
|
|
|
SizedBox(
|
|
|
|
height: 10,
|
|
|
|
height: 10,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
border: Border.all(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
|
|
|
|
child: AppTextFormField(
|
|
|
|
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
|
|
|
|
.firstName,
|
|
|
|
|
|
|
|
borderColor: Colors.white,
|
|
|
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
|
|
|
value == null || value == ''
|
|
|
|
|
|
|
|
? _patientSearchFormValues
|
|
|
|
|
|
|
|
.setFirstName = "0"
|
|
|
|
|
|
|
|
: _patientSearchFormValues
|
|
|
|
|
|
|
|
.setFirstName = value;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (value != null &&
|
|
|
|
|
|
|
|
value.toString().trim().isEmpty) {
|
|
|
|
|
|
|
|
_patientSearchFormValues
|
|
|
|
|
|
|
|
.setFirstName = "0";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
// validator: (value) {
|
|
|
|
|
|
|
|
// return TextValidator().validateName(value);
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
inputFormatter: ONLY_LETTERS),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
if (_selectedType != '7')
|
|
|
|
|
|
|
|
Container(
|
|
|
|
Container(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
@ -387,223 +367,274 @@ class _PatientSearchScreenState extends State<PatientSearchScreen> {
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
child: AppTextFormField(
|
|
|
|
child: AppTextFormField(
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
.phoneNumber,
|
|
|
|
.firstName,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
onSaved: (value) {
|
|
|
|
textInputAction: TextInputAction.done,
|
|
|
|
value == null || value == ''
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
? _patientSearchFormValues
|
|
|
|
focusNode: _nodeText1,
|
|
|
|
.setFirstName = "0"
|
|
|
|
onSaved: (value) {
|
|
|
|
: _patientSearchFormValues
|
|
|
|
value == null || value == ''
|
|
|
|
.setFirstName = value;
|
|
|
|
? _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientMobileNumber = "0"
|
|
|
|
if (value != null &&
|
|
|
|
: _patientSearchFormValues
|
|
|
|
value
|
|
|
|
.setPatientMobileNumber =
|
|
|
|
.toString()
|
|
|
|
value;
|
|
|
|
.trim()
|
|
|
|
|
|
|
|
.isEmpty) {
|
|
|
|
|
|
|
|
_patientSearchFormValues
|
|
|
|
|
|
|
|
.setFirstName = "0";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
// validator: (value) {
|
|
|
|
|
|
|
|
// return TextValidator().validateName(value);
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
inputFormatter: ONLY_LETTERS),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
if (_selectedType != '7')
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
border: Border.all(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
|
|
|
|
child: AppTextFormField(
|
|
|
|
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
|
|
|
|
.phoneNumber,
|
|
|
|
|
|
|
|
borderColor: Colors.white,
|
|
|
|
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
|
|
|
|
textInputAction: TextInputAction.done,
|
|
|
|
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
|
|
|
|
focusNode: _nodeText1,
|
|
|
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
|
|
|
value == null || value == ''
|
|
|
|
|
|
|
|
? _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientMobileNumber =
|
|
|
|
|
|
|
|
"0"
|
|
|
|
|
|
|
|
: _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientMobileNumber =
|
|
|
|
|
|
|
|
value;
|
|
|
|
|
|
|
|
|
|
|
|
if (value != null &&
|
|
|
|
if (value != null &&
|
|
|
|
value.toString().trim().isEmpty) {
|
|
|
|
value
|
|
|
|
_patientSearchFormValues
|
|
|
|
.toString()
|
|
|
|
.setPatientMobileNumber = "0";
|
|
|
|
.trim()
|
|
|
|
}
|
|
|
|
.isEmpty) {
|
|
|
|
},
|
|
|
|
_patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientMobileNumber = "0";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
SizedBox(
|
|
|
|
Container(
|
|
|
|
height: 10,
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
),
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
Container(
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
border: Border.all(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
width: 1.0,
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
border: Border.all(
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
width: 1.0,
|
|
|
|
child: AppTextFormField(
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
.middleName,
|
|
|
|
child: AppTextFormField(
|
|
|
|
borderColor: Colors.white,
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
onSaved: (value) {
|
|
|
|
.middleName,
|
|
|
|
value == null || value == ''
|
|
|
|
borderColor: Colors.white,
|
|
|
|
? _patientSearchFormValues
|
|
|
|
onSaved: (value) {
|
|
|
|
.setMiddleName = "0"
|
|
|
|
value == null || value == ''
|
|
|
|
: _patientSearchFormValues
|
|
|
|
? _patientSearchFormValues
|
|
|
|
.setMiddleName = value;
|
|
|
|
.setMiddleName = "0"
|
|
|
|
if (value != null &&
|
|
|
|
: _patientSearchFormValues
|
|
|
|
value
|
|
|
|
.setMiddleName = value;
|
|
|
|
.toString()
|
|
|
|
if (value != null &&
|
|
|
|
.trim()
|
|
|
|
value.toString().trim().isEmpty) {
|
|
|
|
.isEmpty) {
|
|
|
|
_patientSearchFormValues
|
|
|
|
_patientSearchFormValues
|
|
|
|
.setMiddleName = "0";
|
|
|
|
.setMiddleName = "0";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
// validator: (value) {
|
|
|
|
// validator: (value) {
|
|
|
|
// return TextValidator().validateName(value);
|
|
|
|
// return TextValidator().validateName(value);
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
inputFormatter: ONLY_LETTERS),
|
|
|
|
inputFormatter: ONLY_LETTERS),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
SizedBox(
|
|
|
|
SizedBox(
|
|
|
|
height: 10,
|
|
|
|
height: 10,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Container(
|
|
|
|
Container(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
border: Border.all(
|
|
|
|
border: Border.all(
|
|
|
|
width: 1.0,
|
|
|
|
width: 1.0,
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
child: AppTextFormField(
|
|
|
|
child: AppTextFormField(
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
.lastName,
|
|
|
|
.lastName,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
onSaved: (value) {
|
|
|
|
onSaved: (value) {
|
|
|
|
value == null || value == ''
|
|
|
|
value == null || value == ''
|
|
|
|
? _patientSearchFormValues
|
|
|
|
? _patientSearchFormValues
|
|
|
|
.setLastName = "0"
|
|
|
|
.setLastName = "0"
|
|
|
|
: _patientSearchFormValues
|
|
|
|
: _patientSearchFormValues
|
|
|
|
.setLastName = value;
|
|
|
|
.setLastName = value;
|
|
|
|
if (value != null &&
|
|
|
|
if (value != null &&
|
|
|
|
value.toString().trim().isEmpty) {
|
|
|
|
value
|
|
|
|
_patientSearchFormValues
|
|
|
|
.toString()
|
|
|
|
.setLastName = "0";
|
|
|
|
.trim()
|
|
|
|
}
|
|
|
|
.isEmpty) {
|
|
|
|
},
|
|
|
|
_patientSearchFormValues
|
|
|
|
inputFormatter: ONLY_LETTERS),
|
|
|
|
.setLastName = "0";
|
|
|
|
),
|
|
|
|
}
|
|
|
|
SizedBox(
|
|
|
|
},
|
|
|
|
height: 10,
|
|
|
|
inputFormatter: ONLY_LETTERS),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Container(
|
|
|
|
SizedBox(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
height: 10,
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
),
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
Container(
|
|
|
|
border: Border.all(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
width: 1.0,
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
border: Border.all(
|
|
|
|
child: AppTextFormField(
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
|
|
|
|
child: AppTextFormField(
|
|
|
|
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
|
|
|
|
.patientID,
|
|
|
|
|
|
|
|
borderColor: Colors.white,
|
|
|
|
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
|
|
|
|
focusNode: _nodeText2,
|
|
|
|
|
|
|
|
onSaved: (value) {
|
|
|
|
|
|
|
|
value == null || value == ''
|
|
|
|
|
|
|
|
? _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientID = 0
|
|
|
|
|
|
|
|
: _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientID =
|
|
|
|
|
|
|
|
int.parse(value);
|
|
|
|
|
|
|
|
if (value != null &&
|
|
|
|
|
|
|
|
value
|
|
|
|
|
|
|
|
.trim()
|
|
|
|
|
|
|
|
.toString()
|
|
|
|
|
|
|
|
.isEmpty) {
|
|
|
|
|
|
|
|
_patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientID = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
border: Border.all(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
|
|
|
|
child: AppTextFormField(
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
.patientID,
|
|
|
|
.patientFile,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
borderColor: Colors.white,
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
|
|
|
|
focusNode: _nodeText3,
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
focusNode: _nodeText2,
|
|
|
|
onSaved: (value) {},
|
|
|
|
onSaved: (value) {
|
|
|
|
),
|
|
|
|
value == null || value == ''
|
|
|
|
|
|
|
|
? _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientID = 0
|
|
|
|
|
|
|
|
: _patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientID =
|
|
|
|
|
|
|
|
int.parse(value);
|
|
|
|
|
|
|
|
if (value != null &&
|
|
|
|
|
|
|
|
value.trim().toString().isEmpty) {
|
|
|
|
|
|
|
|
_patientSearchFormValues
|
|
|
|
|
|
|
|
.setPatientID = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
border: Border.all(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
padding: EdgeInsets.all(10),
|
|
|
|
|
|
|
|
child: AppTextFormField(
|
|
|
|
|
|
|
|
labelText: TranslationBase.of(context)
|
|
|
|
|
|
|
|
.patientFile,
|
|
|
|
|
|
|
|
borderColor: Colors.white,
|
|
|
|
|
|
|
|
textInputType: TextInputType.number,
|
|
|
|
|
|
|
|
focusNode: _nodeText3,
|
|
|
|
|
|
|
|
inputFormatter: ONLY_NUMBERS,
|
|
|
|
|
|
|
|
onSaved: (value) {},
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
(!(_selectedType == '2' ||
|
|
|
|
|
|
|
|
_selectedType == '4'))
|
|
|
|
|
|
|
|
? DynamicElements(
|
|
|
|
|
|
|
|
_patientSearchFormValues,
|
|
|
|
|
|
|
|
isFormSubmitted)
|
|
|
|
|
|
|
|
: SizedBox(
|
|
|
|
|
|
|
|
height: 0,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
child: Row(
|
|
|
|
|
|
|
|
mainAxisAlignment:
|
|
|
|
|
|
|
|
MainAxisAlignment.start,
|
|
|
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
border: Border.all(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color:
|
|
|
|
|
|
|
|
HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
height: 25,
|
|
|
|
|
|
|
|
width: 25,
|
|
|
|
|
|
|
|
child: Checkbox(
|
|
|
|
|
|
|
|
value: onlyArrived,
|
|
|
|
|
|
|
|
checkColor: HexColor("#2A930A"),
|
|
|
|
|
|
|
|
activeColor: Colors.white,
|
|
|
|
|
|
|
|
onChanged: (bool newValue) {
|
|
|
|
|
|
|
|
setState(() {
|
|
|
|
|
|
|
|
onlyArrived = newValue;
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
width: 12,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
AppText(
|
|
|
|
|
|
|
|
TranslationBase.of(context)
|
|
|
|
|
|
|
|
.onlyArrivedPatient,
|
|
|
|
|
|
|
|
fontSize:
|
|
|
|
|
|
|
|
SizeConfig.textMultiplier *
|
|
|
|
|
|
|
|
2),
|
|
|
|
|
|
|
|
])),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
])
|
|
|
|
|
|
|
|
: SizedBox(
|
|
|
|
|
|
|
|
height: 0,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
(!(_selectedType == '2' ||
|
|
|
|
],
|
|
|
|
_selectedType == '4'))
|
|
|
|
),
|
|
|
|
? DynamicElements(
|
|
|
|
|
|
|
|
_patientSearchFormValues,
|
|
|
|
|
|
|
|
isFormSubmitted)
|
|
|
|
|
|
|
|
: SizedBox(
|
|
|
|
|
|
|
|
height: 0,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
child: Row(
|
|
|
|
|
|
|
|
mainAxisAlignment:
|
|
|
|
|
|
|
|
MainAxisAlignment.start,
|
|
|
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
|
|
|
|
Radius.circular(6.0)),
|
|
|
|
|
|
|
|
border: Border.all(
|
|
|
|
|
|
|
|
width: 1.0,
|
|
|
|
|
|
|
|
color: HexColor("#CCCCCC"))),
|
|
|
|
|
|
|
|
height: 25,
|
|
|
|
|
|
|
|
width: 25,
|
|
|
|
|
|
|
|
child: Checkbox(
|
|
|
|
|
|
|
|
value: onlyArrived,
|
|
|
|
|
|
|
|
checkColor: HexColor("#2A930A"),
|
|
|
|
|
|
|
|
activeColor: Colors.white,
|
|
|
|
|
|
|
|
onChanged: (bool newValue) {
|
|
|
|
|
|
|
|
setState(() {
|
|
|
|
|
|
|
|
onlyArrived = newValue;
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
width: 12,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
AppText(
|
|
|
|
|
|
|
|
TranslationBase.of(context)
|
|
|
|
|
|
|
|
.onlyArrivedPatient,
|
|
|
|
|
|
|
|
fontSize:
|
|
|
|
|
|
|
|
SizeConfig.textMultiplier * 2),
|
|
|
|
|
|
|
|
])),
|
|
|
|
|
|
|
|
SizedBox(
|
|
|
|
|
|
|
|
height: 10,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
])
|
|
|
|
|
|
|
|
: SizedBox(
|
|
|
|
|
|
|
|
height: SizeConfig.screenHeight * .45,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Column(
|
|
|
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
margin: EdgeInsets.all(SizeConfig.widthMultiplier * 5),
|
|
|
|
|
|
|
|
child: Wrap(
|
|
|
|
|
|
|
|
alignment: WrapAlignment.center,
|
|
|
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
|
|
|
AppButton(
|
|
|
|
|
|
|
|
title: TranslationBase.of(context).search,
|
|
|
|
|
|
|
|
color: Colors.red[800],
|
|
|
|
|
|
|
|
onPressed: () {
|
|
|
|
|
|
|
|
_validateInputs();
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
]),
|
|
|
|
Column(
|
|
|
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
Container(
|
|
|
|
|
|
|
|
margin: EdgeInsets.all(SizeConfig.widthMultiplier * 5),
|
|
|
|
|
|
|
|
child: Wrap(
|
|
|
|
|
|
|
|
alignment: WrapAlignment.center,
|
|
|
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
|
|
|
AppButton(
|
|
|
|
|
|
|
|
title: TranslationBase.of(context).search,
|
|
|
|
|
|
|
|
color: Colors.red[800],
|
|
|
|
|
|
|
|
onPressed: () {
|
|
|
|
|
|
|
|
_validateInputs();
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|