diff --git a/src/components/CurrencyInput.tsx b/src/components/CurrencyInput.tsx index 9d7f7df..e112937 100644 --- a/src/components/CurrencyInput.tsx +++ b/src/components/CurrencyInput.tsx @@ -58,6 +58,7 @@ export const CurrencyInput: FC = forwardRef< onKeyDown, onKeyUp, transformRawValue, + formatValueOnBlur = true, ...props }: CurrencyInputProps, ref @@ -231,7 +232,7 @@ export const CurrencyInput: FC = forwardRef< value: newValue, }); - if (onValueChange) { + if (onValueChange && formatValueOnBlur) { onValueChange(newValue, name, { float: numberValue, formatted: formattedValue, diff --git a/src/components/CurrencyInputProps.ts b/src/components/CurrencyInputProps.ts index 578a565..d69497a 100644 --- a/src/components/CurrencyInputProps.ts +++ b/src/components/CurrencyInputProps.ts @@ -183,5 +183,12 @@ export type CurrencyInputProps = Overwrite< * Transform the raw value form the input before parsing */ transformRawValue?: (rawValue: string) => string; + + /** + * When set to false, the formatValueOnBlur flag disables the application of the __onValueChange__ function + * specifically on blur events. If disabled or set to false, the onValueChange will not trigger on blur. + * Default = true + */ + formatValueOnBlur?: boolean; } >; diff --git a/src/components/__tests__/CurrencyInput-onBlur.spec.tsx b/src/components/__tests__/CurrencyInput-onBlur.spec.tsx index f4ab7d8..a13c2ae 100644 --- a/src/components/__tests__/CurrencyInput-onBlur.spec.tsx +++ b/src/components/__tests__/CurrencyInput-onBlur.spec.tsx @@ -29,7 +29,7 @@ describe(' onBlur', () => { userEvent.type(screen.getByRole('textbox'), '123'); fireEvent.focusOut(screen.getByRole('textbox')); - expect(onBlurSpy).toBeCalled(); + expect(onBlurSpy).toHaveBeenCalled(); expect(onValueChangeSpy).toHaveBeenLastCalledWith('123.00', name, { float: 123, @@ -40,13 +40,34 @@ describe(' onBlur', () => { expect(screen.getByRole('textbox')).toHaveValue('$123.00'); }); + it('should call onBlur, but not onValueChange', () => { + render( + + ); + + userEvent.type(screen.getByRole('textbox'), '123'); + fireEvent.focusOut(screen.getByRole('textbox')); + + expect(onBlurSpy).toHaveBeenCalled(); + + expect(onValueChangeSpy).toHaveBeenCalledTimes(3); + expect(screen.getByRole('textbox')).toHaveValue('$123.00'); + }); + it('should call onBlur for 0', () => { render(); userEvent.type(screen.getByRole('textbox'), '0'); fireEvent.focusOut(screen.getByRole('textbox')); - expect(onBlurSpy).toBeCalled(); + expect(onBlurSpy).toHaveBeenCalled(); expect(screen.getByRole('textbox')).toHaveValue('$0'); }); @@ -56,7 +77,7 @@ describe(' onBlur', () => { fireEvent.focusOut(screen.getByRole('textbox')); - expect(onBlurSpy).toBeCalled(); + expect(onBlurSpy).toHaveBeenCalled(); expect(screen.getByRole('textbox')).toHaveValue(''); }); @@ -67,7 +88,7 @@ describe(' onBlur', () => { userEvent.type(screen.getByRole('textbox'), '-'); fireEvent.focusOut(screen.getByRole('textbox')); - expect(onBlurSpy).toBeCalled(); + expect(onBlurSpy).toHaveBeenCalled(); expect(screen.getByRole('textbox')).toHaveValue(''); });