import FormControl from "@material-ui/core/FormControl"; import FormControlLabel from "@material-ui/core/FormControlLabel"; import FormHelperText from "@material-ui/core/FormHelperText"; import FormLabel from "@material-ui/core/FormLabel"; import MenuItem from "@material-ui/core/MenuItem"; import Radio from "@material-ui/core/Radio"; import RadioGroup from "@material-ui/core/RadioGroup"; import { createStyles, withStyles, WithStyles } from "@material-ui/core/styles"; import classNames from "classnames"; import React from "react"; import { FormattedMessage } from "react-intl"; const styles = createStyles({ formControl: { padding: 0, width: "100%" }, formLabel: { marginLeft: "-5px", paddingBottom: "10px" }, radioLabel: { "& > span": { padding: "6px" } }, secondLabel: { display: "block", fontSize: "12px" } }); interface RadioGroupFieldProps { choices: Array<{ value: string; label: React.ReactNode; }>; className?: string; disabled?: boolean; error?: boolean; hint?: string; label?: string; name?: string; value?: string; onChange: (event: React.ChangeEvent) => void; } export const RadioGroupField = withStyles(styles, { name: "RadioGroupField" })( ({ className, classes, disabled, error, label, choices, value, onChange, name, hint }: RadioGroupFieldProps & WithStyles) => { return ( {label ? ( {label} ) : null} {choices.length > 0 ? ( choices.map(choice => ( } label={choice.label} key={choice.value} /> )) ) : ( )} {hint && {hint}} ); } ); RadioGroupField.displayName = "RadioGroupField"; export default RadioGroupField;