Link back to thread from chat

This commit is contained in:
Jon Staab
2024-10-24 09:21:34 -07:00
parent e327bebe12
commit 72de2e1513
3 changed files with 12 additions and 4 deletions
+10 -2
View File
@@ -1,10 +1,13 @@
<script lang="ts">
import {nip19} from "nostr-tools"
import {nthEq} from "@welshman/lib"
import {Address} from "@welshman/util"
import {trackerStore} from "@welshman/app"
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"
import {deriveEvent, entityLink, userMembership, getMembershipUrls, REPLY} from "@app/state"
import {makeThreadPath} from "@app/routes"
export let value
export let depth = 0
@@ -14,9 +17,14 @@
const idOrAddress = id || addr.toString()
const event = deriveEvent(idOrAddress, relays)
const entity = id ? nip19.neventEncode({id, relays}) : addr.toNaddr()
// If we found this event on a relay that the user is a member of, redirect internally
$: url = getMembershipUrls($userMembership).find(url => $trackerStore.hasRelay($event.id, url))
$: root = $event?.kind === REPLY ? $event.tags.find(nthEq(0, 'E'))?.[1] : $event?.id
$: href = url && root ? makeThreadPath(url, root) : entityLink(entity)
</script>
<Link external href={entityLink(entity)} class="my-2 block max-w-full text-left">
<Link external={!url} {href} 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} />
@@ -120,7 +120,7 @@
</Button>
{/if}
{/if}
<Button on:click={openMenu} class="btn btn-neutral btn-sm">
<Button on:click={openMenu} class="btn btn-neutral btn-sm md:hidden">
<Icon icon="menu-dots" />
</Button>
</div>
@@ -58,7 +58,7 @@
</NoteCard>
<Button class="mb-2 mt-5 flex items-center gap-2" on:click={back}>
<Icon icon="alt-arrow-left" />
Back to threads
Go back
</Button>
</div>
{#if showReply}