2021-08-23 19:31:40 +03:00
|
|
|
import { FC, useRef } from 'react';
|
2020-12-12 13:43:16 +03:00
|
|
|
import { v4 as uuid } from 'uuid';
|
|
|
|
import { InputType } from 'reactstrap/lib/Input';
|
2021-10-17 20:13:06 +03:00
|
|
|
import { FormGroup } from 'reactstrap';
|
2020-12-12 13:43:16 +03:00
|
|
|
|
2021-08-23 20:12:41 +03:00
|
|
|
export interface FormGroupContainerProps {
|
2020-12-12 13:43:16 +03:00
|
|
|
value: string;
|
|
|
|
onChange: (newValue: string) => void;
|
|
|
|
id?: string;
|
|
|
|
type?: InputType;
|
|
|
|
required?: boolean;
|
2021-08-21 18:53:06 +03:00
|
|
|
placeholder?: string;
|
|
|
|
className?: string;
|
2021-08-23 19:31:40 +03:00
|
|
|
labelClassName?: string;
|
2020-12-12 13:43:16 +03:00
|
|
|
}
|
|
|
|
|
2021-02-28 14:56:56 +03:00
|
|
|
export const FormGroupContainer: FC<FormGroupContainerProps> = (
|
2021-08-23 19:31:40 +03:00
|
|
|
{ children, value, onChange, id, type, required, placeholder, className, labelClassName },
|
|
|
|
) => {
|
|
|
|
const forId = useRef<string>(id ?? uuid());
|
|
|
|
|
|
|
|
return (
|
2021-10-17 20:13:06 +03:00
|
|
|
<FormGroup className={className ?? ''}>
|
2021-08-23 19:31:40 +03:00
|
|
|
<label htmlFor={forId.current} className={labelClassName ?? ''}>
|
|
|
|
{children}:
|
|
|
|
</label>
|
|
|
|
<input
|
|
|
|
className="form-control"
|
|
|
|
type={type ?? 'text'}
|
|
|
|
id={forId.current}
|
|
|
|
value={value}
|
|
|
|
required={required ?? true}
|
|
|
|
placeholder={placeholder}
|
|
|
|
onChange={(e) => onChange(e.target.value)}
|
|
|
|
/>
|
2021-10-17 20:13:06 +03:00
|
|
|
</FormGroup>
|
2021-08-23 19:31:40 +03:00
|
|
|
);
|
|
|
|
};
|