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 { ModelServerGroupResponseItem } from "@/types" import { useState } from "react" import { KeyedMutator } from "swr" import { IconButton } from "@/components/xui/icon-button" import { createServerGroup, updateServerGroup } from "@/api/server-group" import { MultiSelect } from "@/components/xui/multi-select" import { useServer } from "@/hooks/useServer" interface ServerGroupCardProps { data?: ModelServerGroupResponseItem; mutate: KeyedMutator; } const serverGroupFormSchema = z.object({ name: z.string().min(1), servers: z.array(z.number()), }); export const ServerGroupCard: React.FC = ({ data, mutate }) => { const form = useForm>({ resolver: zodResolver(serverGroupFormSchema), defaultValues: data ? { name: data.group.name, servers: data.servers, } : { name: "", servers: [], }, resetOptions: { keepDefaultValues: false, } }) const [open, setOpen] = useState(false); const onSubmit = async (values: z.infer) => { data?.group.id ? await updateServerGroup(data.group.id, values) : await createServerGroup(values); setOpen(false); await mutate(); form.reset(); } const { servers } = useServer(); const serverList = servers?.map(s => ({ value: `${s.id}`, label: s.name, })) || [{ value: "", label: "" }]; return ( {data ? : }
New Server Group
( Name )} /> ( Servers { const arr = e.map(Number); field.onChange(arr); }} defaultValue={field.value?.map(String)} /> )} />
) }