mirror of
https://github.com/solidtime-io/solidtime.git
synced 2026-05-07 20:32:26 +00:00
63 lines
2.7 KiB
Vue
63 lines
2.7 KiB
Vue
<template>
|
|
<!-- Global notification live region, render this permanently at the end of the document -->
|
|
<!-- Notification panel, dynamically insert this into the live region when it needs to be displayed -->
|
|
<transition
|
|
enter-active-class="transform ease-out duration-300 transition"
|
|
enter-from-class="translate-y-2 opacity-0 sm:translate-y-0 sm:translate-x-2"
|
|
enter-to-class="translate-y-0 opacity-100 sm:translate-x-0"
|
|
leave-active-class="transition ease-in duration-100"
|
|
leave-from-class="opacity-100"
|
|
leave-to-class="opacity-0">
|
|
<div
|
|
v-if="show"
|
|
class="pointer-events-auto w-full max-w-sm overflow-hidden rounded-lg border border-card-border bg-card-background shadow-lg ring-1 ring-black text-white ring-opacity-5">
|
|
<div class="p-4">
|
|
<div class="flex items-start">
|
|
<div class="flex-shrink-0">
|
|
<CheckCircleIcon
|
|
v-if="type === 'success'"
|
|
class="h-6 w-6 text-green-400"
|
|
aria-hidden="true" />
|
|
<XCircleIcon
|
|
v-if="type === 'error'"
|
|
class="h-6 w-6 text-red-400"
|
|
aria-hidden="true" />
|
|
</div>
|
|
<div class="ml-3 w-0 flex-1 pt-0.5">
|
|
<p class="text-sm font-medium text-white">
|
|
{{ title }}
|
|
</p>
|
|
<p v-if="message" class="mt-1 text-sm text-muted">
|
|
{{ message }}
|
|
</p>
|
|
</div>
|
|
<div class="ml-4 flex flex-shrink-0">
|
|
<button
|
|
type="button"
|
|
class="inline-flex rounded-md bg-card-background text-muted hover:text-white focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2"
|
|
@click="show = false">
|
|
<span class="sr-only">Close</span>
|
|
<XMarkIcon class="h-5 w-5" aria-hidden="true" />
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</transition>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { ref } from 'vue';
|
|
import { CheckCircleIcon, XCircleIcon } from '@heroicons/vue/24/outline';
|
|
import { XMarkIcon } from '@heroicons/vue/20/solid';
|
|
import type { NotificationType } from '@/utils/notification';
|
|
|
|
defineProps<{
|
|
title: string;
|
|
type: NotificationType;
|
|
message?: string;
|
|
}>();
|
|
|
|
const show = ref(true);
|
|
</script>
|