
Security News
Axios Maintainer Confirms Social Engineering Attack Behind npm Compromise
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.
react-native-input-otp
Advanced tools
A fully customizable, one-time password (OTP) input component for smartphones built with React Native.
react-native-input-otp is a fully customizable, one-time password (OTP) input component designed for React Native applications. This package makes it easy to integrate an OTP input feature into your mobile app, ensuring a user-friendly and secure way for users to input their OTP codes.
To install react-native-input-otp, run the following command in your React Native project:
npm install react-native-input-otp
The OtpInput component accepts several props to customize its behavior and style:
| Prop Name | Type | Description | Default Value |
|---|---|---|---|
numInputs | number | The number of input boxes for the OTP. | 4 |
onChange | (otp: string) => void | Function called with the OTP value when it changes. | - |
isDisabled | boolean | If set to true, all input boxes are disabled. | false |
autoFocus | boolean | If set to true, the first input box is focused automatically. | false |
keyboardType | KeyboardType (React Native) | The type of keyboard to display for inputs. | 'default' |
value | string | The current value of the OTP input. | '' (empty string) |
containerStyle | ViewStyle (React Native style) | Custom styles for the container of the input boxes. | - |
inputStyle | TextStyle (React Native style) | Custom styles for each input box. | - |
onUserFocus | Function | Triggered onFocus for user end | - |
You can customize the appearance of the OTP inputs by providing containerStyle and inputStyle props. These props accept standard React Native style objects.
First, import the OtpInput component from the package:
import OtpInput from 'react-native-input-otp';
Then, you can use the OtpInput component in your class component as follows:
import React, { Component } from 'react';
import { View } from 'react-native';
import OtpInput from 'react-native-input-otp';
class YourComponent extends Component {
handleOtpChange = otp => {
console.log(otp); // OTP value
};
render() {
return (
<View>
<OtpInput numInputs={4} onChange={this.handleOtpChange} />
</View>
);
}
}
export default YourComponent;
For functional components, the usage is similar. Import the OtpInput component and use it inside your functional component:
import React from 'react';
import { View } from 'react-native';
import OtpInput from 'react-native-input-otp';
const YourComponent = () => {
const handleOtpChange = otp => {
console.log(otp); // OTP value
};
return (
<View>
<OtpInput numInputs={4} onChange={handleOtpChange} />
</View>
);
};
export default YourComponent;
This project is licensed under the MIT License - see the LICENSE file for details.
FAQs
A fully customizable, one-time password (OTP) input component for smartphones built with React Native.
We found that react-native-input-otp demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?

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.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.

Security News
The Axios compromise shows how time-dependent dependency resolution makes exposure harder to detect and contain.