Отправка на сервер нескольких параметров одновременно - React Native - PullRequest
2 голосов
/ 18 марта 2019

У меня есть проект, в котором я извлекаю из API некоторые данные и отображаю эти данные в React Native.После рендеринга я отображаю список документов и, нажимая на один из них, я передаю некоторые значения на следующую страницу, которая включает в себя Имя, Описание документа и поля ввода.Затем я подписываю документ.

Итак, я хочу записать все эти значения (заголовок, описание, введенные пользователем значения и подпись пользователя) и отправить их с помощью fetch () на мой сервер.

Пожалуйста, дайте мне знать, если вам нужны дополнительные объяснения, спасибо за любые предложения!

Вот код класса, где я показываю все, я не думаю, что вам понадобитсякод домашней страницы:

    class DetailScreen extends React.Component {
  state = {
    isModalVisible: false
  };

  _toggleModal = () =>
    this.setState({ isModalVisible: !this.state.isModalVisible });

  constructor(props) {
    super(props);
    this.state = {
      signature: null,
    }
    this.postToBmp();
  }

  static navigationOptions = {
    title: 'Content of selected'
  };

  handleSignature = signature => {
    this.setState({ signature }), this.setState({ isModalVisible: false });
  };

  postToBmp = () => {
    fetch('https://myurl', {
      method: 'POST',
      headers: {
        Accept: 'application/json',
        'Content-Type': 'application/json',
        'Connection': 'Keep-Alive',
      },
      credentials: 'include',
      body: JSON.stringify({
        from: 'test@test.dk',
        attachmentName: 'The PDF file name',
        recipientFullName: 'My name',
        to: [
          '<test@test.com>'
        ]
      })
    })
  }


  renderTextandInputs = (obje) => {
    console.log("KEYVALUES:", obje.keyValues)
    var keyvalue_to_json = JSON.parse(obje.keyValues);
    var foundTextFields = [];
    for (let i = 0; i < keyvalue_to_json.length; i++) {
      if (keyvalue_to_json[i].type === 'textfield') {
        foundTextFields.push(<TextInput style={{ borderWidth: 1, flex: 1, alignItems: 'flex-start' }}>{keyvalue_to_json[i].placeholderText}</TextInput>)
      }
    }
    return (
      <View>
        <ListItem
          title={obje.name}
          subtitle={obje.description}
        />
        <View >
          {foundTextFields}
        </View>
      </View>
    )
  }

  render() {
    const style = `.m-signature-pad--footer
    .button {
      background-color: red;
      color: #FFF;
    }`;
    const obj = this.props.navigation.state.params.item;
    var propsArray = [];
    const itemArray = Object.assign(obj)
    propsArray.push(itemArray)

    keyExtractor = (item, index) => {
      return index.toString();
    }
    return (
      <View style={{ flex: 1, justifyContent: "center" }}>
        <View style={{ flex: 1, alignItems: 'stretch' }}>
          <FlatList
            key={propsArray.key}
            data={propsArray}
            renderItem={({ item }) => this.renderTextandInputs(item)}
          />
        </View>
        <View >
          {this.state.signature ? (
            <Image
              resizeMode={"contain"}
              style={{ width: 150, height: 114 }}
              source={{ uri: this.state.signature }}
            />
          ) : null}
        </View>
        <Modal isVisible={this.state.isModalVisible}
          onBackdropPress={() => this.setState({ isModalVisible: false })}
        >
          <View style={{ flex: 1 }}>
          </View>
          <Signature
            width="100"
            onOK={this.handleSignature}
            descriptionText="Please draw your signature"
            clearText="Clear"
            confirmText="Save"
            webStyle={signature_styles}
          />
        </Modal>
        <View>
          <Button title="SIGN" onPress={this._toggleModal} />
        </View>
      </View>
    );
  }

Вот снимок экрана домашней страницы, где я отображаю список документов из API:

enter image description here

Это скриншот второй страницы, где я отображаю имя, описание, текстовые входы из API и подписываю документ с помощью компонента: enter image description here

...