2021-05-26 17:24:54 +00:00
|
|
|
import React from 'react';
|
|
|
|
import { FlatList, StyleSheet } from 'react-native';
|
|
|
|
import Animated from 'react-native-reanimated';
|
|
|
|
|
|
|
|
import { isIOS } from '../../../utils/deviceInfo';
|
|
|
|
import scrollPersistTaps from '../../../utils/scrollPersistTaps';
|
|
|
|
|
|
|
|
const AnimatedFlatList = Animated.createAnimatedComponent(FlatList);
|
|
|
|
|
|
|
|
const styles = StyleSheet.create({
|
|
|
|
list: {
|
|
|
|
flex: 1
|
|
|
|
},
|
|
|
|
contentContainer: {
|
|
|
|
paddingTop: 10
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-12-02 22:11:16 +00:00
|
|
|
interface IRoomListProps {
|
|
|
|
listRef: any;
|
2021-12-03 13:06:25 +00:00
|
|
|
onScroll?: any;
|
|
|
|
scrollEventThrottle?: number;
|
|
|
|
data?: any;
|
|
|
|
renderItem?: Function;
|
|
|
|
onEndReached?: Function;
|
|
|
|
ListFooterComponent?: Function;
|
|
|
|
onScrollToIndexFailed?: Function;
|
|
|
|
onViewableItemsChanged?: Function;
|
|
|
|
viewabilityConfig?: any;
|
|
|
|
refreshControl?: any;
|
2021-12-02 22:11:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const List = ({ listRef, ...props }: IRoomListProps) => (
|
|
|
|
// @ts-ignore
|
2021-05-26 17:24:54 +00:00
|
|
|
<AnimatedFlatList
|
|
|
|
testID='room-view-messages'
|
|
|
|
ref={listRef}
|
2021-12-02 22:11:16 +00:00
|
|
|
keyExtractor={(item: any) => item.id}
|
2021-05-26 17:24:54 +00:00
|
|
|
contentContainerStyle={styles.contentContainer}
|
|
|
|
style={styles.list}
|
|
|
|
inverted
|
|
|
|
removeClippedSubviews={isIOS}
|
|
|
|
initialNumToRender={7}
|
|
|
|
onEndReachedThreshold={0.5}
|
|
|
|
maxToRenderPerBatch={5}
|
|
|
|
windowSize={10}
|
|
|
|
{...props}
|
|
|
|
{...scrollPersistTaps}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
|
|
|
|
export default List;
|