Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hyochan/reanimated-masonry-list
Masonry List with Reanimated2 component
https://github.com/hyochan/reanimated-masonry-list
flatlist masonry masonry-layout react-native reanimated reanimated2
Last synced: 4 days ago
JSON representation
Masonry List with Reanimated2 component
- Host: GitHub
- URL: https://github.com/hyochan/reanimated-masonry-list
- Owner: hyochan
- License: mit
- Created: 2022-04-02T13:02:33.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2022-10-10T06:04:43.000Z (about 2 years ago)
- Last Synced: 2024-12-20T16:06:50.765Z (13 days ago)
- Topics: flatlist, masonry, masonry-layout, react-native, reanimated, reanimated2
- Language: TypeScript
- Homepage:
- Size: 561 KB
- Stars: 55
- Watchers: 2
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# reanimated-masonry-list
> Pinterest like ScrollView made in [React Native](https://reactnative.dev) and [Reanmated v2](https://github.com/software-mansion/react-native-reanimated). It just behaves like the [FlatList](https://reactnative.dev/docs/next/flatlist) so it is easy to use. The package has been inherited by [hyochan/react-native-masonry-list](https://github.com/hyochan/react-native-masonry-list) by the issue opened in [hyochan/react-native-masonry-list/issues/14](https://github.com/hyochan/react-native-masonry-list/issues/14).
[![Npm Version](http://img.shields.io/npm/v/reanimated-masonry-list.svg?style=flat-square)](https://npmjs.org/package/reanimated-masonry-list)
[![Downloads](http://img.shields.io/npm/dm/reanimated-masonry-list.svg?style=flat-square)](https://npmjs.org/package/reanimated-masonry-list)
[![CI](https://github.com/hyochan/reanimated-masonry-list/actions/workflows/ci.yml/badge.svg)](https://github.com/hyochan/reanimated-masonry-list/actions/workflows/ci.yml)
[![codecov](https://codecov.io/gh/hyochan/reanimated-masonry-list/branch/main/graph/badge.svg?token=iKCSatGN6S)](https://codecov.io/gh/hyochan/reanimated-masonry-list)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square)](https://github.com/prettier/prettier)
[![LICENSE](http://img.shields.io/npm/l/reanimated-masonry-list.svg?style=flat-square)](https://npmjs.org/package/reanimated-masonry-list)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](CONTRIBUTING.md)
[![supports iOS](https://img.shields.io/badge/iOS-4630EB.svg?style=flat-square&logo=APPLE&labelColor=999999&logoColor=fff)](https://itunes.apple.com/app/apple-store/id982107779)
[![supports Android](https://img.shields.io/badge/Android-4630EB.svg?style=flat-square&logo=ANDROID&labelColor=A4C639&logoColor=fff)](https://play.google.com/store/apps/details?id=host.exp.exponent&referrer=www)
[![supports web](https://img.shields.io/badge/web-4630EB.svg?style=flat-square&logo=GOOGLE-CHROME&labelColor=4285F4&logoColor=fff)](https://docs.expo.io/workflow/web/)
[![runs with expo](https://img.shields.io/badge/Runs%20with%20Expo-000.svg?style=flat&logo=EXPO&labelColor=ffffff&logoColor=000)](https://github.com/expo/expo)## Installation
```
yarn add reanimated-masonry-list react-native-gesture-handler react-native-reanimated
``````tsx
import MasonryList from 'reanimated-masonry-list';
```## Preview
| 2-columns | 3-columns | 4-columns |
|------------|:-----------:|:-----------:|
||||> You can use as many columns as you want. It is flexible!
## YouTube
[See how to use it](https://www.youtube.com/watch?v=QxSKAcKKW_Q)
## Blog
[How it is made](https://dooboolab.medium.com/reanimated-masonry-list-a5365647f2c1)## Description
Current `MasonryList` extends [ScrollView](https://reactnative.dev/docs/next/scrollview) and can pass down its props. Indeed, this looks similar to [FlatList](https://reactnative.dev/docs/next/flatlist) to provide good developer experience. Look how this is used and compare to the `FlatList`.
The `FlatList` won't offer you to draw `MansonryList` because when you provide [numColumns](https://reactnative.dev/docs/next/flatlist#numcolumns) bigger than `1`, the native view will switch to `FlatList` to `GridView` which will render its children with identical height only.
Our `MasonryList` view component is able to render all child views with all different sizes.
## Props
```tsx
innerRef?: MutableRefObject;
loading?: boolean;
refreshing?: RefreshControlProps['refreshing'];
onRefresh?: RefreshControlProps['onRefresh'];
onEndReached?: () => void;
onEndReachedThreshold?: number;
style?: StyleProp;
data: T[];
renderItem: ({item: T, i: number}) => ReactElement;
LoadingView?: React.ComponentType | React.ReactElement | null;
ListHeaderComponent?: React.ComponentType | React.ReactElement | null;
ListEmptyComponent?: React.ComponentType | React.ReactElement | null;
ListFooterComponent?: React.ComponentType | React.ReactElement | null;
numColumns?: number;
keyExtractor?: ((item: T | any, index: number) => string) | undefined;
```**`innerRef`** - Expose ScrollView instance with `ref`, example usage: `ref.current.scrollTo`.
**`loading`** - Currently in loading status.
**`refreshing`** - Currently in refreshing status.
**`onRefresh`** - Callback when `refresh` has been triggered.
**`onEndReached`** - Callback when end is reached just like the [onEndReached in FlatList](https://reactnative.dev/docs/flatlist#onendreached)
**`style`** - Style props for [ScrollView](https://reactnative.dev/docs/next/scrollview) which is the container view.
**`data`** - The array of the `data` for the view to render in `renderItem`
**`renderItem`** - Render custom view with the `data` passed down.
**`LoadingView`** - Custom loading view when the view is in `loading` status.
**`ListHeaderComponent`** - Header component
**`ListFooterComponent`** - Footer component
**`ListEmptyComponent`** - Component to render when the `data` is empty.
**`numColumns`** - Number of columns you want to render. `Default to 2`.
## Usage
```tsx
item.id}
numColumns={2}
showsVerticalScrollIndicator={false}
renderItem={({item}) => }
refreshing={isLoadingNext}
onRefresh={() => refetch({first: ITEM_CNT})}
onEndReachedThreshold={0.1}
onEndReached={() => loadNext(ITEM_CNT)}
/>
```## Run Example
1. Clone the repository.```
git clone https://github.com/hyochan/reanimated-masonry-list.git
```
2. Navigate to example project```
cd RNMasonryExample
```3. Install packages and run it as you do in `react-native` project.
## LICENSE
MIT