mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-25 16:56:22 +02:00
45 lines
1.1 KiB
TypeScript
45 lines
1.1 KiB
TypeScript
"use client";
|
|
|
|
import { MoreHorizontal, Pencil, Trash2 } from "lucide-react";
|
|
import { Button } from "@/components/ui/button";
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuTrigger,
|
|
} from "@/components/ui/dropdown-menu";
|
|
import type { CommentActionsProps } from "./types";
|
|
|
|
export function CommentActions({ canEdit, canDelete, onEdit, onDelete }: CommentActionsProps) {
|
|
if (!canEdit && !canDelete) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger asChild>
|
|
<Button
|
|
variant="ghost"
|
|
size="icon"
|
|
className="size-7 opacity-100 md:opacity-0 md:group-hover:opacity-100 transition-opacity"
|
|
>
|
|
<MoreHorizontal className="size-4 text-muted-foreground" />
|
|
</Button>
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent align="end">
|
|
{canEdit && (
|
|
<DropdownMenuItem onClick={onEdit}>
|
|
<Pencil className="mr-2 size-4" />
|
|
Edit
|
|
</DropdownMenuItem>
|
|
)}
|
|
{canDelete && (
|
|
<DropdownMenuItem onClick={onDelete}>
|
|
<Trash2 className="mr-2 size-4" />
|
|
Delete
|
|
</DropdownMenuItem>
|
|
)}
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
);
|
|
}
|