1.3.2 • Published 4 years ago

react-native-picker-modal-view v1.3.2

Weekly downloads
892
License
MIT
Repository
github
Last release
4 years ago

Maintainability Test Coverage npm version npm downloads per month dependencies Status dev-dependencies Status Build Status

An alternative to Picker and PickerIOS components with an unified API and consistent look & feel on both plaforms. It's fully configurable and includes built-in support for text search and alphabetical index. Ideal for longer lists not suitable for "wheel-pickers".

Getting started

$ npm install react-native-picker-modal-view --save

or

$ yarn add react-native-picker-modal-view

Live Demo with Expo

Explore with Expo Snack

Example

import * as React from 'react';
import { Button, SafeAreaView, Text, View } from 'react-native';

import PickerModal from 'react-native-picker-modal-view';

import data from '../../../top20.json';

export default class Main extends React.Component<{}, { selectedItem: {} }> {

	constructor(props: {}) {
		super(props);

		this.state = {
			selectedItem: {}
		};
	}

	public render(): JSX.Element {
		const { selectedItem } = this.state;

		return (
			<SafeAreaView style={{ flex: 1, justifyContent: 'center', marginHorizontal: 20 }}>
				<PickerModal
					renderSelectView={(disabled, selected, showModal) =>
						<Button disabled={disabled} title={'Show me!'} onPress={showModal} />
					}
					onSelected={this.onSelected.bind(this)}
					onClosed={this.onClosed.bind(this)}
					onBackButtonPressed={this.onBackButtonPressed.bind(this)}
					items={data}
					sortingLanguage={'tr'}
					showToTopButton={true}
					selected={selectedItem}
					showAlphabeticalIndex={true}
					autoGenerateAlphabeticalIndex={true}
					selectPlaceholderText={'Choose one...'}
					onEndReached={() => console.log('list ended...')}
					searchPlaceholderText={'Search...'}
					requireSelection={false}
					autoSort={false}
				/>
				<View style={{ padding: 10, alignItems: 'center', backgroundColor: '#ddd' }}>
					<Text>Chosen: </Text>
					<Text>{JSON.stringify(selectedItem)}</Text>
				</View>
			</SafeAreaView>
		);
	}

	private onClosed(): void {
		console.log('close key pressed');
	}

	private onSelected(selected: any): void {
		this.setState({ selectedItem: selected });

		return selected;
	}

	private onBackButtonPressed(): void {
		console.log('back key pressed');
	}
}

Options

PropertiesTypeDescriptionDefault
modalAnimationTypestringThe RN Modal show/hide animation type"slide"
showAlphabeticalIndexbooleanHides alphabetical index"true"
onClosedFunctionFired when the modal is closed
onBackButtonPressedFunctionFired when the back key is pressed
onSelected *requiredFunctionReturns selected item object"{Id, Name, Value, [key: string]: any}"
items *requiredarrayArray of list items"[{Id, Name, Value, [key: string]: any}]"
renderSelectViewElementRender Select Component<SelectBoxComponent (built-in)>
renderListItemElementRender List item<ListItemComponent (built-in)/>
alphabeticalIndexCharsarrayChracters array for the alphabetical index<Turkish alphabet chracters>
searchInputTextColorstringSearch input placeholder text color"#252525"
keyExtractorFunctionFlatlist defined {key} function<Predefined return map index>
autoGenerateAlphabeticalIndexbooleanAuto-generates alphabetical index from list items data"false"
sortingLanguagestringCountry ISO (Alpha 2) Code for localeCompare"tr"
showToTopButtonbooleanButton for scroll to offset 0"true"
onEndReachedFunctionFired when the list reaches the end
selectPlaceholderTextstringSelect box placeholder text"Choose one..."
searchPlaceholderTextstringSearch input placeholder text"Search..."
selectedobjectDefault selected item
autoSortbooleanAuto-sort data list"false"
disabledbooleanDisable Select box
requireSelectionbooleanRequire at least one list item is selected"false"
backButtonDisabledbooleanHide to back button"false"
renderSearchFunctionRender custom search input

Core Props of React Native

PropertiesTypeDescriptionDefault
ModalPropsobjectReact Native Modal Props
FlatListPropsobjectReact Native Flatlist Props
SearchInputPropsobjectReact Native TextInput Props

Running example project

  1. You should have React Expo CLI to be installed in order to run example. Follow this instructions if you need to install Expo CLI.
  1. Install the dependencies:
npm install
  1. Once the installation is done, you can run the following command:

    npm

    npm start

    You can also use:

    expo

    expo start

    yarn

    expo start

Notes

  • Auto-alphabetical index supported for Turkish and English languages.

Releases

  • 1.3.2 - Added renderSearch feature #54 Thanks to @murilo-campaner
  • 1.3.1 - Fixed #44 Thanks to @fnando
  • 1.3.0 - No back button support #42 Thanks to @ChildishForces
  • 1.2.8 - Fixed #37
  • 1.2.6 - Deprecated lifecycle methods fix
  • 1.2.5 - Flatlist initialNumToRender property hotfix
  • 1.2.3 - Refactor and code coverage
  • 1.2.2 - Fixed #5
  • 1.2.0 - Added renderSelectView and renderListItem properties.
  • 1.0.0 - Initial release
1.3.2

4 years ago

1.3.1

4 years ago

1.3.0

4 years ago

1.2.8

5 years ago

1.2.7

5 years ago

1.2.6

5 years ago

1.2.5

5 years ago

1.2.4

5 years ago

1.2.3

5 years ago

1.2.2

5 years ago

1.2.0

5 years ago

1.1.2

5 years ago

1.1.1

5 years ago

1.1.0

5 years ago

1.0.0

5 years ago