Coder Social home page Coder Social logo

rawroland / react-native-otp-input Goto Github PK

View Code? Open in Web Editor NEW

This project forked from heni-ghodbane/react-native-otp-input

0.0 0.0 0.0 8.58 MB

Tiny Javascript library which provides an elegant UI for user to input one time passcode.

License: MIT License

JavaScript 31.25% Objective-C 15.30% Java 5.53% TypeScript 39.79% Starlark 8.13%

react-native-otp-input's Introduction

PaginatableList

React Native OTP Input

Tests

@twotalltotems/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.

demo.gif demo.gif

Project Status

This project is not actively maintained anymore. If you’d like to contribute, we encourage you to fork this repository and improve it for the community.

Here are some alternatives you could try:

Installation

npm install --save @twotalltotems/react-native-otp-input or yarn add @twotalltotems/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-community/clipboard or yarn add @react-native-community/clipboard

Basic Usage

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

...

<OTPInputView pinCount={4} />

More Advanced Usage

import OTPInputView from '@twotalltotems/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

Parameter required Description
pinCount YES Number of digits in the component
code NO You can use this library as a controlled / uncontrolled component by supplying this prop or not
codeInputFieldStyle NO The style of the input field which is NOT focused
codeInputHighlightStyle NO The style of the input field which is focused
autoFocusOnLoad NO Auto activate the input and bring up the keyboard when component is loaded
onCodeChanged NO Callback when the digits are changed
onCodeFilled NO Callback when the last digit is entered
secureTextEntry NO Hide contents of text fields
editable NO Set editable for inputs
keyboardAppearance NO Keyboard appearance ('default', 'dark', 'light')
keyboardType NO Keyboard type
clearInputs NO Clear inputs after entering code
placeholderCharacter NO The character/string that will be used as placeholder in the individual code input fields
placeholderTextColor NO Color 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

Contributors


Anson Yao

Felipe Peña

Eric Dao

Vinson Li

Felix Cheng

Mitchell Ganton

External Contributors

About the Creators

OTP input is developed by the mobile team at TTT Studios. We are a Digital Innovation Studio based out of Vancouver, Canada, delivering custom software and solutions that are designed and developed 100% in-house. The technologies we work with include AR & VR, IoT, AI, security & encryption, and cloud computing.

Empowering Business Through Technology

react-native-otp-input's People

Contributors

ansonyao avatar fpena avatar beckywu220 avatar dependabot[bot] avatar heni-ghodbane avatar mikhailshvets avatar joelbesada avatar ishanahuja avatar daniakash avatar ericdao37 avatar azimat avatar eric-dao37 avatar dibakarhalder avatar douglasjunior avatar hasithawalpola avatar manishsharma004 avatar rednebmas avatar sunnysit avatar domoniquecarter35 avatar unclebill avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.