mirror of
https://github.com/sqlchat/sqlchat.git
synced 2025-07-28 17:53:21 +08:00
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
import { marked } from "marked";
|
|
import { useUserStore } from "@/store";
|
|
import { Message } from "@/types";
|
|
import Icon from "../Icon";
|
|
|
|
interface Props {
|
|
message: Message;
|
|
}
|
|
|
|
const MessageView = (props: Props) => {
|
|
const message = props.message;
|
|
const userStore = useUserStore();
|
|
const isCurrentUser = message.creatorId === userStore.currentUser.id;
|
|
|
|
return (
|
|
<div className={`w-full flex flex-row justify-start items-start my-4 ${isCurrentUser ? "justify-end pl-8 sm:pl-24" : "pr-8 sm:pr-24"}`}>
|
|
{isCurrentUser ? (
|
|
<>
|
|
<div className="mt-0.5 w-auto max-w-full bg-indigo-600 text-white px-4 py-2 rounded-lg rounded-tr-none shadow whitespace-pre-wrap">
|
|
{message.content}
|
|
</div>
|
|
<div className="w-10 h-10 p-1 border rounded-full flex justify-center items-center ml-2 shrink-0">
|
|
<Icon.Ai.AiOutlineUser className="w-6 h-6" />
|
|
</div>
|
|
</>
|
|
) : (
|
|
<>
|
|
<div className="w-10 h-10 p-1 border rounded-full flex justify-center items-center mr-2 shrink-0">
|
|
<Icon.Ai.AiOutlineRobot className="w-6 h-6" />
|
|
</div>
|
|
<div
|
|
className="mt-0.5 w-auto max-w-full bg-gray-100 px-4 py-2 rounded-lg rounded-tl-none shadow prose prose-neutral"
|
|
dangerouslySetInnerHTML={{ __html: marked.parse(message.content) }}
|
|
></div>
|
|
</>
|
|
)}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default MessageView;
|