import { Button } from "@/components/ui/button" import { Dialog, DialogClose, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger, } from "@/components/ui/dialog" import { Input } from "@/components/ui/input" import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from "@/components/ui/form" import { ScrollArea } from "@/components/ui/scroll-area" import { useForm } from "react-hook-form" import { z } from "zod" import { zodResolver } from "@hookform/resolvers/zod" import { ModelNAT } from "@/types" import { useState } from "react" import { KeyedMutator } from "swr" import { IconButton } from "@/components/xui/icon-button" import { createNAT, updateNAT } from "@/api/nat" import { useTranslation } from "react-i18next"; interface NATCardProps { data?: ModelNAT; mutate: KeyedMutator; } const natFormSchema = z.object({ name: z.string().min(1), server_id: z.coerce.number().int(), host: z.string(), domain: z.string(), }); export const NATCard: React.FC = ({ data, mutate }) => { const { t } = useTranslation(); const form = useForm>({ resolver: zodResolver(natFormSchema), defaultValues: data ? data : { name: "", server_id: 0, host: "", domain: "", }, resetOptions: { keepDefaultValues: false, } }) const [open, setOpen] = useState(false); const onSubmit = async (values: z.infer) => { data?.id ? await updateNAT(data.id, values) : await createNAT(values); setOpen(false); await mutate(); form.reset(); } return ( {data ? : }
{data?t("EditNAT"):t("CreateNAT")}
( {t("Name")} )} /> ( {t("Server")} ID )} /> ( {t("LocalService")} )} /> ( {t("BindHostname")} )} />
) }