react-native-uni-carousel
Version:
This small package is based on FlatList. It provides components to help create both a horizontal list of items and a paginated horizontal list of items.
61 lines (38 loc) • 1.52 kB
Markdown
is based on FlatList. It provides components to help create both a horizontal list of items and a paginated horizontal list of items.
Simple FlatList card with some helper methods
```
<CardList
// Same as item width
spaceBetweenCards={marginBetweenCards * 2}
// Same as item margin
unselectedCardsWidth={otherCardsWidth}
render={({ item, index }, { width }) => (
// render of each item
)}
cards={[{ name: 'item1' }, { name: 'item2' }]}
options={options}
/>
```
**spaceBetweenCards** - Margin between cards
**selectedIndex** - Item that is selected on the list
**onChangeSelected** - Callback called when the selectedItem changes
**unselectedCardsWidth** - Space from the next and previous card that is shown
**render(itemToRender, CardListContainerProps)** - Render callback of every single item
**cards** - The array of items to render
**options** - Object of props that get directly passed to `FlatList`
Just a wrapper around `CardList` that handles the pagination and provides some callbacks to track page changes
```
<PaginatedCardList
// Same props as CardList (they get passed down to CardList, except cards)
pages={pages}
onChangePage={onChangePage}
/>
```
**pages** - Object with keys as numbers (`{1: [page 1 array of items], 2: [page 2 array of items]}`
**onChangePage** - Callback that gets called on page change
This small package