Как получить значение пользовательского ввода и отобразить другой элемент на основе этого в React? - PullRequest
0 голосов
/ 14 марта 2020

Я пытаюсь отобразить флажок («Я согласен»), если, например, пользователь младше 18 лет, в противном случае этот флажок не отображается.

Я написал handleAgreementCheckbox, который должен возвращать логическое значение (true, false), если пользователь младше 18 лет, не уверен, как получить значение элемента и отобразить флажок.

Как мне это сделать в React?

Код

import React from 'react'
import {
  Form,
  Field
} from 'react-advanced-form'
import {
  Input,
  Button
} from 'react-advanced-form-addons'

export default class RegistrationForm extends React.Component {
  registerUser = ({
    serialized,
    fields,
    form
  }) => {
    return fetch('https://backend.dev', {
      body: JSON.stringify(serialized)
    })
  }

  handleAgreementCheckbox = () => {
      const currentTime = new Date();
      const eligibleUserDOB = new Date(currentTime.getFullYear() - 18, currentTime.getMonth(), currentTime.getDate());
      return currentTime>= eligibleUserDOB;
  };

  render() {
    return (
      <section className = "container">
        <Form action = {
          this.registerUser
        }
        onSubmitStart = {
          this.props.onSubmitStart
        }>
            <Input name = "firstName"
            label = "First name"
            required = {
              ({
                get
              }) => {
                return !!get(['lastName', 'value'])
              }
            }/>
            <Input name = "lastName"
            label = "Last name"
            required = {
              ({
                get
              }) => {
                return !!get(['firstName', 'value'])
              }
            }
            />

            <Input name = "emailAddress"
            type = "email"
            label = "Email Address"
            required />

            <Input name = "phoneNumber"
            type = "text"
            label = "Phone Number"
            required />

            <Input name = "dateOfBirth"
            type = "date"
            label = "Date of Birth"
            required />

            <Input name = "eligibleAge"
            type = "checkbox"
            label = "I agree"
            value = "unchecked"
            />
          <Button primary> Submit </Button>
        </Form>
      </section>
    );
  }
}

(Спасибо! Я новичок в React.)

Демонстрация по кодам andbox

1 Ответ

1 голос
/ 15 марта 2020

Хорошо, понял, во-первых, создайте состояние, в котором будут храниться условия истинного и ложного соответствия. Затем установите это состояние внутри вашего метода handleAgreementCheckbox. Наконец, используйте состояние допустимости для условной визуализации флажка, основанного на true или false.

/**
 * Registration form.
 * The component we have built together as the part of
 * React Advanced Form presentation on Medium.
 */
import React, { useState } from "react";
import { Form, Field } from "react-advanced-form";
import { Input, Button } from "react-advanced-form-addons";
// import 'react-phone-number-input/style.css'
// import PhoneInput from 'react-phone-number-input'
import PhoneInput from "react-phone-input-2";
import "react-phone-input-2/lib/style.css";

export default class RegistrationForm extends React.Component {
  registerUser = ({ serialized, fields, form }) => {
    return fetch("https://backend.dev", {
      body: JSON.stringify(serialized)
    });
  };

  state = { phone: "", eligible: false };

  handleOnChange = value => {
    console.log(value);
    this.setState({ phone: value }, () => {
      console.log(this.state.phone);
    });
  };

  handleAgreementCheckbox = event => {
    let selectedDate = event.nextValue; //======> fetch selected date and split it to pass into date object.
    selectedDate = selectedDate.split("-");
    console.log(selectedDate);

    const currentTime = new Date();
    const eligibleUserDOB = new Date(
      selectedDate[0],
      selectedDate[1] - 1,
      selectedDate[2]
    );
    console.log(currentTime, eligibleUserDOB);
    console.log(currentTime > eligibleUserDOB);

    if (currentTime >= eligibleUserDOB) { //====> on greater set eligible to true
      this.setState({ eligible: true });
    } else {                              //====> on less set eligible to false
      console.log(this.state);
      this.setState({ eligible: false });
    }

    return currentTime >= eligibleUserDOB;
  };

  render() {
    return (
      <section className="container">
        <Form
          action={this.registerUser}
          onSubmitStart={this.props.onSubmitStart}
        >
          <Input
            name="firstName"
            label="First name"
            required={({ get }) => {
              return !!get(["lastName", "value"]);
            }}
          />
          <Input
            name="lastName"
            label="Last name"
            required={({ get }) => {
              return !!get(["firstName", "value"]);
            }}
          />

          <Input
            name="emailAddress"
            type="email"
            label="Email Address"
            required
          />

          <PhoneInput
            name="phoneNumber"
            type="text"
            country={"us"}
            enableAreaCodes={true}
            onlyCountries={["us"]}
            areaCodes={{ us: ["332"] }}
            inputProps={{
              name: "phone",
              country: "us",
              required: true,
              autoFocus: true
            }}
            value={this.state.phone}
            onChange={this.handleOnChange}
            required
          />

          <Input
            name="dateOfBirth"
            type="date"
            label="Date of Birth"
            onChange={this.handleAgreementCheckbox}
            required
          />
          {this.state.eligible && ( //===========> print the state here and change time to see it in working. It will display the check on true and hide on false
            <Input
              name="eligibleAge"
              type="checkbox"
              label="I agree"
              value="unchecked"
            />
          )}
          <Button primary> Submit </Button>
        </Form>
      </section>
    );
  }
}

// <PhoneInput
//  country="US"
//  value={this.phoneNumberValidation.value}
//  onChange={this.phoneNumberValidation.setValue} />

рабочая демонстрация здесь

...