import "./stream-page.css"; import { parseNostrLink, TaggedRawEvent } from "@snort/system"; import { useNavigate, useParams } from "react-router-dom"; import { Helmet } from "react-helmet"; import { LiveVideoPlayer } from "element/live-video-player"; import { findTag, getHost } from "utils"; import { Profile, getName } from "element/profile"; import { LiveChat } from "element/live-chat"; import AsyncButton from "element/async-button"; import useEventFeed from "hooks/event-feed"; import { useLogin } from "hooks/login"; import { useZapGoal } from "hooks/goals"; import { StreamState, System } from "index"; import { SendZapsDialog } from "element/send-zap"; import { NostrEvent } from "@snort/system"; import { useUserProfile } from "@snort/system-react"; import { NewStreamDialog } from "element/new-stream"; import { Tags } from "element/tags"; import { StatePill } from "element/state-pill"; import { StreamCards } from "element/stream-cards"; import { formatSats } from "number"; import { StreamTimer } from "element/stream-time"; import { ShareMenu } from "element/share-menu"; import { ContentWarningOverlay, isContentWarningAccepted, } from "element/content-warning"; function ProfileInfo({ ev, goal }: { ev?: NostrEvent; goal?: TaggedRawEvent }) { const login = useLogin(); const navigate = useNavigate(); const host = getHost(ev); const profile = useUserProfile(System, host); const zapTarget = profile?.lud16 ?? profile?.lud06; const status = findTag(ev, "status") ?? ""; const isMine = ev?.pubkey === login?.pubkey; async function deleteStream() { const pub = login?.publisher(); if (pub && ev) { const evDelete = await pub.delete(ev.id); console.debug(evDelete); System.BroadcastEvent(evDelete); navigate("/"); } } const viewers = Number(findTag(ev, "current_participants") ?? "0"); return ( <>

{findTag(ev, "title")}

{findTag(ev, "summary")}

{viewers > 0 && ( {formatSats(viewers)} viewers )} {status === StreamState.Live && ( )} {ev && }
{isMine && (
{ev && } Delete
)}
{ev && ( <> {zapTarget && ( )} )}
); } export function StreamPage() { const params = useParams(); const link = parseNostrLink(params.id!); const { data: ev } = useEventFeed(link, true); const host = getHost(ev); const goal = useZapGoal(host, link, true); const title = findTag(ev, "title"); const summary = findTag(ev, "summary"); const image = findTag(ev, "image"); const status = findTag(ev, "status"); const stream = status === StreamState.Live ? findTag(ev, "streaming") : findTag(ev, "recording"); const contentWarning = findTag(ev, "content-warning"); const tags = ev?.tags.filter((a) => a[0] === "t").map((a) => a[1]) ?? []; if (contentWarning && !isContentWarningAccepted()) { return ; } const descriptionContent = [ title, (summary?.length ?? 0) > 0 ? summary : "Nostr live streaming", ...tags, ].join(", "); return (
{`${title} - zap.stream`}
); }