import { api } from "@/utils/api"; import { useEffect } from "react"; import { Form, FormControl, FormField, FormItem, FormMessage, } from "@/components/ui/form"; import { zodResolver } from "@hookform/resolvers/zod"; import { useForm } from "react-hook-form"; import { z } from "zod"; import { validateAndFormatYAML } from "../../application/advanced/traefik/update-traefik-config"; import { toast } from "sonner"; import { Button } from "@/components/ui/button"; import { RandomizeCompose } from "./randomize-compose"; import { CodeEditor } from "@/components/shared/code-editor"; interface Props { composeId: string; } const AddComposeFile = z.object({ composeFile: z.string(), }); type AddComposeFile = z.infer; export const ComposeFileEditor = ({ composeId }: Props) => { const utils = api.useUtils(); const { data, refetch } = api.compose.one.useQuery( { composeId, }, { enabled: !!composeId }, ); const { mutateAsync, isLoading, error, isError } = api.compose.update.useMutation(); const form = useForm({ defaultValues: { composeFile: "", }, resolver: zodResolver(AddComposeFile), }); useEffect(() => { if (data) { form.reset({ composeFile: data.composeFile || "", }); } }, [form, form.reset, data]); const onSubmit = async (data: AddComposeFile) => { const { valid, error } = validateAndFormatYAML(data.composeFile); if (!valid) { form.setError("composeFile", { type: "manual", message: error || "Invalid YAML", }); return; } form.clearErrors("composeFile"); await mutateAsync({ composeId, composeFile: data.composeFile, sourceType: "raw", }) .then(async () => { toast.success("Compose config Updated"); refetch(); await utils.compose.allServices.invalidate({ composeId, }); }) .catch((e) => { console.log(e); toast.error("Error to update the compose config"); }); }; return ( <>
(
{ field.onChange(value); }} />
										
									
)} />
); };