* feat: redesign * feat: update other columns to new design * chore: small fixes * fix: better manage external webview * feat: redesign note * feat: update ui * chore: update * chore: update * chore: polish ui * chore: update auth ui * feat: finalize note design * chore: small fixes * feat: add window management in rust * chore: format * feat: update ui for event screen * feat: update event screen * feat: final
84 lines
2.2 KiB
TypeScript
84 lines
2.2 KiB
TypeScript
import type { Event } from "@lume/types";
|
|
import { Note, Spinner, User } from "@lume/ui";
|
|
import { cn } from "@lume/utils";
|
|
import { useQuery } from "@tanstack/react-query";
|
|
import { useRouteContext } from "@tanstack/react-router";
|
|
|
|
export function RepostNote({
|
|
event,
|
|
className,
|
|
}: {
|
|
event: Event;
|
|
className?: string;
|
|
}) {
|
|
const { ark } = useRouteContext({ strict: false });
|
|
const {
|
|
isLoading,
|
|
isError,
|
|
data: repostEvent,
|
|
} = useQuery({
|
|
queryKey: ["repost", event.id],
|
|
queryFn: async () => {
|
|
try {
|
|
if (event.content.length > 50) {
|
|
const embed: Event = JSON.parse(event.content);
|
|
return embed;
|
|
}
|
|
|
|
const id = event.tags.find((el) => el[0] === "e")?.[1];
|
|
const repostEvent = await ark.get_event(id);
|
|
|
|
return repostEvent;
|
|
} catch (e) {
|
|
throw new Error(e);
|
|
}
|
|
},
|
|
refetchOnWindowFocus: false,
|
|
refetchOnMount: false,
|
|
});
|
|
|
|
return (
|
|
<Note.Root
|
|
className={cn(
|
|
"bg-white dark:bg-black/20 backdrop-blur-lg rounded-xl mb-3 shadow-primary dark:ring-1 ring-neutral-800/50",
|
|
className,
|
|
)}
|
|
>
|
|
<User.Provider pubkey={event.pubkey}>
|
|
<User.Root className="flex items-center gap-2 px-3 py-3 border-b border-neutral-100 dark:border-neutral-800/50 rounded-t-xl">
|
|
<div className="text-sm font-semibold text-neutral-700 dark:text-neutral-300">
|
|
Reposted by
|
|
</div>
|
|
<User.Avatar className="size-6 shrink-0 rounded-full object-cover ring-1 ring-neutral-200/50 dark:ring-neutral-800/50" />
|
|
</User.Root>
|
|
</User.Provider>
|
|
{isLoading ? (
|
|
<div className="flex h-20 items-center justify-center gap-2">
|
|
<Spinner />
|
|
Loading event...
|
|
</div>
|
|
) : isError || !repostEvent ? (
|
|
<div className="flex h-20 items-center justify-center">
|
|
Event not found within your current relay set
|
|
</div>
|
|
) : (
|
|
<Note.Provider event={repostEvent}>
|
|
<Note.Root>
|
|
<div className="px-3 h-14 flex items-center justify-between">
|
|
<Note.User />
|
|
<Note.Menu />
|
|
</div>
|
|
<Note.Content className="px-3" />
|
|
<div className="mt-3 flex items-center gap-4 h-14 px-3">
|
|
<Note.Open />
|
|
<Note.Reply />
|
|
<Note.Repost />
|
|
<Note.Zap />
|
|
</div>
|
|
</Note.Root>
|
|
</Note.Provider>
|
|
)}
|
|
</Note.Root>
|
|
);
|
|
}
|