mirror of
https://github.com/makeplane/plane
synced 2025-08-07 19:59:33 +00:00
73 lines
2.4 KiB
TypeScript
73 lines
2.4 KiB
TypeScript
"use client";
|
|
|
|
import Link from "next/link";
|
|
// plane imports
|
|
import { API_BASE_URL } from "@plane/constants";
|
|
import { Button, TOAST_TYPE, getButtonStyling, setToast } from "@plane/ui";
|
|
import { cn } from "@plane/utils";
|
|
// hooks
|
|
import { useAppRouter } from "@/hooks/use-app-router";
|
|
// layouts
|
|
import DefaultLayout from "@/layouts/default-layout";
|
|
// services
|
|
import { AuthService } from "@/services/auth.service";
|
|
|
|
// services
|
|
const authService = new AuthService();
|
|
|
|
export default function CustomErrorComponent() {
|
|
const router = useAppRouter();
|
|
|
|
const handleSignOut = async () => {
|
|
await authService
|
|
.signOut(API_BASE_URL)
|
|
.catch(() =>
|
|
setToast({
|
|
type: TOAST_TYPE.ERROR,
|
|
title: "Error!",
|
|
message: "Failed to sign out. Please try again.",
|
|
})
|
|
)
|
|
.finally(() => router.push("/"));
|
|
};
|
|
|
|
return (
|
|
<DefaultLayout>
|
|
<div className={`h-screen w-full overflow-hidden bg-custom-background-100`}>
|
|
<div className="grid h-full place-items-center p-4">
|
|
<div className="space-y-8 text-center">
|
|
<div className="space-y-2 relative flex flex-col justify-center items-center">
|
|
<h3 className="text-lg font-semibold">Yikes! That doesn{"'"}t look good.</h3>
|
|
<p className="mx-auto md:w-1/2 text-sm text-custom-text-200">
|
|
That crashed Plane, pun intended. No worries, though. Our engineers have been notified. If you have more
|
|
details, please write to{" "}
|
|
<a href="mailto:support@plane.so" className="text-custom-primary">
|
|
support@plane.so
|
|
</a>{" "}
|
|
or on our{" "}
|
|
<a
|
|
href="https://discord.com/invite/A92xrEGCge"
|
|
target="_blank"
|
|
className="text-custom-primary"
|
|
rel="noopener noreferrer"
|
|
>
|
|
Discord
|
|
</a>
|
|
.
|
|
</p>
|
|
</div>
|
|
<div className="flex items-center justify-center gap-2">
|
|
<Link href="/" className={cn(getButtonStyling("primary", "md"))}>
|
|
Go to home
|
|
</Link>
|
|
<Button variant="neutral-primary" size="md" onClick={handleSignOut}>
|
|
Sign out
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</DefaultLayout>
|
|
);
|
|
}
|