problem: can't view latest rocket event

This commit is contained in:
gsovereignty
2024-07-03 16:24:49 +08:00
parent d0f3770b01
commit 791422b728
3 changed files with 59 additions and 9 deletions

View File

@@ -70,7 +70,7 @@
>Alert</span
>
<span class="mr-2 flex-auto text-left font-semibold"
>Nostrocket is sooooo not ready yet, don't expect everything to work</span
>Nostrocket is sooooo not ready yet but whatever</span
>
</div>

View File

@@ -1,8 +0,0 @@
<script>
import { page } from "$app/stores";
//flow: fetch all 31108's with this d-tag, sort by WoT, put Nostrocket Name Service one at the top. Dedupe same rocket (same state, shadows) from multiple users, just show them all as everyone agreeing.
//second pass: fetch ignition event for each, rebuild current state and validate all proofs, compute votepower and display only the states with > 50%.
</script>
{$page.params.id}

View File

@@ -0,0 +1,58 @@
<script lang="ts">
import { page } from '$app/stores';
import { ndk } from '@/ndk';
import type { NDKEvent } from '@nostr-dev-kit/ndk';
import type { ExtendedBaseType, NDKEventStore } from '@nostr-dev-kit/ndk-svelte';
import { onDestroy } from 'svelte';
import { derived, type Readable } from 'svelte/store';
//flow if we only have a d-tag: fetch all 31108's with this d-tag, sort by WoT, put Nostrocket Name Service one at the top. Dedupe same rocket (same state, shadows) from multiple users, just show them all as everyone agreeing.
//second pass: fetch ignition event for each, rebuild current state and validate all proofs, compute votepower and display only the states with > 50%.
let rIgnitionOrActual = $page.params.ignition;
let rName = $page.url.searchParams.get('d');
let rPubkey = $page.url.searchParams.get('p');
let events: NDKEventStore<NDKEvent> | undefined;
let latest: Readable<ExtendedBaseType<NDKEvent> | undefined>;
onDestroy(() => {
events?.unsubscribe();
});
//if we don't have a d/p tags we just render the event provided
//todo: to find the latest by name alone we should use a new route and redirect to this page once we've got the relevant data
if (!rName && !rPubkey && rIgnitionOrActual.length == 64) {
//this is the actual event ID the user wants to view so fetch the single event and render
//warn user that this information is probably out of date and let them reroute to get the latest
}
if (rIgnitionOrActual.length == 64 && rName && rPubkey) {
//the user wants the latest valid state of this rocket
events = $ndk.storeSubscribe(
[{ '#d': [rName], authors: [rPubkey], kinds: [31108 as number] }],
{ subId: rName }
);
}
$: {
if (events) {
latest = derived(events, ($events) => {
if (events) {
let sorted = $events.toSorted((a,b) => {
return a.created_at - b.created_at
})
return sorted[0]
}
return undefined;
});
}
}
//todo: handle shadow events (fetch the shadowed event and render it instead)
</script>
{#if latest && $latest}
<p>{$latest.id}</p>
{/if}
IGNITION: {rIgnitionOrActual} <br />
NAME: {rName} <br />
PUBKEY: {rPubkey} <br />