import { zodResolver } from "@hookform/resolvers/zod" import { useMutation, useQueryClient } from "@tanstack/react-query" import { Pencil } from "lucide-react" import { useState } from "react" import { useForm } from "react-hook-form" import { z } from "zod" import { type LocationPublic, LocationsService } from "@/client" import { Button } from "@/components/ui/button" import { Dialog, DialogClose, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, } from "@/components/ui/dialog" import { DropdownMenuItem } from "@/components/ui/dropdown-menu" import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from "@/components/ui/form" import { Input } from "@/components/ui/input" import { LoadingButton } from "@/components/ui/loading-button" import useCustomToast from "@/hooks/useCustomToast" import { handleError } from "@/utils" const formSchema = z.object({ title: z.string().min(1, { message: "Title is required" }), description: z.string().optional(), }) type FormData = z.infer interface EditLocationProps { location: LocationPublic onSuccess: () => void } const EditLocation = ({ location, onSuccess }: EditLocationProps) => { const [isOpen, setIsOpen] = useState(false) const queryClient = useQueryClient() const { showSuccessToast, showErrorToast } = useCustomToast() const form = useForm({ resolver: zodResolver(formSchema), mode: "onBlur", criteriaMode: "all", defaultValues: { title: location.title, description: location.description ?? undefined, }, }) const mutation = useMutation({ mutationFn: (data: FormData) => LocationsService.updateLocation({ id: location.id, requestBody: data }), onSuccess: () => { showSuccessToast("Location updated successfully") setIsOpen(false) onSuccess() }, onError: handleError.bind(showErrorToast), onSettled: () => { queryClient.invalidateQueries({ queryKey: ["locations"] }) }, }) const onSubmit = (data: FormData) => { mutation.mutate(data) } return ( e.preventDefault()} onClick={() => setIsOpen(true)} > Edit Location
Edit Location Update the location details below.
( Title * )} /> ( Description )} />
Save
) } export default EditLocation