0.0.5 • Published 6 years ago

react-native-list-picker v0.0.5

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

react-native-list-picker

The data Picker for React Native.

page 1page 2
npm.ionpm.io

Installation

$ npm i react-native-list-picker --save

Example

import React, { Component } from 'react';
import {
  StyleSheet,
  Text,
  View,
  StatusBar,
  PixelRatio,
  TouchableOpacity,
  Platform
} from 'react-native';
import ListPicker from 'react-native-list-picker';

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center'
  },
  welcome: {
    fontSize: 25,
    fontWeight: 'bold',
    textAlign: 'center',
    margin: 10,
    marginBottom: 25,
  },
  instructions: {
    fontSize: 20,
    textAlign: 'center',
    color: '#888',
    marginBottom: 7
  },
  link: {
    fontSize: 14,
    textAlign: 'center',
    color: '#888',
    textDecorationLine: 'underline'
  },
  data: {
    padding: 15,
    marginTop: 10,
    backgroundColor: '#ddd',
    borderColor: '#888',
    borderWidth: 1 / PixelRatio.get(),
    color: '#777'
  }
});

let dataList =  require('./data/dataList');
export default class Example extends Component {
  constructor(props){
    StatusBar.setHidden(true);
    super(props);
      this.state = {
        pickData:null
      }
  }

  render() {
    return (
      <View style={styles.container}>
        <Text style={styles.welcome}>
          Welcome to Picker!
        </Text>
        <ListPicker
          ref={(picker) => { this.picker = picker; }}
          onChange={(value)=> this.setState({pickData: value})}
          closeable = {true}
          isEmojiable = {false}
          dataList={dataList}
        />
        <TouchableOpacity onPress={()=> this.picker.openModal()}>
          <Text style={styles.link}>
             click here
          </Text>
        </TouchableOpacity>
        {this.state.pickData &&
          <Text style={styles.data}>
            {JSON.stringify(this.state.pickData, null, 2)}
          </Text>
        }
      </View>
    );
  }
}

Props

KeyTypeDefaultDescription
onChangefunction*requiredThe handler when a country is selected
closeableboolfalseIf true, the ListPicker will have a close button
isEmojiableboolfalseIf true, use emoji to render icon
dataListarray*required{"letter":"","icon":"","name":""}

dataList

[ {
    "letter": "AFN",
    "icon": "",
    "name": "阿富汗"
  }]

Dependencies

  • lodash
  • react-native-emoji
  • world-countries

Contribution

Questions

Feel free to contact me or create an issue

made with ♥