2023-07-15 17:46:19 +03:00
|
|
|
import Label from './Label';
|
|
|
|
|
2023-07-25 20:27:29 +03:00
|
|
|
interface TextInputProps
|
2023-09-07 16:30:43 +03:00
|
|
|
extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'className' | 'title'> {
|
2023-09-14 16:53:38 +03:00
|
|
|
id?: string
|
|
|
|
label?: string
|
2023-08-26 17:26:49 +03:00
|
|
|
tooltip?: string
|
2023-09-15 23:29:52 +03:00
|
|
|
dimensions?: string
|
2023-08-10 14:13:34 +03:00
|
|
|
colorClass?: string
|
2023-08-16 18:32:37 +03:00
|
|
|
singleRow?: boolean
|
2023-09-29 15:33:32 +03:00
|
|
|
noBorder?: boolean
|
2023-07-15 17:46:19 +03:00
|
|
|
}
|
|
|
|
|
2023-07-20 17:11:03 +03:00
|
|
|
function TextInput({
|
2023-09-29 15:33:32 +03:00
|
|
|
id, required, label, singleRow, tooltip, noBorder,
|
2023-09-15 23:29:52 +03:00
|
|
|
dimensions = 'w-full',
|
2023-08-10 14:13:34 +03:00
|
|
|
colorClass = 'clr-input',
|
2023-07-23 15:23:01 +03:00
|
|
|
...props
|
2023-07-20 17:11:03 +03:00
|
|
|
}: TextInputProps) {
|
2023-09-30 12:47:27 +03:00
|
|
|
const borderClass = noBorder ? '': 'border shadow';
|
2023-07-15 17:46:19 +03:00
|
|
|
return (
|
2023-09-15 23:29:52 +03:00
|
|
|
<div className={`flex ${singleRow ? 'items-center gap-4 ' + dimensions : 'flex-col items-start gap-2'}`}>
|
2023-09-29 15:33:32 +03:00
|
|
|
{label &&
|
|
|
|
<Label
|
2023-07-15 17:46:19 +03:00
|
|
|
text={label}
|
|
|
|
htmlFor={id}
|
2023-09-14 16:53:38 +03:00
|
|
|
/>}
|
2023-07-15 17:46:19 +03:00
|
|
|
<input id={id}
|
2023-08-26 17:26:49 +03:00
|
|
|
title={tooltip}
|
2023-09-30 12:47:27 +03:00
|
|
|
className={`px-3 py-2 leading-tight ${borderClass} truncate hover:text-clip clr-outline ${colorClass} ${singleRow ? 'w-full' : dimensions}`}
|
2023-07-15 17:46:19 +03:00
|
|
|
required={required}
|
2023-07-23 15:23:01 +03:00
|
|
|
{...props}
|
2023-07-15 17:46:19 +03:00
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-07-25 20:27:29 +03:00
|
|
|
export default TextInput;
|