React Native Masonry component with Infinite Scrolling. For a fully working example check this repo. Also detailed explanations are presented in this medium post
$ npm install react-native-infinite-masonry --save
or with yarn:
$ yarn add react-native-infinite-masonry
For a fully working example check this repo. Also a detailed explanation is presented in this medium post
import Masonry from 'react-native-infinite-masonry';
...
export default function App() {
return (
<SafeAreaView style={styles.container}>
<Masonry
itemsProvider={dataItemProvider}
renderItem={Item}
pageSize={10}
/>
</SafeAreaView>
);
}
Two properties has to be set for this component to work properly, namely: itemsProvider and renderItem. The former is a function that returns data information used by the later to render items inside masonry. Find below an example for those properties.
function Item(dataItem, key){
return (
<View
key={key}
style={{
...styles.card,
height: dataItem.height
}}
>
<Image
style={styles.img}
source={{uri: dataItem.image_url}}
/>
</View>
);
}
function dataItemProvider(pageSize=10){
return [...Array(pageSize).keys()].map((i) => {
return {
image_url: `https://i.picsum.photos/id/${parseInt(Math.random() * 200)}/300/400.jpg`,
height: parseInt(Math.max(0.3, Math.random()) * vpWidth),
key:i
};
});
}