110k
New

Input OTP

Accessible one-time password component with copy paste functionality.

Component input-otp-demo not found in registry.

About

Input OTP is built on top of input-otp by @guilherme_rodz.

Installation

pnpm dlx createui@latest add input-otp

Usage

import {
  InputOTP,
  InputOTPGroup,
  InputOTPSeparator,
  InputOTPSlot,
} from "@/components/ui/input-otp"
<InputOTP maxLength={6}>
  <InputOTPGroup>
    <InputOTPSlot index={0} />
    <InputOTPSlot index={1} />
    <InputOTPSlot index={2} />
  </InputOTPGroup>
  <InputOTPSeparator />
  <InputOTPGroup>
    <InputOTPSlot index={3} />
    <InputOTPSlot index={4} />
    <InputOTPSlot index={5} />
  </InputOTPGroup>
</InputOTP>

Pattern

Use the pattern prop to define a custom pattern for the OTP input.

import { REGEXP_ONLY_DIGITS_AND_CHARS } from "input-otp"
 
;<InputOTP maxLength={6} pattern={REGEXP_ONLY_DIGITS_AND_CHARS}>
  ...
</InputOTP>

Component input-otp-pattern not found in registry.

Examples

Separator

Use the <InputOTPSeparator /> component to add a separator between input groups.

Component input-otp-separator not found in registry.

Disabled

Use the disabled prop to disable the input.

Component input-otp-disabled not found in registry.

Controlled

Use the value and onChange props to control the input value.

Component input-otp-controlled not found in registry.

Invalid

Use aria-invalid on the slots to show an error state.

Component input-otp-invalid not found in registry.

Four Digits

A common pattern for PIN codes. This uses the pattern={REGEXP_ONLY_DIGITS} prop.

Component input-otp-four-digits not found in registry.

Alphanumeric

Use REGEXP_ONLY_DIGITS_AND_CHARS to accept both letters and numbers.

Component input-otp-alphanumeric not found in registry.

Form

Component input-otp-form not found in registry.

API Reference

See the input-otp documentation for more information.