7fa943eb
梁灏
init
|
1
|
<template>
|
7d5431d8
梁灏
update some style
|
2
|
<div :class="wrapClasses">
|
0f822c9b
梁灏
add Input component
|
3
|
<template v-if="type !== 'textarea'">
|
319f5f86
梁灏
fixed #554
|
4
|
<div :class="[prefixCls + '-group-prepend']" v-if="prepend" v-show="slotReady"><slot name="prepend"></slot></div>
|
4e559028
Leon
Fix a confliction...
|
5
|
<i class="ivu-icon" :class="['ivu-icon-ios-close', prefixCls + '-icon', prefixCls + '-icon-clear' , prefixCls + '-icon-normal']" v-if="clearable && currentValue" @click="handleClear"></i>
|
a73ae72b
梁灏
fixed #2884
|
6
|
<i class="ivu-icon" :class="['ivu-icon-' + icon, prefixCls + '-icon', prefixCls + '-icon-normal']" v-else-if="icon" @click="handleIconClick"></i>
|
fc7ef072
梁灏
support Input
|
7
8
9
|
<transition name="fade">
<i class="ivu-icon ivu-icon-load-c ivu-load-loop" :class="[prefixCls + '-icon', prefixCls + '-icon-validate']" v-if="!icon"></i>
</transition>
|
0f822c9b
梁灏
add Input component
|
10
|
<input
|
acb79ba3
梁灏
fixed #433
|
11
|
:id="elementId"
|
9968ddea
zero
Input increase au...
|
12
|
:autocomplete="autocomplete"
|
c17c5ad6
Sergio Crisostomo
normalize autocom...
|
13
|
:spellcheck="spellcheck"
|
545add71
yinheli
input 支持 focus 方法
|
14
|
ref="input"
|
6c145a04
梁灏
fixed #77
|
15
|
:type="type"
|
0f822c9b
梁灏
add Input component
|
16
17
18
19
|
:class="inputClasses"
:placeholder="placeholder"
:disabled="disabled"
:maxlength="maxlength"
|
0a48ac45
梁灏
Input add readonl...
|
20
|
:readonly="readonly"
|
731d69a2
梁灏
fixed #101
|
21
|
:name="name"
|
fc7ef072
梁灏
support Input
|
22
|
:value="currentValue"
|
c3a9f389
梁灏
update Input
|
23
|
:number="number"
|
f15c216a
丁强
Input 组件增加autofoc...
|
24
|
:autofocus="autofocus"
|
0a48ac45
梁灏
Input add readonl...
|
25
|
@keyup.enter="handleEnter"
|
9e7a3740
xingbofeng
fix: add keyup, k...
|
26
27
28
|
@keyup="handleKeyup"
@keypress="handleKeypress"
@keydown="handleKeydown"
|
0a48ac45
梁灏
Input add readonl...
|
29
|
@focus="handleFocus"
|
c46f385a
梁灏
update DatePicker
|
30
|
@blur="handleBlur"
|
531cd165
梁灏
support DatePicke...
|
31
32
|
@input="handleInput"
@change="handleChange">
|
319f5f86
梁灏
fixed #554
|
33
|
<div :class="[prefixCls + '-group-append']" v-if="append" v-show="slotReady"><slot name="append"></slot></div>
|
0f822c9b
梁灏
add Input component
|
34
35
|
</template>
<textarea
|
0f822c9b
梁灏
add Input component
|
36
|
v-else
|
acb79ba3
梁灏
fixed #433
|
37
|
:id="elementId"
|
4f2dc7e3
梁灏
fixed #3086
|
38
|
:wrap="wrap"
|
acb79ba3
梁灏
fixed #433
|
39
|
:autocomplete="autocomplete"
|
c17c5ad6
Sergio Crisostomo
normalize autocom...
|
40
|
:spellcheck="spellcheck"
|
fc7ef072
梁灏
support Input
|
41
|
ref="textarea"
|
0f822c9b
梁灏
add Input component
|
42
43
|
:class="textareaClasses"
:style="textareaStyles"
|
7d5431d8
梁灏
update some style
|
44
|
:placeholder="placeholder"
|
0f822c9b
梁灏
add Input component
|
45
46
47
|
:disabled="disabled"
:rows="rows"
:maxlength="maxlength"
|
0a48ac45
梁灏
Input add readonl...
|
48
|
:readonly="readonly"
|
731d69a2
梁灏
fixed #101
|
49
|
:name="name"
|
a2f27a80
Lawrence Lee
fix #1084
|
50
|
:value="currentValue"
|
67a87e8d
Aresn
fixed #1017
|
51
|
:autofocus="autofocus"
|
0a48ac45
梁灏
Input add readonl...
|
52
|
@keyup.enter="handleEnter"
|
9e7a3740
xingbofeng
fix: add keyup, k...
|
53
54
55
|
@keyup="handleKeyup"
@keypress="handleKeypress"
@keydown="handleKeydown"
|
0a48ac45
梁灏
Input add readonl...
|
56
|
@focus="handleFocus"
|
c46f385a
梁灏
update DatePicker
|
57
|
@blur="handleBlur"
|
fc7ef072
梁灏
support Input
|
58
|
@input="handleInput">
|
0f822c9b
梁灏
add Input component
|
59
|
</textarea>
|
7d5431d8
梁灏
update some style
|
60
|
</div>
|
7fa943eb
梁灏
init
|
61
62
|
</template>
<script>
|
21dad188
梁灏
prevent dispatch ...
|
63
|
import { oneOf, findComponentUpward } from '../../utils/assist';
|
0f822c9b
梁灏
add Input component
|
64
|
import calcTextareaHeight from '../../utils/calcTextareaHeight';
|
cd78c9c4
梁灏
some comps suppor...
|
65
|
import Emitter from '../../mixins/emitter';
|
7fa943eb
梁灏
init
|
66
67
68
69
|
const prefixCls = 'ivu-input';
export default {
|
06322514
梁灏
support Radio
|
70
|
name: 'Input',
|
cd78c9c4
梁灏
some comps suppor...
|
71
|
mixins: [ Emitter ],
|
7fa943eb
梁灏
init
|
72
73
|
props: {
type: {
|
0f822c9b
梁灏
add Input component
|
74
|
validator (value) {
|
9bd074d4
Hsiaoming Yang
Support more type...
|
75
|
return oneOf(value, ['text', 'textarea', 'password', 'url', 'email', 'date']);
|
0f822c9b
梁灏
add Input component
|
76
|
},
|
7fa943eb
梁灏
init
|
77
78
79
80
|
default: 'text'
},
value: {
type: [String, Number],
|
fc7ef072
梁灏
support Input
|
81
|
default: ''
|
7fa943eb
梁灏
init
|
82
|
},
|
7fa943eb
梁灏
init
|
83
84
|
size: {
validator (value) {
|
b6bda1dc
梁灏
update ColorPicker
|
85
|
return oneOf(value, ['small', 'large', 'default']);
|
7fa943eb
梁灏
init
|
86
|
}
|
0f822c9b
梁灏
add Input component
|
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
},
placeholder: {
type: String,
default: ''
},
maxlength: {
type: Number
},
disabled: {
type: Boolean,
default: false
},
icon: String,
autosize: {
type: [Boolean, Object],
default: false
},
rows: {
type: Number,
default: 2
|
0a48ac45
梁灏
Input add readonl...
|
107
108
109
110
|
},
readonly: {
type: Boolean,
default: false
|
731d69a2
梁灏
fixed #101
|
111
112
113
|
},
name: {
type: String
|
c3a9f389
梁灏
update Input
|
114
115
116
117
|
},
number: {
type: Boolean,
default: false
|
f15c216a
丁强
Input 组件增加autofoc...
|
118
119
|
},
autofocus: {
|
8d3a02a5
丁强
修改input组件 autofoc...
|
120
121
|
type: Boolean,
default: false
|
9968ddea
zero
Input increase au...
|
122
|
},
|
c17c5ad6
Sergio Crisostomo
normalize autocom...
|
123
124
125
126
|
spellcheck: {
type: Boolean,
default: false
},
|
9968ddea
zero
Input increase au...
|
127
|
autocomplete: {
|
41918ed8
梁灏
update Input
|
128
129
130
|
validator (value) {
return oneOf(value, ['on', 'off']);
},
|
9968ddea
zero
Input increase au...
|
131
|
default: 'off'
|
acb79ba3
梁灏
fixed #433
|
132
|
},
|
a73ae72b
梁灏
fixed #2884
|
133
134
135
136
|
clearable: {
type: Boolean,
default: false
},
|
acb79ba3
梁灏
fixed #433
|
137
138
|
elementId: {
type: String
|
4f2dc7e3
梁灏
fixed #3086
|
139
140
141
142
143
144
|
},
wrap: {
validator (value) {
return oneOf(value, ['hard', 'soft']);
},
default: 'soft'
|
7fa943eb
梁灏
init
|
145
146
147
148
|
}
},
data () {
return {
|
fc7ef072
梁灏
support Input
|
149
|
currentValue: this.value,
|
0f822c9b
梁灏
add Input component
|
150
151
152
|
prefixCls: prefixCls,
prepend: true,
append: true,
|
6ff31952
梁灏
optimize Input sh...
|
153
|
slotReady: false,
|
0f822c9b
梁灏
add Input component
|
154
|
textareaStyles: {}
|
b0893113
jingsam
add eslint
|
155
|
};
|
7fa943eb
梁灏
init
|
156
157
|
},
computed: {
|
7d5431d8
梁灏
update some style
|
158
|
wrapClasses () {
|
0f822c9b
梁灏
add Input component
|
159
160
161
|
return [
`${prefixCls}-wrapper`,
{
|
12418c6a
梁灏
fixed #74
|
162
|
[`${prefixCls}-wrapper-${this.size}`]: !!this.size,
|
0f822c9b
梁灏
add Input component
|
163
164
|
[`${prefixCls}-type`]: this.type,
[`${prefixCls}-group`]: this.prepend || this.append,
|
f4e462c0
梁灏
#554
|
165
|
[`${prefixCls}-group-${this.size}`]: (this.prepend || this.append) && !!this.size,
|
e2affe49
梁灏
fixed #397
|
166
167
|
[`${prefixCls}-group-with-prepend`]: this.prepend,
[`${prefixCls}-group-with-append`]: this.append,
|
f4e462c0
梁灏
#554
|
168
|
[`${prefixCls}-hide-icon`]: this.append // #554
|
0f822c9b
梁灏
add Input component
|
169
|
}
|
b0893113
jingsam
add eslint
|
170
|
];
|
0f822c9b
梁灏
add Input component
|
171
172
173
174
175
176
177
178
|
},
inputClasses () {
return [
`${prefixCls}`,
{
[`${prefixCls}-${this.size}`]: !!this.size,
[`${prefixCls}-disabled`]: this.disabled
}
|
b0893113
jingsam
add eslint
|
179
|
];
|
7d5431d8
梁灏
update some style
|
180
|
},
|
0f822c9b
梁灏
add Input component
|
181
|
textareaClasses () {
|
7fa943eb
梁灏
init
|
182
183
184
|
return [
`${prefixCls}`,
{
|
0f822c9b
梁灏
add Input component
|
185
|
[`${prefixCls}-disabled`]: this.disabled
|
7fa943eb
梁灏
init
|
186
|
}
|
b0893113
jingsam
add eslint
|
187
|
];
|
7fa943eb
梁灏
init
|
188
|
}
|
0f822c9b
梁灏
add Input component
|
189
190
|
},
methods: {
|
cd50d0d6
young
fix(input): all a...
|
191
192
|
handleEnter (event) {
this.$emit('on-enter', event);
|
0f822c9b
梁灏
add Input component
|
193
|
},
|
9e7a3740
xingbofeng
fix: add keyup, k...
|
194
195
196
197
198
199
200
201
202
|
handleKeydown (event) {
this.$emit('on-keydown', event);
},
handleKeypress(event) {
this.$emit('on-keypress', event);
},
handleKeyup (event) {
this.$emit('on-keyup', event);
},
|
cd50d0d6
young
fix(input): all a...
|
203
204
|
handleIconClick (event) {
this.$emit('on-click', event);
|
0f822c9b
梁灏
add Input component
|
205
|
},
|
cd50d0d6
young
fix(input): all a...
|
206
207
|
handleFocus (event) {
this.$emit('on-focus', event);
|
0a48ac45
梁灏
Input add readonl...
|
208
|
},
|
cd50d0d6
young
fix(input): all a...
|
209
|
handleBlur (event) {
|
57737d74
muei
Update input.vue
|
210
|
this.$emit('on-blur', event);
|
aa9fc758
梁灏
update Transfer
|
211
|
if (!findComponentUpward(this, ['DatePicker', 'TimePicker', 'Cascader', 'Search'])) {
|
21dad188
梁灏
prevent dispatch ...
|
212
213
|
this.dispatch('FormItem', 'on-form-blur', this.currentValue);
}
|
0a48ac45
梁灏
Input add readonl...
|
214
|
},
|
fc7ef072
梁灏
support Input
|
215
|
handleInput (event) {
|
85ed4df8
梁灏
fixed Input bug
|
216
217
|
let value = event.target.value;
if (this.number) value = Number.isNaN(Number(value)) ? value : Number(value);
|
fc7ef072
梁灏
support Input
|
218
219
|
this.$emit('input', value);
this.setCurrentValue(value);
|
e1874103
梁灏
update DatePicker
|
220
|
this.$emit('on-change', event);
|
c46f385a
梁灏
update DatePicker
|
221
|
},
|
531cd165
梁灏
support DatePicke...
|
222
223
224
|
handleChange (event) {
this.$emit('on-input-change', event);
},
|
fc7ef072
梁灏
support Input
|
225
226
227
228
229
230
|
setCurrentValue (value) {
if (value === this.currentValue) return;
this.$nextTick(() => {
this.resizeTextarea();
});
this.currentValue = value;
|
aa9fc758
梁灏
update Transfer
|
231
|
if (!findComponentUpward(this, ['DatePicker', 'TimePicker', 'Cascader', 'Search'])) {
|
21dad188
梁灏
prevent dispatch ...
|
232
233
|
this.dispatch('FormItem', 'on-form-change', value);
}
|
fc7ef072
梁灏
support Input
|
234
|
},
|
0f822c9b
梁灏
add Input component
|
235
236
237
238
239
240
241
242
243
|
resizeTextarea () {
const autosize = this.autosize;
if (!autosize || this.type !== 'textarea') {
return false;
}
const minRows = autosize.minRows;
const maxRows = autosize.maxRows;
|
fc7ef072
梁灏
support Input
|
244
|
this.textareaStyles = calcTextareaHeight(this.$refs.textarea, minRows, maxRows);
|
545add71
yinheli
input 支持 focus 方法
|
245
|
},
|
fed3e09d
梁灏
add AutoComplete ...
|
246
|
focus () {
|
545add71
yinheli
input 支持 focus 方法
|
247
248
249
250
251
|
if (this.type === 'textarea') {
this.$refs.textarea.focus();
} else {
this.$refs.input.focus();
}
|
fed3e09d
梁灏
add AutoComplete ...
|
252
253
254
255
256
257
258
|
},
blur () {
if (this.type === 'textarea') {
this.$refs.textarea.blur();
} else {
this.$refs.input.blur();
}
|
a73ae72b
梁灏
fixed #2884
|
259
260
261
262
263
264
|
},
handleClear () {
const e = { target: { value: '' } };
this.$emit('input', '');
this.setCurrentValue('');
this.$emit('on-change', e);
|
0f822c9b
梁灏
add Input component
|
265
266
267
|
}
},
watch: {
|
fc7ef072
梁灏
support Input
|
268
269
|
value (val) {
this.setCurrentValue(val);
|
0f822c9b
梁灏
add Input component
|
270
271
|
}
},
|
fc7ef072
梁灏
support Input
|
272
273
274
275
276
277
278
279
280
281
|
mounted () {
if (this.type !== 'textarea') {
this.prepend = this.$slots.prepend !== undefined;
this.append = this.$slots.append !== undefined;
} else {
this.prepend = false;
this.append = false;
}
this.slotReady = true;
this.resizeTextarea();
|
7fa943eb
梁灏
init
|
282
|
}
|
b0893113
jingsam
add eslint
|
283
284
|
};
</script>
|