prasi-lib/comps/form/Form.tsx

43 lines
1.0 KiB
TypeScript
Executable File

import { Form as FForm } from "@/comps/ui/form";
import { FC } from "react";
import { useForm } from "react-hook-form";
export const Form: FC<{
on_load: () => any;
on_submit: (arg: { form: any; error: any }) => any;
body: any;
form: { hook: any; render: () => void };
PassProp: any;
}> = ({ on_load, body, form, PassProp, on_submit }) => {
const form_hook = useForm<any>({
defaultValues: on_load,
});
form.hook = form_hook;
return (
<FForm {...form_hook}>
<form
className={
"flex-1 flex flex-col w-full items-stretch relative overflow-auto"
}
onSubmit={(e) => {
e.preventDefault();
e.stopPropagation();
on_submit({ form: form.hook.getValues(), error: {} });
}}
>
<div className="absolute inset-0">
<PassProp
submit={() => {
on_submit({ form: form.hook.getValues(), error: {} });
}}
>
{body}
</PassProp>
</div>
</form>
</FForm>
);
};