my/ui

Command Palette

Search for a command to run...

All components

Textarea

inputs

Origin UI component.

responsive · 420px

Install

Same command in any shadcn project — React (Vite/CRA), Next.js, Remix, Astro, and more:

$npx shadcn@latest add https://your-domain/r/textarea.json

Usage

"use client";

import { Textarea } from "@/registry/origin-ui/textarea";

export default function Demo() {
  return (
    <div className="w-full max-w-xs space-y-2">
      <label
        className="text-sm font-medium text-foreground"
        htmlFor="demo-textarea"
      >
        Message
      </label>
      <Textarea
        id="demo-textarea"
        placeholder="Write your message here…"
      />
    </div>
  );
}

Component source

import type * as React from "react";

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

function Textarea({ className, ...props }: React.ComponentProps<"textarea">) {
  return (
    <textarea
      className={cn(
        "flex min-h-19.5 w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-xs outline-none transition-[color,box-shadow] placeholder:text-muted-foreground/70 focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:cursor-not-allowed disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40",
        className,
      )}
      data-slot="textarea"
      {...props}
    />
  );
}
Textarea.displayName = "Textarea";

export { Textarea };

Source: Origin UI