Input

Base

Styled text input supporting all native input types.

Preview

Usage

example.jsx
import { Input } from "@/components/ui/input";

export default function Example() {
  return <Input />;
}

Source Code

Copy this file into components/ui/input.jsx in your project.

input.jsx
"use client";

import { forwardRef } from "react";
import { cn } from "@/lib/utils";

const Input = forwardRef(({ className, type = "text", ...props }, ref) => {
  return (
    <input
      type={type}
      className={cn(
        "flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-sm",
        "transition-colors 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-1 focus-visible:ring-ring",
        "disabled:cursor-not-allowed disabled:opacity-50",
        className
      )}
      ref={ref}
      {...props}
    />
  );
});
Input.displayName = "Input";

export { Input };

Quick Install

Make sure you have the cn() utility set up. It requires clsx and tailwind-merge.

npm install clsx tailwind-merge