材质ui formik自动完成仅获取fieldarray中的值

时间:2020-05-08 21:06:58

标签: reactjs material-ui formik formik-material-ui

当前尝试在Formik中使用Material UI的自动完成组件。到目前为止,Formik可以很好地处理文本字段和Material-UI中的传统选择之类的事情。并非如此。我从列表中选择项目时遇到的问题是,我不仅获得了价值,而且还反对如何解决该问题

const FAutocomplete = (props) => {
    const {
        field,
        form: { dirty, touched, errors, setFieldValue },
        options,
        getOptionLabel,
        textFieldProps,
        ...autoCompleteProps
    } = props

    // Merge default textFieldProps with textFieldProps passed in the component
    const mergedTextFieldProps = {
        ...FAutocomplete.defaultProps.textFieldProps,
        ...textFieldProps,
    }
    const errorText = getIn(errors, field.name)
    const touchedVal = getIn(touched, field.name)
    const hasError = dirty && touchedVal && errorText !== undefined
    const isMultiple = autoCompleteProps.multiple
    const isMultipleWithValue = isMultiple && field.value
    const canBeRendered = !isMultiple || isMultipleWithValue

    return (
        <>
            {canBeRendered && (
                <Autocomplete
                    options={options}
                    getOptionLabel={getOptionLabel}
                    onChange={(_, value) => setFieldValue(field.name, value)}
                    value={field.value}
                    getOptionSelected={(option, val) => option.value === val.value}
                    filterSelectedOptions 
                    renderInput={(params) => (
                        < TextField
                            {...params}
                            error={hasError}
                            helperText={hasError ? errorText : ''}
                            {...mergedTextFieldProps}
                        />
                    )}
                    {...autoCompleteProps}
                />
            )}
        </>
    )
}

FAutocomplete.propTypes = {
    form: PropTypes.shape({
        dirty: PropTypes.bool,
        errors: PropTypes.object,
        setFieldValue: PropTypes.func,
    }).isRequired,
    options: PropTypes.arrayOf(
        PropTypes.shape({
            label: PropTypes.string,
            value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
        })
    ).isRequired,
    getOptionLabel: PropTypes.func,
    textFieldProps: PropTypes.shape({
        label: PropTypes.string,
        required: PropTypes.bool,
        fullWidth: PropTypes.bool,
        margin: PropTypes.oneOf(['none', 'dense', 'normal']),
    }),
}

FAutocomplete.defaultProps = {
    getOptionLabel: (option) => option.label,
    textFieldProps: {
        required: false,
        fullWidth: true,
        margin: 'normal',
    },
}

export default FAutocomplete


//How I use it;
<Field                                                                name={`types.${index}.typesof`}
options={data}
component={FAutocomplete}
size='small'
textFieldProps={{
label: 'types',
required: true,
variant: "standard",
placeholder: "types"
}}
multiple
/>


// initial values
const initialValues = {   
    types: []
}

const emptyTypesObject = {  
    typesof: [],
};


// where I do have problem is when choose from list my values  like below;
 "types": [
    {      
      "typesof": [
        {
          "label": "CSS",
          "value": "1"
        }
      ]
    }
  ],

// I want it to be like that only need to get the value of selected 
"types": [
    {      
      "typesof": [1]
    }
  ],

0 个答案:

没有答案