2021-04-12 09:49:02 -07:00
|
|
|
interface InputProps {
|
|
|
|
type: string
|
|
|
|
value: any
|
|
|
|
onChange: (e) => void
|
|
|
|
className?: string
|
|
|
|
disabled?: boolean
|
2021-09-13 14:14:59 -07:00
|
|
|
prefixClassname?: string
|
2021-05-18 09:27:09 -07:00
|
|
|
error?: boolean
|
2021-04-12 09:49:02 -07:00
|
|
|
[x: string]: any
|
|
|
|
}
|
|
|
|
|
2021-04-24 19:10:28 -07:00
|
|
|
const Group = ({ children, className = '' }) => {
|
2021-04-18 03:34:37 -07:00
|
|
|
return <div className={`flex ${className}`}>{children}</div>
|
2021-04-13 16:41:04 -07:00
|
|
|
}
|
|
|
|
|
2021-04-12 09:49:02 -07:00
|
|
|
const Input = ({
|
|
|
|
type,
|
|
|
|
value,
|
|
|
|
onChange,
|
|
|
|
className,
|
2021-05-18 09:27:09 -07:00
|
|
|
error,
|
2021-04-18 03:34:37 -07:00
|
|
|
wrapperClassName = 'w-full',
|
2021-04-12 09:49:02 -07:00
|
|
|
disabled,
|
2021-04-12 13:01:55 -07:00
|
|
|
prefix,
|
2021-09-13 14:14:59 -07:00
|
|
|
prefixClassName,
|
2021-04-12 13:01:55 -07:00
|
|
|
suffix,
|
2021-04-12 09:49:02 -07:00
|
|
|
...props
|
|
|
|
}: InputProps) => {
|
|
|
|
return (
|
2021-04-18 03:34:37 -07:00
|
|
|
<div className={`flex relative ${wrapperClassName}`}>
|
2021-04-12 13:01:55 -07:00
|
|
|
{prefix ? (
|
2021-04-24 19:10:28 -07:00
|
|
|
<div
|
2021-09-13 14:14:59 -07:00
|
|
|
className={`flex items-center justify-end p-2 border border-r-0
|
|
|
|
border-th-fgd-4 bg-th-bkg-2 h-full text-xs rounded rounded-r-none text-right ${prefixClassName}`}
|
2021-04-24 19:10:28 -07:00
|
|
|
>
|
2021-04-12 13:01:55 -07:00
|
|
|
{prefix}
|
|
|
|
</div>
|
|
|
|
) : null}
|
2021-09-03 12:02:51 -07:00
|
|
|
<input
|
2021-04-18 03:34:37 -07:00
|
|
|
type={type}
|
|
|
|
value={value}
|
|
|
|
onChange={onChange}
|
2021-09-19 17:36:02 -07:00
|
|
|
className={`${className} pb-px px-2 flex-1 bg-th-bkg-1 rounded h-10 text-th-fgd-1 w-full
|
2021-05-18 09:27:09 -07:00
|
|
|
border ${
|
|
|
|
error ? 'border-th-red' : 'border-th-fgd-4'
|
|
|
|
} default-transition hover:border-th-primary
|
2021-04-24 19:10:28 -07:00
|
|
|
focus:border-th-primary focus:outline-none
|
|
|
|
${
|
|
|
|
disabled
|
2021-05-27 04:35:15 -07:00
|
|
|
? 'bg-th-bkg-3 cursor-not-allowed hover:border-th-fgd-4 text-th-fgd-3'
|
2021-04-24 19:10:28 -07:00
|
|
|
: ''
|
|
|
|
}
|
|
|
|
${prefix ? 'rounded-l-none' : ''}`}
|
2021-04-18 03:34:37 -07:00
|
|
|
disabled={disabled}
|
|
|
|
{...props}
|
|
|
|
/>
|
|
|
|
{suffix ? (
|
|
|
|
<span className="absolute right-0 text-xs flex items-center pr-2 h-full bg-transparent text-th-fgd-4">
|
|
|
|
{suffix}
|
|
|
|
</span>
|
|
|
|
) : null}
|
2021-04-12 09:49:02 -07:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
Input.Group = Group
|
|
|
|
|
|
|
|
export default Input
|