import FilledInput from "@material-ui/core/FilledInput"; import FormControl from "@material-ui/core/FormControl"; import FormHelperText from "@material-ui/core/FormHelperText"; import InputLabel from "@material-ui/core/InputLabel"; import MenuItem from "@material-ui/core/MenuItem"; import Select, { SelectProps } from "@material-ui/core/Select"; import { createStyles, withStyles, WithStyles } from "@material-ui/core/styles"; import classNames from "classnames"; import * as React from "react"; import i18n from "../../i18n"; const styles = createStyles({ formControl: { width: "100%" } }); interface SingleSelectFieldProps extends WithStyles { choices: Array<{ value: string; label: string | React.ReactNode; }>; className?: string; disabled?: boolean; error?: boolean; hint?: string; label?: string; name?: string; selectProps?: SelectProps; placeholder?: string; value?: string; onChange(event: any); } export const SingleSelectField = withStyles(styles, { name: "SingleSelectField" })( ({ className, classes, disabled, error, label, choices, value, onChange, name, hint, selectProps, placeholder }: SingleSelectFieldProps) => { const choicesByKey: { [key: string]: string } = choices === undefined ? {} : choices.reduce((prev, curr) => { prev[curr.value] = curr.label; return prev; }, {}); return ( {label} {hint && {hint}} ); } ); SingleSelectField.displayName = "SingleSelectField"; export default SingleSelectField;