This repository has been archived on 2026-01-31. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
nextjs-auth0/app/customer-form/page.tsx

120 lines
3.1 KiB
TypeScript

'use client';
import { Button } from '@components/Button';
import { FormControl } from '@components/FormControl';
import { FormMessage } from '@components/FormMessage';
import { Input } from '@components/Input';
import { FormField } from '@contexts/FormField/FormFieldProvider';
import { FormItem } from '@contexts/FormItem/FormItemProvider';
import { zodResolver } from '@hookform/resolvers/zod';
import { CustomerFormType } from '@prisma/client';
import {
CustomerForm,
CustomerFormCreate,
CustomerFormCreateSchema,
CustomerFormListSchema,
CustomerFormSchema
} from '@utils/types';
import axios from 'axios';
import { useRouter } from 'next/navigation';
import { useEffect, useState } from 'react';
import { FormProvider, useForm } from 'react-hook-form';
export default function CustomerForms() {
const router = useRouter();
const [customerForms, setCustomerForms] = useState<CustomerForm[]>([]);
const form = useForm<CustomerFormCreate>({
resolver: zodResolver(CustomerFormCreateSchema),
defaultValues: {
type: CustomerFormType.TYPE1,
text: ''
}
});
useEffect(() => {
(async () => {
const response = await axios.get('/api/protected/customer-form');
const validatedResponse = CustomerFormListSchema.safeParse(
response.data.data
);
if (!validatedResponse.success) {
console.error(validatedResponse.error);
return;
}
setCustomerForms(validatedResponse.data);
})();
}, []);
const redirectToCustomerForm = (id: string) => {
router.push(`/customer-form/${id}`);
};
async function handleSubmit(values: CustomerFormCreate) {
try {
const response = await axios.post(
'/api/protected/customer-form',
{
type: CustomerFormType.TYPE1,
text: values.text
},
{
headers: {
'Content-Type': 'application/json'
}
}
);
const validatedResponse = CustomerFormSchema.safeParse(
response.data.data
);
if (!validatedResponse.success) {
console.error(validatedResponse.error);
return;
}
setCustomerForms([...customerForms, validatedResponse.data]);
} catch (error) {
console.error(error);
}
}
return (
<>
<h1>Forms</h1>
{customerForms &&
customerForms.map(customerForm => (
<div
onClick={() => redirectToCustomerForm(customerForm.id)}
key={customerForm.id}
>
{customerForm.text}
of type {customerForm.type}
</div>
))}
<h1>New form</h1>
<FormProvider {...form}>
<form onSubmit={form.handleSubmit(handleSubmit)}>
<FormField
control={form.control}
name='text'
render={({ field }) => (
<FormItem>
<FormMessage />
<FormControl>
<Input placeholder='name' {...field} />
</FormControl>
</FormItem>
)}
/>
<Button type='submit'>Create</Button>
</form>
</FormProvider>
</>
);
}