Реагируйте на Native - 2 TextInput, 1 onPress и отобразите 2 строки - PullRequest
0 голосов
/ 03 июня 2019

Поэтому я пытаюсь заставить работать 2 TextInput, 1 onPress, а затем отобразить 2 строки или значение с помощью React Redux.Я уже пробовал, но отображается только 1 значение / строка.Я не знаю, если это не доступно на React Redux?Пожалуйста, проверьте мои коды.Спасибо!

Вот мои коды:

EventInput.js:

state = {
eventName: "",
eventDescription: ""
};

eventChangedHandler = (val) => {
this.setState({
  eventName: val,
});
};

eventDescriptionHandler = (lol) => {
this.setState({
  eventDescription: lol
});
};

//For button also. In onPress
eventSubmitHandler = () => {
//This will not allow the user if they passed a empty string
if (this.state.eventName.trim() === "") {
  return;
}

//We use props here because the function of this is in the EventCreator.js
this.props.onEventAdded(this.state.eventName);
};

eventDescriptionSubmitHandler = () => {
  if(this.state.eventDescription.trim() === "") {
    return;
  }

this.props.onEventDescriptionAdded(this.state.eventDescription);
};

render () {
return (
  <View style={styles.container}>
    <View style={styles.inputAndButtonContainer}>
      <TextInput
        placeholder="Title of the Event..."
        value={this.state.eventName}
        onChangeText={this.eventChangedHandler}
        style={styles.textInputContainer}
        placeholderTextColor='black'
      />
      <TextInput
        placeholder="Description of the Event"
        value={this.state.eventDescription}
        onChangeText={this.eventDescriptionHandler}
        style={styles.textInputContainer}
        placeholderTextColor='black'
      />
      <TouchableOpacity 
        style={styles.setLocationContainer}
        onPress={this.props.onItemPressed}
      >
        <Text style={{fontWeight: 'bold', fontSize: 13, color: 'white'}}>
          Set Location of the Event or Party
        </Text>
      </TouchableOpacity>
    </View>
    <View style={styles.buttonContainer}>
      <TouchableOpacity onPress={(this.eventSubmitHandler, this.eventDescriptionSubmitHandler)}>
          <View style={styles.button}>
            <Text style={{color: 'black', fontSize: 20, fontWeight: 'bold'}}>Add</Text>
          </View>
      </TouchableOpacity>
    </View>
  </View>
);
}

EventCreator.js:

eventAddedHandler = eventName => {
this.props.onAddEvent(eventName);
};

eventDescriptionHandler = eventDescription => {
this.props.onAddEvent(eventDescription);
};

render() {
return(
  <LinearGradient style={styles.linearGradient} colors={['#718792', '#1c313a', '#000a12']}>
    <View>
      <EventInput
        onEventAdded={this.eventAddedHandler}
        onEventDescriptionAdded={this.eventDescriptionHandler}
        onItemPressed={this.openMapScreen}
      />
    </View>
  </LinearGradient>

);
}

const mapDispatchToProps = dispatch => {
return {
  onAddEvent: (eventName, eventDescription) => dispatch(addEvent(eventName, eventDescription))
  };
};

export default connect(null, mapDispatchToProps)(EventCreator);

Вот мои кодыдля отображения данных:

EventList.js

const eventList = (props) => {
return (
<View>
  <FlatList 
    style={styles.listContainer}
    data={props.events}
    ListHeaderComponent={this.renderHeader}
    renderItem={(info) => (
      <ListItem
        eventName={info.item.name}
        eventImage={info.item.image}
        eventDescription={info.item.description}
        onItemPressed={() => props.onItemSelected(info.item.key)}
      />
    )}
  />
</View>
);
};

Home.js:

  render() {
return(
  <LinearGradient colors={['#718792', '#1c313a', '#000a12']} style={styles.linearGradient}>
    <View style={styles.container}>
      <EventList 
        events={this.props.events}
        onItemSelected={this.itemSelectedHandler}
      />
    </View>
  </LinearGradient>

);
}

const mapStateToProps = state => {
return {
  events: state.events.events
};
};

export default connect(mapStateToProps)(HomeScreen);

Вот мои коды для React Redux:

store / redurs / event.js:

const reducer = (state = initialState, action) => {
switch (action.type) {
case ADD_EVENT:
  return {
    ...state,
    events: state.events.concat({
      key:  `${Math.random()}`,
      name: action.eventName,
      description: action.eventDescription,
      image: {
        uri: "https://c1.staticflickr.com/5/4096/4744241983_34023bf303_b.jpg"
      }
    })
  };
case DELETE_EVENT:
  return {
    ...state,
    events: state.events.filter(event => {
      return event.key !== action.eventKey;
    })
  };
default:
  return state;
}
};

Запросите дополнительную информацию и коды, если вам это нужно, спасибо!

...