Анимации на элементах в FlatList отстают только в первый раз
У меня есть плоский список, и у каждого элемента есть анимация для перемещения элементов по нажатию, анимация в первый раз настолько запаздывает, но после первого раза все в порядке
вот список
<SectionList
sections={date}
renderItem={({index section: {data}}) =>
<Flight flight={item} />
}
/>
вот компонент fligth:
класс экспорта по умолчанию Flight extends Component {
constructor(props) {
super(props)
this.state = {
opened: false
}
this.anim = new Animated.ValueXY(0, 0)
this.panResponder = PanResponder.create({
onStartShouldSetPanResponder: () => true,
onPanResponderMove: (evt, gestureState) => {
this.startAnimation(gestureState.dx)
},
onPanResponderRelease: () => {
}
})
}
getMoreInfo = (ID) => {
//alert(ID)
fetch('https://appdcs.faranegar.com/api/SelectDetailFlight', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
"FlightSchedule_ID": ID
}
)
})
.then((response) => response.json())
.then((responseJson) => {
//this.setState({isLoading : false})
//alert(responseJson.TextShow)
Alert.alert("", responseJson.TextShow);
})
.catch((error) => {
});
}
openMenu = () => {
Animated.spring( // Animate over time
this.anim, // The animated value to drive
{
toValue: {x: -250, y: 0}, // Animate to opacity: 1 (opaque)
duration: 0, // Make it take a while
}
).start();
this.setState({opened: true})
}
closeMenu = () => {
Animated.spring( // Animate over time
this.anim, // The animated value to drive
{
toValue: {x: 0, y: 0}, // Animate to opacity: 1 (opaque)
duration: 0, // Make it take a while
}
).start();
this.setState({opened: false})
}
itemPressed = () => {
if (this.state.opened) {
this.closeMenu()
} else {
this.openMenu()
}
}
emailPressed = () => {
setTimeout(this.closeMenu, 500)
this.props.showFirstPicker(this.props.flight["ID"])
}
messagePressed = () => {
setTimeout(this.closeMenu, 500)
this.getMoreInfo(this.props.flight["ID"])
}
seatMapPressed = () => {
setTimeout(this.closeMenu, 500)
this.props.goToSeatMap(this.props.flight["ID"])
}
render() {
al = this.props.flight["AL"]
flnb = this.props.flight["FLNB"]
pcb = this.props.flight["PCB"]
toCity = this.props.flight["To_City"]
fromCity = this.props.flight["From_City"]
reg = this.props.flight["Registration"]
time = this.props.flight["Time"]
color = this.props.flight["Color"]
id = this.props.flight["ID"]
rowColor = this.props.flight["ColorSelf"]
sciCount = this.props.flight["SelfCheckinCount"]
sum = this.props.flight["SumPassenger"]
sumC = this.props.flight["SumPassengerCheckedIN"]
percent = parseInt(sciCount * 100 / sumC)
mCode = this.props.flight["CountNationalID"]
var swipeoutBtns = [
{
onPress: () => this.props.showFirstPicker(this.props.flight["ID"]),
text: 'send email',
color: 'green',
fontFamily: 'iransans',
backgroundColor: 'white'
}
]
return (
(this.props.oneRow === "normal") ?
<Animated.View style={[this.anim.getLayout(),{marginLeft:10,flexDirection:"row"}]}>
<TouchableOpacity style={{flexDirection: 'row',width:"100%"}}
onPress={() => this.itemPressed()}
// onPress={() => this.seatMapPressed()}
>
<Card style={flightStyles.card}>
<View style={flightStyles.cardView}>
<View style={[flightStyles.imageHolderView, {width: "10%"}]}>
<Image source={imgs[al]}
style={[flightStyles.image, {width: 30, height: 30}]}/> :
<Text style={flightStyles.texts}>{fromCity}</Text>}
</View>
<View style={flightStyles.viewInCard} borderRadius={10} width="87%">
<View style={flightStyles.infoHolder} width="10%">
<Text style={flightStyles.texts}>{toCity}</Text>
</View>
<View style={flightStyles.infoHolder} width="17%">
<Text style={flightStyles.texts}>{al}{flnb}</Text>
</View>
<View alignItems="center" backgroundColor={"#" + color} width="25%" heigh={40}>
<Text style={flightStyles.texts}>{pcb}</Text>
</View>
<View style={flightStyles.infoHolder} width="24%">
<Text style={flightStyles.texts}>{reg}</Text>
</View>
<View style={flightStyles.infoHolder} width="13%">
<Text style={flightStyles.texts}>{time}</Text>
</View>
</View>
</View>
</Card>
</TouchableOpacity>
<TouchableOpacity style={{marginLeft: 20, alignItems: 'center', justifyContent: 'center'}}
onPress={() => this.emailPressed()}><Text
style={{color: 'green'}}>Email</Text></TouchableOpacity>
<TouchableOpacity style={{marginLeft: 20, alignItems: 'center', justifyContent: 'center'}}
onPress={() => this.messagePressed()}><Text
style={{color: 'green'}}>Message</Text></TouchableOpacity>
<TouchableOpacity style={{marginLeft: 20, alignItems: 'center', justifyContent: 'center'}}
onPress={() => this.seatMapPressed()}>
<Text style={{color: 'green'}}>Seat Map</Text>
</TouchableOpacity>
)
}
} экспортировать полет по умолчанию
проблема для обеих платформ и только для первого использования, если мы просмотрим весь список, прежде чем щелкнуть по какой-либо строке, задержки не будет, я думаю, проблема в списках