import { Radio as $Radio } from "antd";
import { Field, FieldProps } from "formik";
import * as React from "react";
import { RadioGroupProps as $RadioGroupProps } from "antd/lib/radio/interface";
import { FormikFieldProps } from "../FieldProps";
export type RadioGroupProps = FormikFieldProps & $RadioGroupProps;
export const Radio = ({ name, validate, onChange, ...restProps }: RadioGroupProps) => (
{({ field: { value }, form: { setFieldValue, setFieldTouched } }: FieldProps) => (
<$Radio
value={value}
onChange={event => {
setFieldValue(name, event.target.value)
setFieldTouched(name, true)
onChange && onChange(event)
}}
{...restProps}
/>
)}
);
export default Radio
Radio.Group = ({ name, validate, onChange, ...restProps }: RadioGroupProps) => (
{({ field: { value }, form: { setFieldValue, setFieldTouched } }: FieldProps) => (
<$Radio.Group
value={value}
onChange={event => {
setFieldValue(name, event.target.value)
setFieldTouched(name, true)
onChange && onChange(event)
}}
{...restProps}
/>
)}
);
Radio.Button = $Radio.Button;