ShadCN-Inspired Tailwind Textarea Component

DSy lets you customize textareas in real time — adjust padding, text size, states, icons, and hints/errors. Copy ShadCN-inspired React/Next.js code with usage examples that match your settings. use.

NOTE: It's UI-only - no validation, connect to any form system.

'use client';

import * as React from 'react';
import { cn } from '@/lib/utils';

export interface TextareaProps
  extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {}

const Textarea = React.forwardRef<HTMLTextAreaElement, TextareaProps>(
  ({ className, ...props }, ref) => {
    return (
      <textarea
        className={cn('flex min-h-[80px] w-full border ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 px-3 py-2 rounded-md text-base border-gray-300 bg-white text-gray-900 placeholder:text-gray-500 focus-visible:border-blue-500 focus-visible:ring-blue-500', className)}
        ref={ref}
        {...props}
      />
    );
  }
);

Textarea.displayName = 'Textarea';

export { Textarea };

Typography

Adjust text size

Padding

Adjust spacing
px
py

Border Radius

Adjust corner roundness