Files
d1a2f309-b9fe-4acd-a8cc-cf0…/research/replit/input-otp.md
2026-04-28 15:30:34 +03:00

2.1 KiB

import * as React from "react" import { OTPInput, OTPInputContext } from "input-otp" import { Minus } from "lucide-react"

import { cn } from "@/lib/utils"

const InputOTP = React.forwardRef< React.ElementRef, React.ComponentPropsWithoutRef

(({ className, containerClassName, ...props }, ref) => ( <OTPInput ref={ref} containerClassName={cn( "flex items-center gap-2 has-[:disabled]:opacity-50", containerClassName )} className={cn("disabled:cursor-not-allowed", className)} {...props} /> )) InputOTP.displayName = "InputOTP"

const InputOTPGroup = React.forwardRef< React.ElementRef<"div">, React.ComponentPropsWithoutRef<"div">

(({ className, ...props }, ref) => (

)) InputOTPGroup.displayName = "InputOTPGroup"

const InputOTPSlot = React.forwardRef< React.ElementRef<"div">, React.ComponentPropsWithoutRef<"div"> & { index: number }

(({ index, className, ...props }, ref) => { const inputOTPContext = React.useContext(OTPInputContext) const { char, hasFakeCaret, isActive } = inputOTPContext.slots[index]

return ( <div ref={ref} className={cn( "relative flex h-9 w-9 items-center justify-center border-y border-r border-input text-sm shadow-sm transition-all first:rounded-l-md first:border-l last:rounded-r-md", isActive && "z-10 ring-1 ring-ring", className )} {...props} > {char} {hasFakeCaret && (

)}
) }) InputOTPSlot.displayName = "InputOTPSlot"

const InputOTPSeparator = React.forwardRef< React.ElementRef<"div">, React.ComponentPropsWithoutRef<"div">

(({ ...props }, ref) => (

)) InputOTPSeparator.displayName = "InputOTPSeparator"

export { InputOTP, InputOTPGroup, InputOTPSlot, InputOTPSeparator }