snort/src/Element/NoteReaction.tsx

71 lines
2.1 KiB
TypeScript
Raw Normal View History

2023-01-02 11:15:13 +00:00
import "./NoteReaction.css";
2023-01-08 18:35:36 +00:00
import { Link } from "react-router-dom";
import { useMemo } from "react";
2023-01-20 11:11:50 +00:00
import EventKind from "Nostr/EventKind";
import Note from "Element/Note";
import ProfileImage from "Element/ProfileImage";
import { default as NEvent } from "Nostr/Event";
import { eventLink, hexToBech32 } from "Util";
import NoteTime from "Element/NoteTime";
import { RawEvent, TaggedRawEvent } from "Nostr";
2023-01-02 11:15:13 +00:00
2023-01-16 17:48:25 +00:00
export interface NoteReactionProps {
data?: TaggedRawEvent,
["data-ev"]?: NEvent,
root?: TaggedRawEvent
}
export default function NoteReaction(props: NoteReactionProps) {
2023-01-25 13:54:45 +00:00
const { ["data-ev"]: dataEv, data } = props;
const ev = useMemo(() => dataEv || new NEvent(data), [data, dataEv])
2023-01-02 11:15:13 +00:00
2023-01-08 18:35:36 +00:00
const refEvent = useMemo(() => {
2023-01-14 20:04:27 +00:00
if (ev) {
2023-01-08 18:35:36 +00:00
let eTags = ev.Tags.filter(a => a.Key === "e");
2023-01-14 20:04:27 +00:00
if (eTags.length > 0) {
return eTags[0].Event;
}
2023-01-08 18:35:36 +00:00
}
return null;
}, [ev]);
if (ev.Kind !== EventKind.Reaction && ev.Kind !== EventKind.Repost) {
2023-01-02 11:15:13 +00:00
return null;
}
2023-01-08 18:35:36 +00:00
/**
* Some clients embed the reposted note in the content
*/
function extractRoot() {
if (ev?.Kind === EventKind.Repost && ev.Content.length > 0) {
try {
2023-01-16 17:48:25 +00:00
let r: RawEvent = JSON.parse(ev.Content);
return r as TaggedRawEvent;
2023-01-08 18:35:36 +00:00
} catch (e) {
console.error("Could not load reposted content", e);
2023-01-02 11:15:13 +00:00
}
}
2023-01-08 18:35:36 +00:00
return props.root;
2023-01-02 11:15:13 +00:00
}
2023-01-08 18:35:36 +00:00
const root = extractRoot();
const opt = {
showHeader: ev?.Kind === EventKind.Repost,
2023-01-24 14:09:56 +00:00
showFooter: false,
2023-01-08 18:35:36 +00:00
};
2023-01-02 11:15:13 +00:00
return (
<div className="reaction">
<div className="header flex">
2023-01-15 23:14:52 +00:00
<ProfileImage pubkey={ev.RootPubKey} />
2023-01-02 11:15:13 +00:00
<div className="info">
2023-01-09 16:18:34 +00:00
<NoteTime from={ev.CreatedAt * 1000} />
2023-01-02 11:15:13 +00:00
</div>
</div>
2023-01-17 13:03:15 +00:00
{root ? <Note data={root} options={opt} related={[]}/> : null}
2023-01-09 16:18:34 +00:00
{!root && refEvent ? <p><Link to={eventLink(refEvent)}>#{hexToBech32("note", refEvent).substring(0, 12)}</Link></p> : null}
2023-01-02 11:15:13 +00:00
</div>
);
2023-01-15 23:14:52 +00:00
}