Files
flotilla/src/app/components/ContentQuote.svelte
T
2024-10-15 12:02:11 -07:00

29 lines
949 B
Svelte

<script lang="ts">
import {nip19} from "nostr-tools"
import {Address} from "@welshman/util"
import Link from "@lib/components/Link.svelte"
import Spinner from "@lib/components/Spinner.svelte"
import NoteCard from "@app/components/NoteCard.svelte"
import {deriveEvent, entityLink} from "@app/state"
export let value
export let depth = 0
const {id, identifier, kind, pubkey, relays} = value
const idOrAddress = id || new Address(kind, pubkey, identifier).toString()
const event = deriveEvent(idOrAddress, relays)
const nevent = nip19.neventEncode({id, relays})
</script>
<Link external href={entityLink(nevent)} class="my-2 block max-w-full text-left">
{#if $event}
<NoteCard event={$event} class="bg-alt rounded-box p-4">
<slot name="note-content" event={$event} {depth} />
</NoteCard>
{:else}
<div class="rounded-box p-4">
<Spinner loading>Loading event...</Spinner>
</div>
{/if}
</Link>