From a4e444277a266a27205db0677ca076d0409ceef0 Mon Sep 17 00:00:00 2001 From: Mukul Bansal Date: Sat, 20 Jul 2024 18:38:40 +0530 Subject: [PATCH] fix: onChangeFormatter in datepicker in form component affects: @medly-components/forms --- .../components/Fields/Fields.components.tsx | 6 +++- .../forms/src/components/Form/Form.test.tsx | 34 +++++++++++++++++++ packages/forms/src/hooks/useForm/types.ts | 2 +- packages/forms/src/hooks/useForm/useForm.ts | 4 +-- 4 files changed, 42 insertions(+), 4 deletions(-) diff --git a/packages/forms/src/components/Fields/Fields.components.tsx b/packages/forms/src/components/Fields/Fields.components.tsx index 39e7fc6df..2f68fd981 100644 --- a/packages/forms/src/components/Fields/Fields.components.tsx +++ b/packages/forms/src/components/Fields/Fields.components.tsx @@ -183,7 +183,11 @@ export const Fields: FC = memo(props => { {...({ ...commonProps, value: value || null, - onChange: handlers.handleDateChange(name, (componentProps as DatePickerProps).displayFormat) + onChange: handlers.handleDateChange( + name, + (componentProps as DatePickerProps).displayFormat, + (componentProps as DatePickerProps).onChangeFormatter + ) } as GetComponentProps)} /> ); diff --git a/packages/forms/src/components/Form/Form.test.tsx b/packages/forms/src/components/Form/Form.test.tsx index 155f562de..0e76fd358 100644 --- a/packages/forms/src/components/Form/Form.test.tsx +++ b/packages/forms/src/components/Form/Form.test.tsx @@ -1,4 +1,5 @@ import { cleanup, fireEvent, render, screen, waitFor } from '@test-utils'; +import { formatRFC3339 } from 'date-fns'; import { FormCustomComponent } from '../Fields/types'; import { Form } from './Form'; import { testSchema } from './testSchema'; @@ -332,6 +333,39 @@ describe('Form', () => { }); }); + it('with onChangeFormatter', async () => { + const mockOnSubmit = jest.fn(), + formData = { + birthDate: '2024-07-19T00:00:00+05:30' + }; + render( +
(value ? new Date(value) : null), + onChangeFormatter: value => (value ? formatRFC3339(value) : null) + } + }} + onSubmit={mockOnSubmit} + initialState={{ + birthDate: '2024-07-18T00:00:00+05:30' + }} + /> + ); + // DatePicker + fireEvent.change(screen.getByRole('textbox', { name: 'Birth Date' }), { + target: { value: '19/07/2024' } + }); + + fireEvent.submit(screen.getByRole('form')); + expect(mockOnSubmit).toHaveBeenCalledWith(formData); + }); + it('should allow user to clear number input', () => { render( (value: any) => void; // DatePicker Component - handleDateChange: (name: string, displayFormat: DisplayFormat) => (value: any) => void; + handleDateChange: (name: string, displayFormat: DisplayFormat, onChangeFormatter?: (value: Date | null) => any) => (value: any) => void; // DateRangePicker Component handleDateRangeChange: (name: string, displayFormat: DisplayFormat) => (value: any) => void; // CheckboxGroup change handler diff --git a/packages/forms/src/hooks/useForm/useForm.ts b/packages/forms/src/hooks/useForm/useForm.ts index dc53b0957..b2785ef8e 100644 --- a/packages/forms/src/hooks/useForm/useForm.ts +++ b/packages/forms/src/hooks/useForm/useForm.ts @@ -92,8 +92,8 @@ export const useForm = (initialState: Record): UseFormResult => ); const handleDateChange: Handlers['handleDateChange'] = useCallback( - memoize((name, displayFormat) => value => { - setValues(val => ({ ...val, [name]: value ? format(value, displayFormat || 'MM/dd/yyyy') : '' })); + memoize((name, displayFormat, onChangeFormatter) => value => { + setValues(val => ({ ...val, [name]: value ? (onChangeFormatter ? value : format(value, displayFormat || 'MM/dd/yyyy')) : '' })); }), [] );