Удалить визуализацию элемента плоского списка из другого компонента нажатием кнопки «Удалить» - PullRequest
0 голосов
/ 23 марта 2019

Я совершенно новичок, чтобы реагировать, и я пытаюсь удалить элемент плоского списка, который поступает из другого компонента. Когда я нажимаю кнопку удаления, элемент должен быть удален.

... Вот файл, из которого я рендеринг flatlist. ...

import React from "react";
import {
  ActivityIndicator,
  AsyncStorage,
  FlatList,
  Text,
  View,
  Linking,
  ScrollView,
  Image
} from "react-native";
import ButtonCom from "../../../components/ButtonCom";
import ClinicCard from "../../../components/ClinicCardCom";
import { Button } from "native-base";
import color from "../../../ui/color";
import { getMyClinic } from "../../../actions/getClinicActions";
import { connect } from "react-redux";
import AddClinic from '../.././DoctorFlow/AddClinic/AddClinic';
class ViewClinic extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      user: null,
      doctorId: null,
      data: [1, 2, 3, 4, 5]
    };
  }

  componentDidMount() {
    this.getUser();
  }

  async getUser() {
    await AsyncStorage.getItem("user").then(user =>
      this.setState({ user: JSON.parse(user) })
    );
    console.log("doctorData", this.state.user);
    this.setState({
      doctorId: this.state.user.user._id
    });
    this.props.getClinics(this.state.doctorId);
  }
  _renderItem = ({ item }) => {
    return (
      <View style={{ flex: 1 }}>

... Компонент, который я создал и рендеринг деталей ...

     <ClinicCard
          clinicName={item.clinicName}
          clinicAddress={item.address}
          clinicNumber={item.mobile}
          days={item.availability.days.join(' ' + ',' + ' ')} 
          time={item.availability.time.from + " " + "-" + " " + item.availability.time.to}
        />
      </View>
    );
  };

  render() {
    if (this.props.loading) {
      return (
        <View
          style={{ flex: 1, alignSelf: "center", justifyContent: "center" }}
        >
          <ActivityIndicator size="large" />
          <Text>Fetching your clinics</Text>
        </View>
      );
    }
    return (
      <View style={{ flex: 1, padding: 10 }}>
        <FlatList
          data={this.props.myClinicList}
          renderItem={this._renderItem}
        />
        <View style={{ flex: 1, alignSelf: "center" }}>
          <Button
            full
            rounded
            style={{
              position: "absolute",
              bottom: 25,
              left: 110,
              marginBottom: 10,
              backgroundColor: color.primary,
              alignSelf: "center",
              shadowColor: 'black',
              shadowOpacity: 0.8,
              elevation: 15,
              shadowRadius: 18,
              shadowOffset : { width: 56, height: 13}
            }}
            onPress={() => this.props.navigation.navigate("AddClinic")}
          >
            <Text style={{ color: "#fff", paddingHorizontal: 14, paddingBottom: 4, fontSize: 31 }}>
              +
            </Text>
          </Button>
        </View>
      </View>
    );
  }
}

const mapStateToProps = ({ myClinicReducer }) => {
  const { myClinicList, loading, errorMsg } = myClinicReducer;
  console.log("myclickiclistinside", myClinicList);
  return {
    myClinicList,
    loading,
    errorMsg
  };
};

const mapDispatchToProps = dispatch => ({
  getClinics: doctorId => dispatch(getMyClinic(doctorId))
});

export default connect(
  mapStateToProps,
  mapDispatchToProps
)(ViewClinic);

... пользовательский компонент, в котором я визуализировал свою кнопку удаления и пользовательские стили ...

import React from "react";
import { Image, 
         StyleSheet, 
         Text, 
         View, 
         Touchable, 
         TouchableHighlight, 
         TouchableOpacity } from "react-native";
import { Button } from "native-base";
import color from "../ui/color";
import { editProfileStyle } from '.././containers/DoctorFlow/EditProfile/EditProfileStyles';
export default class ClinicCard extends React.Component {
  render() {
    return (
      <View
        style={{
          borderRadius: 2.7,
          backgroundColor: "#ffffff",
          borderLeftColor: "#2abb91",
          borderLeftWidth: 2,
          borderRightColor: "#2abb91",
          borderRightWidth: 2,
          marginBottom: 8,
          shadowColor: 'black',
          shadowOpacity: 0.6,
          elevation: 4,
          shadowRadius: 20,
          shadowOffset : { width: 50, height: 10}
        }}
      >
        <View style={{ padding: 15 }}>
          <View style={{ flexDirection: "row", marginBottom: 15 }}>
            <Image
              style={{
                width: 25,
                height: 25
              }}
              source={require("../Images/DoctorFlow/location.png")}
            />
            <View
              style={{
                flexDirection: "column",
                marginLeft: 12
              }}
            >
              <Text
                style={{
                  marginBottom: 3,
                  fontSize: 15,
                  fontWeight: "bold",
                  color: "#333333"
                }}
              >
                {this.props.clinicName}
              </Text>
              <Text
                style={{
                  fontSize: 13,
                  color: "#666666"
                }}
              >
                {this.props.clinicAddress}
              </Text>
            </View>
          </View>
          <View
            style={{
              flexDirection: "row",
              alignItems: "center",
              marginBottom: 12
            }}
          >
            <Image
              style={{
                width: 25,
                height: 25
              }}
              source={require("../Images/DoctorFlow/smartphone.png")}
            />

            <Text
              style={{
                marginLeft: 12,
                fontSize: 15,
                fontWeight: "bold",
                color: "#333333"
              }}
            >
              {this.props.clinicNumber}
            </Text>
          </View>
          <View style={{ flexDirection: "row" }}>
            <Image
              style={{
                width: 25,
                height: 25
              }}
              source={require("../Images/DoctorFlow/time.png")}
            />
            <View
              style={{
                flexDirection: "row",
                marginLeft: 12,
                alignItems: "center"
              }}
            >
              <Text
                style={{
                  fontSize: 15,
                  fontWeight: "bold",
                  color: "#2abb91"
                }}
              >
                {this.props.time}
              </Text>
              <Text
                style={{
                  fontSize: 13,
                  fontWeight: "bold",
                  color: "rgba(102, 102, 102, 0.92)",
                  marginLeft: 5
                }}
              >
                {this.props.days}
              </Text>
            </View>
          </View>
          <View style={{
                  flexDirection: "row",
                  marginBottom: 10
                }}>
            <TouchableHighlight underlayColor="transparent">
              <View style={editProfileStyle.clinicBtn}>
                  <Text style={editProfileStyle.proffesionBtnViewText}>
                    Edit
                  </Text>
              </View>
            </TouchableHighlight>
            <TouchableHighlight 
            underlayColor="transparent"
            onPress={() =>
              this.setState({
                clinicObj: []
              })
            }>
              <View style={editProfileStyle.clinicBtn}>
                  <Text style={editProfileStyle.proffesionBtnViewText}>
                    Delete
                  </Text>
              </View>
            </TouchableHighlight>
            </View>
        </View>
      </View>
    );
  }
}
const styles = StyleSheet.create({
  txt: {
    fontFamily: "Gotham-Medium",
    color: "#fff",
    fontSize: 16
  }
});
...