mirror of
https://github.com/p-stream/p-stream.git
synced 2026-05-13 09:51:13 +00:00
50 lines
1.7 KiB
TypeScript
50 lines
1.7 KiB
TypeScript
import { Helmet } from "react-helmet-async";
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
import { Button } from "@/components/buttons/Button";
|
|
import { Icons } from "@/components/Icon";
|
|
import { IconPill } from "@/components/layout/IconPill";
|
|
import { Navigation } from "@/components/layout/Navigation";
|
|
import { Title } from "@/components/text/Title";
|
|
import { Paragraph } from "@/components/utils/Text";
|
|
import { ErrorContainer, ErrorLayout } from "@/pages/layouts/ErrorLayout";
|
|
|
|
export function NotFoundPart() {
|
|
const { t } = useTranslation();
|
|
|
|
return (
|
|
<div className="relative flex flex-1 flex-col">
|
|
<Helmet>
|
|
<title>{t("notFound.badge")}</title>
|
|
</Helmet>
|
|
<Navigation />
|
|
<div className="flex h-full flex-1 flex-col items-center justify-center p-5 text-center">
|
|
<ErrorLayout>
|
|
<ErrorContainer>
|
|
<IconPill icon={Icons.EYE_SLASH}>{t("notFound.badge")}</IconPill>
|
|
<Title>{t("notFound.title")}</Title>
|
|
<Paragraph>{t("notFound.message")}</Paragraph>
|
|
<div className="flex gap-3">
|
|
<Button
|
|
href="/"
|
|
theme="secondary"
|
|
padding="md:px-12 p-2.5"
|
|
className="mt-6"
|
|
>
|
|
{t("notFound.goHome")}
|
|
</Button>
|
|
<Button
|
|
onClick={() => window.location.reload()}
|
|
theme="purple"
|
|
padding="md:px-12 p-2.5"
|
|
className="mt-6"
|
|
>
|
|
{t("notFound.reloadButton")}
|
|
</Button>
|
|
</div>
|
|
</ErrorContainer>
|
|
</ErrorLayout>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|