import { useEffect } from 'react' import { useRouteError, isRouteErrorResponse, useNavigate } from 'react-router-dom' import * as Sentry from '@sentry/react' import { Button } from '@/components/ui/Button' function isChunkLoadError(error: unknown): boolean { if (!(error instanceof Error)) return false const msg = error.message.toLowerCase() return ( msg.includes('failed to fetch dynamically imported module') || msg.includes('importing a module script failed') || msg.includes('loading chunk') || msg.includes('loading css chunk') ) } const RELOAD_KEY = 'rf_chunk_reload' export function RouteError() { const error = useRouteError() const navigate = useNavigate() // Report route errors to Sentry (skip chunk load errors — those are deploy artifacts) useEffect(() => { if (error && !isChunkLoadError(error)) { Sentry.captureException(error) } }, [error]) // Auto-reload once on chunk load failures (stale deploy) useEffect(() => { if (isChunkLoadError(error)) { const lastReload = sessionStorage.getItem(RELOAD_KEY) const now = Date.now() // Only auto-reload if we haven't reloaded in the last 10 seconds (prevent loops) if (!lastReload || now - Number(lastReload) > 10_000) { sessionStorage.setItem(RELOAD_KEY, String(now)) window.location.reload() } } }, [error]) let errorMessage = 'An unexpected error occurred' let errorDetails = '' if (isChunkLoadError(error)) { errorMessage = 'App Updated' errorDetails = 'A new version was deployed. Please refresh the page.' } else if (isRouteErrorResponse(error)) { errorMessage = error.status === 404 ? 'Page not found' : `Error ${error.status}` errorDetails = error.statusText || '' } else if (error instanceof Error) { errorMessage = 'Something went wrong' errorDetails = error.message } return (

Oops!

{errorMessage}

{errorDetails && (

{errorDetails}

)}
) } export default RouteError