import { FocusEvent, useCallback } from 'react'; import { ariaDescribedByIds, enumOptionsIsSelected, enumOptionsValueForIndex, optionId, FormContextType, RJSFSchema, StrictRJSFSchema, WidgetProps, } from '@rjsf/utils'; /** The `RadioWidget` is a widget for rendering a radio group. * It is typically used with a string property constrained with enum options. * * @param props - The `WidgetProps` for this component */ function RadioWidget({ options, value, required, disabled, readonly, autofocus = false, onBlur, onFocus, onChange, id, }: WidgetProps) { const { enumOptions, enumDisabled, inline, emptyValue } = options; const handleBlur = useCallback( ({ target }: FocusEvent) => onBlur(id, enumOptionsValueForIndex(target && target.value, enumOptions, emptyValue)), [onBlur, id] ); const handleFocus = useCallback( ({ target }: FocusEvent) => onFocus(id, enumOptionsValueForIndex(target && target.value, enumOptions, emptyValue)), [onFocus, id] ); return (
{Array.isArray(enumOptions) && enumOptions.map((option, i) => { const checked = enumOptionsIsSelected(option.value, value); const itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1; const disabledCls = disabled || itemDisabled || readonly ? 'disabled' : ''; const handleChange = () => onChange(option.value); const radio = ( (id)} /> {option.label} ); return inline ? ( ) : (
); })}
); } export default RadioWidget;