Input Component

Displays a form input field or a component that looks like an input field.

Installation

pnpm dlx shadcn@latest add https://ui.vllnt.com/r/input.json
bash

Usage

import { Input } from '@vllnt/ui'

export function InputExample() {
return <Input type="email" placeholder="Email" />
}
tsx

Code

import * as React from 'react'

import { cn } from '../../lib/utils'

const Input = React.forwardRef<HTMLInputElement, React.ComponentProps<'input'>>(
  ({ className, type, ...props }, reference) => {
    return (
      <input
        className={cn(
          'flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-base ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 md:text-sm',
          className,
        )}
        ref={reference}
        type={type}
        {...props}
      />
    )
  },
)
Input.displayName = 'Input'

export { Input }
typescript

Dependencies

  • clsx
  • tailwind-merge