@10yun/cv-mobile-ui 0.3.25 → 0.4.1

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 (190) hide show
  1. package/build/parse-pages.js +2 -2
  2. package/package.json +1 -1
  3. package/plugins/request.js +0 -1
  4. package/ui-cv/README.md +3 -0
  5. package/ui-cv/cv-badge/uni-badge.vue +249 -0
  6. package/ui-cv/cv-banner/cv-banner.vue +1 -1
  7. package/ui-cv/cv-banner-card/cv-banner-card.vue +1 -1
  8. package/ui-cv/cv-block/cv-block.vue +1 -1
  9. package/ui-cv/cv-box/cv-box.vue +1 -1
  10. package/{ui-uni/uni-calendar → ui-cv/cv-calendar}/calendar.js +0 -0
  11. package/{ui-uni/uni-calendar → ui-cv/cv-calendar}/uni-calendar-item.vue +0 -0
  12. package/{ui-uni/uni-calendar → ui-cv/cv-calendar}/uni-calendar.vue +0 -0
  13. package/{ui-uni/uni-calendar → ui-cv/cv-calendar}/util.js +0 -0
  14. package/{ui-uni/uni-card → ui-cv/cv-card}/uni-card.vue +0 -0
  15. package/ui-cv/cv-cell/cv-cell.vue +1 -1
  16. package/ui-cv/cv-checkbox-group/cv-checkbox-group.vue +227 -0
  17. package/ui-cv/cv-checkbox-opt-base/cv-checkbox-opt-base.vue +57 -0
  18. package/ui-cv/cv-checkbox-opt-tag/cv-checkbox-opt-tag.vue +107 -0
  19. package/ui-cv/cv-code-sms/cv-code-sms.vue +23 -42
  20. package/{ui-uni/uni-col → ui-cv/cv-col}/uni-col.vue +0 -0
  21. package/{ui-uni/uni-collapse → ui-cv/cv-collapse}/uni-collapse.vue +0 -0
  22. package/{ui-uni/uni-collapse-item → ui-cv/cv-collapse-item}/uni-collapse-item.vue +0 -0
  23. package/{ui-uni/uni-combox → ui-cv/cv-combox}/uni-combox.vue +0 -0
  24. package/{ui-uni/uni-countdown → ui-cv/cv-countdown}/uni-countdown.vue +0 -0
  25. package/{ui-uni/uni-data-checkbox → ui-cv/cv-data-checkbox}/uni-data-checkbox.vue +0 -0
  26. package/{ui-uni/uni-data-indexed-list → ui-cv/cv-data-indexed-list}/clientdb.js +0 -0
  27. package/{ui-uni/uni-data-indexed-list → ui-cv/cv-data-indexed-list}/uni-data-indexed-list-item.vue +0 -0
  28. package/{ui-uni/uni-data-indexed-list → ui-cv/cv-data-indexed-list}/uni-data-indexed-list.vue +0 -0
  29. package/{ui-uni/uni-data-picker → ui-cv/cv-data-picker}/keypress.js +0 -0
  30. package/{ui-uni/uni-data-picker → ui-cv/cv-data-picker}/uni-data-picker.vue +0 -0
  31. package/{ui-uni/uni-data-pickerview → ui-cv/cv-data-pickerview}/uni-data-picker.js +0 -0
  32. package/{ui-uni/uni-data-pickerview → ui-cv/cv-data-pickerview}/uni-data-pickerview.vue +0 -0
  33. package/{ui-uni/uni-dateformat → ui-cv/cv-dateformat}/date-format.js +0 -0
  34. package/{ui-uni/uni-dateformat → ui-cv/cv-dateformat}/uni-dateformat.vue +0 -0
  35. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/calendar-item.vue +0 -0
  36. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/calendar.js +0 -0
  37. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/calendar.vue +0 -0
  38. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/keypress.js +0 -0
  39. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/time-picker.vue +0 -0
  40. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/uni-datetime-picker.vue +0 -0
  41. package/{ui-uni/uni-datetime-picker → ui-cv/cv-datetime-picker}/util.js +0 -0
  42. package/ui-cv/cv-dialog-bottom/cv-dialog-bottom.vue +1 -1
  43. package/ui-cv/cv-dialog-full/cv-dialog-full.vue +1 -1
  44. package/ui-cv/cv-dialog-loading/cv-dialog-loading.vue +3 -3
  45. package/ui-cv/cv-drawer/cv-drawer.vue +185 -0
  46. package/{ui-uni/uni-drawer → ui-cv/cv-drawer}/keypress.js +14 -14
  47. package/{ui-uni/uni-easyinput → ui-cv/cv-easyinput}/common.js +0 -0
  48. package/{ui-uni/uni-easyinput → ui-cv/cv-easyinput}/uni-easyinput.vue +0 -0
  49. package/ui-cv/cv-editor-parse/readme.md +2 -3
  50. package/ui-cv/{cv-editor → cv-editor-quill}/compressImage.vue +0 -0
  51. package/ui-cv/{cv-editor/cv-editor.vue → cv-editor-quill/cv-editor-quill.vue} +3 -23
  52. package/ui-cv/{cv-editor → cv-editor-quill}/editor-icon.css +0 -0
  53. package/ui-cv/{cv-editor → cv-editor-quill}/editor-icon.ttf +0 -0
  54. package/ui-cv/{cv-editor → cv-editor-quill}/index.js +0 -0
  55. package/{ui-uni/uni-fab → ui-cv/cv-fab}/uni-fab.vue +0 -0
  56. package/{ui-uni/uni-fab → ui-cv/cv-fab}/uni-fab.vue.bak +0 -0
  57. package/{ui-uni/uni-fav → ui-cv/cv-fav}/uni-fav.vue +0 -0
  58. package/{ui-uni/uni-file-picker → ui-cv/cv-file-picker}/choose-and-upload-file.js +0 -0
  59. package/{ui-uni/uni-file-picker → ui-cv/cv-file-picker}/uni-file-picker.vue +0 -0
  60. package/{ui-uni/uni-file-picker → ui-cv/cv-file-picker}/upload-file.vue +0 -0
  61. package/{ui-uni/uni-file-picker → ui-cv/cv-file-picker}/upload-image.vue +0 -0
  62. package/{ui-uni/uni-file-picker → ui-cv/cv-file-picker}/utils.js +0 -0
  63. package/ui-cv/cv-form-base/cv-form-base.vue +470 -0
  64. package/ui-cv/cv-form-base/validate.js +477 -0
  65. package/ui-cv/cv-form-group/cv-form-group.vue +123 -80
  66. package/ui-cv/cv-form-group/cv-form-group2.vue +80 -0
  67. package/ui-cv/cv-form-item/cv-form-item.vue +482 -174
  68. package/ui-cv/cv-form-item/cv-form-item2.vue +215 -0
  69. package/ui-cv/cv-form-merge/cv-form-merge.vue +1 -1
  70. package/ui-cv/cv-geo-local/cv-geo-local.vue +14 -26
  71. package/{ui-uni/uni-goods-nav → ui-cv/cv-goods-nav}/uni-goods-nav.vue +0 -0
  72. package/ui-cv/cv-grid-group/cv-grid-group.vue +148 -0
  73. package/ui-cv/cv-grid-item/cv-grid-item.vue +132 -0
  74. package/ui-cv/cv-icons/cv-icons.vue +1 -1
  75. package/ui-cv/cv-icons2/cv-icons2.vue +78 -0
  76. package/ui-cv/cv-icons2/icons.js +132 -0
  77. package/{ui-uni/uni-icons → ui-cv/cv-icons2}/uni.ttf +0 -0
  78. package/{ui-uni/uni-indexed-list → ui-cv/cv-indexed-list}/uni-indexed-list-item.vue +0 -0
  79. package/{ui-uni/uni-indexed-list → ui-cv/cv-indexed-list}/uni-indexed-list.vue +0 -0
  80. package/ui-cv/cv-info/cv-info.vue +5 -20
  81. package/ui-cv/cv-input-btn/cv-input-btn.vue +25 -43
  82. package/ui-cv/cv-input-digit/cv-input-digit.vue +61 -28
  83. package/ui-cv/cv-input-idcard/cv-input-idcard.vue +47 -29
  84. package/ui-cv/cv-input-number/cv-input-number.vue +60 -28
  85. package/ui-cv/cv-input-password/cv-input-password.vue +80 -30
  86. package/ui-cv/cv-input-text/cv-input-text.vue +55 -37
  87. package/ui-cv/cv-link/uni-link.vue +130 -0
  88. package/{ui-uni/uni-list → ui-cv/cv-list}/uni-list.vue +0 -0
  89. package/{ui-uni/uni-list → ui-cv/cv-list}/uni-refresh.vue +0 -0
  90. package/{ui-uni/uni-list → ui-cv/cv-list}/uni-refresh.wxs +0 -0
  91. package/{ui-uni/uni-list-ad → ui-cv/cv-list-ad}/uni-list-ad.vue +0 -0
  92. package/{ui-uni/uni-list-chat → ui-cv/cv-list-chat}/uni-list-chat.scss +0 -0
  93. package/{ui-uni/uni-list-chat → ui-cv/cv-list-chat}/uni-list-chat.vue +0 -0
  94. package/{ui-uni/uni-list-item → ui-cv/cv-list-item}/uni-list-item.vue +0 -0
  95. package/ui-cv/cv-load-more/config.json +9 -9
  96. package/ui-cv/cv-load-more/cv-load-more.vue +34 -5
  97. package/ui-cv/cv-message/cv-message.vue +1 -1
  98. package/{ui-uni/uni-nav-bar → ui-cv/cv-nav-bar}/uni-nav-bar.vue +0 -0
  99. package/{ui-uni/uni-nav-bar → ui-cv/cv-nav-bar}/uni-status-bar.vue +0 -0
  100. package/ui-cv/cv-nav-col/cv-nav-col.vue +1 -1
  101. package/ui-cv/cv-nav-row/cv-nav-row.vue +1 -1
  102. package/{ui-uni/uni-notice-bar → ui-cv/cv-notice-bar}/uni-notice-bar.vue +0 -0
  103. package/{ui-uni/uni-number-box → ui-cv/cv-number-box}/uni-number-box.vue +0 -0
  104. package/{ui-uni/uni-pagination → ui-cv/cv-pagination}/uni-pagination.vue +0 -0
  105. package/ui-cv/cv-picker-date/cv-picker-date.vue +17 -27
  106. package/ui-cv/cv-picker-datetime/cv-picker-datetime.vue +31 -41
  107. package/ui-cv/cv-picker-datetime5/cv-picker-datetime5.vue +19 -29
  108. package/ui-cv/cv-picker-region/cv-picker-region.vue +23 -33
  109. package/ui-cv/cv-picker-time/cv-picker-time.vue +16 -26
  110. package/ui-cv/cv-picker1/cv-picker1.vue +16 -28
  111. package/ui-cv/cv-picker2/cv-picker2.vue +22 -32
  112. package/ui-cv/cv-picker3/cv-picker3.vue +34 -44
  113. package/{ui-uni/uni-popup → ui-cv/cv-popup}/keypress.js +0 -0
  114. package/{ui-uni/uni-popup → ui-cv/cv-popup}/popup.js +0 -0
  115. package/{ui-uni/uni-popup → ui-cv/cv-popup}/uni-popup.vue +0 -0
  116. package/{ui-uni/uni-popup-dialog → ui-cv/cv-popup-dialog}/keypress.js +0 -0
  117. package/{ui-uni/uni-popup-dialog → ui-cv/cv-popup-dialog}/uni-popup-dialog.vue +0 -0
  118. package/{ui-uni/uni-popup-message → ui-cv/cv-popup-message}/uni-popup-message.vue +0 -0
  119. package/{ui-uni/uni-popup-share → ui-cv/cv-popup-share}/uni-popup-share.vue +0 -0
  120. package/ui-cv/cv-radio-group/cv-radio-group.vue +185 -0
  121. package/ui-cv/cv-radio-opt-base/cv-radio-opt-base.vue +57 -0
  122. package/ui-cv/cv-radio-opt-tag/cv-radio-opt-tag.vue +107 -0
  123. package/ui-cv/cv-rate/cv-rate.vue +13 -17
  124. package/ui-cv/cv-rate/uni-rate.vue +358 -0
  125. package/ui-cv/cv-row/uni-row.vue +157 -0
  126. package/ui-cv/cv-search/cv-search.vue +4 -4
  127. package/{ui-uni/uni-search-bar → ui-cv/cv-search-bar}/uni-search-bar.vue +0 -0
  128. package/{ui-uni/uni-section → ui-cv/cv-section}/uni-section.vue +0 -0
  129. package/{ui-uni/uni-segmented-control → ui-cv/cv-segmented-control}/uni-segmented-control.vue +0 -0
  130. package/ui-cv/cv-skeleton/cv-skeleton2.vue +5 -5
  131. package/ui-cv/cv-specs/cv-specs.vue +1 -1
  132. package/{ui-uni/uni-status-bar → ui-cv/cv-status-bar}/uni-status-bar.vue +0 -0
  133. package/{ui-uni/uni-steps → ui-cv/cv-steps}/uni-steps.vue +0 -0
  134. package/{ui-uni/uni-swipe-action → ui-cv/cv-swipe-action}/uni-swipe-action.vue +0 -0
  135. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/bindingx.js +0 -0
  136. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/index.wxs +0 -0
  137. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/isPC.js +0 -0
  138. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/mpalipay.js +0 -0
  139. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/mpother.js +0 -0
  140. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/mpwxs.js +0 -0
  141. package/{ui-uni/uni-swipe-action-item → ui-cv/cv-swipe-action-item}/uni-swipe-action-item.vue +0 -0
  142. package/{ui-uni/uni-swiper-dot → ui-cv/cv-swiper-dot}/uni-swiper-dot.vue +0 -0
  143. package/ui-cv/cv-switch/cv-switch.vue +5 -9
  144. package/{ui-uni/uni-table → ui-cv/cv-table}/uni-table.vue +0 -0
  145. package/{ui-uni/uni-tag → ui-cv/cv-tag}/uni-tag.vue +0 -0
  146. package/{ui-uni/uni-tbody → ui-cv/cv-tbody}/uni-tbody.vue +0 -0
  147. package/{ui-uni/uni-td → ui-cv/cv-td}/uni-td.vue +0 -0
  148. package/{ui-uni/uni-test → ui-cv/cv-test}/uni-test.vue +0 -0
  149. package/ui-cv/cv-textarea/cv-textarea.vue +56 -41
  150. package/{ui-uni/uni-th → ui-cv/cv-th}/filter-dropdown.vue +0 -0
  151. package/{ui-uni/uni-th → ui-cv/cv-th}/uni-th.vue +0 -0
  152. package/{ui-uni/uni-thead → ui-cv/cv-thead}/uni-thead.vue +0 -0
  153. package/{ui-uni/uni-title → ui-cv/cv-title}/uni-title.vue +0 -0
  154. package/{ui-uni/uni-tr → ui-cv/cv-tr}/table-checkbox.vue +0 -0
  155. package/{ui-uni/uni-tr → ui-cv/cv-tr}/uni-tr.vue +0 -0
  156. package/{ui-uni/uni-transition → ui-cv/cv-transition}/createAnimation.js +0 -0
  157. package/{ui-uni/uni-transition → ui-cv/cv-transition}/uni-transition.vue +0 -0
  158. package/ui-cv/cv-upload-avatar/cv-upload-avatar.vue +24 -22
  159. package/ui-cv/cv-upload-img/cv-upload-img.vue +1 -1
  160. package/ui-cv/mixins/mixins-input.js +20 -29
  161. package/ui-cv/mixins/mixins-picker.js +1 -13
  162. package/ui-uni/amap-wx/js/util.js +158 -166
  163. package/ui-uni/product.vue +52 -52
  164. package/ui-uni/u-charts/u-charts.js +1092 -743
  165. package/ui-cv/cv-checkbox/cv-checkbox.vue +0 -140
  166. package/ui-cv/cv-checkbox-tag/cv-checkbox-tag.vue +0 -164
  167. package/ui-cv/cv-nav-group/cv-nav-group.vue +0 -33
  168. package/ui-cv/cv-radio/cv-radio.vue +0 -111
  169. package/ui-cv/cv-radio-sex/cv-radio-sex.vue +0 -80
  170. package/ui-cv/cv-radio-tag/cv-radio-tag.vue +0 -133
  171. package/ui-cv/mixins/mixins-checkbox.js +0 -71
  172. package/ui-cv/mixins/mixins-common.js +0 -53
  173. package/ui-cv/mixins/mixins-radio.js +0 -84
  174. package/ui-uni/page-foot/page-foot.vue +0 -38
  175. package/ui-uni/page-head/page-head.vue +0 -16
  176. package/ui-uni/u-link/u-link.vue +0 -59
  177. package/ui-uni/uni-badge/uni-badge.vue +0 -250
  178. package/ui-uni/uni-drawer/uni-drawer.vue +0 -178
  179. package/ui-uni/uni-forms/uni-forms.vue +0 -467
  180. package/ui-uni/uni-forms/validate.js +0 -486
  181. package/ui-uni/uni-forms-item/uni-forms-item.vue +0 -500
  182. package/ui-uni/uni-grid/uni-grid.vue +0 -141
  183. package/ui-uni/uni-grid-item/uni-grid-item.vue +0 -123
  184. package/ui-uni/uni-group/uni-group.vue +0 -123
  185. package/ui-uni/uni-icons/icons.js +0 -132
  186. package/ui-uni/uni-icons/uni-icons.vue +0 -72
  187. package/ui-uni/uni-link/uni-link.vue +0 -117
  188. package/ui-uni/uni-load-more/uni-load-more.vue +0 -366
  189. package/ui-uni/uni-rate/uni-rate.vue +0 -357
  190. package/ui-uni/uni-row/uni-row.vue +0 -155
