"use client"; import React, { useState, useEffect } from "react"; import { Dialog, DialogContent, DialogHeader, DialogTitle, DialogDescription, DialogFooter, } from "@/components/ui/dialog"; import { Button } from "@/components/ui/button"; import { Input } from "@/components/ui/input"; import { Label } from "@/components/ui/label"; import { Textarea } from "@/components/ui/textarea"; import { Loader2 } from "lucide-react"; import { apiClient } from "@/lib/api/client"; interface BomDetailEditModalProps { open: boolean; onOpenChange: (open: boolean) => void; node: Record | null; isRootNode?: boolean; tableName: string; onSaved?: () => void; } export function BomDetailEditModal({ open, onOpenChange, node, isRootNode = false, tableName, onSaved, }: BomDetailEditModalProps) { const [formData, setFormData] = useState>({}); const [saving, setSaving] = useState(false); useEffect(() => { if (node && open) { if (isRootNode) { setFormData({ base_qty: node.base_qty || "", unit: node.unit || "", remark: node.remark || "", }); } else { setFormData({ quantity: node.quantity || "", unit: node.unit || node.detail_unit || "", process_type: node.process_type || "", base_qty: node.base_qty || "", loss_rate: node.loss_rate || "", remark: node.remark || "", }); } } }, [node, open, isRootNode]); const handleChange = (field: string, value: string) => { setFormData((prev) => ({ ...prev, [field]: value })); }; const handleSave = async () => { if (!node) return; setSaving(true); try { const targetTable = isRootNode ? "bom" : tableName; const realId = isRootNode ? node.id?.replace("__root_", "") : node.id; await apiClient.put(`/table-management/tables/${targetTable}/${realId}`, formData); onSaved?.(); onOpenChange(false); } catch (error) { console.error("[BomDetailEdit] 저장 실패:", error); } finally { setSaving(false); } }; if (!node) return null; const itemCode = isRootNode ? node.child_item_code || node.item_code || node.bom_number || "-" : node.child_item_code || "-"; const itemName = isRootNode ? node.child_item_name || node.item_name || "-" : node.child_item_name || "-"; return ( {isRootNode ? "BOM 헤더 수정" : "품목 수정"} {isRootNode ? "BOM 기본 정보를 수정합니다" : "선택한 품목의 BOM 구성 정보를 수정합니다"}
handleChange(isRootNode ? "base_qty" : "quantity", e.target.value)} className="mt-1 h-8 text-xs sm:h-10 sm:text-sm" />
handleChange("unit", e.target.value)} className="mt-1 h-8 text-xs sm:h-10 sm:text-sm" />
{!isRootNode && ( <>
handleChange("process_type", e.target.value)} placeholder="예: 조립공정" className="mt-1 h-8 text-xs sm:h-10 sm:text-sm" />
handleChange("loss_rate", e.target.value)} className="mt-1 h-8 text-xs sm:h-10 sm:text-sm" />
)}