List or Grid style item(s) picker for React Native

React Native Item Select

Sometimes selecting items from dropdowns or checkboxes just don't cut it. You may need a fancy grid item picker. May be this highly customizable List Grid item(s) picker for React Native is what you're looking for.

Installation

npm install --save react-native-item-select

Features :tada:

  • List or Grid. If Grid, customizable no of items per row.
  • Multiselect supported.
  • Validation for minimum & maximum no of items to be selected.
  • Fine-grained style control.
  • Preselect items.
  • Provision to implement search.

Demo

You can see the code for the GIF files given above at this repo.

Example

import React, {Component} from 'react';
import { Text, View } from 'react-native';
import ReactNativeItemSelect from 'react-native-item-select';

class LanguageSelectionScreen extends Component {
  render() {
    const textStyle = { textAlign: 'center', color: '#696969', fontWeight: 'bold' };
    const data = [
      { firstLetter: 'அ', displayName: 'தமிழ்', name: 'Tamil' },
      { firstLetter: 'A', displayName: 'English', name: 'English' },
      ...
    ];

    return (
      <ReactNativeItemSelect
        data={data}
        itemComponent={
          item => (
            <View>
                <Text style={{ ...textStyle, fontSize: 35 }}>{item.firstLetter}</Text>
                <Text style={textStyle}>{item.displayName}</Text>
            </View>
          )
        }
        onSubmit={item => navigate('Result')}
      />
    );
  }
}

Props

We can divide props into two types. One is mandatory other one is optional. Without optional props, this library will work properly with its default values. However, you've to pass all required props.

Required Props

Name Type Description
data Array Array of items you pass to itemComponent callback.
itemComponent Function Takes 2 parameters and returns a React element. Two paramerts, (item, selected). item: data prop item, selected: boolean that suggests whether the item is selected. selected boolean is useful when you want to alter the content if it is selected.
onSubmit Function Callback function that consumes selected item(s).

Optional Props

Name Type Default Description
multiselect Boolean false Pass this to enable multiselect
countPerRow Number 2 No of items to display per row, pass 1 for list view
floatSubmitBtn Boolean false When the number of items increase, you may want to float the submit button at the botton of the screen. Pass this prop to do so.
lastRowMargin Number 50 This only takes effect when you float submit button. Most often floating button will hinder the view of last row. This is to avoid it.
submitBtnTitle String Submit Change submit button title
minSelectCount Number 1 Valid only when multiselect is enabled. Minimum number of items to be selected to enable submit button.
maxSelectCount Number null Valid only when multiselect is enabled. To set max limit on the number of items selected. Displays an alert when user tries to select more items.
maxSelectAlertTxt String Check description To change the alert text. Default: You can't select more than N items.
tickStyle String Check description Valid params: check, overlayCheck. For single select check is default. overlayCheck is default for multiselect
tickPosition String Check description Default values: single select - topRight, multiselect - middle. However, you can override the default by passing custom value. Valid params: topLeft, topRight, topMiddle, bottomLeft, bottomRight, bottomMiddle, middle, leftMiddle, rightMiddle
submitBtnWidth Number 100 This number represents percentage width. So, to set the width to 50% just pass 50.
tickTxt String Pass some string to change the tick string rendered.
extraItemHighlighProps Object {} This is to alter existing prop value or to add new values to the TouchableHighlight component that encloses your itemComponent.
extraBtnOpacityProps Object {} Use this to pass props to TouchableOpacity that encloses the submit button.
styles Object {} For custom styling you can use this prop. Refer styling section.
searchKey String null If you want to implement search, you've to pass this prop. Check search implementation section.

Preselect Items

In some cases, you may want to preselect items when ReactNativeItemSelect renders. That can be achieved by setting selected property of the items in data array. In the following example, Apple & Orange are preselected.

Example

<ReactNativeItemSelect
    data={[
      { name: 'Apple', selected: true},
      { name: 'Banana' },
      { name: 'Orange', selected: true}
    ]}
    itemComponent={this.itemComponent}
    onSubmit={this.onSubmit}
/>

Styling

You can alter the styles of any component of this library by passing appropriate prop. For now you can use 11 keys in styles prop to customize the look. They are, btn, btnOpacity, btnTxt, disabledBtnOpacity, disabledBtn, disabledBtnTxt, itemBoxHighlight, activeItemBoxHighlight, tickTxt, itemComponentWrapper, rowWrapper

Example

In the following component, styles prop will change the color of submit button, tick background and selected items border color to material blue.

<ReactNativeItemSelect
    data={data}
    itemComponent={this.itemComponent}
    onSubmit={this.onSubmit}
    styles={
        {
            btn: { backgroundColor: '#2196F3' },
            disabledBtn: { backgroundColor: '#2196F3' },
            tickTxt: { backgroundColor: '#2196F3' },
            activeItemBoxHighlight: { borderColor: '#2196F3' },
        }
    }
/>

btn, disabledBtn

For the Button View. You can use any of the View style props. Use disabledBtn key to style the button when it is in disabled state and use btn for enabled button.

btnOpacity, disabledBtnOpacity

For the TouchableOpacity that encloses the button view. You can use any View style props.

btnTxt, disabledBtnTxt

Use this to style the text inside submit button. Refer Text style props.

itemBoxHighlight, activeItemBoxHighlight

You can use this to style the TouchableHighlight which wraps your item component. All border styling must go here. You can use any View style props here.

itemComponentWrapper

This is a View that wraps your item component. Wrapping order is like this TouchableHighlight > View > itemComponent. You can use this to get rid of the padding inside box. Refer View style props.

tickTxt

You can use this to alter the View the encloses your tick character. Tick color is changed here. Refer Text style props.

rowWrapper

Used to alter the style of the View that wraps the items in a row. Refer View style props.

Search Implementation

To make ReactNativeItemSelect more customizable, styling & implementation of text box for search has to be implemented by the user. You can easily implement search by making use of the state of the parent component. You need to pass searchKey prop to make search work. Just make sure the value of the searchKey is unique for all items. For your better understanding, search has already been implemented in the customized example of demo app - source code.

NOTE: Search implementation is not part of the GIF shown above. Search feature was added after the creation of demo GIF.

GitHub