diff --git a/packages/input-otp/src/input.tsx b/packages/input-otp/src/input.tsx index 398518f..0962ff8 100644 --- a/packages/input-otp/src/input.tsx +++ b/packages/input-otp/src/input.tsx @@ -30,7 +30,15 @@ export const OTPInput = React.forwardRef( // Workarounds const value = uncheckedValue ?? internalValue const previousValue = usePrevious(value) - const onChange = uncheckedOnChange ?? setInternalValue + const onChange = (newValue: string) => { + // Check if input is controlled + if (uncheckedValue !== undefined) { + uncheckedOnChange?.(newValue) + } else { + setInternalValue(newValue) + uncheckedOnChange?.(newValue) + } + } const regexp = pattern ? typeof pattern === 'string' ? new RegExp(pattern) diff --git a/packages/input-otp/src/types.ts b/packages/input-otp/src/types.ts index 8958257..5db65a4 100644 --- a/packages/input-otp/src/types.ts +++ b/packages/input-otp/src/types.ts @@ -8,7 +8,7 @@ export type OTPInputProps = OverrideProps< React.InputHTMLAttributes, { value?: string - onChange?: (...args: any[]) => unknown + onChange?: (newValue: string) => unknown maxLength: number