mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-10 04:22:09 +10:00
96 lines
2.8 KiB
Vue
96 lines
2.8 KiB
Vue
<script setup lang="ts">
|
|
import type { NuxtError } from "#app";
|
|
|
|
const props = defineProps({
|
|
error: Object as () => NuxtError,
|
|
});
|
|
|
|
const route = useRoute();
|
|
const user = useUser();
|
|
|
|
async function signIn() {
|
|
clearError({
|
|
redirect: `/signin?redirect=${encodeURIComponent(route.fullPath)}`,
|
|
});
|
|
}
|
|
|
|
useHead({
|
|
title: `${props.error?.statusCode ?? "An unknown error occurred"} | Drop`,
|
|
});
|
|
console.log(props.error);
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
class="grid min-h-screen grid-cols-1 grid-rows-[1fr,auto,1fr] bg-zinc-950 lg:grid-cols-[max(50%,36rem),1fr]"
|
|
>
|
|
<header
|
|
class="mx-auto w-full max-w-7xl px-6 pt-6 sm:pt-10 lg:col-span-2 lg:col-start-1 lg:row-start-1 lg:px-8"
|
|
>
|
|
<Logo class="h-10 w-auto sm:h-12" />
|
|
</header>
|
|
<main
|
|
class="mx-auto w-full max-w-7xl px-6 py-24 sm:py-32 lg:col-span-2 lg:col-start-1 lg:row-start-2 lg:px-8"
|
|
>
|
|
<div class="max-w-lg">
|
|
<p class="text-base font-semibold leading-8 text-blue-600">
|
|
{{ error?.statusCode }}
|
|
</p>
|
|
<h1
|
|
class="mt-4 text-3xl font-bold font-display tracking-tight text-zinc-100 sm:text-5xl"
|
|
>
|
|
Oh no!
|
|
</h1>
|
|
<p class="mt-6 text-base leading-7 text-zinc-400">
|
|
An error occurred while responding to your request. If you believe
|
|
this to be a bug, please report it.
|
|
</p>
|
|
<div class="mt-10">
|
|
<!-- full app reload to fix errors -->
|
|
<a
|
|
v-if="user"
|
|
href="/"
|
|
class="text-sm font-semibold leading-7 text-blue-600"
|
|
><span aria-hidden="true">←</span> Back to home</a
|
|
>
|
|
<button
|
|
v-else
|
|
@click="signIn"
|
|
class="text-sm font-semibold leading-7 text-blue-600"
|
|
>
|
|
Sign in <span aria-hidden="true">→</span>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</main>
|
|
<footer class="self-end lg:col-span-2 lg:col-start-1 lg:row-start-3">
|
|
<div class="border-t border-zinc-700 bg-zinc-900 py-10">
|
|
<nav
|
|
class="mx-auto flex w-full max-w-7xl items-center gap-x-4 px-6 text-sm leading-7 text-zinc-400 lg:px-8"
|
|
>
|
|
<NuxtLink href="/docs">Documentation</NuxtLink>
|
|
<svg
|
|
viewBox="0 0 2 2"
|
|
aria-hidden="true"
|
|
class="h-0.5 w-0.5 fill-zinc-600"
|
|
>
|
|
<circle cx="1" cy="1" r="1" />
|
|
</svg>
|
|
<a href="https://discord.gg/NHx46XKJWA" target="_blank"
|
|
>Support Discord</a
|
|
>
|
|
</nav>
|
|
</div>
|
|
</footer>
|
|
<div
|
|
class="hidden lg:relative lg:col-start-2 lg:row-start-1 lg:row-end-4 lg:block"
|
|
>
|
|
<img
|
|
src="/wallpapers/error-wallpaper.jpg"
|
|
alt=""
|
|
class="absolute inset-0 h-full w-full object-cover"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</template>
|