1.0.1 • Published 2 years ago

react-native-simple-otp v1.0.1

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

React Native Simple OTP

react-native-simple-otp is a library for react-native that just makes handling otp easy.

Installation

npm install --save react-native-simple-otp or yarn add react-native-simple-otp

Basic Usage

import OTPInputView from 'react-native-simple-otp'

...

<OTPInputView pinCount={4} />

More Advanced Usage

import OTPInputView from 'react-native-simple-otp'

...

<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. 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.