UNPKG

@uiw/react-native

Version:
214 lines (184 loc) 22.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _reactNative = require("react-native"); var _Icon = _interopRequireDefault(require("../Icon")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const noop = () => {}; function normalizeValue(value) { if (typeof value === 'undefined' || value === null) { return ''; } return value; } class Input extends _react.default.Component { constructor(...args) { super(...args); this.inputRef = void 0; this.onChange = text => { const { onChange, type } = this.props; const maxLength = this.props.maxLength; switch (type) { case 'bankCard': text = text.replace(/\D/g, ''); if (maxLength > 0) { text = text.substring(0, maxLength); } text = text.replace(/\D/g, '').replace(/(....)(?=.)/g, '$1 '); break; case 'phone': text = text.replace(/\D/g, '').substring(0, 11); const valueLen = text.length; if (valueLen > 3 && valueLen < 8) { text = `${text.substr(0, 3)} ${text.substr(3)}`; } else if (valueLen >= 8) { text = `${text.substr(0, 3)} ${text.substr(3, 4)} ${text.substr(7)}`; } break; case 'password': break; default: break; } if (onChange) { onChange(text); } }; this.onInputClear = () => { if (this.inputRef) { this.inputRef.clear(); } this.onChange(''); }; } render() { const android = _reactNative.Platform.OS === 'android'; const { type, editable, clear, // eslint-disable-next-line @typescript-eslint/no-unused-vars children, error, extra, // eslint-disable-next-line @typescript-eslint/no-unused-vars last, onExtraClick, onErrorClick, disabled, ...restProps } = this.props; const { value, defaultValue, style } = restProps; let valueProps; if ('value' in this.props) { valueProps = { value: normalizeValue(value) }; } else { valueProps = { defaultValue }; } const keyboardTypeArray = ['default', 'email-address', 'numeric', 'phone-pad', 'ascii-capable', 'numbers-and-punctuation', 'url', 'number-pad', 'name-phone-pad', 'decimal-pad', 'twitter', 'web-search']; let keyboardType = 'default'; if (type === 'number') { keyboardType = 'numeric'; } else if (type === 'bankCard') { keyboardType = 'number-pad'; // 不带小数点 } else if (type === 'phone') { keyboardType = 'phone-pad'; } else if (type && keyboardTypeArray.indexOf(type) > -1) { keyboardType = type; } const disabledStyle = disabled ? inputStyles.disabledStyle : {}; const extraStyle = { width: typeof extra === 'string' && extra.length > 0 ? extra.length * 17 : 0 }; return <_reactNative.View style={inputStyles.container}> <_reactNative.TextInput editable={!disabled && editable} clearButtonMode={clear ? 'while-editing' : 'never'} underlineColorAndroid="transparent" ref={el => this.inputRef = el} {...restProps} {...valueProps} style={[inputStyles.input, error ? inputStyles.inputErrorColor : null, disabledStyle, // 支持自定义样式 style]} keyboardType={keyboardType} onChange={event => this.onChange(event.nativeEvent.text)} secureTextEntry={type === 'password'} /> {editable && clear && value && android ? <_reactNative.TouchableOpacity style={[inputStyles.clear]} onPress={this.onInputClear} hitSlop={{ top: 5, left: 5, bottom: 5, right: 5 }}> <_Icon.default name="circle-close" color="#fff" /> </_reactNative.TouchableOpacity> : null} {extra ? <_reactNative.TouchableWithoutFeedback onPress={onExtraClick}> <_reactNative.View> {typeof extra === 'string' ? <_reactNative.Text style={[inputStyles.extra, extraStyle]}>{extra}</_reactNative.Text> : extra} </_reactNative.View> </_reactNative.TouchableWithoutFeedback> : null} {error && <_reactNative.TouchableWithoutFeedback onPress={onErrorClick}> <_reactNative.View style={[inputStyles.errorIcon]}> <_Icon.default name="circle-close" color="#dc3545" /> </_reactNative.View> </_reactNative.TouchableWithoutFeedback>} </_reactNative.View>; } } exports.default = Input; Input.defaultProps = { type: 'text', editable: true, clear: false, onChange: noop, onBlur: noop, onFocus: noop, extra: '', onExtraClick: noop, error: false, onErrorClick: noop, last: false }; const inputStyles = _reactNative.StyleSheet.create({ container: { height: 30, borderBottomWidth: 1, borderBottomColor: '#ccc', marginTop: 0, marginBottom: 0, flexDirection: 'row', alignItems: 'center' }, input: { flex: 1, backgroundColor: 'transparent', color: '#000', fontSize: 17 }, inputErrorColor: { color: '#f50' }, disabledStyle: { color: '#ccc' }, errorIcon: { marginLeft: 5, width: 20, height: 20 }, extra: { color: '#888888', marginLeft: 5, fontSize: 15 }, clear: { backgroundColor: '#ccc', borderRadius: 15, padding: 2 } }); module.exports = exports.default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Input/index.tsx"],"names":["noop","normalizeValue","value","Input","React","Component","inputRef","onChange","text","type","props","maxLength","replace","substring","valueLen","length","substr","onInputClear","clear","render","android","Platform","OS","editable","children","error","extra","last","onExtraClick","onErrorClick","disabled","restProps","defaultValue","style","valueProps","keyboardTypeArray","keyboardType","indexOf","disabledStyle","inputStyles","extraStyle","width","container","el","input","inputErrorColor","event","nativeEvent","top","left","bottom","right","errorIcon","defaultProps","onBlur","onFocus","StyleSheet","create","height","borderBottomWidth","borderBottomColor","marginTop","marginBottom","flexDirection","alignItems","flex","backgroundColor","color","fontSize","marginLeft","borderRadius","padding"],"mappings":"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","sourcesContent":["import React from 'react';\nimport {\n  TextInput,\n  TextInputProperties,\n  GestureResponderEvent,\n  View,\n  StyleSheet,\n  Platform,\n  TouchableWithoutFeedback,\n  Text,\n  TouchableOpacity,\n} from 'react-native';\nimport Icon from '../Icon';\nimport { InputItemPropsType } from './PropsType';\n\nconst noop = () => {};\n\nfunction normalizeValue(value?: string) {\n  if (typeof value === 'undefined' || value === null) {\n    return '';\n  }\n  return value;\n}\n\nexport interface InputProps extends Omit<TextInputProperties, 'onChange' | 'onFocus' | 'onBlur'>, InputItemPropsType {\n  last?: boolean;\n  onExtraClick?: (event: GestureResponderEvent) => void;\n  onErrorClick?: (event: GestureResponderEvent) => void;\n  disabled?: boolean;\n  onChange?: (value: string) => void;\n}\n\nexport default class Input extends React.Component<InputProps, any> {\n  static defaultProps = {\n    type: 'text',\n    editable: true,\n    clear: false,\n    onChange: noop,\n    onBlur: noop,\n    onFocus: noop,\n    extra: '',\n    onExtraClick: noop,\n    error: false,\n    onErrorClick: noop,\n    last: false,\n  };\n\n  inputRef: TextInput | null | undefined;\n\n  onChange = (text: string) => {\n    const { onChange, type } = this.props;\n    const maxLength = this.props.maxLength as number;\n    switch (type) {\n      case 'bankCard':\n        text = text.replace(/\\D/g, '');\n        if (maxLength > 0) {\n          text = text.substring(0, maxLength);\n        }\n        text = text.replace(/\\D/g, '').replace(/(....)(?=.)/g, '$1 ');\n        break;\n      case 'phone':\n        text = text.replace(/\\D/g, '').substring(0, 11);\n        const valueLen = text.length;\n        if (valueLen > 3 && valueLen < 8) {\n          text = `${text.substr(0, 3)} ${text.substr(3)}`;\n        } else if (valueLen >= 8) {\n          text = `${text.substr(0, 3)} ${text.substr(3, 4)} ${text.substr(7)}`;\n        }\n        break;\n      case 'password':\n        break;\n      default:\n        break;\n    }\n    if (onChange) {\n      onChange(text);\n    }\n  };\n  onInputClear = () => {\n    if (this.inputRef) {\n      this.inputRef.clear();\n    }\n    this.onChange('');\n  };\n  render() {\n    const android = Platform.OS === 'android';\n    const {\n      type,\n      editable,\n      clear,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      children,\n      error,\n      extra,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      last,\n      onExtraClick,\n      onErrorClick,\n      disabled,\n      ...restProps\n    } = this.props;\n    const { value, defaultValue, style } = restProps;\n    let valueProps: any;\n    if ('value' in this.props) {\n      valueProps = {\n        value: normalizeValue(value),\n      };\n    } else {\n      valueProps = {\n        defaultValue,\n      };\n    }\n    const keyboardTypeArray = [\n      'default',\n      'email-address',\n      'numeric',\n      'phone-pad',\n      'ascii-capable',\n      'numbers-and-punctuation',\n      'url',\n      'number-pad',\n      'name-phone-pad',\n      'decimal-pad',\n      'twitter',\n      'web-search',\n    ];\n\n    let keyboardType: any = 'default';\n\n    if (type === 'number') {\n      keyboardType = 'numeric';\n    } else if (type === 'bankCard') {\n      keyboardType = 'number-pad'; // 不带小数点\n    } else if (type === 'phone') {\n      keyboardType = 'phone-pad';\n    } else if (type && keyboardTypeArray.indexOf(type) > -1) {\n      keyboardType = type;\n    }\n    const disabledStyle = disabled ? inputStyles.disabledStyle : {};\n    const extraStyle = {\n      width: typeof extra === 'string' && (extra as string).length > 0 ? (extra as string).length * 17 : 0,\n    };\n    return (\n      <View style={inputStyles.container}>\n        <TextInput\n          editable={!disabled && editable}\n          clearButtonMode={clear ? 'while-editing' : 'never'}\n          underlineColorAndroid=\"transparent\"\n          ref={(el) => (this.inputRef = el)}\n          {...restProps}\n          {...valueProps}\n          style={[\n            inputStyles.input,\n            error ? inputStyles.inputErrorColor : null,\n            disabledStyle,\n            // 支持自定义样式\n            style,\n          ]}\n          keyboardType={keyboardType}\n          onChange={(event) => this.onChange(event.nativeEvent.text)}\n          secureTextEntry={type === 'password'}\n        />\n        {editable && clear && value && android ? (\n          <TouchableOpacity\n            style={[inputStyles.clear]}\n            onPress={this.onInputClear}\n            hitSlop={{ top: 5, left: 5, bottom: 5, right: 5 }}\n          >\n            <Icon name=\"circle-close\" color=\"#fff\" />\n          </TouchableOpacity>\n        ) : null}\n        {extra ? (\n          <TouchableWithoutFeedback onPress={onExtraClick}>\n            <View>\n              {typeof extra === 'string' ? <Text style={[inputStyles.extra, extraStyle]}>{extra}</Text> : extra}\n            </View>\n          </TouchableWithoutFeedback>\n        ) : null}\n        {error && (\n          <TouchableWithoutFeedback onPress={onErrorClick}>\n            <View style={[inputStyles.errorIcon]}>\n              <Icon name=\"circle-close\" color=\"#dc3545\" />\n            </View>\n          </TouchableWithoutFeedback>\n        )}\n      </View>\n    );\n  }\n}\n\nconst inputStyles = StyleSheet.create({\n  container: {\n    height: 30,\n    borderBottomWidth: 1,\n    borderBottomColor: '#ccc',\n    marginTop: 0,\n    marginBottom: 0,\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n  input: {\n    flex: 1,\n    backgroundColor: 'transparent',\n    color: '#000',\n    fontSize: 17,\n  },\n  inputErrorColor: {\n    color: '#f50',\n  },\n  disabledStyle: {\n    color: '#ccc',\n  },\n  errorIcon: {\n    marginLeft: 5,\n    width: 20,\n    height: 20,\n  },\n  extra: {\n    color: '#888888',\n    marginLeft: 5,\n    fontSize: 15,\n  },\n  clear: {\n    backgroundColor: '#ccc',\n    borderRadius: 15,\n    padding: 2,\n  },\n});\n"]}