Files
prowler/ui/components/findings/table/data-table-row-actions.tsx
Alan Buscaglia 4d5676f00e feat: upgrade to React 19, Next.js 15, React Compiler, HeroUI and Tailwind 4 (#8748)
Co-authored-by: Alan Buscaglia <alanbuscaglia@MacBook-Pro.local>
Co-authored-by: alejandrobailo <alejandrobailo94@gmail.com>
Co-authored-by: César Arroba <cesar@prowler.com>
Co-authored-by: Alejandro Bailo <59607668+alejandrobailo@users.noreply.github.com>
2025-09-30 09:59:51 +02:00

77 lines
2.2 KiB
TypeScript

"use client";
import { Button } from "@heroui/button";
import {
Dropdown,
DropdownItem,
DropdownMenu,
DropdownSection,
DropdownTrigger,
} from "@heroui/dropdown";
import { Row } from "@tanstack/react-table";
import { useState } from "react";
import { SendToJiraModal } from "@/components/findings/send-to-jira-modal";
import { VerticalDotsIcon } from "@/components/icons";
import { JiraIcon } from "@/components/icons/services/IconServices";
import type { FindingProps } from "@/types/components";
interface DataTableRowActionsProps {
row: Row<FindingProps>;
}
export function DataTableRowActions({ row }: DataTableRowActionsProps) {
const finding = row.original;
const [isJiraModalOpen, setIsJiraModalOpen] = useState(false);
const findingTitle =
finding.attributes.check_metadata?.checktitle || "Security Finding";
return (
<>
<SendToJiraModal
isOpen={isJiraModalOpen}
onOpenChange={setIsJiraModalOpen}
findingId={finding.id}
findingTitle={findingTitle}
/>
<div className="relative flex items-center justify-end gap-2">
<Dropdown
className="dark:bg-prowler-blue-800 shadow-xl"
placement="bottom"
>
<DropdownTrigger>
<Button isIconOnly radius="full" size="sm" variant="light">
<VerticalDotsIcon className="text-default-400" />
</Button>
</DropdownTrigger>
<DropdownMenu
closeOnSelect
aria-label="Finding actions"
color="default"
variant="flat"
>
<DropdownSection title="Actions">
<DropdownItem
key="jira"
description="Create a Jira issue for this finding"
textValue="Send to Jira"
startContent={
<JiraIcon
size={20}
className="text-default-500 pointer-events-none shrink-0"
/>
}
onPress={() => setIsJiraModalOpen(true)}
>
Send to Jira
</DropdownItem>
</DropdownSection>
</DropdownMenu>
</Dropdown>
</div>
</>
);
}