"use client" import * as React from "react" import { useForm } from "react-hook-form" import { zodResolver } from "@hookform/resolvers/zod" import * as z from "zod" import { Button } from "@/components/ui/button" import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger, } from "@/components/ui/dialog" import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from "@/components/ui/form" import { Input } from "@/components/ui/input" import { Textarea } from "@/components/ui/textarea" import { Switch } from "@/components/ui/switch" import { Plus, Loader2 } from "lucide-react" import { toast } from "sonner" import { createComplianceSurveyTemplate } from "../services" const createTemplateSchema = z.object({ name: z.string().min(1, "템플릿명을 입력해주세요.").max(100, "템플릿명은 100자 이하여야 합니다."), description: z.string().min(1, "설명을 입력해주세요.").max(500, "설명은 500자 이하여야 합니다."), version: z.string().min(1, "버전을 입력해주세요.").max(20, "버전은 20자 이하여야 합니다."), isActive: z.boolean().default(true), }) type CreateTemplateFormValues = z.infer export function ComplianceTemplateCreateDialog() { const [open, setOpen] = React.useState(false) const [isSubmitting, setIsSubmitting] = React.useState(false) // react-hook-form 세팅 const form = useForm({ resolver: zodResolver(createTemplateSchema), defaultValues: { name: "", description: "", version: "1.0", isActive: true, }, mode: "onChange", }) async function onSubmit(data: CreateTemplateFormValues) { setIsSubmitting(true) try { const result = await createComplianceSurveyTemplate(data) if (result) { toast.success("새로운 설문조사 템플릿이 생성되었습니다.") form.reset() setOpen(false) // 페이지 새로고침으로 데이터 업데이트 window.location.reload() } } catch (error) { console.error("템플릿 생성 오류:", error) toast.error("템플릿 생성에 실패했습니다.") } finally { setIsSubmitting(false) } } function handleDialogOpenChange(nextOpen: boolean) { if (!nextOpen) { form.reset() } setOpen(nextOpen) } return ( 새 설문조사 템플릿 생성 새로운 준법 설문조사 템플릿을 생성합니다. 템플릿 생성 후 질문을 추가할 수 있습니다.
( 템플릿명 * )} /> ( 설명 *