import classNames from 'classnames'; import TextArea from './TextArea'; import omit from 'omit.js'; import inputProps from './inputProps'; import { hasProp, getComponentFromProp, getStyle, getClass } from '../_util/props-util'; import { isIE, isIE9 } from '../_util/env'; function noop() {} function fixControlledValue(value) { if (typeof value === 'undefined' || value === null) { return ''; } return value; } export default { name: 'AInput', inheritAttrs: false, model: { prop: 'value', event: 'change.value', }, props: { ...inputProps, }, data() { const { value, defaultValue } = this.$props; return { stateValue: fixControlledValue(!hasProp(this, 'value') ? defaultValue : value), }; }, watch: { value(val) { this.stateValue = fixControlledValue(val); }, }, mounted() { this.$nextTick(() => { if (this.autoFocus) { this.focus(); } }); }, methods: { handleKeyDown(e) { if (e.keyCode === 13) { this.$emit('pressEnter', e); } this.$emit('keydown', e); }, handleChange(e) { // https://github.com/vueComponent/ant-design-vue/issues/92 if (isIE && !isIE9 && this.stateValue === e.target.value) { return; } if (!hasProp(this, 'value')) { this.stateValue = e.target.value; } else { this.$forceUpdate(); } if (!e.target.composing) { this.$emit('change.value', e.target.value); } this.$emit('change', e); this.$emit('input', e); }, focus() { this.$refs.input.focus(); }, blur() { this.$refs.input.blur(); }, select() { this.$refs.input.select(); }, getInputClassName() { const { prefixCls, size, disabled } = this.$props; return { [`${prefixCls}`]: true, [`${prefixCls}-sm`]: size === 'small', [`${prefixCls}-lg`]: size === 'large', [`${prefixCls}-disabled`]: disabled, }; }, renderLabeledInput(children) { const props = this.$props; let addonAfter = getComponentFromProp(this, 'addonAfter'); let addonBefore = getComponentFromProp(this, 'addonBefore'); // Not wrap when there is not addons if (!addonBefore && !addonAfter) { return children; } const wrapperClassName = `${props.prefixCls}-group`; const addonClassName = `${wrapperClassName}-addon`; addonBefore = addonBefore ? {addonBefore} : null; addonAfter = addonAfter ? {addonAfter} : null; const className = { [`${props.prefixCls}-wrapper`]: true, [wrapperClassName]: addonBefore || addonAfter, }; const groupClassName = classNames(`${props.prefixCls}-group-wrapper`, { [`${props.prefixCls}-group-wrapper-sm`]: props.size === 'small', [`${props.prefixCls}-group-wrapper-lg`]: props.size === 'large', }); return ( {addonBefore} {children} {addonAfter} ); }, renderLabeledIcon(children) { const { prefixCls, size } = this.$props; let prefix = getComponentFromProp(this, 'prefix'); let suffix = getComponentFromProp(this, 'suffix'); if (!prefix && !suffix) { return children; } prefix = prefix ? {prefix} : null; suffix = suffix ? {suffix} : null; const affixWrapperCls = classNames(getClass(this), `${prefixCls}-affix-wrapper`, { [`${prefixCls}-affix-wrapper-sm`]: size === 'small', [`${prefixCls}-affix-wrapper-lg`]: size === 'large', }); return ( {prefix} {children} {suffix} ); }, renderInput() { const otherProps = omit(this.$props, [ 'prefixCls', 'addonBefore', 'addonAfter', 'prefix', 'suffix', 'value', 'defaultValue', ]); const { stateValue, getInputClassName, handleKeyDown, handleChange, $listeners } = this; const inputProps = { domProps: { value: stateValue, }, attrs: { ...otherProps, ...this.$attrs }, on: { ...$listeners, keydown: handleKeyDown, input: handleChange, change: noop, }, class: classNames(getInputClassName(), getClass(this)), ref: 'input', }; if ($listeners['change.value']) { inputProps.directives = [{ name: 'ant-input' }]; } return this.renderLabeledIcon(); }, }, render() { if (this.$props.type === 'textarea') { const { $listeners } = this; const textareaProps = { props: this.$props, attrs: this.$attrs, on: { ...$listeners, change: this.handleChange, keydown: this.handleKeyDown, }, directives: [ { name: 'ant-input', }, ], }; return