File size: 1,543 Bytes
246d201
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import { useClickOutsideElement } from "#/hooks/use-click-outside-element";
import { cn } from "#/utils/utils";
import { ContextMenu } from "../context-menu/context-menu";
import { ContextMenuListItem } from "../context-menu/context-menu-list-item";

interface ConversationCardContextMenuProps {
  onClose: () => void;
  onDelete?: (event: React.MouseEvent<HTMLButtonElement>) => void;
  onEdit?: (event: React.MouseEvent<HTMLButtonElement>) => void;
  onDownload?: (event: React.MouseEvent<HTMLButtonElement>) => void;
  position?: "top" | "bottom";
}

export function ConversationCardContextMenu({

  onClose,

  onDelete,

  onEdit,

  onDownload,

  position = "bottom",

}: ConversationCardContextMenuProps) {
  const ref = useClickOutsideElement<HTMLUListElement>(onClose);

  return (
    <ContextMenu

      ref={ref}

      testId="context-menu"

      className={cn(

        "right-0 absolute",

        position === "top" && "bottom-full",

        position === "bottom" && "top-full",

      )}

    >

      {onDelete && (

        <ContextMenuListItem testId="delete-button" onClick={onDelete}>

          Delete

        </ContextMenuListItem>

      )}

      {onEdit && (

        <ContextMenuListItem testId="edit-button" onClick={onEdit}>

          Edit Title

        </ContextMenuListItem>

      )}

      {onDownload && (

        <ContextMenuListItem testId="download-button" onClick={onDownload}>

          Download Workspace

        </ContextMenuListItem>

      )}

    </ContextMenu>
  );
}