Untitled
import { zodResolver } from '@hookform/resolvers/zod'; import { isEqual } from 'lodash'; import { useForm, useWatch } from 'react-hook-form'; import router from 'next/router'; import Button from '@/components/ui/Button'; import DatePicker from '@/components/ui/DatePicker'; import { Form } from '@/components/ui/Form'; import Input from '@/components/ui/Input'; import TextArea from '@/components/ui/Textarea'; import { NewEntry } from '@/lib/api/entries/types'; import { BasicFormField } from '../components'; import { defaultFormValues } from './constants'; import { createEntrySchema, editEntrySchema } from './formSchema'; interface EntryFormProps { onSubmit(data: NewEntry): void; initialData?: Partial<NewEntry>; isSavingEntry?: boolean; isReadonly?: boolean; } const EntryForm = ({ onSubmit, initialData, isSavingEntry, isReadonly }: EntryFormProps) => { const isEditMode = !!initialData; const form = useForm<NewEntry>({ resolver: zodResolver(isEditMode ? editEntrySchema : createEntrySchema), defaultValues: initialData || defaultFormValues, }); const { control, handleSubmit } = form; const watchedValues = useWatch({ control }); const isDataUnchanged = isEqual(watchedValues, initialData); return ( <Form {...form}> <form onSubmit={handleSubmit(onSubmit)} className='space-y-6 mx-auto rounded-lg p-2 w-full'> <BasicFormField name='title' label='Tytuł' control={control} className='pb-4' render={(field) => ( <Input placeholder='Tytuł' className='w-full h-12 p-3 border rounded-md text-sm' disabled={isReadonly} {...field} /> )} /> <BasicFormField name='description' label='Opis' control={control} className='pb-4' render={(field) => ( <TextArea placeholder='Opis' className=' min-h-28 max-h-52' disabled={isReadonly} {...field} /> )} /> <div className='grid grid-cols-1 md:grid-cols-2 gap-3'> {/* <BasicFormField name='startDate' label='Data utworzenia' control={control} render={({ onChange, value }) => ( <DatePicker mode='single' onChange={(value) => onChange(value)} value={value} className='w-full h-12' /> )} /> */} <BasicFormField name='dedicated_time' label='Poświęcony czas (w godzinach)' control={control} className='pb-4' render={({ value, onChange }) => ( <Input placeholder='Poświęcony czas (w godzinach)' className='w-full h-12' disabled={isReadonly} type='number' min='1' value={value ?? ''} onChange={(value) => onChange(Number(value))} /> )} /> </div> <div className='grid gap-3'> <BasicFormField name='achievements' label='Osiągnięcia' control={control} className='pb-4' render={({ value, onChange }) => ( <TextArea placeholder='Osiągnięcia' className='w-full min-h-14 max-h-28' disabled={isReadonly} value={value || ''} onChange={onChange} /> )} /> <BasicFormField name='problems' label='Problemy' control={control} className='pb-4' render={({ value, onChange }) => ( <TextArea placeholder='Problemy' className='w-full min-h-14 max-h-28' disabled={isReadonly} value={value || ''} onChange={onChange} /> )} /> </div> <div className='flex flex-col md:flex-row justify-end space-y-2 md:space-y-0 md:space-x-2'> {!isReadonly && ( <> <Button disabled={isSavingEntry} className='w-32 h-12 ' variant='secondary' onClick={() => router.back()} type='button' > Anuluj </Button> <Button type='submit' isLoading={isSavingEntry} className='w-32 h-12 ' disabled={isDataUnchanged}> {initialData ? 'Edytuj' : 'Dodaj'} </Button> </> )} </div> </form> </Form> ); }; export default EntryForm;
Leave a Comment