Spaces:
Running
Running
<script lang="ts"> | |
import { settings, playingNotificationSound, isLastActiveTab } from '$lib/stores'; | |
import DOMPurify from 'dompurify'; | |
import { marked } from 'marked'; | |
import { createEventDispatcher, onMount } from 'svelte'; | |
const dispatch = createEventDispatcher(); | |
export let onClick: Function = () => {}; | |
export let title: string = 'HI'; | |
export let content: string; | |
onMount(() => { | |
if (!navigator.userActivation.hasBeenActive) { | |
return; | |
} | |
if ($settings?.notificationSound ?? true) { | |
if (!$playingNotificationSound && $isLastActiveTab) { | |
playingNotificationSound.set(true); | |
const audio = new Audio(`/audio/notification.mp3`); | |
audio.play().finally(() => { | |
// Ensure the global state is reset after the sound finishes | |
playingNotificationSound.set(false); | |
}); | |
} | |
} | |
}); | |
</script> | |
<button | |
class="flex gap-2.5 text-left min-w-[var(--width)] w-full dark:bg-gray-850 dark:text-white bg-white text-black border border-gray-50 dark:border-gray-800 rounded-xl px-3.5 py-3.5" | |
on:click={() => { | |
onClick(); | |
dispatch('closeToast'); | |
}} | |
> | |
<div class="flex-shrink-0 self-top -translate-y-0.5"> | |
<img src={'/static/favicon.png'} alt="favicon" class="size-7 rounded-full" /> | |
</div> | |
<div> | |
{#if title} | |
<div class=" text-[13px] font-medium mb-0.5 line-clamp-1 capitalize">{title}</div> | |
{/if} | |
<div class=" line-clamp-2 text-xs self-center dark:text-gray-300 font-normal"> | |
{@html DOMPurify.sanitize(marked(content))} | |
</div> | |
</div> | |
</button> | |