Как проверить множественную реакцию-jsonschema-форму во вкладках - PullRequest
0 голосов
/ 02 января 2019

Я довольно новичок в response-jsonschema-form и пытаюсь выяснить, как проверять несколько форм одним нажатием родительской кнопки.Прямо сейчас у меня есть родительский компонент, который содержит вкладки и кнопку отправки.Каждая вкладка содержит форму response-jsonschema.Есть ли способ проверки форм на каждой вкладке после нажатия родительской кнопки отправки?Я могу использовать console.log с именами вкладок при нажатии кнопки отправки, НО формы, которые в данный момент не активны, выдают ошибку, которая говорит: Недопустимый элемент управления формы с именем = '' не может быть сфокусирован.

Например, у меня есть:

Родительский компонент:

<Paper style={styles.well} >
   <Container style={styles.grid}>
      <Row>
         <Col xs={12} sm={12} md={8} lg={6} >
             <Form >
                 <Form.Group                                              controlId="name">
                 <Form.Label>Name *</Form.Label>
                 <Form.Control placeholder="Enter name" name='name' value={this.state.name} onChange={this.handleChange}/>
                 </Form.Group>

                 <Form.Group controlId="description">
                 <Form.Label>Description </Form.Label>
                 <Form.Control as='textarea' placeholder="Enter Description"= name='description' required value={this.state.description} onChange={this.handleChange} />
                 </Form.Group>
                 <Form.Group controlId="pay">
                 <Form.Label>Pay *</Form.Label>
                 <Form.Control as="select" placeholder="select" name='pay' value={this.state.pay} onChange={this.handleChange}> 

                 <option value="select"></option>                
                 <option value="1">1</option>
                 <option value="2">2</option>
                 <option value="3">3</option>
                 <option value="4">4</option>
                 <option value="5">5</option> 
             </Form.Control>
             </Form.Group>
          </Form>
       </Col>

      {this.state.pay === '' ? <div></div> 
      : <TabContent onResetValidation={this.handleResetValidation} validateForms={this.state.validateForms} payType={this.state.pay}/>}
       <Container>
           <Row style={{paddingBottom:'15px', paddingTop:'10px'}}>
              <Col xs={12} sm={12} md={12} lg={12} >
                  {this.state.pay === '' ? <div></div> :
                  <Button onClick={this.submitForms} variant='primary' size='large'>Submit Form

                   </Button>
      }
      </Col>
    </Row>
 </Container>

Компонент содержимого вкладки:

<Container style={{paddingTop:'30px', width:'100%'}}>
   <Row>
      <Col xs={12} md={12} lg={12} >
          <Tabs id={'PayTabs'} defaultActiveKey={1} >
              <Tab eventKey={1} title="Tab 1">
                 <div style={{paddingTop:'20px'}}>
                   <Tab1 onResetValidation={this.props.onResetValidation} validateForms={this.props.validateForms} payType={payType}/>
                 </div>
             </Tab>
             <Tab eventKey={2} title="Tab 2">
                 <div style={{paddingTop:'20px'}}>
                   <Tab2 onResetValidation={this.props.onResetValidation} validateForms={this.props.validateForms}  payType={payType}/>
                 </div>
             </Tab>
             <Tab eventKey={3} title="Tab 3">
                 <div style={{paddingTop:'20px'}}>
                   <Tab3 onResetValidation={this.props.onResetValidation} validateForms={this.props.validateForms}  payType={payType}/>
                 </div>
             </Tab>
         </Tabs>                   
     </Col>
  </Row>

Каждый дочерний компонент вкладки выглядит следующим образом:

export class Tab1 extends Component {
constructor(props) {
    super(props);

    this.state = {            
    };
}
componentWillReceiveProps(nextProps, nextContent) {
    if (nextProps.validateForms !== this.state.validateForms) {
        if (nextProps.validateForms === true) {
            debugger
            console.log("Tab1");
            this.form.submitButton.click();
            this.props.onResetValidation();
        }
    }
}
render() { 
return (   
<Container style={{width: '100%', paddingBottom:'25px'}}>
    <Row>
       <Col xs={12} md={12} lg={12} style={{marginLeft:'-25px', marginTop:'-15px'}}>
           <MyForm name='form' ref={(form) => {this.form=form;}}/>
       </Col>
    </Row>
 </Container> 
 );
}

}

Компонент MyForm:

function Tpl(props) {
const {id, label, required, children} = props;
return (
    <div className="myfield">
        <label htmlFor={id}>{label}{required ? "*" : null}</label>
        {children}
    </div>
    );
}
class MyForm extends React.Component {

constructor(props) {
    super(props);
    this.state = {
        formData: {}
    }
}

onSubmit(formData) {
    //this only gets called if the validation is successful
    console.log(formData);
}

onError(formData) {
    console.log(formData)
}


render () {
    return (
        <Form2  FieldTemplate={Tpl}  onError={this.onError} onChange={({ formData }) => this.setState({ formData })} formData={this.state.formData} schema={schema} onSubmit={this.onSubmit} className="component-container">
            <button ref={(btn) => {this.submitButton=btn;}} style={{"display": "none"}}/>
        </Form2>
    );
}

}

...