npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@syeda_mehwish/react-native-otp-entry

v0.0.2

Published

A fully modifiable OTP input Component for React Native

Downloads

93

Readme

react-native-otp-entry

npm version npm cov License

react-native-otp-entry is a simple and highly customizable React Native component for entering OTP (One-Time Password). It provides an intuitive and user-friendly interface for inputting one-time passwords in your React Native applications.

Demo

Features

  • Supports OTP input with a fixed number of digits.
  • Highly customizable appearance and styling.
  • Supports autofill
  • Fully covered with unit tests.
  • Seamless integration with React Native and Expo applications.
  • Fully typed with TypeScript.
  • Paste functionality.

Installation

Install react-native-otp-entry using npm or yarn:

npm install react-native-otp-entry

# or

yarn add react-native-otp-entry

Usage

  1. Import the OtpInput component from react-native-otp-entry:

    import { OtpInput } from "react-native-otp-entry";
  2. Render the OtpInput component in your screen/component:

    <OtpInput numberOfDigits={6} onTextChange={(text) => console.log(text)} />
  3. Customize the styling as per your requirements:

    <OtpInput
      numberOfDigits={6}
      focusColor="green"
      focusStickBlinkingDuration={500}
      onTextChange={(text) => console.log(text)}
      onFilled={(text) => console.log(`OTP is ${text}`)}
      theme={{
        containerStyle: styles.container,
        inputsContainerStyle: styles.inputsContainer,
        pinCodeContainerStyle: styles.pinCodeContainer,
        pinCodeTextStyle: styles.pinCodeText,
        focusStickStyle: styles.focusStick,
        focusedPinCodeContainerStyle: styles.activePinCodeContainer,
      }}
    />

Props

The react-native-otp-entry component accepts the following props:

| Prop | Type | Description | | ---------------------------- | ---------------------- | -------------------------------------------------------------------------------------------------------------- | | numberOfDigits | number | The number of digits to be displayed in the OTP entry. | | autoFocus | boolean | Set autofocus. | | focusColor | ColorValue | The color of the input field border and stick when it is focused. | | onTextChange | (text: string) => void | A callback function is invoked when the OTP text changes. It receives the updated text as an argument. | | onFilled | (text: string) => void | A callback function is invoked when the OTP input is fully filled. It receives a full otp code as an argument. | | hideStick | boolean | Hide cursor of the focused input. | | theme | Theme | Custom styles for each element. | | focusStickBlinkingDuration | number | The duration (in milliseconds) for the focus stick to blink. | | autoComplete | string | passed to underlying TextInput (see: https://reactnative.dev/docs/textinput#autocomplete) |

| Theme | Type | Description | | ------------------------------ | --------- | ---------------------------------------------------------------------------------- | | containerStyle | ViewStyle | Custom styles for the root View. | | inputsContainerStyle | ViewStyle | Custom styles for the container that holds the input fields. | | pinCodeContainerStyle | ViewStyle | Custom styles for the container that wraps each individual digit in the OTP entry. | | pinCodeTextStyle | TextStyle | Custom styles for the text within each individual digit in the OTP entry. | | focusStickStyle | ViewStyle | Custom styles for the focus stick, which indicates the focused input field. | | focusedPinCodeContainerStyle | ViewStyle | Custom styles for the input field when it is focused. | | filledPinCodeContainerStyle | ViewStyle | Custom styles for the input field when it has a value. |

Note: The ViewStyle and TextStyle types are imported from react-native and represent the style objects used in React Native for views and text, respectively.

Ref

The react-native-otp-entry component exposes these functions with ref:

| Prop | Type | Description | | ---------- | ------------------------ | ---------------------------------- | | clear | () => void; | Clears the value of the OTP input. | | focus | () => void; | Focus of the OTP input. | | setValue | (value: string) => void; | Sets the value of the OTP input. |

License

This project is licensed under the MIT License.

Contributing

Contributions are welcome! Please feel free to open issues or submit pull requests.

If you find a bug or have any feature requests, please open an issue :)