59 lines
3.3 KiB
PHP
59 lines
3.3 KiB
PHP
@props(['notificationTimeout' => 5000])
|
|
<div
|
|
x-data="{
|
|
messages: [],
|
|
remove(message) {
|
|
this.messages.splice(this.messages.indexOf(message), 1)
|
|
},
|
|
}"
|
|
@notify.window="let message = $event.detail; messages.push(message); setTimeout(() => { remove(message) }, {{ $notificationTimeout }})"
|
|
class="fixed inset-0 flex flex-col items-end justify-center px-4 py-6 pointer-events-none sm:p-6 sm:justify-start space-y-4"
|
|
style="z-index:1000"
|
|
>
|
|
<template x-for="message in messages" :key="messages.indexOf(message)">
|
|
<div
|
|
x-transition:enter="transform ease-out duration-300 transition"
|
|
x-transition:enter-start="translate-y-2 opacity-0 sm:translate-y-0 sm:translate-x-2"
|
|
x-transition:enter-end="translate-y-0 opacity-100 sm:translate-x-0"
|
|
x-transition:leave="transition ease-in duration-100"
|
|
x-transition:leave-start="opacity-100"
|
|
x-transition:leave-end="opacity-0"
|
|
class="max-w-sm w-full bg-white shadow-lg rounded-lg pointer-events-auto"
|
|
>
|
|
<div class="rounded-lg shadow-xs overflow-hidden border border-light-grey">
|
|
<div class="p-4">
|
|
<div class="flex items-center">
|
|
<div class="flex-shrink-0">
|
|
<template x-if="message.type != 'error'">
|
|
<svg class="h-6 w-6 text-green-400" fill="none" viewBox="0 0 24 24" stroke="currentColor">
|
|
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2"
|
|
d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z"></path>
|
|
</svg>
|
|
</template>
|
|
<template x-if="message.type == 'error'">
|
|
<div class="rounded-full bg-red-600 text-white flex justify-center items-center"
|
|
style="width:30px;height:30px">
|
|
<x-icon.exclamation style="transform: scale(1.5)"/>
|
|
</div>
|
|
</template>
|
|
</div>
|
|
<div class="ml-3 w-0 flex-1 pt-0.5">
|
|
<p x-text="message.message" class="text-sm leading-5 font-medium text-gray-900"></p>
|
|
</div>
|
|
<div class="ml-4 flex-shrink-0 flex">
|
|
<button @click="remove(message)"
|
|
class="inline-flex text-gray-400 focus:outline-none focus:text-gray-500 transition ease-in-out duration-150">
|
|
<svg class="h-5 w-5" viewBox="0 0 20 20" fill="currentColor">
|
|
<path fill-rule="evenodd"
|
|
d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
|
|
clip-rule="evenodd"></path>
|
|
</svg>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</div>
|