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

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 (168) hide show
  1. package/package.json +1 -1
  2. package/ui-cv/cv-form-item/cv-form-item.vue +1 -1
  3. package/ui-cv/cv-input-password/cv-input-password.vue +2 -2
  4. package/ui-uni/amap-wx/js/util.js +166 -158
  5. package/ui-uni/page-foot/page-foot.vue +38 -0
  6. package/ui-uni/page-head/page-head.vue +16 -0
  7. package/ui-uni/product.vue +52 -52
  8. package/ui-uni/u-charts/u-charts.js +743 -1092
  9. package/ui-uni/u-link/u-link.vue +59 -0
  10. package/ui-uni/uni-badge/uni-badge.vue +250 -0
  11. package/ui-uni/uni-calendar/calendar.js +546 -0
  12. package/ui-uni/uni-calendar/uni-calendar-item.vue +171 -0
  13. package/ui-uni/uni-calendar/uni-calendar.vue +504 -0
  14. package/{ui-cv/cv-calendar → ui-uni/uni-calendar}/util.js +0 -0
  15. package/ui-uni/uni-card/uni-card.vue +420 -0
  16. package/ui-uni/uni-col/uni-col.vue +2968 -0
  17. package/ui-uni/uni-collapse/uni-collapse.vue +146 -0
  18. package/ui-uni/uni-collapse-item/uni-collapse-item.vue +378 -0
  19. package/ui-uni/uni-combox/uni-combox.vue +237 -0
  20. package/ui-uni/uni-countdown/uni-countdown.vue +234 -0
  21. package/ui-uni/uni-data-checkbox/uni-data-checkbox.vue +792 -0
  22. package/{ui-cv/cv-data-indexed-list → ui-uni/uni-data-indexed-list}/clientdb.js +0 -0
  23. package/ui-uni/uni-data-indexed-list/uni-data-indexed-list-item.vue +142 -0
  24. package/ui-uni/uni-data-indexed-list/uni-data-indexed-list.vue +364 -0
  25. package/{ui-cv/cv-data-picker → ui-uni/uni-data-picker}/keypress.js +0 -0
  26. package/ui-uni/uni-data-picker/uni-data-picker.vue +468 -0
  27. package/{ui-cv/cv-data-pickerview/cv-data-picker.js → ui-uni/uni-data-pickerview/uni-data-picker.js} +0 -0
  28. package/ui-uni/uni-data-pickerview/uni-data-pickerview.vue +298 -0
  29. package/{ui-cv/cv-dateformat → ui-uni/uni-dateformat}/date-format.js +0 -0
  30. package/ui-uni/uni-dateformat/uni-dateformat.vue +88 -0
  31. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/calendar-item.vue +0 -0
  32. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/calendar.js +0 -0
  33. package/ui-uni/uni-datetime-picker/calendar.vue +747 -0
  34. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/keypress.js +0 -0
  35. package/ui-uni/uni-datetime-picker/time-picker.vue +899 -0
  36. package/ui-uni/uni-datetime-picker/uni-datetime-picker.vue +874 -0
  37. package/{ui-cv/cv-datetime-picker → ui-uni/uni-datetime-picker}/util.js +0 -0
  38. package/ui-uni/uni-drawer/keypress.js +45 -0
  39. package/ui-uni/uni-drawer/uni-drawer.vue +178 -0
  40. package/{ui-cv/cv-easyinput → ui-uni/uni-easyinput}/common.js +0 -0
  41. package/ui-uni/uni-easyinput/uni-easyinput.vue +438 -0
  42. package/ui-uni/uni-fab/uni-fab.vue +443 -0
  43. package/{ui-cv/cv-fab/cv-fab.vue.bak → ui-uni/uni-fab/uni-fab.vue.bak} +2 -2
  44. package/ui-uni/uni-fav/uni-fav.vue +136 -0
  45. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/choose-and-upload-file.js +0 -0
  46. package/ui-uni/uni-file-picker/uni-file-picker.vue +614 -0
  47. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/upload-file.vue +0 -0
  48. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/upload-image.vue +0 -0
  49. package/{ui-cv/cv-file-picker → ui-uni/uni-file-picker}/utils.js +0 -0
  50. package/ui-uni/uni-forms/uni-forms.vue +467 -0
  51. package/ui-uni/uni-forms/validate.js +486 -0
  52. package/ui-uni/uni-forms-item/uni-forms-item.vue +500 -0
  53. package/{ui-cv/cv-goods-nav/cv-goods-nav.vue → ui-uni/uni-goods-nav/uni-goods-nav.vue} +1 -1
  54. package/ui-uni/uni-grid/uni-grid.vue +141 -0
  55. package/ui-uni/uni-grid-item/uni-grid-item.vue +123 -0
  56. package/ui-uni/uni-group/uni-group.vue +123 -0
  57. package/ui-uni/uni-icons/icons.js +132 -0
  58. package/ui-uni/uni-icons/uni-icons.vue +72 -0
  59. package/{ui-cv/cv-icon2 → ui-uni/uni-icons}/uni.ttf +0 -0
  60. package/ui-uni/uni-indexed-list/uni-indexed-list-item.vue +142 -0
  61. package/ui-uni/uni-indexed-list/uni-indexed-list.vue +357 -0
  62. package/ui-uni/uni-link/uni-link.vue +117 -0
  63. package/ui-uni/uni-list/uni-list.vue +107 -0
  64. package/ui-uni/uni-list/uni-refresh.vue +65 -0
  65. package/{ui-cv/cv-list → ui-uni/uni-list}/uni-refresh.wxs +0 -0
  66. package/ui-uni/uni-list-ad/uni-list-ad.vue +106 -0
  67. package/{ui-cv/cv-list-chat/cv-list-chat.scss → ui-uni/uni-list-chat/uni-list-chat.scss} +0 -0
  68. package/{ui-cv/cv-list-chat/cv-list-chat.vue → ui-uni/uni-list-chat/uni-list-chat.vue} +0 -0
  69. package/ui-uni/uni-list-item/uni-list-item.vue +428 -0
  70. package/ui-uni/uni-load-more/uni-load-more.vue +366 -0
  71. package/ui-uni/uni-nav-bar/uni-nav-bar.vue +244 -0
  72. package/{ui-cv/cv-nav-bar/cv-status-bar.vue → ui-uni/uni-nav-bar/uni-status-bar.vue} +0 -0
  73. package/ui-uni/uni-notice-bar/uni-notice-bar.vue +394 -0
  74. package/ui-uni/uni-number-box/uni-number-box.vue +224 -0
  75. package/ui-uni/uni-pagination/uni-pagination.vue +376 -0
  76. package/{ui-cv/cv-popup → ui-uni/uni-popup}/keypress.js +0 -0
  77. package/{ui-cv/cv-popup → ui-uni/uni-popup}/popup.js +0 -0
  78. package/ui-uni/uni-popup/uni-popup.vue +412 -0
  79. package/{ui-cv/cv-popup-dialog → ui-uni/uni-popup-dialog}/keypress.js +0 -0
  80. package/{ui-cv/cv-popup-dialog/cv-popup-dialog.vue → ui-uni/uni-popup-dialog/uni-popup-dialog.vue} +0 -0
  81. package/ui-uni/uni-popup-message/uni-popup-message.vue +143 -0
  82. package/{ui-cv/cv-popup-share/cv-popup-share.vue → ui-uni/uni-popup-share/uni-popup-share.vue} +0 -0
  83. package/ui-uni/uni-rate/uni-rate.vue +357 -0
  84. package/ui-uni/uni-row/uni-row.vue +155 -0
  85. package/ui-uni/uni-search-bar/uni-search-bar.vue +262 -0
  86. package/{ui-cv/cv-section/cv-section.vue → ui-uni/uni-section/uni-section.vue} +0 -0
  87. package/{ui-cv/cv-segmented-control/cv-segmented-control.vue → ui-uni/uni-segmented-control/uni-segmented-control.vue} +0 -0
  88. package/{ui-cv/cv-status-bar/cv-status-bar.vue → ui-uni/uni-status-bar/uni-status-bar.vue} +0 -0
  89. package/ui-uni/uni-steps/uni-steps.vue +250 -0
  90. package/{ui-cv/cv-swipe-action/cv-swipe-action.vue → ui-uni/uni-swipe-action/uni-swipe-action.vue} +0 -0
  91. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/bindingx.js +0 -0
  92. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/index.wxs +0 -0
  93. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/isPC.js +0 -0
  94. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/mpalipay.js +0 -0
  95. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/mpother.js +0 -0
  96. package/{ui-cv/cv-swipe-action-item → ui-uni/uni-swipe-action-item}/mpwxs.js +0 -0
  97. 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
  98. package/ui-uni/uni-swiper-dot/uni-swiper-dot.vue +205 -0
  99. package/ui-uni/uni-table/uni-table.vue +455 -0
  100. package/ui-uni/uni-tag/uni-tag.vue +283 -0
  101. package/ui-uni/uni-tbody/uni-tbody.vue +30 -0
  102. package/ui-uni/uni-td/uni-td.vue +88 -0
  103. package/{ui-cv/cv-test/cv-test.vue → ui-uni/uni-test/uni-test.vue} +0 -0
  104. package/{ui-cv/cv-th → ui-uni/uni-th}/filter-dropdown.vue +0 -0
  105. package/ui-uni/uni-th/uni-th.vue +259 -0
  106. package/ui-uni/uni-thead/uni-thead.vue +114 -0
  107. package/ui-uni/uni-title/uni-title.vue +171 -0
  108. package/{ui-cv/cv-tr → ui-uni/uni-tr}/table-checkbox.vue +0 -0
  109. package/ui-uni/uni-tr/uni-tr.vue +156 -0
  110. package/{ui-cv/cv-transition → ui-uni/uni-transition}/createAnimation.js +0 -0
  111. package/ui-uni/uni-transition/uni-transition.vue +287 -0
  112. package/ui-cv/cv-badge/cv-badge.vue +0 -249
  113. package/ui-cv/cv-calendar/calendar.js +0 -963
  114. package/ui-cv/cv-calendar/cv-calendar-item.vue +0 -198
  115. package/ui-cv/cv-calendar/cv-calendar.vue +0 -508
  116. package/ui-cv/cv-card/cv-card.vue +0 -427
  117. package/ui-cv/cv-col/cv-col.vue +0 -2965
  118. package/ui-cv/cv-collapse/cv-collapse.vue +0 -146
  119. package/ui-cv/cv-collapse-item/cv-collapse-item.vue +0 -395
  120. package/ui-cv/cv-combox/cv-combox.vue +0 -250
  121. package/ui-cv/cv-countdown/cv-countdown.vue +0 -245
  122. package/ui-cv/cv-data-checkbox/cv-data-checkbox.vue +0 -841
  123. package/ui-cv/cv-data-indexed-list/cv-data-indexed-list-item.vue +0 -154
  124. package/ui-cv/cv-data-indexed-list/cv-data-indexed-list.vue +0 -376
  125. package/ui-cv/cv-data-picker/cv-data-picker.vue +0 -486
  126. package/ui-cv/cv-data-pickerview/cv-data-pickerview.vue +0 -304
  127. package/ui-cv/cv-dateformat/cv-dateformat.vue +0 -86
  128. package/ui-cv/cv-datetime-picker/calendar.vue +0 -761
  129. package/ui-cv/cv-datetime-picker/cv-datetime-picker.vue +0 -958
  130. package/ui-cv/cv-datetime-picker/time-picker.vue +0 -907
  131. package/ui-cv/cv-drawer/cv-drawer.vue +0 -185
  132. package/ui-cv/cv-drawer/keypress.js +0 -45
  133. package/ui-cv/cv-easyinput/cv-easyinput.vue +0 -514
  134. package/ui-cv/cv-fab/cv-fab.vue +0 -465
  135. package/ui-cv/cv-fav/cv-fav.vue +0 -150
  136. package/ui-cv/cv-file-picker/cv-file-picker.vue +0 -619
  137. package/ui-cv/cv-form-base/cv-form-base.vue +0 -470
  138. package/ui-cv/cv-form-base/validate.js +0 -477
  139. package/ui-cv/cv-grid-group/cv-grid-group.vue +0 -148
  140. package/ui-cv/cv-grid-item/cv-grid-item.vue +0 -132
  141. package/ui-cv/cv-icon2/cv-icon2.vue +0 -78
  142. package/ui-cv/cv-icon2/icons.js +0 -132
  143. package/ui-cv/cv-indexed-list/cv-indexed-list-item.vue +0 -154
  144. package/ui-cv/cv-indexed-list/cv-indexed-list.vue +0 -371
  145. package/ui-cv/cv-link2/cv-link2.vue +0 -130
  146. package/ui-cv/cv-list/cv-list.vue +0 -107
  147. package/ui-cv/cv-list/cv-refresh.vue +0 -65
  148. package/ui-cv/cv-list-ad/cv-list-ad.vue +0 -113
  149. package/ui-cv/cv-list-item/cv-list-item.vue +0 -449
  150. package/ui-cv/cv-nav-bar/cv-nav-bar.vue +0 -256
  151. package/ui-cv/cv-notice-bar/cv-notice-bar.vue +0 -453
  152. package/ui-cv/cv-number-box/cv-number-box.vue +0 -223
  153. package/ui-cv/cv-pagination/cv-pagination.vue +0 -397
  154. package/ui-cv/cv-popup/cv-popup.vue +0 -429
  155. package/ui-cv/cv-popup-message/cv-popup-message.vue +0 -143
  156. package/ui-cv/cv-row/cv-row.vue +0 -157
  157. package/ui-cv/cv-search-bar/cv-search-bar.vue +0 -280
  158. package/ui-cv/cv-steps/cv-steps.vue +0 -293
  159. package/ui-cv/cv-swiper-dot/cv-swiper-dot.vue +0 -255
  160. package/ui-cv/cv-table/cv-table.vue +0 -460
  161. package/ui-cv/cv-tag/cv-tag.vue +0 -276
  162. package/ui-cv/cv-tbody/cv-tbody.vue +0 -28
  163. package/ui-cv/cv-td/cv-td.vue +0 -93
  164. package/ui-cv/cv-th/cv-th.vue +0 -270
  165. package/ui-cv/cv-thead/cv-thead.vue +0 -114
  166. package/ui-cv/cv-title/cv-title.vue +0 -168
  167. package/ui-cv/cv-tr/cv-tr.vue +0 -166
  168. 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>