tianji/src/client/components/DefaultNotFound.tsx

38 lines
1.2 KiB
TypeScript

import React from 'react';
import { Button } from './ui/button';
import { Link, useRouterState } from '@tanstack/react-router';
import { useTranslation } from '@i18next-toolkit/react';
import { Card, CardContent, CardFooter, CardHeader } from './ui/card';
import { Code } from './Code';
export const DefaultNotFound: React.FC = React.memo(() => {
const { t } = useTranslation();
const pathname = useRouterState({
select: (state) => state.location.pathname,
});
return (
<div className="flex h-full w-full items-center justify-center">
<Card className="min-w-[320px] bg-zinc-900">
<CardHeader>
<div className="text-center">
<img className="m-auto h-24 w-24" src="/icon.svg" />
</div>
</CardHeader>
<CardContent className="text-center">
<div>{t('Sorry, but this page is not found')}</div>
<div>
<b>{t('Path')}</b>: <Code>{pathname}</Code>
</div>
</CardContent>
<CardFooter>
<Link className="ml-auto" to="/">
<Button>{t('Back to Homepage')}</Button>
</Link>
</CardFooter>
</Card>
</div>
);
});
DefaultNotFound.displayName = 'DefaultNotFound';