"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 } from "@/types/commonCode"; interface CodeCategoryFormModalProps { isOpen: boolean; onClose: () => void; editingCategoryCode?: string; } export function CodeCategoryFormModal({ isOpen, onClose, editingCategoryCode }: CodeCategoryFormModalProps) { // const { getText } = useMultiLang(); // 무한 루프 방지를 위해 임시 제거 const { categories, createCategory, updateCategory } = useCommonCode(); // 폼 상태 const [formData, setFormData] = useState({ categoryCode: "", categoryName: "", categoryNameEng: "", description: "", sortOrder: 0, isActive: true, }); const [loading, setLoading] = useState(false); const [errors, setErrors] = useState>({}); // 수정 모드일 때 기존 데이터 로드 useEffect(() => { if (editingCategoryCode && categories.length > 0) { const category = categories.find((c) => c.category_code === editingCategoryCode); if (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 { // 새 카테고리일 때 초기값 setFormData({ categoryCode: "", categoryName: "", categoryNameEng: "", description: "", sortOrder: 0, isActive: true, }); } setErrors({}); }, [editingCategoryCode, categories, isOpen]); // 입력값 검증 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 updateCategory(editingCategoryCode, { categoryName: formData.categoryName, categoryNameEng: formData.categoryNameEng, description: formData.description, sortOrder: formData.sortOrder, isActive: formData.isActive, }); } else { // 생성 await createCategory({ 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={"카테고리 영문명을 입력하세요"} />
{/* 설명 */}