|
|
|
@ -3,6 +3,7 @@ import 'package:doctor_app_flutter/config/size_config.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/models/clinic_model.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/models/doctor_profile_model.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/models/profile_req_Model.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/presentation/doctor_app_icons.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/providers/auth_provider.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/providers/doctor_reply_provider.dart';
|
|
|
|
|
import 'package:doctor_app_flutter/providers/hospital_provider.dart';
|
|
|
|
@ -36,6 +37,7 @@ class DashboardScreen extends StatefulWidget {
|
|
|
|
|
|
|
|
|
|
final String title;
|
|
|
|
|
final String iconURL = 'assets/images/dashboard_icon/';
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
_DashboardScreenState createState() => _DashboardScreenState();
|
|
|
|
|
}
|
|
|
|
@ -44,6 +46,7 @@ class _DashboardScreenState extends State<DashboardScreen> {
|
|
|
|
|
HospitalProvider hospitalProvider;
|
|
|
|
|
AuthProvider authProvider;
|
|
|
|
|
bool isLoading = false;
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
hospitalProvider = Provider.of(context);
|
|
|
|
@ -428,4 +431,96 @@ class _DashboardScreenState extends State<DashboardScreen> {
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
showCupertinoPicker(
|
|
|
|
|
{context, List<ClinicModel> actionList, decKey, onSelectFun}) {
|
|
|
|
|
showModalBottomSheet(
|
|
|
|
|
isDismissible: false,
|
|
|
|
|
isScrollControlled: true,
|
|
|
|
|
context: context,
|
|
|
|
|
builder: (BuildContext builder) {
|
|
|
|
|
return Container(
|
|
|
|
|
// height: 500,
|
|
|
|
|
height: SizeConfig.realScreenHeight * 0.4,
|
|
|
|
|
color: Color(0xfff7f7f7),
|
|
|
|
|
child: Column(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
Container(
|
|
|
|
|
color: Color(0xfff7f7f7),
|
|
|
|
|
child: Row(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
CupertinoButton(
|
|
|
|
|
child: Text(
|
|
|
|
|
'Cancel'.toUpperCase(),
|
|
|
|
|
// style: TextStyle(context)
|
|
|
|
|
),
|
|
|
|
|
onPressed: () {
|
|
|
|
|
Navigator.pop(context);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
CupertinoButton(
|
|
|
|
|
child: Text(
|
|
|
|
|
'Done'.toUpperCase(),
|
|
|
|
|
// style: textStyle(context),
|
|
|
|
|
),
|
|
|
|
|
onPressed: () {
|
|
|
|
|
Navigator.pop(context);
|
|
|
|
|
// onSelectFun(cupertinoPickerIndex);
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Container(
|
|
|
|
|
height: SizeConfig.realScreenHeight * 0.3,
|
|
|
|
|
color: Color(0xfff7f7f7),
|
|
|
|
|
child: Column(
|
|
|
|
|
children: actionList
|
|
|
|
|
.map((e) => Container(
|
|
|
|
|
child: InkWell(
|
|
|
|
|
onTap: () =>
|
|
|
|
|
changeClinic(e.clinicID, context),
|
|
|
|
|
child: Text(
|
|
|
|
|
e.clinicName,
|
|
|
|
|
style: TextStyle(fontSize: 15),
|
|
|
|
|
)),
|
|
|
|
|
))
|
|
|
|
|
.toList(),
|
|
|
|
|
))
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
changeClinic(clinicId, BuildContext context) async {
|
|
|
|
|
Navigator.pop(context);
|
|
|
|
|
changeIsLoading(true);
|
|
|
|
|
Map profile = await sharedPref.getObj(DOCTOR_PROFILE);
|
|
|
|
|
DoctorProfileModel doctorProfile = new DoctorProfileModel.fromJson(profile);
|
|
|
|
|
ProfileReqModel docInfo = new ProfileReqModel(
|
|
|
|
|
doctorID: doctorProfile.doctorID,
|
|
|
|
|
clinicID: clinicId,
|
|
|
|
|
license: true,
|
|
|
|
|
projectID: doctorProfile.projectID,
|
|
|
|
|
tokenID: '',
|
|
|
|
|
languageID: 2);
|
|
|
|
|
|
|
|
|
|
// authProvider.getDocProfiles(docInfo)
|
|
|
|
|
authProvider.getDocProfiles(docInfo.toJson()).then((res) async {
|
|
|
|
|
changeIsLoading(false);
|
|
|
|
|
sharedPref.setObj(DOCTOR_PROFILE, res['DoctorProfileList'][0]);
|
|
|
|
|
}).catchError((err) {
|
|
|
|
|
changeIsLoading(false);
|
|
|
|
|
helpers.showErrorToast(err);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
changeIsLoading(bool val) {
|
|
|
|
|
setState(() {
|
|
|
|
|
this.isLoading = val;
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|