Добавление className, если условие истинно - PullRequest
0 голосов
/ 13 марта 2020

У меня есть форма с несколькими полями и кнопка отправки. как только я нажму кнопку отправки, она перейдет к этой функции filterProperties. у меня есть условие if внутри этой filterProperties функции. так что в том случае, если условие я проверяю, является ли дата выезда нулевой. Если условие if истинно, я хочу добавить класс с ошибкой в ​​средство выбора даты. если кто-нибудь знает, как это сделать, пожалуйста, помогите.

      filterProperties = () => {
        let checkin = this.state.checkin;
        let checkout = this.state.checkout;
        let guestCount = this.state.guest_count;
        let cityID = this.state.selectedcityID;
        let budget = parseFloat(this.state.textthree).toFixed(2);
        if (checkin !== "" && checkout === '') {
            alert('plz enter the check out date');
        }

        const cityProperties = {
            checkin: checkin,
            checkout: checkout,
            guestCount: guestCount,
            cityID: cityID,
            budget: budget
        }
        console.log(cityProperties);
        this.props.getCityProperties(cityProperties);
    }
                  <FormItem style={{ marginBottom: '0' }} label="Check Out">
                        <span>
                            {getFieldDecorator('check_out', {
                                rules: [
                                    {
                                        required: true,
                                        message: 'Please select a Check Out Date',
                                    }, {
                                        validator: this.checkCheckoutDates,
                                    }
                                ],
                            })(<DatePicker
                                className={className}
                                disabled={(this.state.checkin === '')}
                                disabledDate={this.disabledDateCheckout}
                                onChange={(e) => this.dateSelected(e, 'checkout')}
                                defaultValue={moment(new Date((new Date()).valueOf() + 1000 * 60 * 60 * 24))}
                                format={dateFormat}
                            />)}
                        </span>
                    </FormItem>

Ответы [ 2 ]

0 голосов
/ 13 марта 2020

Попробуйте это-

<DatePicker
                                className={(this.state.checkin !== "" && this.state.checkout === "")? "class-name": ""}
                                disabled={(this.state.checkin === '')}
                                disabledDate={this.disabledDateCheckout}
                                onChange={(e) => this.dateSelected(e, 'checkout')}
                                defaultValue={moment(new Date((new Date()).valueOf() + 1000 * 60 * 60 * 24))}
                                format={dateFormat}
                            />
0 голосов
/ 13 марта 2020

Вы можете использовать что-то вроде этого

<Element className={`${this.state.flag ? className : ''}`} />
...