"use client"; import { useState, useEffect } from "react"; import { Dialog, DialogContent, DialogHeader, DialogTitle } from "@/components/ui/dialog"; import { Button } from "@/components/ui/button"; import { Input } from "@/components/ui/input"; import { Textarea } from "@/components/ui/textarea"; import { Label } from "@/components/ui/label"; import { Switch } from "@/components/ui/switch"; // import { useCommonCode } from "@/hooks/useCommonCode"; // 제거: 상태 공유 문제 해결 // import { useMultiLang } from "@/hooks/useMultiLang"; // 무한 루프 방지를 위해 임시 제거 import { LoadingSpinner } from "@/components/common/LoadingSpinner"; import { CodeCategory, CreateCategoryRequest, UpdateCategoryRequest } from "@/types/commonCode"; interface CodeCategoryFormModalProps { isOpen: boolean; onClose: () => void; editingCategoryCode?: string; categories: CodeCategory[]; onCreateCategory: (data: CreateCategoryRequest) => Promise; onUpdateCategory: (categoryCode: string, data: UpdateCategoryRequest) => Promise; } export function CodeCategoryFormModal({ isOpen, onClose, editingCategoryCode, categories, onCreateCategory, onUpdateCategory, }: CodeCategoryFormModalProps) { // const { getText } = useMultiLang(); // 무한 루프 방지를 위해 임시 제거 // const { categories, createCategory, updateCategory } = useCommonCode(); // 제거: props로 전달받음 // 폼 상태 const [formData, setFormData] = useState({ categoryCode: "", categoryName: "", categoryNameEng: "", description: "", sortOrder: 1, isActive: true, }); const [loading, setLoading] = useState(false); const [errors, setErrors] = useState>({}); // 모달 열릴 때 데이터 초기화 useEffect(() => { if (isOpen) { if (editingCategoryCode && categories.length > 0) { // 수정 모드: 기존 데이터 로드 const category = categories.find((c) => c.category_code === editingCategoryCode); if (category) { console.log("🔄 카테고리 수정 모드 - 기존 데이터 로드:", category); setFormData({ categoryCode: category.category_code, categoryName: category.category_name, categoryNameEng: category.category_name_eng || "", description: category.description || "", sortOrder: category.sort_order, isActive: category.is_active === "Y", }); } } else { // 새 카테고리 모드: 초기값 설정 및 자동 순서 계산 const maxSortOrder = categories.length > 0 ? Math.max(...categories.map((c) => c.sort_order)) : 0; console.log("✨ 새 카테고리 모드 - 초기값 설정, 다음 순서:", maxSortOrder + 1); setFormData({ categoryCode: "", categoryName: "", categoryNameEng: "", description: "", sortOrder: maxSortOrder + 1, isActive: true, }); } setErrors({}); } }, [isOpen, editingCategoryCode, categories]); // 입력값 검증 const validateForm = () => { const newErrors: Record = {}; if (!formData.categoryCode.trim()) { newErrors.categoryCode = "필수 입력 항목입니다."; } if (!formData.categoryName.trim()) { newErrors.categoryName = "필수 입력 항목입니다."; } setErrors(newErrors); return Object.keys(newErrors).length === 0; }; // 폼 제출 핸들러 const handleSubmit = async (e: React.FormEvent) => { e.preventDefault(); if (!validateForm()) return; setLoading(true); try { if (editingCategoryCode) { // 수정 await onUpdateCategory(editingCategoryCode, { categoryName: formData.categoryName, categoryNameEng: formData.categoryNameEng, description: formData.description, sortOrder: formData.sortOrder, isActive: formData.isActive, }); } else { // 생성 await onCreateCategory({ categoryCode: formData.categoryCode, categoryName: formData.categoryName, categoryNameEng: formData.categoryNameEng, description: formData.description, sortOrder: formData.sortOrder, }); } onClose(); } catch (error) { console.error("카테고리 저장 오류:", error); // 에러 처리는 useCommonCode 훅에서 처리됨 } finally { setLoading(false); } }; // 입력값 변경 핸들러 const handleChange = (field: string, value: any) => { setFormData((prev) => ({ ...prev, [field]: value })); // 에러 제거 if (errors[field]) { setErrors((prev) => ({ ...prev, [field]: "" })); } }; return ( {editingCategoryCode ? "카테고리 수정" : "새 카테고리"}
{/* 카테고리 코드 */}
handleChange("categoryCode", e.target.value)} disabled={!!editingCategoryCode || loading} placeholder={"카테고리 코드를 입력하세요"} className={errors.categoryCode ? "border-red-500" : ""} /> {errors.categoryCode &&

{errors.categoryCode}

}
{/* 카테고리명 */}
handleChange("categoryName", e.target.value)} disabled={loading} placeholder={"카테고리명을 입력하세요"} className={errors.categoryName ? "border-red-500" : ""} /> {errors.categoryName &&

{errors.categoryName}

}
{/* 영문명 */}
handleChange("categoryNameEng", e.target.value)} disabled={loading} placeholder={"카테고리 영문명을 입력하세요"} />
{/* 설명 */}