"use client" import * as React from "react" import { toast } from "sonner" import { Trash2 } from "lucide-react" import { Button } from "@/components/ui/button" import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle, AlertDialogTrigger, } from "@/components/ui/alert-dialog" import { deleteTechVendor } from "../service" import type { TechVendor } from "@/db/schema/techVendors" interface DeleteTechVendorDialogProps { vendor: TechVendor onSuccess?: () => void } // 임시 삭제 버튼 export function DeleteTechVendorDialog({ vendor, onSuccess }: DeleteTechVendorDialogProps) { const [isDeleting, setIsDeleting] = React.useState(false) const handleDelete = async () => { setIsDeleting(true) try { const result = await deleteTechVendor(vendor.id) if (result.success) { toast.success("벤더가 성공적으로 삭제되었습니다.") onSuccess?.() } else { toast.error(result.error || "벤더 삭제 중 오류가 발생했습니다.") } } catch (error) { console.error("벤더 삭제 오류:", error) toast.error("벤더 삭제 중 오류가 발생했습니다.") } finally { setIsDeleting(false) } } return ( 벤더 삭제 {vendor.vendorName} 벤더를 정말 삭제하시겠습니까?
이 작업은 되돌릴 수 없으며, 관련된 모든 데이터(담당자, 아이템 등)가 함께 삭제됩니다.
취소 {isDeleting ? "삭제 중..." : "삭제"}
) }