From 9b8cd6e7e9b537f124b5ec2e6b4eef8ae887eb6f Mon Sep 17 00:00:00 2001 From: dimakruhlyi Date: Fri, 12 Jan 2024 15:15:14 +0200 Subject: [PATCH] feat:lastInputFocused is added --- README.md | 7 +++++++ src/index.tsx | 7 ++++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 6931cd7..30bc5d0 100644 --- a/README.md +++ b/README.md @@ -145,6 +145,13 @@ const handlePaste: React.ClipboardEventHandler = (event) => { false Auto focuses input on initial page load. + + lastInputFocused + boolean + false + false + Auto focuses the last input element on initial page load. shouldAutoFocus has higher priority if two auto focus props are set. + skipDefaultStyles boolean diff --git a/src/index.tsx b/src/index.tsx index 3afd218..310429b 100644 --- a/src/index.tsx +++ b/src/index.tsx @@ -37,6 +37,8 @@ interface OTPInputProps { renderInput: (inputProps: InputProps, index: number) => React.ReactNode; /** Whether the first input should be auto focused */ shouldAutoFocus?: boolean; + /** Whether the last input should be auto focused */ + lastInputFocused?: boolean; /** Placeholder for the inputs */ placeholder?: string; /** Function to render the separator */ @@ -60,6 +62,7 @@ const OTPInput = ({ onPaste, renderInput, shouldAutoFocus = false, + lastInputFocused = false, inputType = 'text', renderSeparator, placeholder, @@ -81,8 +84,10 @@ const OTPInput = ({ React.useEffect(() => { if (shouldAutoFocus) { inputRefs.current[0]?.focus(); + } else if (lastInputFocused) { + focusInput(numInputs - 1); } - }, [shouldAutoFocus]); + }, [shouldAutoFocus, lastInputFocused]); const getPlaceholderValue = () => { if (typeof placeholder === 'string') {