@@ -1,30 +1,26 @@
1
1
  <template>
2
- <cv-form-item
3
- :tip="tip"
4
- :must="must"
5
- :label="label"
6
- :message="message"
7
- :messageDisplay="messageDisplay"
8
- :labelWidth="localLabelWidth"
9
- :layout="localLayout"
10
- :onQClear="onQClear"
11
- :rtip="rtip"
12
- :input-value="localVal"
13
- >
14
- <view class="cv-input-text">
15
- <input
16
- class="cv-input-text-item"
17
- placeholder-class="cv-input-text-item-placeholder"
18
- v-model="localVal"
19
- type="number"
20
- :maxlength="maxlength"
21
- :disabled="disabled"
22
- :placeholder="placeholder"
23
- @input="updateInput"
24
- @blur="onBlur"
25
- />
2
+ <view class="cv-input-text">
3
+ <input
4
+ class="cv-input__content"
5
+ placeholder-class="cv-input__placeholder"
6
+ v-model="localVal"
7
+ type="number"
8
+ :maxlength="maxlength"
9
+ :disabled="disabled"
10
+ :placeholder="placeholder"
11
+ @input="funcOnInput"
12
+ @blur="onBlur"
13
+ />
14
+ <!-- 输入框右侧信息 -->
15
+ <view class="cv-input__right">
16
+ <!-- 清空 -->
17
+ <view class="cv-input__clear" @click="onEmpty" v-if="clearable == true && localVal != ''">X</view>
18
+ <!-- 追加-->
19
+ <view class="cv-input__append" v-if="$slots['append']">
20
+ <slot name="append"></slot>
21
+ </view>
26
22
  </view>
