224 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			224 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Vue
		
	
	
| 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 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) {
 | |
|       // 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 ? (
 | |
|         <span class={addonClassName}>
 | |
|           {addonBefore}
 | |
|         </span>
 | |
|       ) : null
 | |
| 
 | |
|       addonAfter = addonAfter ? (
 | |
|         <span class={addonClassName}>
 | |
|           {addonAfter}
 | |
|         </span>
 | |
|       ) : 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 (
 | |
|         <span
 | |
|           class={groupClassName}
 | |
|           style={getStyle(this)}
 | |
|         >
 | |
|           <span class={className}>
 | |
|             {addonBefore}
 | |
|             {children}
 | |
|             {addonAfter}
 | |
|           </span>
 | |
|         </span>
 | |
|       )
 | |
|     },
 | |
|     renderLabeledIcon (children) {
 | |
|       const { prefixCls, size } = this.$props
 | |
|       let prefix = getComponentFromProp(this, 'prefix')
 | |
|       let suffix = getComponentFromProp(this, 'suffix')
 | |
|       if (!prefix && !suffix) {
 | |
|         return children
 | |
|       }
 | |
| 
 | |
|       prefix = prefix ? (
 | |
|         <span class={`${prefixCls}-prefix`}>
 | |
|           {prefix}
 | |
|         </span>
 | |
|       ) : null
 | |
| 
 | |
|       suffix = suffix ? (
 | |
|         <span class={`${prefixCls}-suffix`}>
 | |
|           {suffix}
 | |
|         </span>
 | |
|       ) : null
 | |
|       const affixWrapperCls = classNames(getClass(this), `${prefixCls}-affix-wrapper`, {
 | |
|         [`${prefixCls}-affix-wrapper-sm`]: size === 'small',
 | |
|         [`${prefixCls}-affix-wrapper-lg`]: size === 'large',
 | |
|       })
 | |
|       return (
 | |
|         <span
 | |
|           class={affixWrapperCls}
 | |
|           style={getStyle(this)}
 | |
|         >
 | |
|           {prefix}
 | |
|           {children}
 | |
|           {suffix}
 | |
|         </span>
 | |
|       )
 | |
|     },
 | |
| 
 | |
|     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,
 | |
|         },
 | |
|         class: classNames(getInputClassName(), getClass(this)),
 | |
|         ref: 'input',
 | |
|       }
 | |
|       if ($listeners['change.value']) {
 | |
|         inputProps.directives = [{ name: 'ant-input' }]
 | |
|       }
 | |
|       return this.renderLabeledIcon(
 | |
|         <input
 | |
|           {...inputProps}
 | |
|         />,
 | |
|       )
 | |
|     },
 | |
|   },
 | |
|   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 <TextArea {...textareaProps} ref='input' />
 | |
|     }
 | |
|     return this.renderLabeledInput(this.renderInput())
 | |
|   },
 | |
| }
 | |
| 
 |