forked from coracle/flotilla
Link back to thread from chat
This commit is contained in:
@@ -1,10 +1,13 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import {nip19} from "nostr-tools"
|
import {nip19} from "nostr-tools"
|
||||||
|
import {nthEq} from "@welshman/lib"
|
||||||
import {Address} from "@welshman/util"
|
import {Address} from "@welshman/util"
|
||||||
|
import {trackerStore} from "@welshman/app"
|
||||||
import Link from "@lib/components/Link.svelte"
|
import Link from "@lib/components/Link.svelte"
|
||||||
import Spinner from "@lib/components/Spinner.svelte"
|
import Spinner from "@lib/components/Spinner.svelte"
|
||||||
import NoteCard from "@app/components/NoteCard.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 value
|
||||||
export let depth = 0
|
export let depth = 0
|
||||||
@@ -14,9 +17,14 @@
|
|||||||
const idOrAddress = id || addr.toString()
|
const idOrAddress = id || addr.toString()
|
||||||
const event = deriveEvent(idOrAddress, relays)
|
const event = deriveEvent(idOrAddress, relays)
|
||||||
const entity = id ? nip19.neventEncode({id, relays}) : addr.toNaddr()
|
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>
|
</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}
|
{#if $event}
|
||||||
<NoteCard event={$event} class="bg-alt rounded-box p-4">
|
<NoteCard event={$event} class="bg-alt rounded-box p-4">
|
||||||
<slot name="note-content" event={$event} {depth} />
|
<slot name="note-content" event={$event} {depth} />
|
||||||
|
|||||||
@@ -120,7 +120,7 @@
|
|||||||
</Button>
|
</Button>
|
||||||
{/if}
|
{/if}
|
||||||
{/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" />
|
<Icon icon="menu-dots" />
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -58,7 +58,7 @@
|
|||||||
</NoteCard>
|
</NoteCard>
|
||||||
<Button class="mb-2 mt-5 flex items-center gap-2" on:click={back}>
|
<Button class="mb-2 mt-5 flex items-center gap-2" on:click={back}>
|
||||||
<Icon icon="alt-arrow-left" />
|
<Icon icon="alt-arrow-left" />
|
||||||
Back to threads
|
Go back
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
{#if showReply}
|
{#if showReply}
|
||||||
|
|||||||
Reference in New Issue
Block a user