Skip to main content
Glama
textarea.tsx2.2 kB
"use client"; import { Field as FieldPrimitive } from "@base-ui/react/field"; import { mergeProps } from "@base-ui/react/merge-props"; import type * as React from "react"; import { cn } from "@/lib/utils"; type TextareaProps = React.ComponentProps<"textarea"> & { size?: "sm" | "default" | "lg" | number; unstyled?: boolean; }; function Textarea({ className, size = "default", unstyled = false, ...props }: TextareaProps) { return ( <span className={ cn( !unstyled && "relative inline-flex w-full rounded-lg border border-input bg-background bg-clip-padding text-base shadow-xs ring-ring/24 transition-shadow before:pointer-events-none before:absolute before:inset-0 before:rounded-[calc(var(--radius-lg)-1px)] has-focus-visible:has-aria-invalid:border-destructive/64 has-focus-visible:has-aria-invalid:ring-destructive/16 has-aria-invalid:border-destructive/36 has-focus-visible:border-ring has-disabled:opacity-64 has-[:disabled,:focus-visible,[aria-invalid]]:shadow-none has-focus-visible:ring-[3px] not-has-disabled:has-not-focus-visible:not-has-aria-invalid:before:shadow-[0_1px_--theme(--color-black/4%)] sm:text-sm dark:bg-input/32 dark:bg-clip-border dark:has-aria-invalid:ring-destructive/24 dark:not-has-disabled:has-not-focus-visible:not-has-aria-invalid:before:shadow-[0_-1px_--theme(--color-white/8%)]", className, ) || undefined } data-size={size} data-slot="textarea-control" > <FieldPrimitive.Control render={(defaultProps) => ( <textarea className={cn( "field-sizing-content min-h-17.5 w-full rounded-[inherit] px-[calc(--spacing(3)-1px)] py-[calc(--spacing(1.5)-1px)] outline-none max-sm:min-h-20.5", size === "sm" && "min-h-16.5 px-[calc(--spacing(2.5)-1px)] py-[calc(--spacing(1)-1px)] max-sm:min-h-19.5", size === "lg" && "min-h-18.5 py-[calc(--spacing(2)-1px)] max-sm:min-h-21.5", )} data-slot="textarea" {...mergeProps(defaultProps, props)} /> )} /> </span> ); } export { Textarea, type TextareaProps };

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/bytebase/dbhub'

If you have feedback or need assistance with the MCP directory API, please join our Discord server