如何在获取异步数据时使用redux-form将defaultValue设置为DropdownList?

时间:2020-02-20 14:42:16

标签: reactjs redux react-redux redux-form react-widgets

我将redux-form中的DropdownListreact-widgets一起使用。因此,我有一个组件开始在他的componentDidMount中获取异步数据并将其推送到存储位置,从那里我必须将其发送给我的DropdownList。我通过了data道具-它可以工作-但我无法通过defaultValue道具,因为它取决于异步数据,并且在呈现表单时仍然是undefined。如何重新初始化表单以设置defaultValue

组件

import React, { Component } from 'react';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import { Field, reduxForm } from 'redux-form';
import { required, email } from 'redux-form-validators';
import {
    actionGetUsersRoles,
    actionGetUsersStatuses,
    actionSendNewUser
} from '../../../actions/adminActions';
import DropdownList from 'react-widgets/lib/DropdownList'
import UiBtn from '../ui-btn/UiBtn';
import FieldError from '../field-error/field-error';
import 'react-widgets/dist/css/react-widgets.css'

class AddUser extends Component {
    componentDidMount() {
        this.props.actionGetUsersRoles()
        this.props.actionGetUsersStatuses()
    }

    render() {
        const { appId, countries, roles, statuses } = this.props;
        const { actionSendNewUser } = this.props;

        const handleSubmit = formData => {
            actionSendNewUser(
                appId,
                formData.name,
                formData.surname,
                formData.email,
                formData.country,
                formData.role,
                formData.status
            )
        }

        return (
            <AddUserForm 
                onSubmit={handleSubmit}
                countries={countries}
                roles={roles}
                statuses={statuses}
            />
        )
    }
}

let FormInput = ({ input, meta, ...custom }) => {
    const hasError = meta.touched && meta.error;

    return (
        <div className="popup-inner-content-field">
            <input 
                {...input}
                type={custom.type}
                placeholder={custom.placeholder} 
            />
            {
                hasError &&
                <FieldError 
                    txt={meta.error}
                />
            }
        </div>
    )
} 

let FormDropableInput = ({ input, meta, ...custom }) => {
    const hasError = meta.touched && meta.error;

    return (
        <div className="popup-inner-content-array-field">
            <div className="drop-input">
                <input 
                    {...input}
                    type={custom.type} 
                    placeholder={custom.placeholder}
                />
                {
                    hasError &&
                    <FieldError 
                        txt={meta.error}
                    />
                }
            </div>
        </div>
    )
}

let FormSelect = ({ input, ...custom }) => {
    // console.log(custom.defaultValue)
    return (
        <div className="popup-inner-content-array-field">
            <DropdownList 
                {...input}
                defaultValue={custom.defaultValue}
                data={custom.data}
            />
        </div>
    )
}

let AddUserForm = props => {
    const { handleSubmit, countries, roles, statuses } = props;

    let parsedRoles = roles.map(item => (item.value))
    let parsedStatuses = statuses.map(item => (item.value))

    return (
        <form onSubmit={handleSubmit}>
            <Field 
                name='email'
                component={FormInput}
                type='email'
                placeholder='E-mail'
                validate={
                    required({ msg: 'e-mail is required' }),
                    email({ msg: 'invalid e-mail' })
                }
            />
            <Field 
                name='name'
                component={FormInput}
                type='text'
                placeholder='Name'
                validate={
                    required({ msg: 'name is required' })
                }
            />
            <Field 
                name='surname'
                component={FormInput}
                type='text'
                placeholder='Surname'
                validate={
                    required({ msg: 'Surname is required' })
                }
            />

            <div className="popup-inner-content-array">
                <Field 
                    name='country'
                    component={FormDropableInput}
                    type='text'
                    placeholder='Choose country'
                    validate={
                        required({ msg: 'country is required' })
                    }
                />
                <Field 
                    name='role'
                    component={FormSelect}
                    defaultValue={parsedRoles[0]}
                    data={parsedRoles}
                />
                <Field 
                    name='status'
                    component={FormSelect}
                    defaultValue={parsedStatuses[0]}
                    data={parsedStatuses}
                />
            </div>
            <UiBtn
                txt='Save'
                small
            />
        </form>
    )
}

AddUserForm = reduxForm({
    form: 'add-user'
})(AddUserForm)

AddUser.propTypes = {
    appId: PropTypes.number.isRequired
}

export default connect(state => ({
    appId: state.user.appId,
    countries: state.admin.countries,
    roles: state.admin.roles,
    statuses: state.admin.statuses,
}), {
    actionGetUsersRoles,
    actionGetUsersStatuses,
    actionSendNewUser
})(AddUser)

0 个答案:

没有答案