website/layouts/auth.vue

47 lines
1.1 KiB
Vue
Raw Normal View History

2024-05-25 15:20:10 +08:00
<script setup lang="ts">
useHead({
bodyAttrs: {
class: 'dark:bg-gray-950'
}
})
</script>
<template>
<div class="h-screen flex items-center justify-center overlay">
<div class="gradient" />
<UButton icon="i-heroicons-home" label="Home" to="/" color="black" class="absolute top-4" />
<slot />
</div>
</template>
<style scoped>
.gradient {
position: absolute;
inset: 0;
pointer-events: none;
background: radial-gradient(50% 50% at 50% 50%, rgb(var(--color-primary-500) / 0.25) 0, #FFF 100%);
}
.dark {
.gradient {
background: radial-gradient(50% 50% at 50% 50%, rgb(var(--color-primary-400) / 0.1) 0, rgb(var(--color-gray-950)) 100%);
}
}
.overlay {
background-size: 100px 100px;
background-image:
linear-gradient(to right, rgb(var(--color-gray-200)) 0.5px, transparent 0.5px),
linear-gradient(to bottom, rgb(var(--color-gray-200)) 0.5px, transparent 0.5px);
}
.dark {
.overlay {
background-image:
linear-gradient(to right, rgb(var(--color-gray-900)) 0.5px, transparent 0.5px),
linear-gradient(to bottom, rgb(var(--color-gray-900)) 0.5px, transparent 0.5px);
}
}
</style>