/**
* WordPress dependencies
*/
import { privateApis, Spinner } from '@wordpress/components';
import { useCallback } from '@wordpress/element';
/**
* Internal dependencies
*/
import type { DataFormControlProps } from '../../types';
import { unlock } from '../../lock-unlock';
import getCustomValidity from './utils/get-custom-validity';
import useElements from '../../hooks/use-elements';
const { ValidatedRadioControl } = unlock( privateApis );
export default function Radio< Item >( {
data,
field,
onChange,
hideLabelFromVision,
markWhenOptional,
validity,
}: DataFormControlProps< Item > ) {
const { label, description, getValue, setValue, isValid } = field;
const { elements, isLoading } = useElements( {
elements: field.elements,
getElements: field.getElements,
} );
const value = getValue( { item: data } );
const onChangeControl = useCallback(
( newValue: string ) =>
onChange( setValue( { item: data, value: newValue } ) ),
[ data, onChange, setValue ]
);
if ( isLoading ) {
return ;
}
return (
);
}