@10yun/cv-mobile-ui 0.4.2 → 0.4.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (166) hide show
  1. package/package.json +1 -1
  2. package/ui-uni/amap-wx/js/util.js +166 -158
  3. package/ui-uni/page-foot/page-foot.vue +38 -0
  4. package/ui-uni/page-head/page-head.vue +16 -0
  5. package/ui-uni/product.vue +52 -52
  6. package/ui-uni/u-charts/u-charts.js +743 -1092
  7. package/ui-uni/u-link/u-link.vue +59 -0
  8. package/ui-uni/uni-badge/uni-badge.vue +250 -0
  9. package/ui-uni/uni-calendar/calendar.js +546 -0
  10. package/ui-uni/uni-calendar/uni-calendar-item.vue +171 -0
  11. package/ui-uni/uni-calendar/uni-calendar.vue +504 -0
  12. package/{ui-cv/cv-calendar → ui-uni/uni-calendar}/util.js +0 -0
  13. package/ui-uni/uni-card/uni-card.vue +420 -0
  14. package/ui-uni/uni-col/uni-col.vue +2968 -0
  15. package/ui-uni/uni-collapse/uni-collapse.vue +146 -0
  16. package/ui-uni/uni-collapse-item/uni-collapse-item.vue +378 -0
  17. package/ui-uni/uni-combox/uni-combox.vue +237 -0
  18. package/ui-uni/uni-countdown/uni-countdown.vue +234 -0
  19. package/ui-uni/uni-data-checkbox/uni-data-checkbox.vue +792 -0
  20. package/{ui-cv/cv-data-indexed-list → ui-uni/uni-data-indexed-list}/clientdb.js +0 -0
  21. package/ui-uni/uni-data-indexed-list/uni-data-indexed-list-item.vue +142 -0
  22. package/ui-uni/uni-data-indexed-list/uni-data-indexed-list.vue +364 -0
  23. package/{ui-cv/cv-data-picker → ui-uni/uni-data-picker}/keypress.js +0 -0
  24. package/ui-uni/uni-data-picker/uni-data-picker.vue +468 -0
  25. package/{ui-cv/cv-data-pickerview/cv-data-picker.js → ui-uni/uni-data-pickerview/uni-data-picker.js} +0 -0
  26. package/ui-uni/uni-data-pickerview/uni-data-pickerview.vue +298 -0
  27. package/{ui-cv/cv-dateformat → ui-uni/uni-dateformat}/date-format.js +0 -0
  28. package/ui-uni/uni-dateformat/uni-dateformat.vue +88 -0
  29. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/calendar-item.vue +0 -0
  30. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/calendar.js +0 -0
  31. package/ui-uni/uni-datetime-picker/calendar.vue +747 -0
  32. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/keypress.js +0 -0
  33. package/ui-uni/uni-datetime-picker/time-picker.vue +899 -0
  34. package/ui-uni/uni-datetime-picker/uni-datetime-picker.vue +874 -0
  35. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/util.js +0 -0
  36. package/ui-uni/uni-drawer/keypress.js +45 -0
  37. package/ui-uni/uni-drawer/uni-drawer.vue +178 -0
  38. package/{ui-cv/cv-easyinput → ui-uni/uni-easyinput}/common.js +0 -0
  39. package/ui-uni/uni-easyinput/uni-easyinput.vue +438 -0
  40. package/ui-uni/uni-fab/uni-fab.vue +443 -0
  41. package/{ui-cv/cv-fab/cv-fab.vue.bak → ui-uni/uni-fab/uni-fab.vue.bak} +2 -2
  42. package/ui-uni/uni-fav/uni-fav.vue +136 -0
  43. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/choose-and-upload-file.js +0 -0
  44. package/ui-uni/uni-file-picker/uni-file-picker.vue +614 -0
  45. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/upload-file.vue +0 -0
  46. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/upload-image.vue +0 -0
  47. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/utils.js +0 -0
  48. package/ui-uni/uni-forms/uni-forms.vue +467 -0
  49. package/ui-uni/uni-forms/validate.js +486 -0
  50. package/ui-uni/uni-forms-item/uni-forms-item.vue +500 -0
  51. package/{ui-cv/cv-goods-nav/cv-goods-nav.vue → ui-uni/uni-goods-nav/uni-goods-nav.vue} +1 -1
  52. package/ui-uni/uni-grid/uni-grid.vue +141 -0
  53. package/ui-uni/uni-grid-item/uni-grid-item.vue +123 -0
  54. package/ui-uni/uni-group/uni-group.vue +123 -0
  55. package/ui-uni/uni-icons/icons.js +132 -0
  56. package/ui-uni/uni-icons/uni-icons.vue +72 -0
  57. package/{ui-cv/cv-icon2 → ui-uni/uni-icons}/uni.ttf +0 -0
  58. package/ui-uni/uni-indexed-list/uni-indexed-list-item.vue +142 -0
  59. package/ui-uni/uni-indexed-list/uni-indexed-list.vue +357 -0
  60. package/ui-uni/uni-link/uni-link.vue +117 -0
  61. package/ui-uni/uni-list/uni-list.vue +107 -0
  62. package/ui-uni/uni-list/uni-refresh.vue +65 -0
  63. package/{ui-cv/cv-list → ui-uni/uni-list}/uni-refresh.wxs +0 -0
  64. package/ui-uni/uni-list-ad/uni-list-ad.vue +106 -0
  65. package/{ui-cv/cv-list-chat/cv-list-chat.scss → ui-uni/uni-list-chat/uni-list-chat.scss} +0 -0
  66. package/{ui-cv/cv-list-chat/cv-list-chat.vue → ui-uni/uni-list-chat/uni-list-chat.vue} +0 -0
  67. package/ui-uni/uni-list-item/uni-list-item.vue +428 -0
  68. package/ui-uni/uni-load-more/uni-load-more.vue +366 -0
  69. package/ui-uni/uni-nav-bar/uni-nav-bar.vue +244 -0
  70. package/{ui-cv/cv-nav-bar/cv-status-bar.vue → ui-uni/uni-nav-bar/uni-status-bar.vue} +0 -0
  71. package/ui-uni/uni-notice-bar/uni-notice-bar.vue +394 -0
  72. package/ui-uni/uni-number-box/uni-number-box.vue +224 -0
  73. package/ui-uni/uni-pagination/uni-pagination.vue +376 -0
  74. package/{ui-cv/cv-popup → ui-uni/uni-popup}/keypress.js +0 -0
  75. package/{ui-cv/cv-popup → ui-uni/uni-popup}/popup.js +0 -0
  76. package/ui-uni/uni-popup/uni-popup.vue +412 -0
  77. package/{ui-cv/cv-popup-dialog → ui-uni/uni-popup-dialog}/keypress.js +0 -0
  78. package/{ui-cv/cv-popup-dialog/cv-popup-dialog.vue → ui-uni/uni-popup-dialog/uni-popup-dialog.vue} +0 -0
  79. package/ui-uni/uni-popup-message/uni-popup-message.vue +143 -0
  80. package/{ui-cv/cv-popup-share/cv-popup-share.vue → ui-uni/uni-popup-share/uni-popup-share.vue} +0 -0
  81. package/ui-uni/uni-rate/uni-rate.vue +357 -0
  82. package/ui-uni/uni-row/uni-row.vue +155 -0
  83. package/ui-uni/uni-search-bar/uni-search-bar.vue +262 -0
  84. package/{ui-cv/cv-section/cv-section.vue → ui-uni/uni-section/uni-section.vue} +0 -0
  85. package/{ui-cv/cv-segmented-control/cv-segmented-control.vue → ui-uni/uni-segmented-control/uni-segmented-control.vue} +0 -0
  86. package/{ui-cv/cv-status-bar/cv-status-bar.vue → ui-uni/uni-status-bar/uni-status-bar.vue} +0 -0
  87. package/ui-uni/uni-steps/uni-steps.vue +250 -0
  88. package/{ui-cv/cv-swipe-action/cv-swipe-action.vue → ui-uni/uni-swipe-action/uni-swipe-action.vue} +0 -0
  89. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/bindingx.js +0 -0
  90. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/index.wxs +0 -0
  91. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/isPC.js +0 -0
  92. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/mpalipay.js +0 -0
  93. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/mpother.js +0 -0
  94. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/mpwxs.js +0 -0
  95. package/{ui-cv/cv-swipe-action-item/cv-swipe-action-item.vue → ui-uni/uni-swipe-action-item/uni-swipe-action-item.vue} +0 -0
  96. package/ui-uni/uni-swiper-dot/uni-swiper-dot.vue +205 -0
  97. package/ui-uni/uni-table/uni-table.vue +455 -0
  98. package/ui-uni/uni-tag/uni-tag.vue +283 -0
  99. package/ui-uni/uni-tbody/uni-tbody.vue +30 -0
  100. package/ui-uni/uni-td/uni-td.vue +88 -0
  101. package/{ui-cv/cv-test/cv-test.vue → ui-uni/uni-test/uni-test.vue} +0 -0
  102. package/{ui-cv/cv-th → ui-uni/uni-th}/filter-dropdown.vue +0 -0
  103. package/ui-uni/uni-th/uni-th.vue +259 -0
  104. package/ui-uni/uni-thead/uni-thead.vue +114 -0
  105. package/ui-uni/uni-title/uni-title.vue +171 -0
  106. package/{ui-cv/cv-tr → ui-uni/uni-tr}/table-checkbox.vue +0 -0
  107. package/ui-uni/uni-tr/uni-tr.vue +156 -0
  108. package/{ui-cv/cv-transition → ui-uni/uni-transition}/createAnimation.js +0 -0
  109. package/ui-uni/uni-transition/uni-transition.vue +287 -0
  110. package/ui-cv/cv-badge/cv-badge.vue +0 -249
  111. package/ui-cv/cv-calendar/calendar.js +0 -963
  112. package/ui-cv/cv-calendar/cv-calendar-item.vue +0 -198
  113. package/ui-cv/cv-calendar/cv-calendar.vue +0 -508
  114. package/ui-cv/cv-card/cv-card.vue +0 -427
  115. package/ui-cv/cv-col/cv-col.vue +0 -2965
  116. package/ui-cv/cv-collapse/cv-collapse.vue +0 -146
  117. package/ui-cv/cv-collapse-item/cv-collapse-item.vue +0 -395
  118. package/ui-cv/cv-combox/cv-combox.vue +0 -250
  119. package/ui-cv/cv-countdown/cv-countdown.vue +0 -245
  120. package/ui-cv/cv-data-checkbox/cv-data-checkbox.vue +0 -841
  121. package/ui-cv/cv-data-indexed-list/cv-data-indexed-list-item.vue +0 -154
  122. package/ui-cv/cv-data-indexed-list/cv-data-indexed-list.vue +0 -376
  123. package/ui-cv/cv-data-picker/cv-data-picker.vue +0 -486
  124. package/ui-cv/cv-data-pickerview/cv-data-pickerview.vue +0 -304
  125. package/ui-cv/cv-dateformat/cv-dateformat.vue +0 -86
  126. package/ui-cv/cv-datetime-picker/calendar.vue +0 -761
  127. package/ui-cv/cv-datetime-picker/cv-datetime-picker.vue +0 -958
  128. package/ui-cv/cv-datetime-picker/time-picker.vue +0 -907
  129. package/ui-cv/cv-drawer/cv-drawer.vue +0 -185
  130. package/ui-cv/cv-drawer/keypress.js +0 -45
  131. package/ui-cv/cv-easyinput/cv-easyinput.vue +0 -514
  132. package/ui-cv/cv-fab/cv-fab.vue +0 -465
  133. package/ui-cv/cv-fav/cv-fav.vue +0 -150
  134. package/ui-cv/cv-file-picker/cv-file-picker.vue +0 -619
  135. package/ui-cv/cv-form-base/cv-form-base.vue +0 -470
  136. package/ui-cv/cv-form-base/validate.js +0 -477
  137. package/ui-cv/cv-grid-group/cv-grid-group.vue +0 -148
  138. package/ui-cv/cv-grid-item/cv-grid-item.vue +0 -132
  139. package/ui-cv/cv-icon2/cv-icon2.vue +0 -78
  140. package/ui-cv/cv-icon2/icons.js +0 -132
  141. package/ui-cv/cv-indexed-list/cv-indexed-list-item.vue +0 -154
  142. package/ui-cv/cv-indexed-list/cv-indexed-list.vue +0 -371
  143. package/ui-cv/cv-link2/cv-link2.vue +0 -130
  144. package/ui-cv/cv-list/cv-list.vue +0 -107
  145. package/ui-cv/cv-list/cv-refresh.vue +0 -65
  146. package/ui-cv/cv-list-ad/cv-list-ad.vue +0 -113
  147. package/ui-cv/cv-list-item/cv-list-item.vue +0 -449
  148. package/ui-cv/cv-nav-bar/cv-nav-bar.vue +0 -256
  149. package/ui-cv/cv-notice-bar/cv-notice-bar.vue +0 -453
  150. package/ui-cv/cv-number-box/cv-number-box.vue +0 -223
  151. package/ui-cv/cv-pagination/cv-pagination.vue +0 -397
  152. package/ui-cv/cv-popup/cv-popup.vue +0 -429
  153. package/ui-cv/cv-popup-message/cv-popup-message.vue +0 -143
  154. package/ui-cv/cv-row/cv-row.vue +0 -157
  155. package/ui-cv/cv-search-bar/cv-search-bar.vue +0 -280
  156. package/ui-cv/cv-steps/cv-steps.vue +0 -293
  157. package/ui-cv/cv-swiper-dot/cv-swiper-dot.vue +0 -255
  158. package/ui-cv/cv-table/cv-table.vue +0 -460
  159. package/ui-cv/cv-tag/cv-tag.vue +0 -276
  160. package/ui-cv/cv-tbody/cv-tbody.vue +0 -28
  161. package/ui-cv/cv-td/cv-td.vue +0 -93
  162. package/ui-cv/cv-th/cv-th.vue +0 -270
  163. package/ui-cv/cv-thead/cv-thead.vue +0 -114
  164. package/ui-cv/cv-title/cv-title.vue +0 -168
  165. package/ui-cv/cv-tr/cv-tr.vue +0 -166
  166. package/ui-cv/cv-transition/cv-transition.vue +0 -279
