import "./stream-page.css"; import { NostrLink, NostrPrefix, TaggedNostrEvent, tryParseNostrLink, } from "@snort/system"; import { fetchNip05Pubkey } from "@snort/shared"; import { useLocation, useNavigate, useParams } from "react-router-dom"; import { Helmet } from "react-helmet"; import { LiveVideoPlayer } from "element/live-video-player"; import { createNostrLink, findTag, getEventFromLocationState, getHost, hexToBech32, } from "utils"; import { Profile, getName } from "element/profile"; import { LiveChat } from "element/live-chat"; import AsyncButton from "element/async-button"; 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"; import { useCurrentStreamFeed } from "hooks/current-stream-feed"; import { useEffect, useState } from "react"; function ProfileInfo({ ev, goal, }: { ev?: NostrEvent; goal?: TaggedNostrEvent; }) { const login = useLogin(); const navigate = useNavigate(); const host = getHost(ev); const profile = useUserProfile(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, "summary")}