Files
papermark/components/chat/chat-message-actions.tsx
2024-05-13 14:52:25 +02:00

44 lines
1.0 KiB
TypeScript

"use client";
import { type Message } from "ai";
import { Button } from "@/components/ui/button";
import { cn } from "@/lib/utils";
import { useCopyToClipboard } from "@/lib/utils/use-copy-to-clipboard";
import Check from "../shared/icons/check";
import Copy from "../shared/icons/copy";
interface ChatMessageActionsProps extends React.ComponentProps<"div"> {
message: Message;
}
export function ChatMessageActions({
message,
className,
...props
}: ChatMessageActionsProps) {
const { isCopied, copyToClipboard } = useCopyToClipboard({ timeout: 2000 });
const onCopy = () => {
if (isCopied) return;
copyToClipboard(message.content);
};
return (
<div
className={cn(
"flex items-center justify-end md:absolute md:-top-2 md:right-0 md:hidden",
className,
)}
{...props}
>
<Button variant="ghost" size="icon" onClick={onCopy}>
{isCopied ? <Check /> : <Copy />}
<span className="sr-only">Copy message</span>
</Button>
</div>
);
}