mirror of
https://github.com/prowler-cloud/prowler.git
synced 2026-03-22 03:08:23 +00:00
60 lines
1.6 KiB
TypeScript
60 lines
1.6 KiB
TypeScript
"use client";
|
|
|
|
import { Row } from "@tanstack/react-table";
|
|
import { Pencil, Trash2 } from "lucide-react";
|
|
|
|
import { VerticalDotsIcon } from "@/components/icons";
|
|
import { Button } from "@/components/shadcn";
|
|
import {
|
|
ActionDropdown,
|
|
ActionDropdownDangerZone,
|
|
ActionDropdownItem,
|
|
} from "@/components/shadcn/dropdown";
|
|
|
|
import { EnrichedApiKey } from "./types";
|
|
|
|
interface DataTableRowActionsProps {
|
|
row: Row<EnrichedApiKey>;
|
|
onEdit: (apiKey: EnrichedApiKey) => void;
|
|
onRevoke: (apiKey: EnrichedApiKey) => void;
|
|
}
|
|
|
|
export function DataTableRowActions({
|
|
row,
|
|
onEdit,
|
|
onRevoke,
|
|
}: DataTableRowActionsProps) {
|
|
const apiKey = row.original;
|
|
const isRevoked = apiKey.attributes.revoked;
|
|
const isExpired = new Date(apiKey.attributes.expires_at) < new Date();
|
|
const canRevoke = !isRevoked && !isExpired;
|
|
|
|
return (
|
|
<div className="relative flex items-center justify-end gap-2">
|
|
<ActionDropdown
|
|
trigger={
|
|
<Button variant="ghost" size="icon-sm" className="rounded-full">
|
|
<VerticalDotsIcon className="text-slate-400" />
|
|
</Button>
|
|
}
|
|
>
|
|
<ActionDropdownItem
|
|
icon={<Pencil />}
|
|
label="Edit API Key"
|
|
onSelect={() => onEdit(apiKey)}
|
|
/>
|
|
{canRevoke && (
|
|
<ActionDropdownDangerZone>
|
|
<ActionDropdownItem
|
|
icon={<Trash2 />}
|
|
label="Revoke API Key"
|
|
destructive
|
|
onSelect={() => onRevoke(apiKey)}
|
|
/>
|
|
</ActionDropdownDangerZone>
|
|
)}
|
|
</ActionDropdown>
|
|
</div>
|
|
);
|
|
}
|