From fce6a2d237f888f3624eae86b3be55ce2a967066 Mon Sep 17 00:00:00 2001 From: Dylan Decrulle <81740200+ddecrulle@users.noreply.github.com> Date: Mon, 6 May 2024 17:58:54 +0200 Subject: [PATCH] fix: reset cache error boundary after navigate in visualize page --- src/components/Error/ErrorComponent.tsx | 12 +++++++++--- src/pages/Visualize/route.tsx | 7 +++---- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/src/components/Error/ErrorComponent.tsx b/src/components/Error/ErrorComponent.tsx index 6807471b..f29d08e5 100644 --- a/src/components/Error/ErrorComponent.tsx +++ b/src/components/Error/ErrorComponent.tsx @@ -1,16 +1,18 @@ import { fr } from '@codegouvfr/react-dsfr' import Button from '@codegouvfr/react-dsfr/Button' import TechnicalError from '@codegouvfr/react-dsfr/dsfr/artwork/pictograms/system/technical-error.svg' +import { useNavigate } from '@tanstack/react-router' import { Container } from 'components/Container' import { useDocumentTitle } from 'hooks/useDocumentTitle' import { getErrorInformations } from 'utils/error/errorUtils' export function ErrorComponent(props: { error: unknown + reset?: () => void redirectTo: 'home' | 'portal' | 'visualizeForm' | undefined }) { - const { error, redirectTo } = props - + const { error, redirectTo, reset } = props + const navigate = useNavigate() const { title, subtitle, paragraph, code } = getErrorInformations(error) useDocumentTitle(title) @@ -39,7 +41,11 @@ export function ErrorComponent(props: { case 'portal': return { href: import.meta.env.VITE_PORTAIL_URL } case 'visualizeForm': - return { to: '/visualize' } + return { + onClick: () => { + navigate({ to: '/visualize' }).then(reset) + }, + } default: return {} } diff --git a/src/pages/Visualize/route.tsx b/src/pages/Visualize/route.tsx index 8f35ea3a..e648cb06 100644 --- a/src/pages/Visualize/route.tsx +++ b/src/pages/Visualize/route.tsx @@ -32,7 +32,6 @@ export const visualizeRoute = createRoute({ }) => { //TODO get name (Filière d'Enquête) in metadata document.title = "Visualisation | Filière d'Enquête" - if (!sourceUrl) { return } @@ -55,7 +54,7 @@ export const visualizeRoute = createRoute({ } ) }, - errorComponent: ({ error }) => { - return - }, + errorComponent: ({ error, reset }) => ( + + ), })