Files
formbricks/packages/survey-ui/src/components/general/input.tsx
T

57 lines
1.9 KiB
TypeScript

import * as React from "react";
import { cn } from "@/lib/utils";
interface InputProps extends React.ComponentProps<"input"> {
/** Text direction for RTL language support */
dir?: "ltr" | "rtl" | "auto";
/** Error message to display above the input */
errorMessage?: string;
}
const Input = React.forwardRef<HTMLInputElement, InputProps>(function Input(
{ className, type, dir, ...props },
ref
): React.JSX.Element {
return (
<div className="relative space-y-1">
<input
ref={ref}
type={type}
dir={dir}
data-slot="input"
style={{ fontSize: "var(--fb-input-font-size)" }}
className={cn(
// Layout and behavior
"flex min-w-0 border transition-[color,box-shadow] outline-none",
// Customizable styles via CSS variables (using Tailwind theme extensions)
"w-input min-h-[var(--fb-input-height)]",
"bg-input-bg border-input-border rounded-input",
"font-input font-input-weight",
"text-input-text",
"px-input-x py-input-y",
"shadow-input",
// Placeholder styling
"placeholder:opacity-input-placeholder",
"placeholder:text-input-placeholder",
// Selection styling
"selection:bg-primary selection:text-primary-foreground",
// File input specifics
"file:text-foreground file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium",
// Focus ring
"focus-visible:border-ring focus-visible:ring-ring focus-visible:ring-[3px]",
// Error state ring
"aria-invalid:ring-destructive/20 aria-invalid:border-destructive",
// Disabled state
"disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50",
className
)}
{...props}
/>
</div>
);
});
export { Input };
export type { InputProps };