import { cn } from '@/lib/utils/cn'; interface ColorInputProps { value: string; onChange: (color: string) => void; disabled?: boolean; className?: string; } /** * Colour swatch (type="color") + hex text input pair. * Renders them in a flex row at equal height. Disabled state dims both inputs. */ export function ColorInput({ value, onChange, disabled, className }: ColorInputProps) { return (
onChange(e.target.value)} disabled={disabled} className={cn( 'w-8 h-8 rounded-lg cursor-pointer border border-border/40 bg-transparent shrink-0 p-0.5 transition-opacity', disabled && 'opacity-30 cursor-not-allowed' )} /> onChange(e.target.value)} disabled={disabled} className={cn( 'flex-1 bg-transparent border border-border/40 rounded-lg px-3 py-1.5 text-xs font-mono outline-none focus:border-primary/50 transition-colors text-foreground/80 placeholder:text-muted-foreground/30', disabled && 'opacity-30' )} />
); }