BAPickerAndroid.js 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import React, { Component } from 'react';
  2. import {
  3. Platform,
  4. requireNativeComponent,
  5. View,
  6. ViewPropTypes
  7. } from 'react-native';
  8. import PropTypes from 'prop-types';
  9. let iface = {
  10. name: 'PickerView',
  11. propTypes: {
  12. ...ViewPropTypes,
  13. data: PropTypes.array,
  14. selectedIndex: PropTypes.number,
  15. onValueChange: PropTypes.func,
  16. itemStyle: PropTypes.object
  17. }
  18. }
  19. let Picker = Platform.OS == 'ios' ? View : requireNativeComponent('AndroidPicker', iface);
  20. export default class BAPickerAndroid extends Component {
  21. static propTypes = {
  22. ...ViewPropTypes,
  23. data: PropTypes.array,
  24. selectedIndex: PropTypes.number,
  25. onValueChange: PropTypes.func,
  26. itemStyle: PropTypes.object
  27. }
  28. render() {
  29. data = {
  30. list: this.props.data,
  31. selectedIndex: this.props.selectedIndex
  32. }
  33. return (
  34. <Picker
  35. {...this.props}
  36. dataAndSelectedIndex={data}
  37. onValueChange={(e) => this._onValueChange(e)}
  38. />
  39. );
  40. }
  41. _onValueChange(event) {
  42. if (!this.props.onValueChange)
  43. return;
  44. this.props.onValueChange(event.nativeEvent);
  45. }
  46. }