wag-frontend-version-3/oldCode/building/create/CreatePage.tsx

97 lines
2.8 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

"use client";
import { RetrieveInputByType } from "@/hooks/renderInputWithValidation";
import * as z from "zod";
import { zodResolver } from "@hookform/resolvers/zod";
import { useForm } from "react-hook-form";
import {
Form,
FormControl,
FormField,
FormItem,
FormLabel,
FormMessage,
FormDescription,
} from "@/components/ui/form";
import { convertApiValidationToZodValidation } from "@/lib/renderZodValidation";
interface CreatePageComponentInterface {
validator: any;
headers: any;
}
const CreatePageComponent: React.FC<CreatePageComponentInterface> = ({
validator,
headers,
}) => {
const returnValidation = convertApiValidationToZodValidation(validator);
const { validSchemaZod, zodValidation, apiValidation } = returnValidation;
const form = useForm<z.infer<typeof validSchemaZod>>({
resolver: zodResolver(validSchemaZod),
defaultValues: {},
});
function submitUpdate(formData: z.infer<typeof validSchemaZod>) {
// saveFunction({
// uu_id: updateUUID,
// payload: validDataParser(formData),
// }).then((res: any) => {
// console.log(res);
// if (res?.status === 200) {
// } else {
// alert("Güncelleme başarısız");
// }
// });
}
return (
<div className="container mx-auto p-4">
<Form {...form}>
<form action="">
{Object.entries(validator).map(([key, value]: [string, any]) => (
<FormField
key={key}
control={form.control}
name={String(key)}
render={({ field }) => {
return (
<FormItem>
<FormLabel>
{headers[key] || `Header not found ${key}`}
</FormLabel>
<FormControl>
{RetrieveInputByType({
type: value?.fieldType || "string",
props: {
className: "",
field: field,
placeholder: headers[key],
required: value?.required || false,
},
})}
</FormControl>
{String(form.formState.errors[key]?.type) ===
"invalid_type" ? (
<span id={key} className="text-red-700">
"Lütfen metinsel bir değer giriniz"
</span>
) : (
<></>
)}
</FormItem>
);
}}
/>
))}
<button type="submit" className="mt-4">
Submit
</button>
</form>
</Form>
</div>
);
};
export default CreatePageComponent;