UNPKG

@uiw/react-native

Version:
223 lines (188 loc) 23.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _reactNative = require("react-native"); var _react = _interopRequireWildcard(require("react")); var _picker = require("@react-native-picker/picker"); var _arrayTreeFilter = _interopRequireDefault(require("../utils/arrayTreeFilter")); var _Modal = _interopRequireDefault(require("../Modal")); var _utils = require("../utils"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } class SelectCascader extends _react.Component { constructor(...args) { super(...args); this.state = { value: this.getValue(this.props.data, this.props.defaultValue || this.props.value), modalVisible: this.props.visible }; this.outerCtrl = () => { this.setState({ modalVisible: !this.state.modalVisible }); }; this.onValueChange = (itemValue, index) => { const value = this.state.value.concat(); value[index] = itemValue; const children = (0, _arrayTreeFilter.default)(this.props.data, (c, level) => { return level <= index && c.value === value[level]; }); let data = children[index]; let i; for (i = index + 1; data && data.children && data.children.length && i < this.props.cols; i++) { data = data.children[0]; value[i] = data.value; } value.length = i; value[index] = itemValue; this.setState({ value }); if (this.props.onChange) { this.props.onChange(value, this.getSel(value)); } }; this.getCols = () => { const { data, cols, pickerItemStyle } = this.props; const { value } = this.state; const childrenTree = (0, _arrayTreeFilter.default)(data, (c, level) => { return c.value === value[level]; }).map(c => c.children); const needPad = cols - childrenTree.length; if (needPad > 0) { for (let i = 0; i < needPad; i++) { childrenTree.push([]); } } childrenTree.length = cols - 1; childrenTree.unshift(data); return childrenTree.map((children = [], level) => <_picker.Picker key={level} // eslint-disable-next-line react-native/no-inline-styles style={{ flex: 1 }} selectedValue={value[level]} onValueChange={itemValue => this.onValueChange(itemValue, level)} itemStyle={pickerItemStyle}> {children.map(item => <_picker.Picker.Item value={item.value} label={item.label} key={item.value} />)} </_picker.Picker>); }; this.onDismiss = () => { if (this.props.onDismiss) { this.props.onDismiss(); } }; this.onOk = () => { if (this.props.onOk) { const { value } = this.state; this.props.onOk(value, this.getSel(value)); } }; } componentWillReceiveProps(nextProps) { if ('value' in nextProps) { this.setState({ value: this.getValue(nextProps.data, nextProps.value) }); } if ('visible' in nextProps) { this.setState({ modalVisible: nextProps.visible }); } } getSel(value) { if (!value) { return ''; } const treeChildren = (0, _arrayTreeFilter.default)(this.props.data, (c, level) => { return c.value === value[level]; }); return treeChildren.map(v => { return v.label; }).join(','); } getValue(d, val) { let data = d || this.props.data; let value = val || this.props.value || this.props.defaultValue; if (!value || !value.length || value.indexOf(undefined) > -1) { value = []; for (let i = 0; i < this.props.cols; i++) { if (data && data.length) { value[i] = data[0].value; if (data[0].children) { data = data[0].children; } } } } return value; } render() { const { title, dismissText, okText, onDismiss, headerStyle } = this.props; const cols = this.getCols(); return <_Modal.default visible={this.state.modalVisible} onClosed={() => { this.setState({ modalVisible: false }); }}> <> <_reactNative.View style={[styles.header, headerStyle]}> <_reactNative.TouchableHighlight onPress={onDismiss} style={[styles.headerItem]}> <_reactNative.Text>{dismissText}</_reactNative.Text> </_reactNative.TouchableHighlight> <_reactNative.View style={[styles.headerItem]}> <_reactNative.Text>{title}</_reactNative.Text> </_reactNative.View> <_reactNative.TouchableHighlight onPress={this.onOk} style={[styles.headerItem]}> <_reactNative.Text>{okText}</_reactNative.Text> </_reactNative.TouchableHighlight> </_reactNative.View> <_reactNative.View style={styles.list}>{cols}</_reactNative.View> </> </_Modal.default>; } } exports.default = SelectCascader; SelectCascader.defaultProps = { dismissText: '取消', okText: '确定', title: '请选择', disabled: false, cols: 3 }; const styles = _reactNative.StyleSheet.create({ header: { height: 44, alignItems: 'center', flexDirection: 'row', justifyContent: 'center', borderBottomWidth: 1, borderBottomColor: _utils.colors.blue }, headerItem: { height: 44, alignItems: 'center', justifyContent: 'center', flex: 1 }, list: { flexDirection: 'row', alignItems: 'center' } }); module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SelectCascader/index.tsx"],"names":["SelectCascader","Component","state","value","getValue","props","data","defaultValue","modalVisible","visible","outerCtrl","setState","onValueChange","itemValue","index","concat","children","c","level","i","length","cols","onChange","getSel","getCols","pickerItemStyle","childrenTree","map","needPad","push","unshift","flex","item","label","onDismiss","onOk","componentWillReceiveProps","nextProps","treeChildren","v","join","d","val","indexOf","undefined","render","title","dismissText","okText","headerStyle","styles","header","headerItem","list","defaultProps","disabled","StyleSheet","create","height","alignItems","flexDirection","justifyContent","borderBottomWidth","borderBottomColor","colors","blue"],"mappings":"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","sourcesContent":["import { View, Text, StyleSheet, TouchableHighlight, StyleProp, TextStyle, ViewStyle } from 'react-native';\nimport React, { Component } from 'react';\nimport { Picker } from '@react-native-picker/picker';\nimport arrayTreeFilter from '../utils/arrayTreeFilter';\nimport Modal from '../Modal';\nimport { colors } from '../utils';\n\nexport declare type CascaderOneValue = string | number | undefined;\nexport declare type CascaderValue = CascaderOneValue[];\n\nexport interface ICascaderDataItem {\n  label: React.ReactNode;\n  value: CascaderOneValue;\n  children?: ICascaderDataItem[];\n}\n\nexport interface ISelectCascaderProps {\n  onDismiss?: () => void;\n  title?: string;\n  dismissText?: string;\n  okText?: string;\n  value?: CascaderValue;\n  onChange?: (value: CascaderValue, label: string) => void;\n  visible: boolean;\n  onVisibleChange?: () => {};\n  data: ICascaderDataItem[];\n  defaultValue?: CascaderValue | undefined;\n  onOk?: (value: CascaderValue, label: string) => void;\n  disabled?: boolean;\n  cols?: number;\n  pickerItemStyle?: StyleProp<TextStyle>;\n  headerStyle?: StyleProp<ViewStyle>;\n}\n\nexport interface Istate {\n  modalVisible: boolean;\n  value: CascaderValue;\n}\n\nexport default class SelectCascader extends Component<ISelectCascaderProps, Istate> {\n  static defaultProps = {\n    dismissText: '取消',\n    okText: '确定',\n    title: '请选择',\n    disabled: false,\n    cols: 3,\n  };\n  state = {\n    value: this.getValue(this.props.data, this.props.defaultValue || this.props.value),\n    modalVisible: this.props.visible,\n  };\n\n  outerCtrl = () => {\n    this.setState({\n      modalVisible: !this.state.modalVisible,\n    });\n  };\n\n  componentWillReceiveProps(nextProps: ISelectCascaderProps) {\n    if ('value' in nextProps) {\n      this.setState({\n        value: this.getValue(nextProps.data, nextProps.value),\n      });\n    }\n    if ('visible' in nextProps) {\n      this.setState({\n        modalVisible: nextProps.visible,\n      });\n    }\n  }\n\n  getSel(value: CascaderValue) {\n    if (!value) {\n      return '';\n    }\n    const treeChildren = arrayTreeFilter(this.props.data, (c, level) => {\n      return c.value === value[level];\n    });\n    return treeChildren\n      .map((v) => {\n        return v.label;\n      })\n      .join(',');\n  }\n\n  onValueChange = (itemValue: CascaderOneValue, index: number) => {\n    const value = this.state.value.concat();\n    value[index] = itemValue;\n    const children = arrayTreeFilter(this.props.data, (c, level) => {\n      return level <= index && c.value === value[level];\n    });\n    let data = children[index];\n    let i;\n    for (i = index + 1; data && data.children && data.children.length && i < this.props.cols!; i++) {\n      data = data.children[0];\n\n      value[i] = data.value;\n    }\n    value.length = i;\n    value[index] = itemValue;\n    this.setState({ value });\n    if (this.props.onChange) {\n      this.props.onChange(value, this.getSel(value));\n    }\n  };\n\n  getValue(d: ICascaderDataItem[], val: CascaderValue | undefined) {\n    let data = d || this.props.data;\n    let value = val || this.props.value || this.props.defaultValue;\n    if (!value || !value.length || value.indexOf(undefined) > -1) {\n      value = [];\n      for (let i = 0; i < this.props.cols!; i++) {\n        if (data && data.length) {\n          value[i] = data[0].value;\n          if (data[0].children) {\n            data = data[0].children;\n          }\n        }\n      }\n    }\n    return value;\n  }\n\n  getCols = () => {\n    const { data, cols, pickerItemStyle } = this.props;\n    const { value } = this.state;\n    const childrenTree = arrayTreeFilter(data, (c, level) => {\n      return c.value === value[level];\n    }).map((c) => c.children);\n    const needPad = cols! - childrenTree.length;\n    if (needPad > 0) {\n      for (let i = 0; i < needPad; i++) {\n        childrenTree.push([]);\n      }\n    }\n    childrenTree.length = cols! - 1;\n    childrenTree.unshift(data);\n    return childrenTree.map((children: any[] = [], level) => (\n      <Picker\n        key={level}\n        // eslint-disable-next-line react-native/no-inline-styles\n        style={{ flex: 1 }}\n        selectedValue={value[level]}\n        onValueChange={(itemValue) => this.onValueChange(itemValue, level)}\n        itemStyle={pickerItemStyle}\n      >\n        {children.map((item) => (\n          <Picker.Item value={item.value} label={item.label} key={item.value} />\n        ))}\n      </Picker>\n    ));\n  };\n\n  onDismiss = () => {\n    if (this.props.onDismiss) {\n      this.props.onDismiss();\n    }\n  };\n  onOk = () => {\n    if (this.props.onOk) {\n      const { value } = this.state;\n      this.props.onOk(value, this.getSel(value));\n    }\n  };\n\n  render() {\n    const { title, dismissText, okText, onDismiss, headerStyle } = this.props;\n    const cols = this.getCols();\n    return (\n      <Modal\n        visible={this.state.modalVisible}\n        onClosed={() => {\n          this.setState({ modalVisible: false });\n        }}\n      >\n        <>\n          <View style={[styles.header, headerStyle]}>\n            <TouchableHighlight onPress={onDismiss} style={[styles.headerItem]}>\n              <Text>{dismissText}</Text>\n            </TouchableHighlight>\n            <View style={[styles.headerItem]}>\n              <Text>{title}</Text>\n            </View>\n            <TouchableHighlight onPress={this.onOk} style={[styles.headerItem]}>\n              <Text>{okText}</Text>\n            </TouchableHighlight>\n          </View>\n          <View style={styles.list}>{cols}</View>\n        </>\n      </Modal>\n    );\n  }\n}\n\nconst styles = StyleSheet.create({\n  header: {\n    height: 44,\n    alignItems: 'center',\n    flexDirection: 'row',\n    justifyContent: 'center',\n    borderBottomWidth: 1,\n    borderBottomColor: colors.blue,\n  },\n  headerItem: {\n    height: 44,\n    alignItems: 'center',\n    justifyContent: 'center',\n    flex: 1,\n  },\n  list: {\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n});\n"]}