mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-25 08:46:22 +02:00
52 lines
1.1 KiB
TypeScript
52 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-0 group-hover:opacity-100 transition-opacity"
|
||
|
|
>
|
||
|
|
<MoreHorizontal className="size-4" />
|
||
|
|
</Button>
|
||
|
|
</DropdownMenuTrigger>
|
||
|
|
<DropdownMenuContent align="end">
|
||
|
|
{canEdit && (
|
||
|
|
<DropdownMenuItem onClick={onEdit}>
|
||
|
|
<Pencil className="mr-2 size-4" />
|
||
|
|
Edit
|
||
|
|
</DropdownMenuItem>
|
||
|
|
)}
|
||
|
|
{canDelete && (
|
||
|
|
<DropdownMenuItem onClick={onDelete} className="text-destructive">
|
||
|
|
<Trash2 className="mr-2 size-4" />
|
||
|
|
Delete
|
||
|
|
</DropdownMenuItem>
|
||
|
|
)}
|
||
|
|
</DropdownMenuContent>
|
||
|
|
</DropdownMenu>
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|