194 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			194 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Vue
		
	
	
| <script>
 | |
| import TextArea from './TextArea'
 | |
| import omit from 'omit.js'
 | |
| import inputProps from './inputProps'
 | |
| import { hasProp, getComponentFromProp } from '../_util/props-util'
 | |
| 
 | |
| function fixControlledValue (value) {
 | |
|   if (typeof value === 'undefined' || value === null) {
 | |
|     return ''
 | |
|   }
 | |
|   return value
 | |
| }
 | |
| 
 | |
| export default {
 | |
|   name: 'Input',
 | |
|   props: {
 | |
|     ...inputProps,
 | |
|   },
 | |
|   model: {
 | |
|     prop: 'value',
 | |
|     event: 'change.value',
 | |
|   },
 | |
|   data () {
 | |
|     const { value, defaultValue } = this.$props
 | |
|     return {
 | |
|       stateValue: fixControlledValue(!hasProp(this, 'value') ? defaultValue : value),
 | |
|     }
 | |
|   },
 | |
|   computed: {
 | |
|   },
 | |
|   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 ? (
 | |
|         <span class={addonClassName}>
 | |
|           {addonBefore}
 | |
|         </span>
 | |
|       ) : null
 | |
| 
 | |
|       addonAfter = addonAfter ? (
 | |
|         <span class={addonClassName}>
 | |
|           {addonAfter}
 | |
|         </span>
 | |
|       ) : null
 | |
| 
 | |
|       const className = {
 | |
|         [`${props.prefixCls}-wrapper`]: true,
 | |
|         [wrapperClassName]: (addonBefore || addonAfter),
 | |
|       }
 | |
| 
 | |
|       if (addonBefore || addonAfter) {
 | |
|         return (
 | |
|           <span
 | |
|             class={`${props.prefixCls}-group-wrapper`}
 | |
|           >
 | |
|             <span class={className}>
 | |
|               {addonBefore}
 | |
|               {children}
 | |
|               {addonAfter}
 | |
|             </span>
 | |
|           </span>
 | |
|         )
 | |
|       }
 | |
|       return (
 | |
|         <span class={className}>
 | |
|           {addonBefore}
 | |
|           {children}
 | |
|           {addonAfter}
 | |
|         </span>
 | |
|       )
 | |
|     },
 | |
|     renderLabeledIcon (children) {
 | |
|       const { prefixCls } = 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
 | |
| 
 | |
|       return (
 | |
|         <span
 | |
|           class={`${prefixCls}-affix-wrapper`}
 | |
|         >
 | |
|           {prefix}
 | |
|           {children}
 | |
|           {suffix}
 | |
|         </span>
 | |
|       )
 | |
|     },
 | |
| 
 | |
|     renderInput () {
 | |
|       const otherProps = omit(this.$props, [
 | |
|         'prefixCls',
 | |
|       ])
 | |
|       const { stateValue, getInputClassName, handleKeyDown, handleChange, $listeners } = this
 | |
|       const inputProps = {
 | |
|         domProps: {
 | |
|           value: stateValue,
 | |
|         },
 | |
|         attrs: { ...otherProps, ...this.$attrs },
 | |
|         on: {
 | |
|           ...$listeners,
 | |
|           keydown: handleKeyDown,
 | |
|           input: handleChange,
 | |
|         },
 | |
|         class: getInputClassName(),
 | |
|         ref: '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,
 | |
|         },
 | |
|       }
 | |
|       return <TextArea {...textareaProps} ref='input' />
 | |
|     }
 | |
|     return this.renderLabeledInput(this.renderInput())
 | |
|   },
 | |
| }
 | |
| </script>
 |