Как правильно отправлять даты из DatePicker в React? - PullRequest
0 голосов
/ 06 ноября 2018

У меня есть два компонента. Мне нужно получить даты и отправить их, чтобы забрать. В компоненте MainPage я добавляю состояние для значений дат. В компоненте InputForm я добавляю ответный сборщик данных.

Когда пользователь устанавливает даты для сборщиков данных, эти значения следует отправлять для извлечения в формате 'dd.mm.yyyy' или 'yyyy-mm-dd' (я использую dateFormat для изменения).

В результате у меня есть этот код для MainPage :

import React, { PropTypes, Component } from 'react';
import dateFormat from 'dateformat';

class ReportPage extends Component {
  constructor(props) {
    super(props);
    this.state = {      
      date1: new Date(),
      date2: new Date()      
    };  
    this.onHandleFetch = this.onHandleFetch.bind(this);
    this.onChangeInputDate1 = this.onChangeInputDate1.bind(this);
    this.onChangeInputDate2 = this.onChangeInputDate2.bind(this);
    this.checkInputs = this.checkInputs.bind(this);    
  }

  handleShowClick() {         // if button clicked 
    if (this.checkInputs()) {     // if dates not null
      this.onHandleFetch(); 
    }
  }

  checkInputs() {
    if (this.state.date1 === null || this.state.date2 === null) {
      return false;
    }   
    return true;
  }

  onChangeInputDate1(d1) {   
    console.log(dateFormat(d1, 'isoDate')); // format yyyy-mm-dd
    this.setState({
      date1: d1     
    });
  }

  onChangeInputDate2(d2) {
    console.log(dateFormat(d2, 'isoDate'));
    this.setState({
      date2: d2
    });
  } 

  onHandleFetch() {    
    fetch(`${Config.baseUrl}/find/${dateFormat(this.state.date1, 'isoDate')}/
    ${dateFormat(this.state.date2, 'isoDate')}`, {
      method: 'GET'
    })
        ...
  }

  render() {
    return (
      <div>        
       <InputForm
         handleChangeInputDate1={this.onChangeInputDate1} handleChangeInputDate2={this.onChangeInputDate2}
         date1={this.state.date1} date2={this.state.date2}
       />
      )
    ...
    }

InputForm

import React, { PropTypes, Component } from 'react';
import DatePicker from 'react-date-picker';

const propTypes = {  
  date1: PropTypes.string,
  date2: PropTypes.string,
  handleChangeInputDate1: PropTypes.func,
  handleChangeInputDate2: PropTypes.func
};

class InputForm extends Component {
  constructor(props) {
    super(props);
    this.handleOnChange1 = this.handleOnChange1.bind(this);
    this.handleOnChange2 = this.handleOnChange2.bind(this);
  }

  handleOnChange1(date1) {
    this.props.handleChangeInputDate1(date1);
  }

  handleOnChange2(date2) {
    this.props.handleChangeInputDate2(date2);
  }

  render() {
    return (
      <form>
       ...
         <DatePicker onChange={this.handleOnChange1}
           value={this.props.date1}
         />               
         <DatePicker onChange={this.handleOnChange2}
           value={this.props.date2}
         />
       ...
      </form>
    );
  }
}

В результате у меня появляется эта ошибка в консоли:

Объекты недопустимы в качестве дочерних элементов React (найдено: ср. 17 октября 2018 г. 00:00:00 GMT + 0500 (Екатеринбург, стандартное время)).

Как я могу это исправить?

...