NEW: MIH Access Controlls Provider Setup
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:go_router/go_router.dart';
|
import 'package:go_router/go_router.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/about_mih_provider.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/about_mih_provider.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_access_controlls_provider.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_authentication_provider.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_authentication_provider.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_banner_ad_provider.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_banner_ad_provider.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_calculator_provider.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_calculator_provider.dart';
|
||||||
@@ -96,6 +97,9 @@ class _MzansiInnovationHubState extends State<MzansiInnovationHub> {
|
|||||||
ChangeNotifierProvider(
|
ChangeNotifierProvider(
|
||||||
create: (context) => MihCalculatorProvider(),
|
create: (context) => MihCalculatorProvider(),
|
||||||
),
|
),
|
||||||
|
ChangeNotifierProvider(
|
||||||
|
create: (context) => MihAccessControllsProvider(),
|
||||||
|
),
|
||||||
ChangeNotifierProvider(
|
ChangeNotifierProvider(
|
||||||
create: (context) => MihCalendarProvider(),
|
create: (context) => MihCalendarProvider(),
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -0,0 +1,31 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_components/mih_objects/patient_access.dart';
|
||||||
|
|
||||||
|
class MihAccessControllsProvider extends ChangeNotifier {
|
||||||
|
int toolIndex;
|
||||||
|
List<PatientAccess>? accessList;
|
||||||
|
|
||||||
|
MihAccessControllsProvider({
|
||||||
|
this.toolIndex = 0,
|
||||||
|
});
|
||||||
|
|
||||||
|
void setToolIndex(int index) {
|
||||||
|
toolIndex = index;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setAccessList(List<PatientAccess> accesses) {
|
||||||
|
accessList = accesses;
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
|
||||||
|
void editAccessItem(PatientAccess updatedAccess) {
|
||||||
|
if (accessList == null) return;
|
||||||
|
int index = accessList!.indexWhere((access) =>
|
||||||
|
access.app_id == updatedAccess.app_id &&
|
||||||
|
access.business_id == updatedAccess.business_id);
|
||||||
|
if (index != -1) {
|
||||||
|
accessList![index] = updatedAccess;
|
||||||
|
notifyListeners();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -321,8 +321,7 @@ class MihGoRouter {
|
|||||||
name: "mihAccess",
|
name: "mihAccess",
|
||||||
path: MihGoRouterPaths.mihAccess,
|
path: MihGoRouterPaths.mihAccess,
|
||||||
builder: (BuildContext context, GoRouterState state) {
|
builder: (BuildContext context, GoRouterState state) {
|
||||||
final AppUser? signedInUser = state.extra as AppUser?;
|
if (context.watch<MzansiProfileProvider>().business == null) {
|
||||||
if (signedInUser == null) {
|
|
||||||
WidgetsBinding.instance.addPostFrameCallback((_) {
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
||||||
context.go(MihGoRouterPaths.mihHome);
|
context.go(MihGoRouterPaths.mihHome);
|
||||||
});
|
});
|
||||||
@@ -330,7 +329,6 @@ class MihGoRouter {
|
|||||||
}
|
}
|
||||||
return MihAccess(
|
return MihAccess(
|
||||||
key: UniqueKey(),
|
key: UniqueKey(),
|
||||||
signedInUser: signedInUser,
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -2,15 +2,14 @@ import 'package:go_router/go_router.dart';
|
|||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package.dart';
|
||||||
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_action.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tools.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tools.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/app_user.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mih_access_controlls_provider.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_packages/access_review/package_tools/mih_access_requests.dart';
|
import 'package:mzansi_innovation_hub/mih_packages/access_review/package_tools/mih_access_requests.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
|
||||||
class MihAccess extends StatefulWidget {
|
class MihAccess extends StatefulWidget {
|
||||||
final AppUser signedInUser;
|
|
||||||
const MihAccess({
|
const MihAccess({
|
||||||
super.key,
|
super.key,
|
||||||
required this.signedInUser,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
@@ -18,7 +17,6 @@ class MihAccess extends StatefulWidget {
|
|||||||
}
|
}
|
||||||
|
|
||||||
class _MihAccessState extends State<MihAccess> {
|
class _MihAccessState extends State<MihAccess> {
|
||||||
int _selcetedIndex = 0;
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return MihPackage(
|
return MihPackage(
|
||||||
@@ -26,12 +24,9 @@ class _MihAccessState extends State<MihAccess> {
|
|||||||
appTools: getTools(),
|
appTools: getTools(),
|
||||||
appBody: getToolBody(),
|
appBody: getToolBody(),
|
||||||
appToolTitles: getToolTitle(),
|
appToolTitles: getToolTitle(),
|
||||||
selectedbodyIndex: _selcetedIndex,
|
selectedbodyIndex: context.watch<MihAccessControllsProvider>().toolIndex,
|
||||||
onIndexChange: (newValue) {
|
onIndexChange: (newValue) {
|
||||||
setState(() {
|
context.read<MihAccessControllsProvider>().setToolIndex(newValue);
|
||||||
_selcetedIndex = newValue;
|
|
||||||
});
|
|
||||||
print("Index: $_selcetedIndex");
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -52,21 +47,17 @@ class _MihAccessState extends State<MihAccess> {
|
|||||||
MihPackageTools getTools() {
|
MihPackageTools getTools() {
|
||||||
Map<Widget, void Function()?> temp = {};
|
Map<Widget, void Function()?> temp = {};
|
||||||
temp[const Icon(Icons.people)] = () {
|
temp[const Icon(Icons.people)] = () {
|
||||||
setState(() {
|
context.read<MihAccessControllsProvider>().setToolIndex(0);
|
||||||
_selcetedIndex = 0;
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
return MihPackageTools(
|
return MihPackageTools(
|
||||||
tools: temp,
|
tools: temp,
|
||||||
selcetedIndex: _selcetedIndex,
|
selcetedIndex: context.watch<MihAccessControllsProvider>().toolIndex,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Widget> getToolBody() {
|
List<Widget> getToolBody() {
|
||||||
List<Widget> toolBodies = [
|
List<Widget> toolBodies = [
|
||||||
MihAccessRequest(
|
MihAccessRequest(),
|
||||||
signedInUser: widget.signedInUser,
|
|
||||||
),
|
|
||||||
];
|
];
|
||||||
return toolBodies;
|
return toolBodies;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,17 +2,14 @@ import 'package:go_router/go_router.dart';
|
|||||||
import 'package:mzansi_innovation_hub/main.dart';
|
import 'package:mzansi_innovation_hub/main.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tile.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tile.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_icons.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_icons.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/app_user.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_config/mih_colors.dart';
|
import 'package:mzansi_innovation_hub/mih_config/mih_colors.dart';
|
||||||
|
|
||||||
class MihAccessTile extends StatefulWidget {
|
class MihAccessTile extends StatefulWidget {
|
||||||
final AppUser signedInUser;
|
|
||||||
final double packageSize;
|
final double packageSize;
|
||||||
|
|
||||||
const MihAccessTile({
|
const MihAccessTile({
|
||||||
super.key,
|
super.key,
|
||||||
required this.signedInUser,
|
|
||||||
required this.packageSize,
|
required this.packageSize,
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -28,7 +25,6 @@ class _MihAccessTileState extends State<MihAccessTile> {
|
|||||||
onTap: () {
|
onTap: () {
|
||||||
context.goNamed(
|
context.goNamed(
|
||||||
"mihAccess",
|
"mihAccess",
|
||||||
extra: widget.signedInUser,
|
|
||||||
);
|
);
|
||||||
// Navigator.of(context).pushNamed(
|
// Navigator.of(context).pushNamed(
|
||||||
// '/mih-access',
|
// '/mih-access',
|
||||||
|
|||||||
@@ -1,28 +1,24 @@
|
|||||||
import 'package:go_router/go_router.dart';
|
import 'package:go_router/go_router.dart';
|
||||||
import 'package:ken_logger/ken_logger.dart';
|
import 'package:ken_logger/ken_logger.dart';
|
||||||
import 'package:mzansi_innovation_hub/main.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_layout/mih_action.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_icons.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_layout/mih_header.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_config/mih_colors.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_objects/patient_access.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/mih_access_controlls_provider.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_config/mih_env.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_packages/access_review/builder/build_business_access_list.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_services/mih_access_controls_services.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_services/mih_validation_services.dart';
|
import 'package:mzansi_innovation_hub/mih_services/mih_validation_services.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_single_child_scroll.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_single_child_scroll.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_dropdwn_field.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_dropdwn_field.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tool_body.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tool_body.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import '../../../mih_services/mih_service_calls.dart';
|
import 'package:provider/provider.dart';
|
||||||
import '../../../mih_components/mih_layout/mih_action.dart';
|
|
||||||
import '../../../mih_components/mih_layout/mih_header.dart';
|
|
||||||
import '../../../mih_components/mih_pop_up_messages/mih_loading_circle.dart';
|
|
||||||
import '../../../mih_config/mih_env.dart';
|
|
||||||
import '../../../mih_components/mih_objects/app_user.dart';
|
|
||||||
import '../../../mih_components/mih_objects/patient_access.dart';
|
|
||||||
import '../builder/build_business_access_list.dart';
|
|
||||||
|
|
||||||
class MihAccessRequest extends StatefulWidget {
|
class MihAccessRequest extends StatefulWidget {
|
||||||
final AppUser signedInUser;
|
|
||||||
|
|
||||||
const MihAccessRequest({
|
const MihAccessRequest({
|
||||||
super.key,
|
super.key,
|
||||||
required this.signedInUser,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
@@ -31,7 +27,7 @@ class MihAccessRequest extends StatefulWidget {
|
|||||||
|
|
||||||
class _MihAccessRequestState extends State<MihAccessRequest> {
|
class _MihAccessRequestState extends State<MihAccessRequest> {
|
||||||
TextEditingController filterController = TextEditingController();
|
TextEditingController filterController = TextEditingController();
|
||||||
|
bool isLoading = true;
|
||||||
String baseUrl = AppEnviroment.baseApiUrl;
|
String baseUrl = AppEnviroment.baseApiUrl;
|
||||||
|
|
||||||
String errorCode = "";
|
String errorCode = "";
|
||||||
@@ -41,35 +37,8 @@ class _MihAccessRequestState extends State<MihAccessRequest> {
|
|||||||
bool forceRefresh = false;
|
bool forceRefresh = false;
|
||||||
late String selectedDropdown;
|
late String selectedDropdown;
|
||||||
|
|
||||||
late Future<List<PatientAccess>> accessList;
|
|
||||||
|
|
||||||
// Future<List<AccessRequest>> fetchAccessRequests() async {
|
|
||||||
// //print("Patien manager page: $endpoint");
|
|
||||||
// final response = await http.get(
|
|
||||||
// Uri.parse("$baseUrl/access-requests/${widget.signedInUser.app_id}"));
|
|
||||||
// // print("Here");
|
|
||||||
// // print("Body: ${response.body}");
|
|
||||||
// // print("Code: ${response.statusCode}");
|
|
||||||
// errorCode = response.statusCode.toString();
|
|
||||||
// errorBody = response.body;
|
|
||||||
|
|
||||||
// if (response.statusCode == 200) {
|
|
||||||
// //print("Here1");
|
|
||||||
// Iterable l = jsonDecode(response.body);
|
|
||||||
// //print("Here2");
|
|
||||||
// List<AccessRequest> patientQueue = List<AccessRequest>.from(
|
|
||||||
// l.map((model) => AccessRequest.fromJson(model)));
|
|
||||||
// //print("Here3");
|
|
||||||
// //print(patientQueue);
|
|
||||||
// return patientQueue;
|
|
||||||
// } else {
|
|
||||||
// throw Exception('failed to load patients');
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
List<PatientAccess> filterSearchResults(List<PatientAccess> accessList) {
|
List<PatientAccess> filterSearchResults(List<PatientAccess> accessList) {
|
||||||
List<PatientAccess> templist = [];
|
List<PatientAccess> templist = [];
|
||||||
|
|
||||||
for (var item in accessList) {
|
for (var item in accessList) {
|
||||||
if (filterController.text == "All") {
|
if (filterController.text == "All") {
|
||||||
templist.add(item);
|
templist.add(item);
|
||||||
@@ -83,16 +52,24 @@ class _MihAccessRequestState extends State<MihAccessRequest> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void refreshList() {
|
void refreshList() {
|
||||||
|
MzansiProfileProvider mzansiProfileProvider =
|
||||||
|
context.read<MzansiProfileProvider>();
|
||||||
|
MihAccessControllsProvider accessProvider =
|
||||||
|
context.read<MihAccessControllsProvider>();
|
||||||
if (forceRefresh == true) {
|
if (forceRefresh == true) {
|
||||||
|
MihAccessControlsServices().getBusinessAccessListOfPatient(
|
||||||
|
mzansiProfileProvider.user!.app_id,
|
||||||
|
accessProvider,
|
||||||
|
);
|
||||||
setState(() {
|
setState(() {
|
||||||
accessList = MIHApiCalls.getBusinessAccessListOfPatient(
|
|
||||||
widget.signedInUser.app_id);
|
|
||||||
forceRefresh = false;
|
forceRefresh = false;
|
||||||
});
|
});
|
||||||
} else if (selectedDropdown != filterController.text) {
|
} else if (selectedDropdown != filterController.text) {
|
||||||
|
MihAccessControlsServices().getBusinessAccessListOfPatient(
|
||||||
|
mzansiProfileProvider.user!.app_id,
|
||||||
|
accessProvider,
|
||||||
|
);
|
||||||
setState(() {
|
setState(() {
|
||||||
accessList = MIHApiCalls.getBusinessAccessListOfPatient(
|
|
||||||
widget.signedInUser.app_id);
|
|
||||||
selectedDropdown = filterController.text;
|
selectedDropdown = filterController.text;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -131,166 +108,92 @@ class _MihAccessRequestState extends State<MihAccessRequest> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Widget getBody() {
|
Widget getBody() {
|
||||||
return MihSingleChildScroll(
|
return Consumer2<MzansiProfileProvider, MihAccessControllsProvider>(
|
||||||
child: Column(
|
builder: (BuildContext context,
|
||||||
children: [
|
MzansiProfileProvider mzansiProfileProvider,
|
||||||
Row(
|
MihAccessControllsProvider accessProvider,
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
Widget? child) {
|
||||||
crossAxisAlignment: CrossAxisAlignment.end,
|
if (isLoading) {
|
||||||
mainAxisSize: MainAxisSize.max,
|
return const Center(
|
||||||
|
child: Mihloadingcircle(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return MihSingleChildScroll(
|
||||||
|
child: Column(
|
||||||
children: [
|
children: [
|
||||||
Flexible(
|
Row(
|
||||||
child: MihDropdownField(
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
controller: filterController,
|
crossAxisAlignment: CrossAxisAlignment.end,
|
||||||
hintText: "Access Type",
|
mainAxisSize: MainAxisSize.max,
|
||||||
dropdownOptions: const [
|
children: [
|
||||||
"All",
|
Flexible(
|
||||||
"Approved",
|
child: MihDropdownField(
|
||||||
"Pending",
|
controller: filterController,
|
||||||
"Declined",
|
hintText: "Access Type",
|
||||||
"Cancelled",
|
dropdownOptions: const [
|
||||||
],
|
"All",
|
||||||
requiredText: true,
|
"Approved",
|
||||||
editable: true,
|
"Pending",
|
||||||
enableSearch: true,
|
"Declined",
|
||||||
validator: (value) {
|
"Cancelled",
|
||||||
return MihValidationServices().isEmpty(value);
|
],
|
||||||
},
|
requiredText: true,
|
||||||
),
|
editable: true,
|
||||||
),
|
enableSearch: true,
|
||||||
IconButton(
|
validator: (value) {
|
||||||
iconSize: 35,
|
return MihValidationServices().isEmpty(value);
|
||||||
onPressed: () {
|
},
|
||||||
setState(() {
|
),
|
||||||
forceRefresh = true;
|
),
|
||||||
});
|
IconButton(
|
||||||
KenLogger.warning("Refreshing Access List");
|
iconSize: 35,
|
||||||
refreshList();
|
onPressed: () {
|
||||||
},
|
|
||||||
icon: const Icon(
|
|
||||||
Icons.refresh,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
const SizedBox(height: 10),
|
|
||||||
FutureBuilder(
|
|
||||||
future: accessList,
|
|
||||||
builder: (context, snapshot) {
|
|
||||||
//print("patient Queue List ${snapshot.hasData}");
|
|
||||||
if (snapshot.connectionState == ConnectionState.waiting) {
|
|
||||||
return const Mihloadingcircle();
|
|
||||||
} else if (snapshot.connectionState == ConnectionState.done) {
|
|
||||||
List<PatientAccess> accessRequestList;
|
|
||||||
accessRequestList = filterSearchResults(snapshot.requireData);
|
|
||||||
if (accessRequestList.isNotEmpty) {
|
|
||||||
return BuildBusinessAccessList(
|
|
||||||
signedInUser: widget.signedInUser,
|
|
||||||
patientAccessList: accessRequestList,
|
|
||||||
onSuccessUpate: () {
|
|
||||||
setState(() {
|
setState(() {
|
||||||
forceRefresh = true;
|
forceRefresh = true;
|
||||||
});
|
});
|
||||||
|
KenLogger.warning("Refreshing Access List");
|
||||||
refreshList();
|
refreshList();
|
||||||
},
|
},
|
||||||
);
|
icon: const Icon(
|
||||||
} else {
|
Icons.refresh,
|
||||||
return Padding(
|
|
||||||
padding: const EdgeInsets.symmetric(horizontal: 10.0),
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.center,
|
|
||||||
children: [
|
|
||||||
const SizedBox(height: 50),
|
|
||||||
Icon(
|
|
||||||
MihIcons.accessControl,
|
|
||||||
size: 165,
|
|
||||||
color: MihColors.getSecondaryColor(
|
|
||||||
MzansiInnovationHub.of(context)!.theme.mode ==
|
|
||||||
"Dark"),
|
|
||||||
),
|
|
||||||
const SizedBox(height: 10),
|
|
||||||
Text(
|
|
||||||
"No access has been granted to your MIH Profile",
|
|
||||||
textAlign: TextAlign.center,
|
|
||||||
overflow: TextOverflow.visible,
|
|
||||||
style: TextStyle(
|
|
||||||
fontSize: 25,
|
|
||||||
fontWeight: FontWeight.bold,
|
|
||||||
color: MihColors.getSecondaryColor(
|
|
||||||
MzansiInnovationHub.of(context)!.theme.mode ==
|
|
||||||
"Dark"),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
// const SizedBox(height: 10),
|
|
||||||
// Center(
|
|
||||||
// child: RichText(
|
|
||||||
// textAlign: TextAlign.center,
|
|
||||||
// text: TextSpan(
|
|
||||||
// style: TextStyle(
|
|
||||||
// fontSize: 20,
|
|
||||||
// fontWeight: FontWeight.normal,
|
|
||||||
// color: MzansiInnovationHub.of(context)!
|
|
||||||
// .theme
|
|
||||||
// .secondaryColor(),
|
|
||||||
// ),
|
|
||||||
// children: [
|
|
||||||
// TextSpan(text: "Press "),
|
|
||||||
// WidgetSpan(
|
|
||||||
// alignment: PlaceholderAlignment.middle,
|
|
||||||
// child: Icon(
|
|
||||||
// Icons.menu,
|
|
||||||
// size: 20,
|
|
||||||
// color: MzansiInnovationHub.of(context)!
|
|
||||||
// .theme
|
|
||||||
// .secondaryColor(),
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// TextSpan(
|
|
||||||
// text: " to add your first loyalty card."),
|
|
||||||
// ],
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
],
|
|
||||||
),
|
),
|
||||||
);
|
|
||||||
// return Center(
|
|
||||||
// child: Text(
|
|
||||||
// "No Request have been made.",
|
|
||||||
// style: TextStyle(
|
|
||||||
// fontSize: 25,
|
|
||||||
// color: MzansiInnovationHub.of(context)!
|
|
||||||
// .theme
|
|
||||||
// .messageTextColor()),
|
|
||||||
// textAlign: TextAlign.center,
|
|
||||||
// ),
|
|
||||||
// );
|
|
||||||
}
|
|
||||||
|
|
||||||
// return Expanded(
|
|
||||||
// child: displayAccessRequestList(accessRequestList),
|
|
||||||
// );
|
|
||||||
} else {
|
|
||||||
return Center(
|
|
||||||
child: Text(
|
|
||||||
"$errorCode: Error pulling Patients Data\n$baseUrl/queue/patients/\n$errorBody",
|
|
||||||
style: TextStyle(
|
|
||||||
fontSize: 25,
|
|
||||||
color: MihColors.getGreenColor(
|
|
||||||
MzansiInnovationHub.of(context)!.theme.mode ==
|
|
||||||
"Dark")),
|
|
||||||
textAlign: TextAlign.center,
|
|
||||||
),
|
),
|
||||||
);
|
],
|
||||||
}
|
),
|
||||||
},
|
const SizedBox(height: 10),
|
||||||
|
BuildBusinessAccessList(
|
||||||
|
filterText: filterController.text,
|
||||||
|
onSuccessUpate: () {
|
||||||
|
setState(() {
|
||||||
|
forceRefresh = true;
|
||||||
|
});
|
||||||
|
refreshList();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
),
|
),
|
||||||
],
|
);
|
||||||
),
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> initiasizeAccessList() async {
|
||||||
|
MzansiProfileProvider mzansiProfileProvider =
|
||||||
|
context.read<MzansiProfileProvider>();
|
||||||
|
MihAccessControllsProvider accessProvider =
|
||||||
|
context.read<MihAccessControllsProvider>();
|
||||||
|
setState(() {
|
||||||
|
isLoading = true;
|
||||||
|
});
|
||||||
|
await MihAccessControlsServices().getBusinessAccessListOfPatient(
|
||||||
|
mzansiProfileProvider.user!.app_id,
|
||||||
|
accessProvider,
|
||||||
|
);
|
||||||
|
setState(() {
|
||||||
|
isLoading = false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void dispose() {
|
void dispose() {
|
||||||
filterController.dispose();
|
filterController.dispose();
|
||||||
@@ -302,9 +205,8 @@ class _MihAccessRequestState extends State<MihAccessRequest> {
|
|||||||
selectedDropdown = "All";
|
selectedDropdown = "All";
|
||||||
filterController.text = "All";
|
filterController.text = "All";
|
||||||
filterController.addListener(refreshList);
|
filterController.addListener(refreshList);
|
||||||
setState(() {
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
||||||
accessList = MIHApiCalls.getBusinessAccessListOfPatient(
|
await initiasizeAccessList();
|
||||||
widget.signedInUser.app_id);
|
|
||||||
});
|
});
|
||||||
super.initState();
|
super.initState();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -37,7 +37,6 @@ class _MzansiCalendarState extends State<MzansiCalendar> {
|
|||||||
icon: const Icon(Icons.arrow_back),
|
icon: const Icon(Icons.arrow_back),
|
||||||
iconSize: 35,
|
iconSize: 35,
|
||||||
onTap: () {
|
onTap: () {
|
||||||
// Navigator.of(context).pop();
|
|
||||||
context.read<MihCalendarProvider>().resetSelectedDay();
|
context.read<MihCalendarProvider>().resetSelectedDay();
|
||||||
context.goNamed(
|
context.goNamed(
|
||||||
'mihHome',
|
'mihHome',
|
||||||
|
|||||||
@@ -98,7 +98,6 @@ class _MihPersonalHomeState extends State<MihPersonalHome>
|
|||||||
//=============== Mzansi Wallet ===============
|
//=============== Mzansi Wallet ===============
|
||||||
temp.add({
|
temp.add({
|
||||||
"Mzansi Wallet": MihWalletTile(
|
"Mzansi Wallet": MihWalletTile(
|
||||||
signedInUser: widget.signedInUser,
|
|
||||||
packageSize: packageSize,
|
packageSize: packageSize,
|
||||||
)
|
)
|
||||||
});
|
});
|
||||||
@@ -150,7 +149,6 @@ class _MihPersonalHomeState extends State<MihPersonalHome>
|
|||||||
//=============== MIH Access ===============
|
//=============== MIH Access ===============
|
||||||
temp.add({
|
temp.add({
|
||||||
"MIH Access": MihAccessTile(
|
"MIH Access": MihAccessTile(
|
||||||
signedInUser: widget.signedInUser,
|
|
||||||
packageSize: packageSize,
|
packageSize: packageSize,
|
||||||
)
|
)
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -2,18 +2,14 @@ import 'package:go_router/go_router.dart';
|
|||||||
import 'package:mzansi_innovation_hub/main.dart';
|
import 'package:mzansi_innovation_hub/main.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tile.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tile.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_icons.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_icons.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/app_user.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/arguments.dart';
|
|
||||||
import 'package:mzansi_innovation_hub/mih_config/mih_colors.dart';
|
import 'package:mzansi_innovation_hub/mih_config/mih_colors.dart';
|
||||||
|
|
||||||
class MihWalletTile extends StatefulWidget {
|
class MihWalletTile extends StatefulWidget {
|
||||||
final AppUser signedInUser;
|
|
||||||
final double packageSize;
|
final double packageSize;
|
||||||
|
|
||||||
const MihWalletTile({
|
const MihWalletTile({
|
||||||
super.key,
|
super.key,
|
||||||
required this.signedInUser,
|
|
||||||
required this.packageSize,
|
required this.packageSize,
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -29,7 +25,6 @@ class _MihWalletTileState extends State<MihWalletTile> {
|
|||||||
onTap: () {
|
onTap: () {
|
||||||
context.goNamed(
|
context.goNamed(
|
||||||
'mzansiWallet',
|
'mzansiWallet',
|
||||||
extra: WalletArguments(widget.signedInUser, 0),
|
|
||||||
);
|
);
|
||||||
// Navigator.of(context).pushNamed(
|
// Navigator.of(context).pushNamed(
|
||||||
// '/mzansi-wallet',
|
// '/mzansi-wallet',
|
||||||
|
|||||||
@@ -2,11 +2,36 @@ import 'dart:convert';
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:go_router/go_router.dart';
|
import 'package:go_router/go_router.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/app_user.dart';
|
import 'package:mzansi_innovation_hub/mih_components/mih_objects/app_user.dart';
|
||||||
|
import 'package:mzansi_innovation_hub/mih_components/mih_objects/patient_access.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_components/mih_pop_up_messages/mih_loading_circle.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/mih_access_controlls_provider.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_config/mih_env.dart';
|
import 'package:mzansi_innovation_hub/mih_config/mih_env.dart';
|
||||||
import 'package:supertokens_flutter/http.dart' as http;
|
import 'package:supertokens_flutter/http.dart' as http;
|
||||||
|
|
||||||
class MihAccessControlsServices {
|
class MihAccessControlsServices {
|
||||||
|
Future<int> getBusinessAccessListOfPatient(
|
||||||
|
String app_id,
|
||||||
|
MihAccessControllsProvider mihAccessColtrollsProvider,
|
||||||
|
) async {
|
||||||
|
final response = await http.get(Uri.parse(
|
||||||
|
"${AppEnviroment.baseApiUrl}/access-requests/personal/patient/$app_id"));
|
||||||
|
// var errorCode = response.statusCode.toString();
|
||||||
|
// print(response.statusCode);
|
||||||
|
// print(response.body);
|
||||||
|
|
||||||
|
if (response.statusCode == 200) {
|
||||||
|
Iterable l = jsonDecode(response.body);
|
||||||
|
List<PatientAccess> patientAccesses = List<PatientAccess>.from(
|
||||||
|
l.map((model) => PatientAccess.fromJson(model)));
|
||||||
|
if (response.statusCode == 200) {
|
||||||
|
mihAccessColtrollsProvider.setAccessList(patientAccesses);
|
||||||
|
}
|
||||||
|
return response.statusCode;
|
||||||
|
} else {
|
||||||
|
throw Exception('failed to pull patient access List for business');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// This function is used to UPDATE access the business has.
|
/// This function is used to UPDATE access the business has.
|
||||||
///
|
///
|
||||||
/// Patameters:-
|
/// Patameters:-
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:mzansi_innovation_hub/mih_services/mih_business_details_services.dart';
|
import 'package:mzansi_innovation_hub/mih_services/mih_business_details_services.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_services/mih_file_services.dart';
|
import 'package:mzansi_innovation_hub/mih_services/mih_file_services.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_services/mih_my_business_user_services.dart';
|
import 'package:mzansi_innovation_hub/mih_services/mih_my_business_user_services.dart';
|
||||||
@@ -7,20 +6,8 @@ import 'package:mzansi_innovation_hub/mih_services/mih_notification_services.dar
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_services/mih_patient_services.dart';
|
import 'package:mzansi_innovation_hub/mih_services/mih_patient_services.dart';
|
||||||
import 'package:mzansi_innovation_hub/mih_services/mih_user_services.dart';
|
import 'package:mzansi_innovation_hub/mih_services/mih_user_services.dart';
|
||||||
// import '../mih_components/mih_pop_up_messages/mih_error_message.dart';
|
|
||||||
// import '../mih_components/mih_pop_up_messages/mih_success_message.dart';
|
|
||||||
// import '../mih_env/mih_env.dart';
|
|
||||||
// import '../mih_objects/app_user.dart';
|
|
||||||
// import '../mih_objects/arguments.dart';
|
|
||||||
// import '../mih_objects/business.dart';
|
|
||||||
// import '../mih_objects/business_user.dart';
|
|
||||||
// import '../mih_objects/notification.dart';
|
|
||||||
// import '../mih_objects/patient_access.dart';
|
|
||||||
// import '../mih_objects/patient_queue.dart';
|
|
||||||
// import '../mih_objects/patients.dart';
|
|
||||||
import 'package:supertokens_flutter/supertokens.dart';
|
import 'package:supertokens_flutter/supertokens.dart';
|
||||||
import 'package:supertokens_flutter/http.dart' as http;
|
import 'package:supertokens_flutter/http.dart' as http;
|
||||||
|
|
||||||
import '../mih_components/mih_pop_up_messages/mih_error_message.dart';
|
import '../mih_components/mih_pop_up_messages/mih_error_message.dart';
|
||||||
import '../mih_components/mih_pop_up_messages/mih_success_message.dart';
|
import '../mih_components/mih_pop_up_messages/mih_success_message.dart';
|
||||||
import '../mih_config/mih_env.dart';
|
import '../mih_config/mih_env.dart';
|
||||||
@@ -163,29 +150,6 @@ class MIHApiCalls {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// This function is used to get list of access the business has.
|
|
||||||
///
|
|
||||||
/// Patameters: String business_id.
|
|
||||||
///
|
|
||||||
/// Returns List<PatientAccess> (List of access that match the above parameters).
|
|
||||||
static Future<List<PatientAccess>> getBusinessAccessListOfPatient(
|
|
||||||
String app_id) async {
|
|
||||||
final response = await http.get(Uri.parse(
|
|
||||||
"${AppEnviroment.baseApiUrl}/access-requests/personal/patient/$app_id"));
|
|
||||||
// var errorCode = response.statusCode.toString();
|
|
||||||
// print(response.statusCode);
|
|
||||||
// print(response.body);
|
|
||||||
|
|
||||||
if (response.statusCode == 200) {
|
|
||||||
Iterable l = jsonDecode(response.body);
|
|
||||||
List<PatientAccess> patientAccesses = List<PatientAccess>.from(
|
|
||||||
l.map((model) => PatientAccess.fromJson(model)));
|
|
||||||
return patientAccesses;
|
|
||||||
} else {
|
|
||||||
throw Exception('failed to pull patient access List for business');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// This function is used to UPDATE access the business has.
|
/// This function is used to UPDATE access the business has.
|
||||||
///
|
///
|
||||||
/// Patameters:-
|
/// Patameters:-
|
||||||
|
|||||||
Reference in New Issue
Block a user