"use client";
import React, { useEffect, useState } from 'react';
import { useRouter } from 'next/router';
import { useNostr } from '@/hooks/useNostr';
import { parseEvent, findKind0Fields, hexToNpub } from '@/utils/nostr';
import { useImageProxy } from '@/hooks/useImageProxy';
import { Button } from 'primereact/button';
import { Tag } from 'primereact/tag';
import { nip19 } from 'nostr-tools';
import { useLocalStorageWithEffect } from '@/hooks/useLocalStorage';
import Image from 'next/image';
import dynamic from 'next/dynamic';
import ZapThreadsWrapper from '@/components/ZapThreadsWrapper';
import 'primeicons/primeicons.css';
import ReactMarkdown from 'react-markdown';
import rehypeRaw from 'rehype-raw';
const MarkdownContent = ({ content }) => {
return (
{content}
);
};
const BitcoinConnectPayButton = dynamic(
() => import('@getalby/bitcoin-connect-react').then((mod) => mod.PayButton),
{
ssr: false,
}
);
export default function Details() {
const [event, setEvent] = useState(null);
const [processedEvent, setProcessedEvent] = useState({});
const [author, setAuthor] = useState(null);
const [bitcoinConnect, setBitcoinConnect] = useState(false);
const [nAddress, setNAddress] = useState(null);
const [user] = useLocalStorageWithEffect('user', {});
console.log('user:', user);
const { returnImageProxy } = useImageProxy();
const { fetchSingleEvent, fetchKind0, zapEvent } = useNostr();
const router = useRouter();
const handleZapEvent = async () => {
if (!event) return;
const response = await zapEvent(event);
console.log('zap response:', response);
}
useEffect(() => {
if (typeof window === 'undefined') return;
const bitcoinConnectConfig = window.localStorage.getItem('bc:config');
if (bitcoinConnectConfig) {
setBitcoinConnect(true);
}
}, []);
useEffect(() => {
if (router.isReady) {
const { slug } = router.query;
const fetchEvent = async (slug) => {
const event = await fetchSingleEvent(slug);
if (event) {
setEvent(event);
}
};
fetchEvent(slug);
}
}, [router.isReady, router.query]);
useEffect(() => {
const fetchAuthor = async (pubkey) => {
const author = await fetchKind0(pubkey);
const fields = await findKind0Fields(author);
console.log('fields:', fields);
if (fields) {
setAuthor(fields);
}
}
if (event) {
fetchAuthor(event.pubkey);
}
}, [fetchKind0, event]);
useEffect(() => {
if (event) {
const { id, pubkey, content, title, summary, image, published_at, d, topics } = parseEvent(event);
setProcessedEvent({ id, pubkey, content, title, summary, image, published_at, d, topics });
}
}, [event]);
useEffect(() => {
if (processedEvent?.d) {
const naddr = nip19.naddrEncode({
pubkey: processedEvent.pubkey,
kind: processedEvent.kind,
identifier: processedEvent.d,
});
console.log('naddr:', naddr);
setNAddress(naddr);
}
}, [processedEvent]);
return (
router.push('/')} />
{processedEvent && processedEvent.topics && processedEvent.topics.length > 0 && (
processedEvent.topics.map((topic, index) => (
))
)
}
{processedEvent?.title}
{processedEvent?.summary}
{processedEvent && (
{bitcoinConnect ? (
) : (
)}
{typeof window !== 'undefined' && nAddress !== null && (
)}
{
processedEvent?.content &&
}
);
}