@@ -1,514 +0,0 @@
1
- <template>
2
- <view
3
- class="uni-easyinput"
4
- :class="{ 'uni-easyinput-error': msg }"
5
- :style="{ color: inputBorder && msg ? '#dd524d' : styles.color }"
6
- >
7
- <view
8
- class="uni-easyinput__content"
9
- :class="{
10
- 'is-input-border': inputBorder,
11
- 'is-input-error-border': inputBorder && msg,
12
- 'is-textarea': type === 'textarea',
13
- 'is-disabled': disabled
14
- }"
15
- :style="{
16
- 'border-color': inputBorder && msg ? '#dd524d' : styles.borderColor,
17
- 'background-color': disabled ? styles.disableColor : ''
18
- }"
19
- >
20
- <cv-icon2
21
- v-if="prefixIcon"
22
- class="content-clear-icon"
23
- :type="prefixIcon"
24
- color="#c0c4cc"
25
- @click="onClickIcon('prefix')"
26
- ></cv-icon2>
27
- <textarea
28
- v-if="type === 'textarea'"
29
- class="uni-easyinput__content-textarea"
30
- :class="{ 'input-padding': inputBorder }"
31
- :name="name"
32
- :value="val"
33
- :placeholder="placeholder"
34
- :placeholderStyle="placeholderStyle"
35
- :disabled="disabled"
36
- :maxlength="inputMaxlength"
37
- :focus="focused"
38
- :autoHeight="autoHeight"
39
- @input="onInput"
40
- @blur="onBlur"
41
- @focus="onFocus"
42
- @confirm="onConfirm"
43
- ></textarea>
44
- <input
45
- v-else
46
- :type="type === 'password' ? 'text' : type"
47
- class="uni-easyinput__content-input"
48
- :style="{
49
- 'padding-right': type === 'password' || clearable || prefixIcon ? '' : '10px',
50
- 'padding-left': prefixIcon ? '' : '10px'
51
- }"
52
- :name="name"
53
- :value="val"
54
- :password="!showPassword && type === 'password'"
55
- :placeholder="placeholder"
56
- :placeholderStyle="placeholderStyle"
57
- :disabled="disabled"
58
- :maxlength="inputMaxlength"
59
- :focus="focused"
60
- :confirmType="confirmType"
61
- @focus="onFocus"
62
- @blur="onBlur"
63
- @input="onInput"
64
- @confirm="onConfirm"
65
- />
66
- <template v-if="type === 'password' && passwordIcon">
67
- <cv-icon2
68
- v-if="val != ''"
69
- class="content-clear-icon"
70
- :class="{ 'is-textarea-icon': type === 'textarea' }"
71
- :type="showPassword ? 'eye-slash-filled' : 'eye-filled'"
72
- :size="18"
73
- color="#c0c4cc"
74
- @click="onEyes"
75
- ></cv-icon2>
76
- </template>
77
- <template v-else-if="suffixIcon">
78
- <cv-icon2
79
- v-if="suffixIcon"
80
- class="content-clear-icon"
81
- :type="suffixIcon"
82
- color="#c0c4cc"
83
- @click="onClickIcon('suffix')"
84
- ></cv-icon2>
85
- </template>
86
- <template v-else>
87
- <cv-icon2
88
- class="content-clear-icon"
89
- :class="{ 'is-textarea-icon': type === 'textarea' }"
90
- type="clear"
91
- :size="clearSize"
92
- v-if="clearable && val && !disabled"
93
- color="#c0c4cc"
94
- @click="onClear"
95
- ></cv-icon2>
96
- </template>
97
- <slot name="right"></slot>
98
- </view>
99
- </view>
100
- </template>
101
-
102
- <script>
103
- // import {
104
- // debounce,
105
- // throttle
106
- // } from './common.js'
107
- /**
108
- * Easyinput 输入框
109
- * @description 此组件可以实现表单的输入与校验,包括 "text" 和 "textarea" 类型。
110
- * @tutorial https://ext.dcloud.net.cn/plugin?id=3455
111
- * @property {String} value 输入内容
112
- * @property {String } type 输入框的类型(默认text) password/text/textarea/..
113
- * @value text 文本输入键盘
114
- * @value textarea 多行文本输入键盘
115
- * @value password 密码输入键盘
116
- * @value number 数字输入键盘,注意iOS上app-vue弹出的数字键盘并非9宫格方式
117
- * @value idcard 身份证输入键盘,信、支付宝、百度、QQ小程序
118
- * @value digit 带小数点的数字键盘 ,App的nvue页面、微信、支付宝、百度、头条、QQ小程序支持
119
- * @property {Boolean} clearable 是否显示右侧清空内容的图标控件,点击可清空输入框内容(默认true)
120
- * @property {Boolean} autoHeight 是否自动增高输入区域,type为textarea时有效(默认true)
121
- * @property {String } placeholder 输入框的提示文字
122
- * @property {String } placeholderStyle placeholder的样式(内联样式,字符串),如"color: #ddd"
123
- * @property {Boolean} focus 是否自动获得焦点(默认false)
124
- * @property {Boolean} disabled 是否禁用(默认false)
125
- * @property {Number } maxlength 最大输入长度,设置为 -1 的时候不限制最大长度(默认140)
126
- * @property {String } confirmType 设置键盘右下角按钮的文字,仅在type="text"时生效(默认done)
127
- * @property {Number } clearSize 清除图标的大小,单位px(默认15)
128
- * @property {String} prefixIcon 输入框头部图标
129
- * @property {String} suffixIcon 输入框尾部图标
130
- * @property {Boolean} trim 是否自动去除两端的空格
131
- * @value both 去除两端空格
132
- * @value left 去除左侧空格
133
- * @value right 去除右侧空格
134
- * @value start 去除左侧空格
135
- * @value end 去除右侧空格
136
- * @value all 去除全部空格
137
- * @value none 不去除空格
138
- * @property {Boolean} inputBorder 是否显示input输入框的边框(默认true)
139
- * @property {Boolean} passwordIcon type=password时是否显示小眼睛图标
140
- * @property {Object} styles 自定义颜色
141
- * @event {Function} input 输入框内容发生变化时触发
142
- * @event {Function} focus 输入框获得焦点时触发
143
- * @event {Function} blur 输入框失去焦点时触发
144
- * @event {Function} confirm 点击完成按钮时触发
145
- * @event {Function} iconClick 点击图标时触发
146
- * @example <uni-easyinput v-model="mobile"></uni-easyinput>
147
- */
148
-
149
- export default {
150
- name: 'cv-easyinput',
151
- emits: ['click', 'iconClick', 'update:modelValue', 'input', 'focus', 'blur', 'confirm'],
152
- model: {
153
- prop: 'modelValue',
154
- event: 'update:modelValue'
155
- },
156
- props: {
157
- name: String,
158
- value: [Number, String],
159
- modelValue: [Number, String],
160
- type: {
161
- type: String,
162
- default: 'text'
163
- },
164
- clearable: {
165
- type: Boolean,
166
- default: true
167
- },
168
- autoHeight: {
169
- type: Boolean,
170
- default: false
171
- },
172
- placeholder: String,
173
- placeholderStyle: String,
174
- focus: {
175
- type: Boolean,
176
- default: false
177
- },
178
- disabled: {
179
- type: Boolean,
180
- default: false
181
- },
182
- maxlength: {
183
- type: [Number, String],
184
- default: 140
185
- },
186
- confirmType: {
187
- type: String,
188
- default: 'done'
189
- },
190
- clearSize: {
191
- type: [Number, String],
192
- default: 15
193
- },
194
- inputBorder: {
195
- type: Boolean,
196
- default: true
197
- },
198
- prefixIcon: {
199
- type: String,
200
- default: ''
201
- },
202
- suffixIcon: {
203
- type: String,
204
- default: ''
205
- },
206
- trim: {
207
- type: [Boolean, String],
208
- default: true
209
- },
210
- passwordIcon: {
211
- type: Boolean,
212
- default: true
213
- },
214
- styles: {
215
- type: Object,
216
- default() {
217
- return {
218
- color: '#333',
219
- disableColor: '#eee',
220
- borderColor: '#e5e5e5'
221
- };
222
- }
223
- },
224
- errorMessage: {
225
- type: [String, Boolean],
226
- default: ''
227
- }
228
- },
229
- data() {
230
- return {
231
- focused: false,
232
- errMsg: '',
233
- val: '',
234
- showMsg: '',
235
- border: false,
236
- isFirstBorder: false,
237
- showClearIcon: false,
238
- showPassword: false
239
- };
240
- },
241
- computed: {
242
- msg() {
243
- return this.errorMessage || this.errMsg;
244
- },
245
- // 因为uniapp的input组件的maxlength组件必须要数值,这里转为数值,给用户可以传入字符串数值
246
- inputMaxlength() {
247
- return Number(this.maxlength);
248
- }
249
- },
250
- watch: {
251
- value(newVal) {
252
- if (this.errMsg) this.errMsg = '';
253
- this.val = newVal;
254
- if (this.form && this.formItem) {
255
- this.formItem.setValue(newVal);
256
- }
257
- },
258
- modelValue(newVal) {
259
- if (this.errMsg) this.errMsg = '';
260
- this.val = newVal;
261
- if (this.form && this.formItem) {
262
- this.formItem.setValue(newVal);
263
- }
264
- },
265
- focus(newVal) {
266
- this.$nextTick(() => {
267
- this.focused = this.focus;
268
- });
269
- }
270
- },
271
- created() {
272
- if (!this.value) {
273
- this.val = this.modelValue;
274
- }
275
- if (!this.modelValue) {
276
- this.val = this.value;
277
- }
278
- this.form = this.getForm('uniForms');
279
- this.formItem = this.getForm('uniFormsItem');
280
- if (this.form && this.formItem) {
281
- if (this.formItem.name) {
282
- this.rename = this.formItem.name;
283
- this.form.inputChildrens.push(this);
284
- }
285
- }
286
- },
287
- mounted() {
288
- // this.onInput = throttle(this.input, 500)
289
- this.$nextTick(() => {
290
- // setTimeout(()=>{
291
- // },1000)
292
- this.focused = this.focus;
293
- });
294
- },
295
- methods: {
296
- /**
297
- * 初始化变量值
298
- */
299
- init() {},
300
- onClickIcon(type) {
301
- this.$emit('iconClick', type);
302
- },
303
- /**
304
- * 获取父元素实例
305
- */
306
- getForm(name = 'uniForms') {
307
- let parent = this.$parent;
308
- let parentName = parent.$options.name;
309
- while (parentName !== name) {
310
- parent = parent.$parent;
311
- if (!parent) return false;
312
- parentName = parent.$options.name;
313
- }
314
- return parent;
315
- },
316
-
317
- onEyes() {
318
- this.showPassword = !this.showPassword;
319
- },
320
- onInput(event) {
321
- let value = event.detail.value;
322
- // 判断是否去除空格
323
- if (this.trim) {
324
- if (typeof this.trim === 'boolean' && this.trim) {
325
- value = this.trimStr(value);
326
- }
327
- if (typeof this.trim === 'string') {
328
- value = this.trimStr(value, this.trim);
329
- }
330
- }
331
- if (this.errMsg) this.errMsg = '';
332
- this.val = value;
333
- // TODO 兼容 vue2
334
- this.$emit('input', value);
335
- // TODO 兼容 vue3
336
- this.$emit('update:modelValue', value);
337
- },
338
-
339
- onFocus(event) {
340
- // this.focused = true;
341
- this.$emit('focus', event);
342
- },
343
- onBlur(event) {
344
- let value = event.detail.value;
345
- // setTimeout(() => {
346
- // this.focused = false;
347
- // }, 100);
348
- this.$emit('blur', event);
349
- },
350
- onConfirm(e) {
351
- this.$emit('confirm', e.detail.value);
352
- },
353
- onClear(event) {
354
- this.val = '';
355
- // TODO 兼容 vue2
356
- this.$emit('input', '');
357
- // TODO 兼容 vue2
358
- // TODO 兼容 vue3
359
- this.$emit('update:modelValue', '');
360
- },
361
- fieldClick() {
362
- this.$emit('click');
363
- },
364
- trimStr(str, pos = 'both') {
365
- if (pos === 'both') {
366
- return str.trim();
367
- } else if (pos === 'left') {
368
- return str.trimLeft();
369
- } else if (pos === 'right') {
370
- return str.trimRight();
371
- } else if (pos === 'start') {
372
- return str.trimStart();
373
- } else if (pos === 'end') {
374
- return str.trimEnd();
375
- } else if (pos === 'all') {
376
- return str.replace(/\s+/g, '');
377
- } else if (pos === 'none') {
378
- return str;
379
- }
380
- return str;
381
- }
382
- }
383
- };
384
- </script>
385
-
386
- <style scoped>
387
- .uni-easyinput {
388
- /* #ifndef APP-NVUE */
389
- width: 100%;
390
- /* #endif */
391
- flex: 1;
392
- position: relative;
393
- text-align: left;
394
- color: #333;
395
- font-size: 14px;
396
- }
397
-
398
- .uni-easyinput__content {
399
- flex: 1;
400
- /* #ifndef APP-NVUE */
401
- width: 100%;
402
- display: flex;
403
- box-sizing: border-box;
404
- min-height: 36px;
405
- /* #endif */
406
- flex-direction: row;
407
- align-items: center;
408
- }
409
-
410
- .uni-easyinput__content-input {
411
- /* #ifndef APP-NVUE */
412
- width: auto;
413
- /* #endif */
414
- position: relative;
415
- overflow: hidden;
416
- flex: 1;
417
- line-height: 1;
418
- font-size: 14px;
419
- }
420
-
421
- .is-textarea {
422
- align-items: flex-start;
423
- }
424
-
425
- .is-textarea-icon {
426
- margin-top: 5px;
427
- }
428
-
429
- .uni-easyinput__content-textarea {
430
- position: relative;
431
- overflow: hidden;
432
- flex: 1;
433
- line-height: 1.5;
434
- font-size: 14px;
435
- padding-top: 6px;
436
- padding-bottom: 10px;
437
- height: 80px;
438
- /* #ifndef APP-NVUE */
439
- min-height: 80px;
440
- width: auto;
441
- /* #endif */
442
- }
443
-
444
- .input-padding {
445
- padding-left: 10px;
446
- }
447
-
448
- .content-clear-icon {
449
- padding: 0 5px;
450
- }
451
-
452
- .label-icon {
453
- margin-right: 5px;
454
- margin-top: -1px;
455
- }
456
-
457
- .is-input-border {
458
- /* #ifndef APP-NVUE */
459
- display: flex;
460
- box-sizing: border-box;
461
- /* #endif */
462
- flex-direction: row;
463
- align-items: center;
464
- border: 1px solid #e5e5e5;
465
- border-radius: 4px;
466
- }
467
-
468
- .is-required {
469
- color: #dd524d;
470
- }
471
-
472
- .uni-error-message {
473
- position: absolute;
474
- bottom: -17px;
475
- left: 0;
476
- line-height: 12px;
477
- color: #dd524d;
478
- font-size: 12px;
479
- text-align: left;
480
- }
481
-
482
- .uni-error-msg--boeder {
483
- position: relative;
484
- bottom: 0;
485
- line-height: 22px;
486
- }
487
-
488
- .is-input-error-border {
489
- border-color: #dd524d;
490
- }
491
-
492
- .uni-easyinput--border {
493
- margin-bottom: 0;
494
- padding: 10px 15px;
495
- border-top: 1px #eee solid;
496
- }
497
-
498
- .uni-easyinput-error {
499
- padding-bottom: 0;
500
- }
501
-
502
- .is-first-border {
503
- /* #ifndef APP-NVUE */
504
- border: none;
505
- /* #endif */
506
- /* #ifdef APP-NVUE */
507
- border-width: 0;
508
- /* #endif */
509
- }
510
-
511
- .is-disabled {
512
- background-color: #eee;
513
- }
514
- </style>