New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@hirbod/react-native-otp-input

Package Overview
Dependencies
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@hirbod/react-native-otp-input

is a tiny JS library for one time passcode (OTP). Supports smart input suggestion on iOS and code autofill on Android (it will be filled when you press the copy button on the SMS notification bar)

  • 2.0.0
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

PaginatableList

React Native OTP Input

Tests

@hirbod/react-native-otp-input is a tiny Javascript library which provides an elegant UI for the end user to input one time passcode (OTP). It handles the input suggestion on iOS when the OTP SMS is received. For Android, it will autofill when the user presses the copy button on the SMS notification bar. It also features a carefully crafted flow to handle edge cases for volatile user gestures. We provide default UI, but you can always customize the appearance as you like.

This is a fork of twotalltotems/react-native-otp-input, since it has been updated for a while and was breaking on Android.

demo.gif demo.gif

Installation

npm install --save @hirbod/react-native-otp-input or yarn add @hirbod/react-native-otp-input

Dependencies

NOTES:

From version 1.3.10: We use @react-native-community/clipboard to handle the clipboard in this package, So you should install @react-native-community/clipboard

npm install --save @react-native-clipboard/clipboard or yarn add @react-native-clipboard/clipboard

Expo:

This library works on Expo, SDK 43+ (but you will need to use a custom expo-dev-client)

Basic Usage

import OTPInputView from '@hirbod/react-native-otp-input'

...

<OTPInputView pinCount={4} />

More Advanced Usage

import OTPInputView from '@hirbod/react-native-otp-input'

...

<OTPInputView
    style={{width: '80%', height: 200}}
    pinCount={4}
    // code={this.state.code} //You can supply this prop or not. The component will be used as a controlled / uncontrolled component respectively.
    // onCodeChanged = {code => { this.setState({code})}}
    autoFocusOnLoad
    codeInputFieldStyle={styles.underlineStyleBase}
    codeInputHighlightStyle={styles.underlineStyleHighLighted}
    onCodeFilled = {(code) => {
        console.log(`Code is ${code}, you are good to go!`)
    }}
/>

const styles = StyleSheet.create({
  borderStyleBase: {
    width: 30,
    height: 45
  },

  borderStyleHighLighted: {
    borderColor: "#03DAC6",
  },

  underlineStyleBase: {
    width: 30,
    height: 45,
    borderWidth: 0,
    borderBottomWidth: 1,
  },

  underlineStyleHighLighted: {
    borderColor: "#03DAC6",
  },
});

Parameters

ParameterrequiredDescription
pinCountYESNumber of digits in the component
codeNOYou can use this library as a controlled / uncontrolled component by supplying this prop or not
codeInputFieldStyleNOThe style of the input field which is NOT focused
codeInputHighlightStyleNOThe style of the input field which is focused
autoFocusOnLoadNOAuto activate the input and bring up the keyboard when component is loaded
onCodeChangedNOCallback when the digits are changed
onCodeFilledNOCallback when the last digit is entered
secureTextEntryNOHide contents of text fields
editableNOSet editable for inputs
keyboardAppearanceNOKeyboard appearance ('default', 'dark', 'light')
keyboardTypeNOKeyboard type
clearInputsNOClear inputs after entering code
placeholderCharacterNOThe character/string that will be used as placeholder in the individual code input fields
placeholderTextColorNOColor of the placeholderCharacter

Notes

The iOS input suggestion requires React Native 0.58+ and works for iOS 12 and above.

On Android, it will be auto filled when you press the copy code button in the notification bar (see above GIF). It will do so only if the code is sent after the view is loaded. So make sure you request the code AFTER this view is loaded.

If you are interested in Android SMS Retriever API, we would suggest @Faizal's repo React-Native-OTP-Verify. It looks pretty cool and it should be straight-forward to use React-Native-OTP-Verify along with this library.

Roadmap

  • Typescript definition file
  • Typescript implementation
  • Add basic unit tests
  • Add integration tests

Keywords

FAQs

Package last updated on 08 Feb 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc