2022-02-07 23:22:35 +01:00
|
|
|
export interface TextInputControlPropsNoLabel {
|
|
|
|
onChange?: (data: string) => void;
|
2022-05-03 20:58:34 +02:00
|
|
|
onUnFocus?: () => void;
|
2023-08-20 17:59:46 +02:00
|
|
|
onFocus?: () => void;
|
2022-02-07 23:22:35 +01:00
|
|
|
value?: string;
|
2022-02-10 23:45:17 +01:00
|
|
|
placeholder?: string;
|
|
|
|
className?: string;
|
2022-02-07 23:22:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface TextInputControlProps extends TextInputControlPropsNoLabel {
|
|
|
|
label?: string;
|
|
|
|
}
|
|
|
|
|
2022-02-10 23:45:17 +01:00
|
|
|
export function TextInputControl({
|
|
|
|
onChange,
|
2022-05-03 20:58:34 +02:00
|
|
|
onUnFocus,
|
2022-02-10 23:45:17 +01:00
|
|
|
value,
|
|
|
|
label,
|
|
|
|
className,
|
|
|
|
placeholder,
|
2023-08-20 17:59:46 +02:00
|
|
|
onFocus,
|
2022-02-10 23:45:17 +01:00
|
|
|
}: TextInputControlProps) {
|
|
|
|
const input = (
|
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
className={className}
|
|
|
|
placeholder={placeholder}
|
|
|
|
onChange={(e) => onChange && onChange(e.target.value)}
|
|
|
|
value={value}
|
2022-05-03 20:58:34 +02:00
|
|
|
onBlur={() => onUnFocus && onUnFocus()}
|
2023-08-20 17:59:46 +02:00
|
|
|
onFocus={() => onFocus?.()}
|
2022-02-10 23:45:17 +01:00
|
|
|
/>
|
|
|
|
);
|
2022-02-07 23:22:35 +01:00
|
|
|
|
|
|
|
if (label) {
|
|
|
|
return (
|
|
|
|
<label>
|
|
|
|
<span>{label}</span>
|
|
|
|
{input}
|
|
|
|
</label>
|
2022-02-10 23:45:17 +01:00
|
|
|
);
|
2022-02-07 23:22:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return input;
|
|
|
|
}
|