shlink-web-client/src/utils/FormGroupContainer.tsx

39 lines
1 KiB
TypeScript
Raw Normal View History

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;
placeholder?: string;
className?: string;
labelClassName?: string;
2020-12-12 13:43:16 +03:00
}
export const FormGroupContainer: FC<FormGroupContainerProps> = (
{ 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 ?? ''}>
<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>
);
};