add extend access api call and notification creation
This commit is contained in:
@@ -45,7 +45,8 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
TextEditingController idController = TextEditingController();
|
TextEditingController idController = TextEditingController();
|
||||||
TextEditingController fnameController = TextEditingController();
|
TextEditingController fnameController = TextEditingController();
|
||||||
TextEditingController lnameController = TextEditingController();
|
TextEditingController lnameController = TextEditingController();
|
||||||
|
TextEditingController daysExtensionController = TextEditingController();
|
||||||
|
int counter = 0;
|
||||||
Future<void> updateAccessAPICall(int index, String accessType) async {
|
Future<void> updateAccessAPICall(int index, String accessType) async {
|
||||||
var response = await http.put(
|
var response = await http.put(
|
||||||
Uri.parse("$baseAPI/access-requests/update/"),
|
Uri.parse("$baseAPI/access-requests/update/"),
|
||||||
@@ -81,6 +82,27 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> extendAccessAPICall(int index, String revokeDate) async {
|
||||||
|
var response = await http.put(
|
||||||
|
Uri.parse("$baseAPI/access-requests/extension/"),
|
||||||
|
headers: <String, String>{
|
||||||
|
"Content-Type": "application/json; charset=UTF-8"
|
||||||
|
},
|
||||||
|
body: jsonEncode(<String, dynamic>{
|
||||||
|
"business_id": widget.business!.business_id,
|
||||||
|
"app_id": widget.patientQueue[index].app_id,
|
||||||
|
"date_time": widget.patientQueue[index].date_time,
|
||||||
|
"revoke_date": revokeDate,
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
if (response.statusCode == 200) {
|
||||||
|
addAccessExtensionNotificationAPICall(index, revokeDate);
|
||||||
|
//addCancelledAppointmentNotificationAPICall(index);
|
||||||
|
} else {
|
||||||
|
internetConnectionPopUp();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Future<void> updateApointmentAPICall(int index) async {
|
Future<void> updateApointmentAPICall(int index) async {
|
||||||
var response = await http.put(
|
var response = await http.put(
|
||||||
Uri.parse("$baseAPI/queue/update/"),
|
Uri.parse("$baseAPI/queue/update/"),
|
||||||
@@ -373,6 +395,41 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> addAccessExtensionNotificationAPICall(
|
||||||
|
int index, String revokeDate) async {
|
||||||
|
var response = await http.post(
|
||||||
|
Uri.parse("$baseAPI/notifications/insert/"),
|
||||||
|
headers: <String, String>{
|
||||||
|
"Content-Type": "application/json; charset=UTF-8"
|
||||||
|
},
|
||||||
|
body: jsonEncode(<String, dynamic>{
|
||||||
|
"app_id": widget.patientQueue[index].app_id,
|
||||||
|
"notification_type": "Access Extension Request",
|
||||||
|
"notification_message":
|
||||||
|
"${widget.business!.Name} - access expiry date extension for appointment: ${widget.patientQueue[index].date_time.split("T")[0]}. Expiry Date: from ${widget.patientQueue[index].revoke_date.split("T")[0]} to ${revokeDate.split(" ")[0]}.",
|
||||||
|
"action_path": "/access-review",
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
if (response.statusCode == 201) {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
Navigator.of(context).pushNamed(
|
||||||
|
'/patient-manager',
|
||||||
|
arguments: BusinessArguments(
|
||||||
|
widget.signedInUser,
|
||||||
|
widget.businessUser,
|
||||||
|
widget.business,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
String message =
|
||||||
|
"you have successfully requested an extension on the expirey date. The request has been sent tp ${widget.patientQueue[index].first_name} ${widget.patientQueue[index].last_name} to review and approve the request";
|
||||||
|
|
||||||
|
successPopUp(message);
|
||||||
|
} else {
|
||||||
|
internetConnectionPopUp();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void manageAppointmentPopUp(int index) {
|
void manageAppointmentPopUp(int index) {
|
||||||
showDialog(
|
showDialog(
|
||||||
context: context,
|
context: context,
|
||||||
@@ -526,7 +583,7 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
text: TextSpan(
|
text: TextSpan(
|
||||||
text: line234,
|
text: line234,
|
||||||
style: DefaultTextStyle.of(context).style,
|
style: DefaultTextStyle.of(context).style,
|
||||||
children: <TextSpan>[
|
children: [
|
||||||
TextSpan(text: line5),
|
TextSpan(text: line5),
|
||||||
accessWithColour,
|
accessWithColour,
|
||||||
TextSpan(text: line6),
|
TextSpan(text: line6),
|
||||||
@@ -572,9 +629,144 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
//noAccessWarning();
|
//noAccessWarning();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
trailing: Icon(
|
//leading: getExtendAccessButton(access),
|
||||||
|
trailing: getExtendAccessButton(access, index),
|
||||||
|
// Icon(
|
||||||
|
// Icons.arrow_forward,
|
||||||
|
// color: MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
||||||
|
// ),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool isAccessExpired(String accessType) {
|
||||||
|
if (accessType == "EXPIRED") {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Widget getExtendAccessButton(String accessType, int index) {
|
||||||
|
if (isAccessExpired(accessType)) {
|
||||||
|
return IconButton(
|
||||||
|
icon: const Icon(Icons.cached),
|
||||||
|
onPressed: () {
|
||||||
|
setState(() {
|
||||||
|
daysExtensionController.text = counter.toString();
|
||||||
|
});
|
||||||
|
reapplyForAccess(index);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
return Icon(
|
||||||
Icons.arrow_forward,
|
Icons.arrow_forward,
|
||||||
color: MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
color: MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void reapplyForAccess(int index) {
|
||||||
|
showDialog(
|
||||||
|
context: context,
|
||||||
|
barrierDismissible: false,
|
||||||
|
builder: (context) => MIHWindow(
|
||||||
|
fullscreen: false,
|
||||||
|
windowTitle: "Extend Access",
|
||||||
|
windowTools: const [],
|
||||||
|
onWindowTapClose: () {
|
||||||
|
Navigator.pop(context);
|
||||||
|
},
|
||||||
|
windowBody: [
|
||||||
|
Text(
|
||||||
|
"Current Expiration Date : ${widget.patientQueue[index].revoke_date.replaceAll("T", " ")}",
|
||||||
|
style: TextStyle(
|
||||||
|
color: MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
||||||
|
fontSize: 15,
|
||||||
|
fontWeight: FontWeight.normal,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 5),
|
||||||
|
Text(
|
||||||
|
"Select the number of days you would like to extend the access by.",
|
||||||
|
style: TextStyle(
|
||||||
|
color: MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
||||||
|
fontSize: 15,
|
||||||
|
fontWeight: FontWeight.normal,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 5),
|
||||||
|
Text(
|
||||||
|
"Once you click \"Apply\", an access review request will be triggered to the patient.",
|
||||||
|
style: TextStyle(
|
||||||
|
color: MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
||||||
|
fontSize: 15,
|
||||||
|
fontWeight: FontWeight.normal,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 30),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
IconButton.filled(
|
||||||
|
onPressed: () {
|
||||||
|
if (counter > 0) {
|
||||||
|
counter--;
|
||||||
|
setState(() {
|
||||||
|
daysExtensionController.text = counter.toString();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
icon: const Icon(Icons.remove),
|
||||||
|
),
|
||||||
|
const SizedBox(width: 15),
|
||||||
|
SizedBox(
|
||||||
|
width: 100,
|
||||||
|
child: MIHTextField(
|
||||||
|
controller: daysExtensionController,
|
||||||
|
hintText: "Days",
|
||||||
|
editable: false,
|
||||||
|
required: true,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(width: 15),
|
||||||
|
IconButton.filled(
|
||||||
|
onPressed: () {
|
||||||
|
counter++;
|
||||||
|
setState(() {
|
||||||
|
daysExtensionController.text = counter.toString();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
icon: const Icon(Icons.add),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
const SizedBox(height: 30),
|
||||||
|
SizedBox(
|
||||||
|
width: 300,
|
||||||
|
height: 50,
|
||||||
|
child: MIHButton(
|
||||||
|
onTap: () {
|
||||||
|
print(
|
||||||
|
"Revoke Date (String): ${widget.patientQueue[index].revoke_date}");
|
||||||
|
var revokeDate = DateTime.parse(widget
|
||||||
|
.patientQueue[index].revoke_date
|
||||||
|
.replaceAll("T", " "));
|
||||||
|
var newRevokeDate = revokeDate.add(
|
||||||
|
Duration(days: int.parse(daysExtensionController.text)));
|
||||||
|
print("Revoke Date (DateTime): $revokeDate");
|
||||||
|
print("New Revoke Date (DateTime): $newRevokeDate");
|
||||||
|
print(
|
||||||
|
"${widget.business!.Name} would like to extend the access expirey date for your appointment on the ${widget.patientQueue[index].date_time}.\nNew Expirey Date: $revokeDate",
|
||||||
|
);
|
||||||
|
extendAccessAPICall(index, "$newRevokeDate");
|
||||||
|
},
|
||||||
|
buttonText: "Apply",
|
||||||
|
buttonColor:
|
||||||
|
MzanziInnovationHub.of(context)!.theme.secondaryColor(),
|
||||||
|
textColor: MzanziInnovationHub.of(context)!.theme.primaryColor(),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -617,6 +809,7 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
void dispose() {
|
void dispose() {
|
||||||
|
daysExtensionController.dispose();
|
||||||
dateController.dispose();
|
dateController.dispose();
|
||||||
timeController.dispose();
|
timeController.dispose();
|
||||||
super.dispose();
|
super.dispose();
|
||||||
@@ -625,6 +818,7 @@ class _BuildPatientsListState extends State<BuildPatientQueueList> {
|
|||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return ListView.separated(
|
return ListView.separated(
|
||||||
|
physics: const NeverScrollableScrollPhysics(),
|
||||||
shrinkWrap: true,
|
shrinkWrap: true,
|
||||||
separatorBuilder: (BuildContext context, index) {
|
separatorBuilder: (BuildContext context, index) {
|
||||||
return Divider(
|
return Divider(
|
||||||
|
|||||||
Reference in New Issue
Block a user