2022-11-16 13:38:32 -08:00
|
|
|
import React, { useMemo } from 'react';
|
|
|
|
import { v4 as uuidv4 } from 'uuid';
|
2022-11-25 10:28:43 -08:00
|
|
|
|
2022-11-25 09:04:11 -08:00
|
|
|
import HStack from '../hstack/hstack';
|
2022-11-16 13:38:32 -08:00
|
|
|
|
|
|
|
interface IRadioButton {
|
|
|
|
value: string
|
|
|
|
checked?: boolean
|
|
|
|
name: string
|
|
|
|
onChange: React.ChangeEventHandler<HTMLInputElement>
|
|
|
|
label: React.ReactNode
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A group for radio input with label.
|
|
|
|
*/
|
|
|
|
const RadioButton: React.FC<IRadioButton> = ({ name, value, checked, onChange, label }) => {
|
|
|
|
const formFieldId: string = useMemo(() => `radio-${uuidv4()}`, []);
|
|
|
|
|
|
|
|
return (
|
2022-11-25 09:04:11 -08:00
|
|
|
<HStack alignItems='center' space={3}>
|
2022-11-16 13:38:32 -08:00
|
|
|
<input
|
|
|
|
type='radio'
|
|
|
|
name={name}
|
|
|
|
id={formFieldId}
|
|
|
|
value={value}
|
|
|
|
checked={checked}
|
|
|
|
onChange={onChange}
|
2023-02-06 09:18:49 -08:00
|
|
|
className='text-primary-600 focus:ring-primary-500 h-4 w-4 border-gray-300'
|
2022-11-16 13:38:32 -08:00
|
|
|
/>
|
|
|
|
|
2022-11-25 09:04:11 -08:00
|
|
|
<label htmlFor={formFieldId} className='block text-sm font-medium text-gray-700'>
|
2022-11-16 13:38:32 -08:00
|
|
|
{label}
|
|
|
|
</label>
|
2022-11-25 09:04:11 -08:00
|
|
|
</HStack>
|
2022-11-16 13:38:32 -08:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default RadioButton;
|