2023-09-21 13:25:19 +00:00
|
|
|
import { isRouteErrorResponse, useNavigate, useRouteError } from 'react-router';
|
|
|
|
import { RainbowButton } from './buttons';
|
|
|
|
import { AnimatedDudeWithWire } from './graphics/dude';
|
|
|
|
import { LayoutWithSky } from './layout';
|
|
|
|
import { Routes } from '../../lib/links';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
2023-09-21 13:25:19 +00:00
|
|
|
|
|
|
|
export const ErrorBoundary = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-09-21 13:25:19 +00:00
|
|
|
const error = useRouteError();
|
|
|
|
const navigate = useNavigate();
|
|
|
|
|
|
|
|
const title = isRouteErrorResponse(error)
|
|
|
|
? `${error.status} ${error.statusText}`
|
2023-11-16 03:10:39 +00:00
|
|
|
: t('Something went wrong');
|
2023-09-21 13:25:19 +00:00
|
|
|
|
|
|
|
const code = isRouteErrorResponse(error) ? error.status : 0;
|
|
|
|
|
|
|
|
const messages: Record<number, string> = {
|
2023-11-16 03:10:39 +00:00
|
|
|
0: t('An unknown error occurred.'),
|
|
|
|
404: t("The page you're looking for doesn't exists."),
|
2023-09-21 13:25:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<LayoutWithSky className="pt-32">
|
|
|
|
<div
|
|
|
|
aria-hidden
|
|
|
|
className="absolute top-64 right-[220px] md:right-[340px] max-sm:hidden"
|
|
|
|
>
|
|
|
|
<AnimatedDudeWithWire className="animate-spin" />
|
|
|
|
</div>
|
|
|
|
<h1 className="text-6xl font-alpha calt mb-10">{title}</h1>
|
|
|
|
|
|
|
|
{Object.keys(messages).includes(code.toString()) ? (
|
|
|
|
<p className="text-lg mb-10">{messages[code]}</p>
|
|
|
|
) : null}
|
|
|
|
|
|
|
|
<p className="text-lg mb-10">
|
|
|
|
<RainbowButton
|
|
|
|
onClick={() => navigate('..')}
|
|
|
|
variant="border"
|
|
|
|
className="text-xs"
|
|
|
|
>
|
2023-10-24 15:43:33 +00:00
|
|
|
{t('Go back and try again')}
|
2023-09-21 13:25:19 +00:00
|
|
|
</RainbowButton>
|
|
|
|
</p>
|
|
|
|
</LayoutWithSky>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export const NotFound = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-09-21 13:25:19 +00:00
|
|
|
const navigate = useNavigate();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="pt-32">
|
|
|
|
<div
|
|
|
|
aria-hidden
|
|
|
|
className="absolute top-64 right-[220px] md:right-[340px] max-sm:hidden"
|
|
|
|
>
|
|
|
|
<AnimatedDudeWithWire className="animate-spin" />
|
|
|
|
</div>
|
|
|
|
<h1 className="text-6xl font-alpha calt mb-10">{'Not found'}</h1>
|
|
|
|
|
|
|
|
<p className="text-lg mb-10">
|
2023-10-24 15:43:33 +00:00
|
|
|
{t("The page you're looking for doesn't exists.")}
|
2023-09-21 13:25:19 +00:00
|
|
|
</p>
|
|
|
|
|
|
|
|
<p className="text-lg mb-10">
|
|
|
|
<RainbowButton
|
|
|
|
onClick={() => navigate(Routes.REFERRALS)}
|
|
|
|
variant="border"
|
|
|
|
className="text-xs"
|
|
|
|
>
|
2023-10-24 15:43:33 +00:00
|
|
|
{t('Go back and try again')}
|
2023-09-21 13:25:19 +00:00
|
|
|
</RainbowButton>
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|