"use client"; import { Form } from "@/components/ui/form"; import { FormControl, FormField, FormItem, FormLabel, } from "@/components/ui/form"; import { Input } from "@/components/ui/input"; import { zodResolver } from "@hookform/resolvers/zod"; import { isTRPCClientError } from "@trpc/client"; import { useTransition } from "react"; import { useForm } from "react-hook-form"; import { toast } from "sonner"; import { z } from "zod"; const schema = z.object({ password: z.string().min(1), }); type FormValues = z.infer; export function FormPassword({ onSubmit, ...props }: Omit, "onSubmit"> & { onSubmit: (values: FormValues) => Promise; }) { const form = useForm({ resolver: zodResolver(schema), defaultValues: { password: "", }, }); const [isPending, startTransition] = useTransition(); function submitAction(values: FormValues) { if (isPending) return; startTransition(async () => { try { const promise = onSubmit(values); toast.promise(promise, { loading: "Confirming...", success: "Confirmed", error: (error) => { if (isTRPCClientError(error)) { form.setError("password", { message: error.message }); return error.message; } return "Failed to confirm"; }, }); await promise; } catch (error) { console.error(error); } }); } return (
( Password )} /> ); }