'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _classnames3 = require('classnames'); var _classnames4 = _interopRequireDefault(_classnames3); var _propTypes = require('prop-types'); var PropTypes = _interopRequireWildcard(_propTypes); var _react = require('react'); var React = _interopRequireWildcard(_react); var _rmcFeedback = require('rmc-feedback'); var _rmcFeedback2 = _interopRequireDefault(_rmcFeedback); var _getLocale = require('../_util/getLocale'); var _CustomInput = require('./CustomInput'); var _CustomInput2 = _interopRequireDefault(_CustomInput); var _Input = require('./Input'); var _Input2 = _interopRequireDefault(_Input); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var __rest = undefined && undefined.__rest || function (s, e) { var t = {}; for (var p in s) { if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; }if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0) t[p[i]] = s[p[i]]; }return t; }; /* tslint:disable:jsx-no-multiline-js */ function noop() {} function normalizeValue(value) { if (typeof value === 'undefined' || value === null) { return ''; } return value + ''; } var InputItem = function (_React$Component) { (0, _inherits3['default'])(InputItem, _React$Component); function InputItem(props) { (0, _classCallCheck3['default'])(this, InputItem); var _this = (0, _possibleConstructorReturn3['default'])(this, (InputItem.__proto__ || Object.getPrototypeOf(InputItem)).call(this, props)); _this.onInputChange = function (e) { var el = e.target; var rawVal = el.value; var prePos = 0; try { // some input type do not support selection, see https://html.spec.whatwg.org/multipage/input.html#do-not-apply prePos = el.selectionEnd || 0; } catch (error) { console.warn('Get selection error:', error); } var _this$state$value = _this.state.value, preCtrlVal = _this$state$value === undefined ? '' : _this$state$value; var type = _this.props.type; var ctrlValue = rawVal; switch (type) { case 'bankCard': ctrlValue = rawVal.replace(/\D/g, '').replace(/(....)(?=.)/g, '$1 '); break; case 'phone': ctrlValue = rawVal.replace(/\D/g, '').substring(0, 11); var valueLen = ctrlValue.length; if (valueLen > 3 && valueLen < 8) { ctrlValue = ctrlValue.substr(0, 3) + ' ' + ctrlValue.substr(3); } else if (valueLen >= 8) { ctrlValue = ctrlValue.substr(0, 3) + ' ' + ctrlValue.substr(3, 4) + ' ' + ctrlValue.substr(7); } break; case 'number': ctrlValue = rawVal.replace(/\D/g, ''); break; case 'text': case 'password': default: break; } _this.handleOnChange(ctrlValue, ctrlValue !== rawVal, function () { switch (type) { case 'bankCard': case 'phone': case 'number': // controlled input type needs to adjust the position of the caret try { // some input type do not support selection, see https://html.spec.whatwg.org/multipage/input.html#do-not-apply var pos = _this.calcPos(prePos, preCtrlVal, rawVal, ctrlValue, [' '], /\D/g); if (type === 'phone' && (pos === 4 || pos === 9) || type === 'bankCard' && pos > 0 && pos % 5 === 0) { pos -= 1; } el.selectionStart = el.selectionEnd = pos; } catch (error) { console.warn('Set selection error:', error); } break; default: break; } }); }; _this.handleOnChange = function (value) { var isMutated = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var adjustPos = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : noop; var onChange = _this.props.onChange; if (!('value' in _this.props)) { _this.setState({ value: value }); } else { _this.setState({ value: _this.props.value }); } if (onChange) { if (isMutated) { setTimeout(function () { onChange(value); adjustPos(); }); } else { onChange(value); adjustPos(); } } else { adjustPos(); } }; _this.onInputFocus = function (value) { if (_this.debounceTimeout) { clearTimeout(_this.debounceTimeout); _this.debounceTimeout = null; } _this.setState({ focus: true }); if (_this.props.onFocus) { _this.props.onFocus(value); } }; _this.onInputBlur = function (value) { if (_this.inputRef) { // this.inputRef may be null if customKeyboard unmount _this.debounceTimeout = window.setTimeout(function () { if (document.activeElement !== (_this.inputRef && _this.inputRef.inputRef)) { _this.setState({ focus: false }); } }, 200); } if (_this.props.onBlur) { // fix autoFocus item blur with flash setTimeout(function () { // fix ios12 wechat browser click failure after input if (document.body) { document.body.scrollTop = document.body.scrollTop; } }, 100); _this.props.onBlur(value); } }; _this.clearInput = function () { if (_this.props.type !== 'password' && _this.props.updatePlaceholder) { _this.setState({ placeholder: _this.props.value }); } _this.setState({ value: '' }); if (_this.props.onChange) { _this.props.onChange(''); } _this.focus(); }; // this is instance method for user to use _this.focus = function () { if (_this.inputRef) { _this.inputRef.focus(); } }; // calculate the position of the caret _this.calcPos = function (prePos, preCtrlVal, rawVal, ctrlVal, placeholderChars, maskReg) { var editLength = rawVal.length - preCtrlVal.length; var isAddition = editLength > 0; var pos = prePos; if (isAddition) { var additionStr = rawVal.substr(pos - editLength, editLength); var ctrlCharCount = additionStr.replace(maskReg, '').length; pos -= editLength - ctrlCharCount; var placeholderCharCount = 0; while (ctrlCharCount > 0) { if (placeholderChars.indexOf(ctrlVal.charAt(pos - ctrlCharCount + placeholderCharCount)) === -1) { ctrlCharCount--; } else { placeholderCharCount++; } } pos += placeholderCharCount; } return pos; }; _this.state = { placeholder: props.placeholder, value: normalizeValue(props.value || props.defaultValue) }; return _this; } (0, _createClass3['default'])(InputItem, [{ key: 'componentWillReceiveProps', value: function componentWillReceiveProps(nextProps) { if ('placeholder' in nextProps && !nextProps.updatePlaceholder) { this.setState({ placeholder: nextProps.placeholder }); } if ('value' in nextProps) { this.setState({ value: nextProps.value }); } } }, { key: 'componentWillUnmount', value: function componentWillUnmount() { if (this.debounceTimeout) { window.clearTimeout(this.debounceTimeout); this.debounceTimeout = null; } } }, { key: 'render', value: function render() { var _classnames, _classnames2, _this2 = this; var props = (0, _extends3['default'])({}, this.props); delete props.updatePlaceholder; var prefixCls = props.prefixCls, prefixListCls = props.prefixListCls, editable = props.editable, style = props.style, clear = props.clear, children = props.children, error = props.error, className = props.className, extra = props.extra, labelNumber = props.labelNumber, type = props.type, onExtraClick = props.onExtraClick, onErrorClick = props.onErrorClick, moneyKeyboardAlign = props.moneyKeyboardAlign, moneyKeyboardWrapProps = props.moneyKeyboardWrapProps, moneyKeyboardHeader = props.moneyKeyboardHeader, onVirtualKeyboardConfirm = props.onVirtualKeyboardConfirm, autoAdjustHeight = props.autoAdjustHeight, disabledKeys = props.disabledKeys, restProps = __rest(props, ["prefixCls", "prefixListCls", "editable", "style", "clear", "children", "error", "className", "extra", "labelNumber", "type", "onExtraClick", "onErrorClick", "moneyKeyboardAlign", "moneyKeyboardWrapProps", "moneyKeyboardHeader", "onVirtualKeyboardConfirm", "autoAdjustHeight", "disabledKeys"]); var name = restProps.name, disabled = restProps.disabled, maxLength = restProps.maxLength; var value = this.state.value; // tslint:disable-next-line:variable-name var _locale = (0, _getLocale.getComponentLocale)(this.props, this.context, 'InputItem', function () { return require('./locale/zh_CN'); }); var confirmLabel = _locale.confirmLabel, backspaceLabel = _locale.backspaceLabel, cancelKeyboardLabel = _locale.cancelKeyboardLabel; var _state = this.state, focus = _state.focus, placeholder = _state.placeholder; var wrapCls = (0, _classnames4['default'])(prefixListCls + '-item', prefixCls + '-item', prefixListCls + '-item-middle', className, (_classnames = {}, (0, _defineProperty3['default'])(_classnames, prefixCls + '-disabled', disabled), (0, _defineProperty3['default'])(_classnames, prefixCls + '-error', error), (0, _defineProperty3['default'])(_classnames, prefixCls + '-focus', focus), (0, _defineProperty3['default'])(_classnames, prefixCls + '-android', focus), _classnames)); var labelCls = (0, _classnames4['default'])(prefixCls + '-label', (_classnames2 = {}, (0, _defineProperty3['default'])(_classnames2, prefixCls + '-label-2', labelNumber === 2), (0, _defineProperty3['default'])(_classnames2, prefixCls + '-label-3', labelNumber === 3), (0, _defineProperty3['default'])(_classnames2, prefixCls + '-label-4', labelNumber === 4), (0, _defineProperty3['default'])(_classnames2, prefixCls + '-label-5', labelNumber === 5), (0, _defineProperty3['default'])(_classnames2, prefixCls + '-label-6', labelNumber === 6), (0, _defineProperty3['default'])(_classnames2, prefixCls + '-label-7', labelNumber === 7), _classnames2)); var controlCls = prefixCls + '-control'; var inputType = 'text'; if (type === 'bankCard' || type === 'phone') { inputType = 'tel'; } else if (type === 'password') { inputType = 'password'; } else if (type === 'digit') { inputType = 'number'; } else if (type !== 'text' && type !== 'number') { inputType = type; } var patternProps = void 0; if (type === 'number') { patternProps = { pattern: '[0-9]*' }; } var classNameProps = void 0; if (type === 'digit') { classNameProps = { className: 'h5numInput' }; } return React.createElement( 'div', { className: wrapCls }, React.createElement( 'div', { className: prefixListCls + '-line' }, children ? React.createElement( 'div', { className: labelCls }, children ) : null, React.createElement( 'div', { className: controlCls }, type === 'money' ? React.createElement(_CustomInput2['default'], { value: normalizeValue(value), type: type, ref: function ref(el) { return _this2.inputRef = el; }, maxLength: maxLength, placeholder: placeholder, onChange: this.onInputChange, onFocus: this.onInputFocus, onBlur: this.onInputBlur, onVirtualKeyboardConfirm: onVirtualKeyboardConfirm, disabled: disabled, editable: editable, prefixCls: prefixCls, style: style, confirmLabel: confirmLabel, backspaceLabel: backspaceLabel, cancelKeyboardLabel: cancelKeyboardLabel, moneyKeyboardAlign: moneyKeyboardAlign, moneyKeyboardWrapProps: moneyKeyboardWrapProps, moneyKeyboardHeader: moneyKeyboardHeader, autoAdjustHeight: autoAdjustHeight, disabledKeys: disabledKeys }) : React.createElement(_Input2['default'], (0, _extends3['default'])({}, patternProps, restProps, classNameProps, { value: normalizeValue(value), defaultValue: undefined, ref: function ref(el) { return _this2.inputRef = el; }, style: style, type: inputType, maxLength: maxLength, name: name, placeholder: placeholder, onChange: this.onInputChange, onFocus: this.onInputFocus, onBlur: this.onInputBlur, readOnly: !editable, disabled: disabled })) ), clear && editable && !disabled && value && ('' + value).length > 0 ? React.createElement( _rmcFeedback2['default'], { activeClassName: prefixCls + '-clear-active' }, React.createElement('div', { className: prefixCls + '-clear', onClick: this.clearInput }) ) : null, error ? React.createElement('div', { className: prefixCls + '-error-extra', onClick: onErrorClick }) : null, extra !== '' ? React.createElement( 'div', { className: prefixCls + '-extra', onClick: onExtraClick }, extra ) : null ) ); } }]); return InputItem; }(React.Component); InputItem.defaultProps = { prefixCls: 'am-input', prefixListCls: 'am-list', type: 'text', editable: true, disabled: false, placeholder: '', clear: false, onChange: noop, onBlur: noop, onFocus: noop, extra: '', onExtraClick: noop, error: false, onErrorClick: noop, onVirtualKeyboardConfirm: noop, labelNumber: 5, updatePlaceholder: false, moneyKeyboardAlign: 'right', moneyKeyboardWrapProps: {}, moneyKeyboardHeader: null, disabledKeys: null }; InputItem.contextTypes = { antLocale: PropTypes.object }; exports['default'] = InputItem; module.exports = exports['default'];