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.
354 lines
15 KiB
Dart
354 lines
15 KiB
Dart
import 'package:doctor_app_flutter/config/shared_pref_kay.dart';
|
|
import 'package:doctor_app_flutter/routes.dart';
|
|
import 'package:doctor_app_flutter/util/dr_app_shared_pref.dart';
|
|
import 'package:flutter/services.dart';
|
|
|
|
import '../../config/size_config.dart';
|
|
import '../../widgets/shared/app_buttons_widget.dart';
|
|
import '../../widgets/shared/app_scaffold_widget.dart';
|
|
import '../../widgets/shared/app_text_form_field.dart';
|
|
import '../../widgets/shared/app_texts_widget.dart';
|
|
import '../../widgets/shared/rounded_container_widget.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/rendering.dart';
|
|
|
|
import '../../lookups/patient_lookup.dart';
|
|
import '../../models/patient_model.dart';
|
|
import '../../widgets/patients/dynamic_elements.dart';
|
|
import '../../config/config.dart';
|
|
|
|
DrAppSharedPreferances sharedPref = new DrAppSharedPreferances();
|
|
|
|
// OWNER : Ibrahim albitar
|
|
// DATE : 19-04-2020
|
|
// DESCRIPTION : Patient Search Screen.
|
|
|
|
class PatientSearchScreen extends StatefulWidget {
|
|
@override
|
|
_PatientSearchScreenState createState() => _PatientSearchScreenState();
|
|
}
|
|
|
|
class _PatientSearchScreenState extends State<PatientSearchScreen> {
|
|
String _selectedType = '1';
|
|
String _selectedLocation = '1';
|
|
|
|
final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
|
|
bool _autoValidate = false;
|
|
|
|
var _patientSearchFormValues = PatientModel(
|
|
ProjectID: 15,
|
|
ClinicID: 0,
|
|
DoctorID: 4709,
|
|
FirstName: "0",
|
|
MiddleName: "0",
|
|
LastName: "0",
|
|
PatientMobileNumber: "0",
|
|
PatientIdentificationID: "0",
|
|
PatientID: 0,
|
|
From: "0",
|
|
To: "0",
|
|
LanguageID: 2,
|
|
stamp: "2020-03-02T13:56:39.170Z",
|
|
IPAdress: "11.11.11.11",
|
|
VersionID: 1.2,
|
|
Channel: 9,
|
|
TokenID: "2Fi7HoIHB0eDyekVa6tCJg==",
|
|
SessionID: "5G0yXn0Jnq",
|
|
IsLoginForDoctorApp: true,
|
|
PatientOutSA: false);
|
|
|
|
void _validateInputs() {
|
|
print("####IBRAHIM TEST#####"+_patientSearchFormValues.From);
|
|
// _patientSearchFormValues.TokenID =
|
|
|
|
if (_formKey.currentState.validate()) {
|
|
// If all data are correct then save data to out variables
|
|
_formKey.currentState.save();
|
|
|
|
sharedPref.getString(TOKEN).then((token) {
|
|
print(token+"EEEEEE");
|
|
_patientSearchFormValues.TokenID = token;
|
|
_patientSearchFormValues.ProjectID= 15;
|
|
print(_patientSearchFormValues.PatientMobileNumber+"dfdfdfddf");
|
|
Navigator.of(context).pushNamed(PATIENTS, arguments: {
|
|
"patientSearchForm": _patientSearchFormValues,
|
|
"selectedType": _selectedType
|
|
});
|
|
});
|
|
} else {
|
|
// If all data are not valid then start auto validation.
|
|
setState(() {
|
|
_autoValidate = true;
|
|
});
|
|
}
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return AppScaffold(
|
|
appBarTitle: "SEARCH FOR PATIENT",
|
|
body: ListView(
|
|
children: <Widget>[
|
|
RoundedContainer(
|
|
child: Column(
|
|
children: <Widget>[
|
|
Icon(
|
|
Icons.search,
|
|
size: SizeConfig.imageSizeMultiplier * 15,
|
|
),
|
|
Container(
|
|
padding: EdgeInsets.all(15),
|
|
width: SizeConfig.screenWidth * 1,
|
|
child: Form(
|
|
key: _formKey,
|
|
autovalidate: _autoValidate,
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: <Widget>[
|
|
SizedBox(
|
|
height: 5,
|
|
),
|
|
RoundedContainer(
|
|
margin: 0,
|
|
showBorder: true,
|
|
raduis: 30,
|
|
borderColor: Color(0xff707070),
|
|
width: double.infinity,
|
|
child: Padding(
|
|
padding: EdgeInsets.only(
|
|
top: SizeConfig.widthMultiplier * 0.9,
|
|
bottom: SizeConfig.widthMultiplier * 0.9,
|
|
right: SizeConfig.widthMultiplier * 3,
|
|
left: SizeConfig.widthMultiplier * 3),
|
|
child: Row(
|
|
mainAxisSize: MainAxisSize.max,
|
|
children: <Widget>[
|
|
Expanded(
|
|
// add Expanded to have your dropdown button fill remaining space
|
|
child: DropdownButton(
|
|
isExpanded: true,
|
|
value: _selectedType,
|
|
iconSize: 40,
|
|
elevation: 16,
|
|
selectedItemBuilder:
|
|
(BuildContext context) {
|
|
return PATIENT_TYPE.map((item) {
|
|
return Row(
|
|
mainAxisSize: MainAxisSize.max,
|
|
children: <Widget>[
|
|
AppText(
|
|
item['text'],
|
|
fontSize:
|
|
SizeConfig.textMultiplier *
|
|
2.1,
|
|
),
|
|
],
|
|
);
|
|
}).toList();
|
|
},
|
|
onChanged: (String newValue) => {
|
|
setState(() {
|
|
_selectedType = newValue;
|
|
})
|
|
},
|
|
items: PATIENT_TYPE.map((item) {
|
|
return DropdownMenuItem(
|
|
child: Text(
|
|
'${item['text']}',
|
|
textAlign: TextAlign.end,
|
|
),
|
|
value: item['val'],
|
|
);
|
|
}).toList(),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFormField(
|
|
hintText: 'First Name',
|
|
onSaved: (value) {
|
|
_patientSearchFormValues.FirstName = value;
|
|
},
|
|
// validator: (value) {
|
|
// return TextValidator().validateName(value);
|
|
// },
|
|
inputFormatter: ONLY_LETTERS
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFormField(
|
|
hintText: 'Middle Name',
|
|
onSaved: (value) {
|
|
_patientSearchFormValues.MiddleName = value;
|
|
},
|
|
// validator: (value) {
|
|
// return TextValidator().validateName(value);
|
|
// },
|
|
inputFormatter: ONLY_LETTERS
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFormField(
|
|
hintText: 'Last Name',
|
|
onSaved: (value) {
|
|
_patientSearchFormValues.LastName = value;
|
|
},
|
|
// validator: (value) {
|
|
// return TextValidator().validateName(value);
|
|
// },
|
|
inputFormatter: ONLY_LETTERS
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFormField(
|
|
textInputType: TextInputType.number,
|
|
hintText: 'Phone Number',
|
|
// validator: (value) {
|
|
// return TextValidator().validateMobile(value);
|
|
// },
|
|
inputFormatter: ONLY_NUMBERS,
|
|
onSaved: (value) {
|
|
_patientSearchFormValues.PatientMobileNumber =
|
|
value;
|
|
},
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFormField(
|
|
textInputType: TextInputType.number,
|
|
hintText: 'Patiant ID',
|
|
//
|
|
inputFormatter: ONLY_NUMBERS,
|
|
onSaved: (value) {
|
|
_patientSearchFormValues.PatientID = 89000;
|
|
}),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
AppTextFormField(
|
|
textInputType: TextInputType.number,
|
|
hintText: 'Patiant File',
|
|
// validator: (value) {
|
|
// return TextValidator().validateIdNumber(value);
|
|
// },
|
|
inputFormatter: ONLY_NUMBERS,
|
|
onSaved: (value) {
|
|
//_patientSearchFormValues. = value;
|
|
},
|
|
),
|
|
(!(_selectedType == '3' || _selectedType == '5'))
|
|
? DynamicElements(_patientSearchFormValues)
|
|
: SizedBox(
|
|
height: 0,
|
|
),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
RoundedContainer(
|
|
margin: 0,
|
|
showBorder: true,
|
|
raduis: 30,
|
|
borderColor: Color(0xff707070),
|
|
width: double.infinity,
|
|
child: Padding(
|
|
padding: EdgeInsets.only(
|
|
top: SizeConfig.widthMultiplier * 0.9,
|
|
bottom: SizeConfig.widthMultiplier * 0.9,
|
|
right: SizeConfig.widthMultiplier * 3,
|
|
left: SizeConfig.widthMultiplier * 3),
|
|
child: Row(
|
|
mainAxisSize: MainAxisSize.max,
|
|
children: <Widget>[
|
|
Expanded(
|
|
// add Expanded to have your dropdown button fill remaining space
|
|
child: DropdownButton(
|
|
isExpanded: true,
|
|
value: _selectedLocation,
|
|
iconSize: 40,
|
|
elevation: 16,
|
|
selectedItemBuilder:
|
|
(BuildContext context) {
|
|
return LOCATIONS.map((item) {
|
|
return Row(
|
|
mainAxisSize: MainAxisSize.max,
|
|
children: <Widget>[
|
|
AppText(
|
|
item['text'],
|
|
fontSize:
|
|
SizeConfig.textMultiplier *
|
|
2.1,
|
|
),
|
|
],
|
|
);
|
|
}).toList();
|
|
},
|
|
onChanged: (String newValue) => {
|
|
setState(() {
|
|
_selectedLocation = newValue;
|
|
})
|
|
},
|
|
items: LOCATIONS.map((item) {
|
|
return DropdownMenuItem(
|
|
child: Text(
|
|
'${item['text']}',
|
|
textAlign: TextAlign.end,
|
|
),
|
|
value: item['val'],
|
|
);
|
|
}).toList(),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
Container(
|
|
child: Row(
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
children: <Widget>[
|
|
Checkbox(
|
|
value: true,
|
|
activeColor: Color(0xffFFDDD9),
|
|
onChanged: (bool newValue) {}),
|
|
AppText('Only Arrived Patient',
|
|
fontSize: SizeConfig.textMultiplier * 2),
|
|
])),
|
|
SizedBox(
|
|
height: 10,
|
|
),
|
|
],
|
|
),
|
|
),
|
|
)
|
|
],
|
|
),
|
|
),
|
|
Container(
|
|
margin: EdgeInsets.all(SizeConfig.widthMultiplier * 5),
|
|
child: Wrap(
|
|
alignment: WrapAlignment.center,
|
|
children: <Widget>[
|
|
AppButton(
|
|
title: "Search",
|
|
color: Color(0xff58434F),
|
|
onPressed: () {
|
|
_validateInputs();
|
|
},
|
|
),
|
|
],
|
|
),
|
|
)
|
|
],
|
|
));
|
|
}
|
|
}
|