From 8a5705e6ce4bcb3cfa0dd14c67266e5c69f8806b Mon Sep 17 00:00:00 2001 From: Eunju Huss Date: Tue, 17 Dec 2024 13:19:26 +0100 Subject: [PATCH] Navigate to profile/account when user cancel re-authen --- src/components/Dashboard/AuthenticateModal.tsx | 16 ++++++++++++---- src/components/Dashboard/ChangePassword.tsx | 1 + .../Dashboard/ChangePasswordDisplay.tsx | 1 + 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/src/components/Dashboard/AuthenticateModal.tsx b/src/components/Dashboard/AuthenticateModal.tsx index 8c5a978fc..e919f3452 100644 --- a/src/components/Dashboard/AuthenticateModal.tsx +++ b/src/components/Dashboard/AuthenticateModal.tsx @@ -2,6 +2,7 @@ import { authenticate } from "apis/eduidAuthn"; import NotificationModal from "components/Common/NotificationModal"; import { useAppDispatch, useAppSelector } from "eduid-hooks"; import { FormattedMessage } from "react-intl"; +import { useNavigate } from "react-router-dom"; import authnSlice from "slices/Authn"; import { clearNotifications } from "slices/Notifications"; @@ -10,6 +11,7 @@ export function AuthenticateModal() { const re_authenticate = useAppSelector((state) => state.authn.re_authenticate); const frontend_action = useAppSelector((state) => state.authn.frontend_action); const frontend_state = useAppSelector((state) => state.authn.frontend_state); + const navigate = useNavigate(); async function handleAuthenticate() { dispatch(authnSlice.actions.setReAuthenticate(false)); @@ -21,6 +23,15 @@ export function AuthenticateModal() { } } + function handleCloseModal() { + // navigate to account when user cancel re-authentication + if (frontend_action === "changepwAuthn" && re_authenticate) { + navigate("profile/account/"); + } + dispatch(authnSlice.actions.setAuthnFrontendReset()); + dispatch(authnSlice.actions.setReAuthenticate(false)); + } + return ( } showModal={re_authenticate} - closeModal={() => { - dispatch(authnSlice.actions.setAuthnFrontendReset()); - dispatch(authnSlice.actions.setReAuthenticate(false)); - }} + closeModal={handleCloseModal} acceptModal={handleAuthenticate} acceptButtonText={} /> diff --git a/src/components/Dashboard/ChangePassword.tsx b/src/components/Dashboard/ChangePassword.tsx index 314e92ec5..25019e67a 100644 --- a/src/components/Dashboard/ChangePassword.tsx +++ b/src/components/Dashboard/ChangePassword.tsx @@ -38,6 +38,7 @@ export function ChangePassword() { const dispatch = useAppDispatch(); const intl = useIntl(); const suggested = useAppSelector((state) => state.chpass.suggested_password); + const re_authenticate = useAppSelector((state) => state.authn.re_authenticate); const [renderSuggested, setRenderSuggested] = useState(true); // toggle display of custom or suggested password forms const navigate = useNavigate(); let isMounted = true; diff --git a/src/components/Dashboard/ChangePasswordDisplay.tsx b/src/components/Dashboard/ChangePasswordDisplay.tsx index 01361c958..c7c54a15b 100644 --- a/src/components/Dashboard/ChangePasswordDisplay.tsx +++ b/src/components/Dashboard/ChangePasswordDisplay.tsx @@ -11,6 +11,7 @@ function ChangePasswordDisplay() { async function handleSuggestedPassword() { const response = await dispatch(fetchSuggestedPassword()); if (fetchSuggestedPassword.fulfilled.match(response)) { + console.log("response", response); navigate("/profile/chpass"); } }