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' function fixControlledValue (value) { if (typeof value === 'undefined' || value === null) { return '' } return value } export default { inheritAttrs: false, name: 'AInput', props: { ...inputProps, }, model: { prop: 'value', event: 'change.value', }, data () { const { value, defaultValue } = this.$props return { stateValue: fixControlledValue(!hasProp(this, 'value') ? defaultValue : value), } }, mounted () { this.$nextTick(() => { if (this.autoFocus) { this.focus() } }) }, watch: { value (val) { this.stateValue = fixControlledValue(val) }, }, methods: { handleKeyDown (e) { if (e.keyCode === 13) { this.$emit('pressEnter', e) } this.$emit('keydown', e) }, handleChange (e) { if (!hasProp(this, 'value')) { this.stateValue = e.target.value } else { this.$forceUpdate() } 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() }, 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', }) if (addonBefore || addonAfter) { return ( {addonBefore} {children} {addonAfter} ) } 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', ]) const { stateValue, getInputClassName, handleKeyDown, handleChange, $listeners } = this const inputProps = { domProps: { value: stateValue, }, attrs: { ...otherProps, ...this.$attrs }, on: { ...$listeners, keydown: handleKeyDown, input: handleChange, }, class: classNames(getInputClassName(), getClass(this)), ref: '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, }, } return