27
- </cv-form-item>
23
+ </view>
28
24
  </template>
29
25
 
30
26
  <script>
@@ -39,7 +35,12 @@ export default {
39
35
  }
40
36
  }
41
37
  },
42
- props: {},
38
+ props: {
39
+ placeholder: {
40
+ type: [String],
41
+ default: '请输入数字'
42
+ }
43
+ },
43
44
  data() {
44
45
  return {};
45
46
  },
@@ -48,7 +49,7 @@ export default {
48
49
  this.localVal = this._dealValue(newVal);
49
50
  }
50
51
  },
51
- created: function () {
52
+ created() {
52
53
  this.localVal = this._dealValue(this.value);
53
54
  },
54
55
  methods: {
@@ -64,9 +65,40 @@ export default {
64
65
  </script>
65
66
 
66
67
  <style>
67
- .cv-input-text-item {
68
+ .cv-input__content {
68
69
  height: 35px;
69
70
  line-height: 35px;
70
71
  font-size: 14px;
71
72
  }
73
+ .cv-input__placeholder {
74
+ font-size: 14px;
75
+ }
76
+ .cv-input__right {
77
+ height: 16px;
78
+ position: absolute;
79
+ bottom: 10px;
80
+ right: 0px;
81
+ z-index: 2;
82
+ }
83
+ .cv-input__clear {
84
+ width: 16px;
85
+ height: 16px;
86
+ border-radius: 50%;
87
+ background-color: rgba(0, 0, 0, 0.4);
88
+ font-size: 8px;
89
+ line-height: 16px;
90
+ text-align: center;
91
+ color: #fff;
92
+ float: left;
93
+ margin-left: 10px;
94
+ }
95
+ .cv-input__append {
96
+ color: rgba(0, 0, 0, 0.4);
97
+ width: 25px;
98
+ text-align: center;
99
+ overflow: hidden;
100
+ height: 16px;
101
+ font-size: 12px;
102
+ line-height: 16px;
103
+ }
72
104
  </style>
@@ -1,30 +1,32 @@
1
1
  <template>
2
- <cv-form-item
3
- :tip="tip"
4
- :must="must"
5
- :label="label"
6
- :message="message"
7
- :messageDisplay="messageDisplay"
8
- :labelWidth="localLabelWidth"
9
- :layout="localLayout"
10
- :onQClear="onQClear"
11
- :input-value="localVal"
12
- >
13
- <view class="cv-input-text">
14
- <input
15
- class="cv-input-text-item"
16
- placeholder-class="cv-input-text-item-placeholder"
17
- v-model="localVal"
18
- type="text"
19
- :maxlength="maxlength"
20
- :disabled="disabled"
21
- password
22
- :placeholder="placeholder"
23
- @input="updateInput"
24
- @blur="onBlur"
25
- />
2
+ <view class="cv-input-password">
3
+ <input
4
+ class="cv-input__content"
5
+ placeholder-class="cv-input__placeholder"
6
+ v-model="localVal"
7
+ type="text"
8
+ :maxlength="maxlength"
9
+ :disabled="disabled"
10
+ :password="!showPassword"
11
+ :placeholder="placeholder"
12
+ @input="funcOnInput"
13
+ @blur="onBlur"
14
+ />
15
+ <!-- 输入框右侧信息 -->
16
+ <view class="cv-input__right">
17
+ <!-- 清空 -->
18
+ <view class="cv-input__clear" @click="onEmpty" v-if="clearable == true && localVal != ''">X</view>
19
+ <!-- 眼睛-->
20
+ <cv-icons2
21
+ class="cv-input__eyes"
22
+ v-if="localVal != '' && passwordIcon"
23
+ :type="showPassword ? 'eye-slash-filled' : 'eye-filled'"
24
+ :size="18"
25
+ color="rgba(0, 0, 0, 0.4)"
26
+ @click="onEyes"
27
+ ></cv-icons2>
26
28
  </view>
27
- </cv-form-item>
29
+ </view>
28
30
  </template>
29
31
 
30
32
  <script>
@@ -39,19 +41,67 @@ export default {
39
41
  }
40
42
  }
41
43
  },
42
- props: {},
44
+ props: {
45
+ placeholder: {
46
+ type: [String],
47
+ default: '请输入密码'
48
+ },
49
+ passwordIcon: {
50
+ type: Boolean,
51
+ default: true
52
+ }
53
+ },
43
54
  watch: {},
44
55
  data() {
45
- return {};
56
+ return {
57
+ showPassword: false
58
+ };
46
59
  },
47
- created: function () {},
48
- methods: {}
60
+ created() {},
61
+ methods: {
62
+ onEyes() {
63
+ this.showPassword = !this.showPassword;
64
+ }
65
+ }
49
66
  };
50
67
  </script>
51
68
  <style>
52
- .cv-input-text-item {
69
+ .cv-input__content {
53
70
  height: 35px;
54
71
  line-height: 35px;
55
72
  font-size: 14px;
56
73
  }
74
+
75
+ .cv-input__placeholder {
76
+ font-size: 14px;
77
+ }
78
+ .cv-input__right {
79
+ height: 16px;
80
+ position: absolute;
81
+ bottom: 10px;
82
+ right: 0px;
83
+ z-index: 2;
84
+ }
85
+ .cv-input__clear {
86
+ width: 16px;
87
+ height: 16px;
88
+ border-radius: 50%;
89
+ background-color: rgba(0, 0, 0, 0.4);
90
+ font-size: 8px;
91
+ line-height: 16px;
92
+ text-align: center;
93
+ color: #fff;
94
+ float: left;
95
+ margin-left: 10px;
96
+ }
97
+ .cv-input__eyes {
98
+ color: rgba(0, 0, 0, 0.4);
99
+ width: 25px;
100
+ text-align: center;
101
+ overflow: hidden;
102
+ height: 16px;
103
+ font-size: 12px;
104
+ line-height: 16px;
105
+ padding: 0 5px;
106
+ }
57
107
  </style>
@@ -1,31 +1,27 @@
1
1
  <template>
2
- <cv-form-item
3
- :tip="tip"
4
- :label="label"
5
- :message="message"
6
- :must="must"
7
- :messageDisplay="messageDisplay"
8
- :labelWidth="localLabelWidth"
9
- :layout="localLayout"
10
- :onQClear="onQClear"
11
- :rtip="rtip"
12
- :inputValue="localVal"
13
- >
14
- <view class="cv-input-text" ref="onEmpty">
15
- <input
16
- class="cv-input-text-item"
17
- :style="localItemStyle"
18
- placeholder-class="cv-input-text-item-placeholder"
19
- v-model="localVal"
20
- type="text"
21
- :placeholder="placeholder"
22
- :maxlength="maxlength"
23
- :disabled="disabled"
24
- @input="updateInput"
25
- @blur="onBlur"
26
- />
2
+ <view class="cv-input-text">
3
+ <input
4
+ class="cv-input__content"
5
+ :style="localStyle"
6
+ placeholder-class="cv-input__placeholder"
7
+ v-model="localVal"
8
+ type="text"
9
+ :placeholder="placeholder"
10
+ :maxlength="maxlength"
11
+ :disabled="disabled"
12
+ @input="funcOnInput"
13
+ @blur="onBlur"
14
+ />
15
+ <!-- 输入框右侧信息 -->
16
+ <view class="cv-input__right">
17
+ <!-- 清空 -->
18
+ <view class="cv-input__clear" @click="onEmpty" v-if="clearable == true && localVal != ''">X</view>
19
+ <!-- 追加-->
20
+ <view class="cv-input__append" v-if="$slots['append']">
21
+ <slot name="append"></slot>
22
+ </view>
27
23
  </view>
28
- </cv-form-item>
24
+ </view>
29
25
  </template>
30
26
 
31
27
  <script>
@@ -37,31 +33,53 @@ export default {
37
33
  addGlobalClass: true
38
34
  },
39
35
  props: {
40
- rtip: {
41
- type: String,
42
- default: ''
36
+ placeholder: {
37
+ type: [String],
38
+ default: '请输入文本'
43
39
  }
44
40
  },
45
41
  data() {
46
42
  return {};
47
43
  },
48
- created: function () {},
44
+ created() {},
49
45
  methods: {}
50
46
  };
51
47
  </script>
52
48
  <style>
53
- .cv-input-text-item {
49
+ .cv-input__content {
54
50
  height: 35px;
55
51
  line-height: 35px;
56
52
  font-size: 14px;
57
53
  }
58
- .cv-input-text-rtip {
59
- color: #999;
60
- width: 50rpx;
61
- padding: 10rpx 0rpx 10rpx 0;
54
+ .cv-input__placeholder {
55
+ font-size: 14px;
56
+ }
57
+ .cv-input__right {
58
+ height: 16px;
62
59
  position: absolute;
63
- right: 0;
64
- top: -7px;
60
+ bottom: 10px;
61
+ right: 0px;
62
+ z-index: 2;
63
+ }
64
+ .cv-input__clear {
65
+ width: 16px;
66
+ height: 16px;
67
+ border-radius: 50%;
68
+ background-color: rgba(0, 0, 0, 0.4);
69
+ font-size: 8px;
70
+ line-height: 16px;
71
+ text-align: center;
72
+ color: #fff;
73
+ float: left;
74
+ margin-left: 10px;
75
+ }
76
+ .cv-input__append {
77
+ color: rgba(0, 0, 0, 0.4);
78
+ width: 25px;
79
+ text-align: center;
65
80
  overflow: hidden;
81
+ height: 16px;
82
+ font-size: 12px;
83
+ line-height: 16px;
66
84
  }
67
85
  </style>
@@ -0,0 +1,130 @@
1
+ <template>
2
+ <a
3
+ v-if="isShowA"
4
+ class="uni-link"
5
+ :href="href"
6
+ :class="{ 'uni-link--withline': showUnderLine === true || showUnderLine === 'true' }"
7
+ :style="{ color, fontSize: fontSize + 'px' }"
8
+ :download="download"
9
+ >
10
+ <slot>{{ text }}</slot>
11
+ </a>
12
+ <text
13
+ v-else
14
+ class="uni-link"
15
+ :class="{ 'uni-link--withline': showUnderLine === true || showUnderLine === 'true' }"
16
+ :style="{ color, fontSize: fontSize + 'px' }"
17
+ @click="openURL"
18
+ >
19
+ <slot>{{ text }}</slot>
20
+ </text>
21
+ </template>
22
+
23
+ <script>
24
+ /**
25
+ * Link 外部网页超链接组件
26
+ * @description uni-link是一个外部网页超链接组件,在小程序内复制url,在app内打开外部浏览器,在h5端打开新网页
27
+ * @tutorial https://ext.dcloud.net.cn/plugin?id=1182
28
+ * @property {String} href 点击后打开的外部网页url
29
+ * @property {String} text 显示的文字
30
+ * @property {String} downlaod H5平台下载文件名
31
+ * @property {Boolean} showUnderLine 是否显示下划线
32
+ * @property {String} copyTips 在小程序端复制链接时显示的提示语
33
+ * @property {String} color 链接文字颜色
34
+ * @property {String} fontSize 链接文字大小
35
+ * @example * <uni-link href="https://ext.dcloud.net.cn" text="https://ext.dcloud.net.cn"></uni-link>
36
+ */
37
+ export default {
38
+ name: 'uniLink',
39
+ props: {
40
+ href: {
41
+ type: String,
42
+ default: ''
43
+ },
44
+ text: {
45
+ type: String,
46
+ default: ''
47
+ },
48
+ download: {
49
+ type: String,
50
+ default: ''
51
+ },
52
+ showUnderLine: {
53
+ type: [Boolean, String],
54
+ default: true
55
+ },
56
+ copyTips: {
57
+ type: String,
58
+ default: '已自动复制网址,请在手机浏览器里粘贴该网址'
59
+ },
60
+ color: {
61
+ type: String,
62
+ default: '#999999'
63
+ },
64
+ fontSize: {
65
+ type: [Number, String],
66
+ default: 14
67
+ }
68
+ },
69
+ computed: {
70
+ isShowA() {
71
+ // #ifdef H5
72
+ this._isH5 = true;
73
+ // #endif
74
+ if ((this.isMail() || this.isTel()) && this._isH5 === true) {
75
+ return true;
76
+ }
77
+ return false;
78
+ }
79
+ },
80
+ created() {
81
+ this._isH5 = null;
82
+ },
83
+ methods: {
84
+ isMail() {
85
+ return this.href.startsWith('mailto:');
86
+ },
87
+ isTel() {
88
+ return this.href.startsWith('tel:');
89
+ },
90
+ openURL() {
91
+ // #ifdef APP-PLUS
92
+ if (this.isTel()) {
93
+ this.makePhoneCall(this.href.replace('tel:', ''));
94
+ } else {
95
+ plus.runtime.openURL(this.href);
96
+ }
97
+ // #endif
98
+ // #ifdef H5
99
+ window.open(this.href);
100
+ // #endif
101
+ // #ifdef MP
102
+ uni.setClipboardData({
103
+ data: this.href
104
+ });
105
+ uni.showModal({
106
+ content: this.copyTips,
107
+ showCancel: false
108
+ });
109
+ // #endif
110
+ },
111
+ makePhoneCall(phoneNumber) {
112
+ uni.makePhoneCall({
113
+ phoneNumber
114
+ });
115
+ }
116
+ }
117
+ };
118
+ </script>
119
+
120
+ <style scoped>
121
+ /* #ifndef APP-NVUE */
122
+ .uni-link {
123
+ cursor: pointer;
124
+ }
125
+
126
+ /* #endif */
127
+ .uni-link--withline {
128
+ text-decoration: underline;
129
+ }
130
+ </style>
File without changes
@@ -1,10 +1,10 @@
1
1
  {
2
- "id": "29",
3
- "name": "LoadMore",
4
- "desc": "加载更多",
5
- "url": "load-more",
6
- "type": "功能组件",
7
- "edition": "1.1.5",
8
- "path": "https://ext.dcloud.net.cn/plugin?id=29",
9
- "update_log": "- 新增 颜色大小等配置项"
10
- }
2
+ "id": "29",
3
+ "name": "LoadMore",
4
+ "desc": "加载更多",
5
+ "url": "load-more",
6
+ "type": "功能组件",
7
+ "edition": "1.1.5",
8
+ "path": "https://ext.dcloud.net.cn/plugin?id=29",
9
+ "update_log": "- 新增 颜色大小等配置项"
10
+ }
@@ -66,10 +66,32 @@
66
66
  </template>
67
67
 
68
68
  <script>
69
- const platform = uni.getSystemInfoSync().platform;
70
-
69
+ let platform;
70
+ setTimeout(() => {
71
+ platform = uni.getSystemInfoSync().platform;
72
+ }, 16);
73
+
74
+ /**
75
+ * LoadMore 加载更多
76
+ * @description 用于列表中,做滚动加载使用,展示 loading 的各种状态
77
+ * @tutorial https://ext.dcloud.net.cn/plugin?id=29
78
+ * @property {String} status = [more|loading|noMore] loading 的状态
79
+ * @value more loading前
80
+ * @value loading loading中
81
+ * @value noMore 没有更多了
82
+ * @property {Number} iconSize 指定图标大小
83
+ * @property {Boolean} iconSize = [true|false] 是否显示 loading 图标
84
+ * @property {String} iconType = [snow|circle|auto] 指定图标样式
85
+ * @value snow ios雪花加载样式
86
+ * @value circle 安卓唤醒加载样式
87
+ * @value auto 根据平台自动选择加载样式
88
+ * @property {String} color 图标和文字颜色
89
+ * @property {Object} contentText 各状态文字说明,值为:{contentdown: "上拉显示更多",contentrefresh: "正在加载...",contentnomore: "没有更多数据了"}
90
+ * @event {Function} clickLoadMore 点击加载更多时触发
91
+ */
71
92
  export default {
72
93
  name: 'cvLoadMore',
94
+ emits: ['clickLoadMore'],
73
95
  props: {
74
96
  status: {
75
97
  // 上拉的状态:more-loading前;loading-loading中;noMore-没有更多了
@@ -141,7 +163,7 @@ export default {
141
163
  };
142
164
  </script>
143
165
 
144
- <style>
166
+ <style scoped>
145
167
  .cv-load-more {
146
168
  /* #ifndef APP-NVUE */
147
169
  display: flex;
@@ -256,7 +278,6 @@ export default {
256
278
  }
257
279
 
258
280
  /* #endif */
259
-
260
281
  /* #ifdef H5 */
261
282
  .cv-load-more__img--android-H5 {
262
283
  animation: loading-android-H5-rotate 2s linear infinite;
@@ -298,7 +319,6 @@ export default {
298
319
  }
299
320
 
300
321
  /* #endif */
301
-
302
322
  /* #ifndef APP-NVUE || H5 */
303
323
  .cv-load-more__img--android-MP {
304
324
  position: relative;
@@ -345,34 +365,43 @@ export default {
345
365
  0% {
346
366
  transform: rotate(0deg);
347
367
  }
368
+
348
369
  50% {
349
370
  transform: rotate(90deg);
350
371
  }
372
+
351
373
  100% {
352
374
  transform: rotate(360deg);
353
375
  }
354
376
  }
377
+
355
378
  @keyframes loading-android-MP-2 {
356
379
  0% {
357
380
  transform: rotate(0deg);
358
381
  }
382
+
359
383
  50% {
360
384
  transform: rotate(180deg);
361
385
  }
386
+
362
387
  100% {
363
388
  transform: rotate(360deg);
364
389
  }
365
390
  }
391
+
366
392
  @keyframes loading-android-MP-3 {
367
393
  0% {
368
394
  transform: rotate(0deg);
369
395
  }
396
+
370
397
  50% {
371
398
  transform: rotate(270deg);
372
399
  }
400
+
373
401
  100% {
374
402
  transform: rotate(360deg);
375
403
  }
376
404
  }
405
+
377
406
  /* #endif */
378
407
  </style>
@@ -22,7 +22,7 @@ export default {
22
22
  loaclStyle: {}
23
23
  };
24
24
  },
25
- created: function () {
25
+ created() {
26
26
  this.loaclStyle = { color: this.color };
27
27
  }
28
28
  };
@@ -80,7 +80,7 @@ export default {
80
80
  isViewPla: true
81
81
  };
82
82
  },
83
- created: function () {
83
+ created() {
84
84
  this._dealStyle();
85
85
  this._changeIsViewPla();
86
86
  },
@@ -96,7 +96,7 @@ export default {
96
96
  data() {
97
97
  return {};
98
98
  },
99
- created: function () {
99
+ created() {
100
100
  // console.log(this.$slots);
101
101
  },
102
102
  methods: {