QOL: Patient Manager get data on package open
This commit is contained in:
@@ -4,11 +4,7 @@ import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_icons.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/arguments.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/patient_manager_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_config/mih_colors.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_patient_services.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class PatientProfileTile extends StatefulWidget {
|
||||
final PatientViewArguments arguments;
|
||||
@@ -30,29 +26,7 @@ class _PatientProfileTileState extends State<PatientProfileTile> {
|
||||
return MihPackageTile(
|
||||
authenticateUser: true,
|
||||
onTap: () async {
|
||||
PatientManagerProvider patientManagerProvider =
|
||||
context.read<PatientManagerProvider>();
|
||||
MzansiProfileProvider profileProvider =
|
||||
context.read<MzansiProfileProvider>();
|
||||
String? app_id = profileProvider.user!.app_id;
|
||||
if (patientManagerProvider.selectedPatient == null) {
|
||||
await MihPatientServices()
|
||||
.getPatientDetails(app_id, patientManagerProvider);
|
||||
}
|
||||
patientManagerProvider.setSelectedPatientProfilePicUrl(
|
||||
profileProvider.userProfilePicUrl!);
|
||||
patientManagerProvider.setPersonalMode(true);
|
||||
if (patientManagerProvider.selectedPatient != null) {
|
||||
context.goNamed(
|
||||
'patientProfile',
|
||||
);
|
||||
} else {
|
||||
context.goNamed("patientProfileSetup");
|
||||
}
|
||||
// Navigator.of(context).pushNamed(
|
||||
// '/patient-profile',
|
||||
// arguments: widget.arguments,
|
||||
// );
|
||||
context.goNamed("patientProfile");
|
||||
},
|
||||
appName: "Patient Profile",
|
||||
appIcon: Icon(
|
||||
|
||||
@@ -3,6 +3,7 @@ import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_action.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tools.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_pop_up_messages/mih_loading_circle.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/patient_manager_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_packages/patient_manager/pat_profile/package_tools/patient_claim_or_statement.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_packages/patient_manager/pat_profile/package_tools/patient_consultation.dart';
|
||||
@@ -10,6 +11,7 @@ import 'package:mzansi_innovation_hub/mih_packages/patient_manager/pat_profile/p
|
||||
import 'package:mzansi_innovation_hub/mih_packages/patient_manager/pat_profile/package_tools/patient_info.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_claim_statement_generation_services.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_data_helper_services.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_patient_services.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
@@ -23,14 +25,30 @@ class PatientProfile extends StatefulWidget {
|
||||
}
|
||||
|
||||
class _PatientProfileState extends State<PatientProfile> {
|
||||
bool isLoading = true;
|
||||
bool _isLoadingInitialData = true;
|
||||
|
||||
Future<void> initialisePatientData() async {
|
||||
Future<void> _loadInitialData() async {
|
||||
setState(() {
|
||||
isLoading = true;
|
||||
_isLoadingInitialData = true;
|
||||
});
|
||||
MzansiProfileProvider mzansiProfileProvider =
|
||||
context.read<MzansiProfileProvider>();
|
||||
PatientManagerProvider patientManagerProvider =
|
||||
context.read<PatientManagerProvider>();
|
||||
await MihDataHelperServices().loadUserDataOnly(
|
||||
mzansiProfileProvider,
|
||||
);
|
||||
if (patientManagerProvider.selectedPatient == null) {
|
||||
await MihPatientServices().getPatientDetails(
|
||||
mzansiProfileProvider.user!.app_id, patientManagerProvider);
|
||||
}
|
||||
if (patientManagerProvider.selectedPatient == null) {
|
||||
context.goNamed("patientProfileSetup");
|
||||
return;
|
||||
}
|
||||
patientManagerProvider.setSelectedPatientProfilePicUrl(
|
||||
mzansiProfileProvider.userProfilePicUrl!);
|
||||
patientManagerProvider.setPersonalMode(mzansiProfileProvider.personalHome);
|
||||
if (patientManagerProvider.selectedPatient != null) {
|
||||
await MihPatientServices()
|
||||
.getPatientConsultationNotes(patientManagerProvider);
|
||||
@@ -39,29 +57,41 @@ class _PatientProfileState extends State<PatientProfile> {
|
||||
patientManagerProvider);
|
||||
}
|
||||
setState(() {
|
||||
isLoading = false;
|
||||
_isLoadingInitialData = false;
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
||||
initialisePatientData();
|
||||
});
|
||||
_loadInitialData();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return MihPackage(
|
||||
appActionButton: getAction(),
|
||||
appTools: getTools(),
|
||||
appBody: getToolBody(),
|
||||
appToolTitles: getToolTitle(),
|
||||
selectedbodyIndex:
|
||||
context.watch<PatientManagerProvider>().patientProfileIndex,
|
||||
onIndexChange: (newValue) {
|
||||
context.read<PatientManagerProvider>().setPatientProfileIndex(newValue);
|
||||
return Consumer<PatientManagerProvider>(
|
||||
builder: (BuildContext context,
|
||||
PatientManagerProvider patientManagerProvider, Widget? child) {
|
||||
if (_isLoadingInitialData) {
|
||||
return Scaffold(
|
||||
body: Center(
|
||||
child: Mihloadingcircle(),
|
||||
),
|
||||
);
|
||||
}
|
||||
return MihPackage(
|
||||
appActionButton: getAction(),
|
||||
appTools: getTools(),
|
||||
appBody: getToolBody(),
|
||||
appToolTitles: getToolTitle(),
|
||||
selectedbodyIndex:
|
||||
context.watch<PatientManagerProvider>().patientProfileIndex,
|
||||
onIndexChange: (newValue) {
|
||||
context
|
||||
.read<PatientManagerProvider>()
|
||||
.setPatientProfileIndex(newValue);
|
||||
},
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
@@ -109,20 +139,6 @@ class _PatientProfileState extends State<PatientProfile> {
|
||||
}
|
||||
|
||||
List<Widget> getToolBody() {
|
||||
if (isLoading) {
|
||||
return [
|
||||
Center(
|
||||
child: Mihloadingcircle(),
|
||||
),
|
||||
];
|
||||
}
|
||||
PatientManagerProvider patientManagerProvider =
|
||||
context.read<PatientManagerProvider>();
|
||||
if (patientManagerProvider.selectedPatient == null) {
|
||||
return [
|
||||
const SizedBox(),
|
||||
];
|
||||
}
|
||||
List<Widget> toolBodies = [
|
||||
PatientInfo(),
|
||||
PatientConsultation(),
|
||||
|
||||
Reference in New Issue
Block a user