import { observer } from "mobx-react-lite"; import { Message as MessageObject } from "revolt.js/dist/maps/Messages"; import { attachContextMenu } from "preact-context-menu"; import { memo } from "preact/compat"; import { useState } from "preact/hooks"; import { internalEmit } from "../../../lib/eventEmitter"; import { QueuedMessage } from "../../../mobx/stores/MessageQueue"; import { useIntermediate } from "../../../context/intermediate/Intermediate"; import { useClient } from "../../../context/revoltjs/RevoltClient"; import Overline from "../../ui/Overline"; import { Children } from "../../../types/Preact"; import Markdown from "../../markdown/Markdown"; import UserIcon from "../user/UserIcon"; import { Username } from "../user/UserShort"; import MessageBase, { MessageContent, MessageDetail, MessageInfo, } from "./MessageBase"; import Attachment from "./attachments/Attachment"; import { MessageReply } from "./attachments/MessageReply"; import Embed from "./embed/Embed"; import InviteList from "./embed/EmbedInvite"; interface Props { attachContext?: boolean; queued?: QueuedMessage; message: MessageObject; highlight?: boolean; contrast?: boolean; content?: Children; head?: boolean; hideReply?: boolean; } const Message = observer( ({ highlight, attachContext, message, contrast, content: replacement, head: preferHead, queued, hideReply, }: Props) => { const client = useClient(); const user = message.author; const { openScreen } = useIntermediate(); const content = message.content as string; const head = preferHead || (message.reply_ids && message.reply_ids.length > 0); // ! TODO: tell fatal to make this type generic // bree: Fatal please... const userContext = attachContext ? (attachContextMenu("Menu", { user: message.author_id, contextualChannel: message.channel_id, // eslint-disable-next-line }) as any) : undefined; const openProfile = () => openScreen({ id: "profile", user_id: message.author_id }); const handleUserClick = (e: MouseEvent) => { if (e.shiftKey && user?._id) { internalEmit( "MessageBox", "append", `<@${user._id}>`, "mention", ); } else { openProfile(); } }; // ! FIXME(?): animate on hover const [animate, setAnimate] = useState(false); return (
{!hideReply && message.reply_ids?.map((message_id, index) => ( ))} 0 )) ?? false } contrast={contrast} sending={typeof queued !== "undefined"} mention={message.mention_ids?.includes(client.user!._id)} failed={typeof queued?.error !== "undefined"} onContextMenu={ attachContext ? attachContextMenu("Menu", { message, contextualChannel: message.channel_id, queued, }) : undefined } onMouseEnter={() => setAnimate(true)} onMouseLeave={() => setAnimate(false)}> {head ? ( ) : ( )} {head && ( )} {replacement ?? } {!queued && } {queued?.error && ( )} {message.attachments?.map((attachment, index) => ( 0 || content.length > 0} /> ))} {message.embeds?.map((embed, index) => ( ))}
); }, ); export default memo(Message);