diff --git a/src/pages/Appoinments/PatientRegistration.tsx b/src/pages/Appoinments/PatientRegistration.tsx index 079478a4923..580dfb3c0e4 100644 --- a/src/pages/Appoinments/PatientRegistration.tsx +++ b/src/pages/Appoinments/PatientRegistration.tsx @@ -150,15 +150,15 @@ export function PatientRegistration(props: PatientRegistrationProps) { onSuccess: (data: Appointment) => { Notification.Success({ msg: t("appointment_created_success") }); queryClient.invalidateQueries({ - queryKey: ["patients", tokenData.phoneNumber], + queryKey: [ + ["patients", tokenData.phoneNumber], + ["appointment", tokenData.phoneNumber], + ], }); navigate( `/facility/${props.facilityId}/appointments/${data.id}/success`, { replace: true, - // Added to ensure navigate only triggers once data is loaded - // Resulted in ErrorBoundary without it - state: { appointment: data }, }, ); }, diff --git a/src/pages/Appoinments/PatientSelect.tsx b/src/pages/Appoinments/PatientSelect.tsx index efb4e2d9a30..8506130ea67 100644 --- a/src/pages/Appoinments/PatientSelect.tsx +++ b/src/pages/Appoinments/PatientSelect.tsx @@ -1,4 +1,4 @@ -import { useMutation, useQuery } from "@tanstack/react-query"; +import { useMutation, useQuery, useQueryClient } from "@tanstack/react-query"; import dayjs from "dayjs"; import { navigate } from "raviger"; import { useState } from "react"; @@ -42,6 +42,8 @@ export default function PatientSelect({ ); const [selectedPatient, setSelectedPatient] = useState(null); + const queryClient = useQueryClient(); + if (!staffUsername) { Notification.Error({ msg: "Staff Username Not Found" }); navigate(`/facility/${facilityId}/`); @@ -79,11 +81,14 @@ export default function PatientSelect({ })(body), onSuccess: (data: Appointment) => { Notification.Success({ msg: t("appointment_created_success") }); + queryClient.invalidateQueries({ + queryKey: [ + ["patients", tokenData.phoneNumber], + ["appointment", tokenData.phoneNumber], + ], + }); navigate(`/facility/${facilityId}/appointments/${data.id}/success`, { replace: true, - // Added to ensure navigate only triggers once data is loaded - // Sometimes resulted in ErrorBoundary without it - state: { appointment: data }, }); }, onError: (error) => { diff --git a/src/pages/Appoinments/Success.tsx b/src/pages/Appoinments/Success.tsx index e3c5e0a3f9c..618e39d61da 100644 --- a/src/pages/Appoinments/Success.tsx +++ b/src/pages/Appoinments/Success.tsx @@ -77,10 +77,12 @@ export function AppointmentSuccess(props: { appointmentId: string }) { {t("date")}:

- {format( - new Date(appointmentData?.token_slot.start_datetime ?? ""), - "do MMMM", - )} + {appointmentData?.token_slot.start_datetime + ? format( + new Date(appointmentData?.token_slot.start_datetime), + "do MMMM", + ) + : ""}

@@ -89,10 +91,12 @@ export function AppointmentSuccess(props: { appointmentId: string }) { {t("time")}:

- {format( - new Date(appointmentData?.token_slot.start_datetime ?? ""), - "hh:mm a", - )} + {appointmentData?.token_slot.start_datetime + ? format( + new Date(appointmentData?.token_slot.start_datetime), + "hh:mm a", + ) + : ""}