Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/robcalcroft/react-native-multiselect
:ballot_box_with_check: A simple RN component that allows row selection
https://github.com/robcalcroft/react-native-multiselect
multiselect react-native
Last synced: 2 months ago
JSON representation
:ballot_box_with_check: A simple RN component that allows row selection
- Host: GitHub
- URL: https://github.com/robcalcroft/react-native-multiselect
- Owner: robcalcroft
- License: mit
- Created: 2016-12-21T23:27:01.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2023-04-17T19:00:39.000Z (almost 2 years ago)
- Last Synced: 2024-10-29T13:49:53.520Z (3 months ago)
- Topics: multiselect, react-native
- Language: JavaScript
- Homepage:
- Size: 98.6 KB
- Stars: 19
- Watchers: 2
- Forks: 5
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-reactnative-ui - react-native-multiselect
- awesome-react-native-ui - react-native-multiselect ★6 - A simple multi select component with events and a flexible API. (Components / UI)
- awesome-react-native - react-native-multiselect ★15 - A simple multi select component with events and a flexible API. (Components / UI)
- awesome-reactnative-ui - react-native-multiselect
README
# react-native-multiselect
> A simple RN component that allows row selection## Install
`yarn add react-native-multiselect` or `npm install react-native-multiselect --save`### 3.0.0
`3.0.0` swaps out `ListView` for `FlatList` or `SectionList`. This gives a huge performance increase for larger lists. This is a **breaking change** so you might need to modify your implementation of `react-native-multiselect` for this to work. Don't worry though, its not a massive change.### 2.0.0
**If you used `<2.0.0` the `renderRow` API has changed and you'll need to do a small rewrite**`2.0.0` brings some major performance enhancements and removes the dependancy on `react-native-vector-icons`, you are now just given an `isSelected` parameter which you can use to style the `renderRow`. Thanks to [@indesignlatam](https://github.com/indesignlatam) for proposing a fix to performance issues with large datasets.
## API
### `options[]` `required`
An array of values for the list to display. Each item in the array should be an
object that looks like this:
```javascript
{
// A unique identifier for the row
key: Number || String
// The name displayed in the row
name: String
// This namespace can also be used to store custom props
...customProps
}
```### `renderRow` `(row, isSelected)` `required`
A function that renders each row. The current row object is passed to it to
allow dynamic rows. This is where you could use the `customProps` mentioned
above. You can use the `isSelected` parameter to decide how to style your row when its selected### `onSelectionChange` `(selectedRow, allSelectedRows)`
A callback that is fired when a row is clicked. It is passed the row that was
just selected as well as an array of all the currently selected rowStyle.### `selectedOptions[]`
An array of `keys` that match those in `options` that will be preselected on the
list.### `rowStyle{}`
A React Native style object, you can also pass StyleSheet styles to this; they
will be flattened.### `listProps{}`
An object of props that are given to the FlatList or SectionList, this for things like `ListHeaderComponent`### `activeOpacity` `Number`
Proxied to the TouchableHighlight component when you click the row### `underlayColor` `String`
Proxied to the TouchableHighlight component when you click the row### `useSections` `Boolean`
Use this to render a `SectionList` instead of a `FlatList`. Your `options` prop needs to looks like the one seen here: https://facebook.github.io/react-native/docs/sectionlist.html## Usage
```javascript
import MultiSelect from 'react-native-multiselect';const MyComponent = ({
// [{id: 1, name: 'Thing 1', data: [...]}, {id: 2, name: 'Thing 2', data: [...]} ...]
listOfThings,
// [0, 4]
preselectedThings,
// (selectedRows) => this.setState({ selectedRows })
updateListOfSelectedThings,
}) => (
Select some items from the list
({ key: thing.id, name: thing.name }) )}
renderRow={(row, isSelected) => {row.name} {isSelected ? 'I am selected' : 'I am not selected'}}
onSelectionChange={
(selectedRow, allSelectedRows) => updateListOfSelectedThings(allSelectedRows)
}
selectedOptions={[]}
rowStyle={{ backgroundColor: 'skyblue' }}
/>
);
```