uview-ui-wjf 1.0.0

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 (368) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +71 -0
  3. package/changelog.md +388 -0
  4. package/components/u--form/u--form.vue +92 -0
  5. package/components/u--image/u--image.vue +73 -0
  6. package/components/u--input/u--input.vue +115 -0
  7. package/components/u--text/u--text.vue +72 -0
  8. package/components/u--textarea/u--textarea.vue +85 -0
  9. package/components/u-action-sheet/props.js +54 -0
  10. package/components/u-action-sheet/u-action-sheet.vue +278 -0
  11. package/components/u-album/props.js +59 -0
  12. package/components/u-album/u-album.vue +259 -0
  13. package/components/u-alert/props.js +44 -0
  14. package/components/u-alert/u-alert.vue +243 -0
  15. package/components/u-avatar/props.js +78 -0
  16. package/components/u-avatar/u-avatar.vue +173 -0
  17. package/components/u-avatar-group/props.js +52 -0
  18. package/components/u-avatar-group/u-avatar-group.vue +103 -0
  19. package/components/u-back-top/props.js +54 -0
  20. package/components/u-back-top/u-back-top.vue +129 -0
  21. package/components/u-badge/props.js +72 -0
  22. package/components/u-badge/u-badge.vue +171 -0
  23. package/components/u-button/nvue.scss +46 -0
  24. package/components/u-button/props.js +161 -0
  25. package/components/u-button/u-button.vue +495 -0
  26. package/components/u-button/vue.scss +80 -0
  27. package/components/u-calendar/header.vue +99 -0
  28. package/components/u-calendar/month.vue +579 -0
  29. package/components/u-calendar/props.js +144 -0
  30. package/components/u-calendar/u-calendar.vue +384 -0
  31. package/components/u-calendar/util.js +85 -0
  32. package/components/u-car-keyboard/props.js +14 -0
  33. package/components/u-car-keyboard/u-car-keyboard.vue +311 -0
  34. package/components/u-cell/props.js +110 -0
  35. package/components/u-cell/u-cell.vue +229 -0
  36. package/components/u-cell-group/props.js +14 -0
  37. package/components/u-cell-group/u-cell-group.vue +61 -0
  38. package/components/u-checkbox/props.js +69 -0
  39. package/components/u-checkbox/u-checkbox.vue +344 -0
  40. package/components/u-checkbox-group/props.js +82 -0
  41. package/components/u-checkbox-group/u-checkbox-group.vue +103 -0
  42. package/components/u-circle-progress/props.js +8 -0
  43. package/components/u-circle-progress/u-circle-progress.vue +198 -0
  44. package/components/u-code/props.js +34 -0
  45. package/components/u-code/u-code.vue +129 -0
  46. package/components/u-code-input/props.js +79 -0
  47. package/components/u-code-input/u-code-input.vue +252 -0
  48. package/components/u-col/props.js +29 -0
  49. package/components/u-col/u-col.vue +162 -0
  50. package/components/u-collapse/props.js +19 -0
  51. package/components/u-collapse/u-collapse.vue +90 -0
  52. package/components/u-collapse-item/props.js +59 -0
  53. package/components/u-collapse-item/u-collapse-item.vue +225 -0
  54. package/components/u-column-notice/props.js +55 -0
  55. package/components/u-column-notice/u-column-notice.vue +160 -0
  56. package/components/u-count-down/props.js +24 -0
  57. package/components/u-count-down/u-count-down.vue +163 -0
  58. package/components/u-count-down/utils.js +62 -0
  59. package/components/u-count-to/props.js +59 -0
  60. package/components/u-count-to/u-count-to.vue +184 -0
  61. package/components/u-datetime-picker/props.js +120 -0
  62. package/components/u-datetime-picker/u-datetime-picker.vue +361 -0
  63. package/components/u-divider/props.js +44 -0
  64. package/components/u-divider/u-divider.vue +116 -0
  65. package/components/u-dropdown/props.js +65 -0
  66. package/components/u-dropdown/u-dropdown.vue +127 -0
  67. package/components/u-dropdown-item/props.js +36 -0
  68. package/components/u-dropdown-item/u-dropdown-item.vue +127 -0
  69. package/components/u-empty/props.js +59 -0
  70. package/components/u-empty/u-empty.vue +128 -0
  71. package/components/u-form/props.js +45 -0
  72. package/components/u-form/u-form.vue +214 -0
  73. package/components/u-form-item/props.js +48 -0
  74. package/components/u-form-item/u-form-item.vue +235 -0
  75. package/components/u-gap/props.js +24 -0
  76. package/components/u-gap/u-gap.vue +38 -0
  77. package/components/u-grid/props.js +19 -0
  78. package/components/u-grid/u-grid.vue +97 -0
  79. package/components/u-grid-item/props.js +14 -0
  80. package/components/u-grid-item/u-grid-item.vue +209 -0
  81. package/components/u-icon/icons.js +214 -0
  82. package/components/u-icon/props.js +89 -0
  83. package/components/u-icon/u-icon.vue +237 -0
  84. package/components/u-image/props.js +84 -0
  85. package/components/u-image/u-image.vue +232 -0
  86. package/components/u-index-anchor/props.js +29 -0
  87. package/components/u-index-anchor/u-index-anchor.vue +91 -0
  88. package/components/u-index-item/props.js +5 -0
  89. package/components/u-index-item/u-index-item.vue +87 -0
  90. package/components/u-index-list/props.js +29 -0
  91. package/components/u-index-list/u-index-list.vue +440 -0
  92. package/components/u-input/props.js +187 -0
  93. package/components/u-input/u-input.vue +369 -0
  94. package/components/u-keyboard/props.js +84 -0
  95. package/components/u-keyboard/u-keyboard.vue +164 -0
  96. package/components/u-line/props.js +33 -0
  97. package/components/u-line/u-line.vue +62 -0
  98. package/components/u-line-progress/props.js +28 -0
  99. package/components/u-line-progress/u-line-progress.vue +144 -0
  100. package/components/u-link/props.js +39 -0
  101. package/components/u-link/u-link.vue +83 -0
  102. package/components/u-list/props.js +76 -0
  103. package/components/u-list/u-list.vue +157 -0
  104. package/components/u-list-item/props.js +9 -0
  105. package/components/u-list-item/u-list-item.vue +116 -0
  106. package/components/u-loading-icon/props.js +59 -0
  107. package/components/u-loading-icon/u-loading-icon.vue +343 -0
  108. package/components/u-loading-page/props.js +49 -0
  109. package/components/u-loading-page/u-loading-page.vue +115 -0
  110. package/components/u-loadmore/props.js +94 -0
  111. package/components/u-loadmore/u-loadmore.vue +150 -0
  112. package/components/u-modal/props.js +89 -0
  113. package/components/u-modal/u-modal.vue +228 -0
  114. package/components/u-navbar/props.js +84 -0
  115. package/components/u-navbar/u-navbar.vue +186 -0
  116. package/components/u-no-network/props.js +19 -0
  117. package/components/u-no-network/u-no-network.vue +220 -0
  118. package/components/u-notice-bar/props.js +70 -0
  119. package/components/u-notice-bar/u-notice-bar.vue +101 -0
  120. package/components/u-notify/props.js +49 -0
  121. package/components/u-notify/u-notify.vue +211 -0
  122. package/components/u-number-box/props.js +109 -0
  123. package/components/u-number-box/u-number-box.vue +416 -0
  124. package/components/u-number-keyboard/props.js +19 -0
  125. package/components/u-number-keyboard/u-number-keyboard.vue +196 -0
  126. package/components/u-overlay/props.js +24 -0
  127. package/components/u-overlay/u-overlay.vue +68 -0
  128. package/components/u-parse/node/node.vue +499 -0
  129. package/components/u-parse/parser.js +1075 -0
  130. package/components/u-parse/props.js +45 -0
  131. package/components/u-parse/u-parse.vue +366 -0
  132. package/components/u-picker/props.js +79 -0
  133. package/components/u-picker/u-picker.vue +286 -0
  134. package/components/u-picker-column/props.js +5 -0
  135. package/components/u-picker-column/u-picker-column.vue +27 -0
  136. package/components/u-popup/props.js +79 -0
  137. package/components/u-popup/u-popup.vue +304 -0
  138. package/components/u-radio/props.js +64 -0
  139. package/components/u-radio/u-radio.vue +339 -0
  140. package/components/u-radio-group/props.js +85 -0
  141. package/components/u-radio-group/u-radio-group.vue +108 -0
  142. package/components/u-rate/props.js +69 -0
  143. package/components/u-rate/u-rate.vue +306 -0
  144. package/components/u-read-more/props.js +61 -0
  145. package/components/u-read-more/u-read-more.vue +157 -0
  146. package/components/u-row/props.js +19 -0
  147. package/components/u-row/u-row.vue +93 -0
  148. package/components/u-row-notice/props.js +39 -0
  149. package/components/u-row-notice/u-row-notice.vue +330 -0
  150. package/components/u-safe-bottom/props.js +5 -0
  151. package/components/u-safe-bottom/u-safe-bottom.vue +56 -0
  152. package/components/u-scroll-list/nvue.js +28 -0
  153. package/components/u-scroll-list/other.js +0 -0
  154. package/components/u-scroll-list/props.js +34 -0
  155. package/components/u-scroll-list/scrollWxs.wxs +50 -0
  156. package/components/u-scroll-list/u-scroll-list.vue +224 -0
  157. package/components/u-search/props.js +118 -0
  158. package/components/u-search/u-search.vue +303 -0
  159. package/components/u-skeleton/props.js +59 -0
  160. package/components/u-skeleton/u-skeleton.vue +244 -0
  161. package/components/u-slider/mpother.js +113 -0
  162. package/components/u-slider/mpwxs.js +42 -0
  163. package/components/u-slider/mpwxs.wxs +121 -0
  164. package/components/u-slider/nvue - /345/211/257/346/234/254.js" +180 -0
  165. package/components/u-slider/nvue.js +193 -0
  166. package/components/u-slider/props.js +54 -0
  167. package/components/u-slider/u-slider.vue +55 -0
  168. package/components/u-status-bar/props.js +8 -0
  169. package/components/u-status-bar/u-status-bar.vue +46 -0
  170. package/components/u-steps/props.js +39 -0
  171. package/components/u-steps/u-steps.vue +80 -0
  172. package/components/u-steps-item/props.js +24 -0
  173. package/components/u-steps-item/u-steps-item.vue +316 -0
  174. package/components/u-sticky/props.js +40 -0
  175. package/components/u-sticky/u-sticky.vue +212 -0
  176. package/components/u-subsection/props.js +49 -0
  177. package/components/u-subsection/u-subsection.vue +299 -0
  178. package/components/u-swipe-action/props.js +9 -0
  179. package/components/u-swipe-action/u-swipe-action.vue +67 -0
  180. package/components/u-swipe-action-item/index - backup.wxs +256 -0
  181. package/components/u-swipe-action-item/index.wxs +225 -0
  182. package/components/u-swipe-action-item/nvue - backup.js +270 -0
  183. package/components/u-swipe-action-item/nvue.js +174 -0
  184. package/components/u-swipe-action-item/props.js +41 -0
  185. package/components/u-swipe-action-item/u-swipe-action-item.vue +190 -0
  186. package/components/u-swipe-action-item/wxs.js +15 -0
  187. package/components/u-swiper/props.js +125 -0
  188. package/components/u-swiper/u-swiper.vue +255 -0
  189. package/components/u-swiper-indicator/props.js +29 -0
  190. package/components/u-swiper-indicator/u-swiper-indicator.vue +110 -0
  191. package/components/u-switch/props.js +54 -0
  192. package/components/u-switch/u-switch.vue +177 -0
  193. package/components/u-tabbar/props.js +44 -0
  194. package/components/u-tabbar/u-tabbar.vue +141 -0
  195. package/components/u-tabbar-item/props.js +35 -0
  196. package/components/u-tabbar-item/u-tabbar-item.vue +142 -0
  197. package/components/u-table/props.js +5 -0
  198. package/components/u-table/u-table.vue +29 -0
  199. package/components/u-tabs/props.js +64 -0
  200. package/components/u-tabs/u-tabs.vue +363 -0
  201. package/components/u-tabs-item/props.js +5 -0
  202. package/components/u-tabs-item/u-tabs-item.vue +29 -0
  203. package/components/u-tag/props.js +84 -0
  204. package/components/u-tag/u-tag.vue +358 -0
  205. package/components/u-td/props.js +5 -0
  206. package/components/u-td/u-td.vue +31 -0
  207. package/components/u-text/props.js +110 -0
  208. package/components/u-text/u-text.vue +223 -0
  209. package/components/u-text/value.js +85 -0
  210. package/components/u-textarea/props.js +119 -0
  211. package/components/u-textarea/u-textarea.vue +239 -0
  212. package/components/u-toast/u-toast.vue +291 -0
  213. package/components/u-toolbar/props.js +34 -0
  214. package/components/u-toolbar/u-toolbar.vue +102 -0
  215. package/components/u-tooltip/clipboard.min.js +58 -0
  216. package/components/u-tooltip/props.js +59 -0
  217. package/components/u-tooltip/u-tooltip.vue +366 -0
  218. package/components/u-tr/props.js +5 -0
  219. package/components/u-tr/u-tr.vue +31 -0
  220. package/components/u-transition/nvue.ani-map.js +68 -0
  221. package/components/u-transition/props.js +24 -0
  222. package/components/u-transition/transition.js +157 -0
  223. package/components/u-transition/u-transition.vue +92 -0
  224. package/components/u-transition/vue.ani-style.scss +113 -0
  225. package/components/u-upload/mixin.js +21 -0
  226. package/components/u-upload/props.js +124 -0
  227. package/components/u-upload/u-upload.vue +566 -0
  228. package/components/u-upload/utils.js +151 -0
  229. package/components/uview-ui/uview-ui.vue +15 -0
  230. package/index.js +79 -0
  231. package/index.scss +23 -0
  232. package/libs/config/color.js +17 -0
  233. package/libs/config/config.js +34 -0
  234. package/libs/config/props/actionSheet.js +25 -0
  235. package/libs/config/props/album.js +25 -0
  236. package/libs/config/props/alert.js +22 -0
  237. package/libs/config/props/avatar.js +28 -0
  238. package/libs/config/props/avatarGroup.js +23 -0
  239. package/libs/config/props/backtop.js +27 -0
  240. package/libs/config/props/badge.js +27 -0
  241. package/libs/config/props/button.js +42 -0
  242. package/libs/config/props/calendar.js +42 -0
  243. package/libs/config/props/carKeyboard.js +15 -0
  244. package/libs/config/props/cell.js +35 -0
  245. package/libs/config/props/cellGroup.js +17 -0
  246. package/libs/config/props/checkbox.js +27 -0
  247. package/libs/config/props/checkboxGroup.js +29 -0
  248. package/libs/config/props/circleProgress.js +15 -0
  249. package/libs/config/props/code.js +21 -0
  250. package/libs/config/props/codeInput.js +29 -0
  251. package/libs/config/props/col.js +19 -0
  252. package/libs/config/props/collapse.js +17 -0
  253. package/libs/config/props/collapseItem.js +25 -0
  254. package/libs/config/props/columnNotice.js +24 -0
  255. package/libs/config/props/countDown.js +18 -0
  256. package/libs/config/props/countTo.js +25 -0
  257. package/libs/config/props/datetimePicker.js +37 -0
  258. package/libs/config/props/divider.js +23 -0
  259. package/libs/config/props/empty.js +26 -0
  260. package/libs/config/props/form.js +22 -0
  261. package/libs/config/props/formItem.js +23 -0
  262. package/libs/config/props/gap.js +19 -0
  263. package/libs/config/props/grid.js +17 -0
  264. package/libs/config/props/gridItem.js +16 -0
  265. package/libs/config/props/icon.js +36 -0
  266. package/libs/config/props/image.js +30 -0
  267. package/libs/config/props/indexAnchor.js +19 -0
  268. package/libs/config/props/indexList.js +19 -0
  269. package/libs/config/props/input.js +48 -0
  270. package/libs/config/props/keyboard.js +30 -0
  271. package/libs/config/props/line.js +20 -0
  272. package/libs/config/props/lineProgress.js +19 -0
  273. package/libs/config/props/link.js +26 -0
  274. package/libs/config/props/list.js +28 -0
  275. package/libs/config/props/listItem.js +15 -0
  276. package/libs/config/props/loadingIcon.js +30 -0
  277. package/libs/config/props/loadingPage.js +23 -0
  278. package/libs/config/props/loadmore.js +32 -0
  279. package/libs/config/props/modal.js +31 -0
  280. package/libs/config/props/navbar.js +32 -0
  281. package/libs/config/props/noNetwork.js +18 -0
  282. package/libs/config/props/noticeBar.js +27 -0
  283. package/libs/config/props/notify.js +22 -0
  284. package/libs/config/props/numberBox.js +35 -0
  285. package/libs/config/props/numberKeyboard.js +17 -0
  286. package/libs/config/props/overlay.js +18 -0
  287. package/libs/config/props/parse.js +22 -0
  288. package/libs/config/props/picker.js +29 -0
  289. package/libs/config/props/popup.js +29 -0
  290. package/libs/config/props/radio.js +27 -0
  291. package/libs/config/props/radioGroup.js +30 -0
  292. package/libs/config/props/rate.js +26 -0
  293. package/libs/config/props/readMore.js +22 -0
  294. package/libs/config/props/row.js +17 -0
  295. package/libs/config/props/rowNotice.js +21 -0
  296. package/libs/config/props/scrollList.js +20 -0
  297. package/libs/config/props/search.js +37 -0
  298. package/libs/config/props/section.js +24 -0
  299. package/libs/config/props/skeleton.js +25 -0
  300. package/libs/config/props/slider.js +25 -0
  301. package/libs/config/props/statusBar.js +15 -0
  302. package/libs/config/props/steps.js +21 -0
  303. package/libs/config/props/stepsItem.js +18 -0
  304. package/libs/config/props/sticky.js +20 -0
  305. package/libs/config/props/subsection.js +23 -0
  306. package/libs/config/props/swipeAction.js +15 -0
  307. package/libs/config/props/swipeActionItem.js +21 -0
  308. package/libs/config/props/swiper.js +39 -0
  309. package/libs/config/props/swipterIndicator.js +19 -0
  310. package/libs/config/props/switch.js +24 -0
  311. package/libs/config/props/tabbar.js +22 -0
  312. package/libs/config/props/tabbarItem.js +20 -0
  313. package/libs/config/props/tabs.js +32 -0
  314. package/libs/config/props/tag.js +29 -0
  315. package/libs/config/props/text.js +38 -0
  316. package/libs/config/props/textarea.js +36 -0
  317. package/libs/config/props/toast.js +30 -0
  318. package/libs/config/props/toolbar.js +21 -0
  319. package/libs/config/props/tooltip.js +25 -0
  320. package/libs/config/props/transition.js +18 -0
  321. package/libs/config/props/upload.js +36 -0
  322. package/libs/config/props.js +190 -0
  323. package/libs/config/zIndex.js +20 -0
  324. package/libs/css/color.scss +155 -0
  325. package/libs/css/common.scss +97 -0
  326. package/libs/css/components.scss +15 -0
  327. package/libs/css/flex.scss +257 -0
  328. package/libs/css/h5.scss +0 -0
  329. package/libs/css/mixin.scss +8 -0
  330. package/libs/css/mp.scss +0 -0
  331. package/libs/css/nvue.scss +0 -0
  332. package/libs/css/vue.scss +27 -0
  333. package/libs/function/colorGradient.js +134 -0
  334. package/libs/function/debounce.js +29 -0
  335. package/libs/function/digit.js +167 -0
  336. package/libs/function/index.js +731 -0
  337. package/libs/function/platform.js +75 -0
  338. package/libs/function/test.js +288 -0
  339. package/libs/function/throttle.js +30 -0
  340. package/libs/luch-request/adapters/index.js +97 -0
  341. package/libs/luch-request/core/InterceptorManager.js +50 -0
  342. package/libs/luch-request/core/Request.js +198 -0
  343. package/libs/luch-request/core/buildFullPath.js +20 -0
  344. package/libs/luch-request/core/defaults.js +29 -0
  345. package/libs/luch-request/core/dispatchRequest.js +3 -0
  346. package/libs/luch-request/core/mergeConfig.js +103 -0
  347. package/libs/luch-request/core/settle.js +16 -0
  348. package/libs/luch-request/helpers/buildURL.js +69 -0
  349. package/libs/luch-request/helpers/combineURLs.js +14 -0
  350. package/libs/luch-request/helpers/isAbsoluteURL.js +14 -0
  351. package/libs/luch-request/index.d.ts +116 -0
  352. package/libs/luch-request/index.js +3 -0
  353. package/libs/luch-request/utils/clone.js +264 -0
  354. package/libs/luch-request/utils.js +131 -0
  355. package/libs/mixin/button.js +13 -0
  356. package/libs/mixin/mixin.js +160 -0
  357. package/libs/mixin/mpMixin.js +8 -0
  358. package/libs/mixin/mpShare.js +13 -0
  359. package/libs/mixin/openType.js +25 -0
  360. package/libs/mixin/style.js +228 -0
  361. package/libs/mixin/touch.js +59 -0
  362. package/libs/util/async-validator.js +1343 -0
  363. package/libs/util/calendar.js +546 -0
  364. package/libs/util/dayjs.js +308 -0
  365. package/libs/util/emitter.js +51 -0
  366. package/libs/util/route.js +124 -0
  367. package/package.json +83 -0
  368. package/theme.scss +44 -0
@@ -0,0 +1,440 @@
1
+ <template>
2
+ <view class="u-index-list">
3
+ <!-- #ifdef APP-NVUE -->
4
+ <list
5
+ :scrollTop="scrollTop"
6
+ enable-back-to-top
7
+ :offset-accuracy="1"
8
+ :style="{
9
+ maxHeight: $u.addUnit(scrollViewHeight)
10
+ }"
11
+ @scroll="scrollHandler"
12
+ ref="uList"
13
+ >
14
+ <cell
15
+ v-if="$slots.header"
16
+ ref="header"
17
+ >
18
+ <slot name="header" />
19
+ </cell>
20
+ <slot />
21
+ <cell v-if="$slots.footer">
22
+ <slot name="footer" />
23
+ </cell>
24
+ </list>
25
+ <!-- #endif -->
26
+ <!-- #ifndef APP-NVUE -->
27
+ <scroll-view
28
+ :scrollTop="scrollTop"
29
+ :scrollIntoView="scrollIntoView"
30
+ :offset-accuracy="1"
31
+ :style="{
32
+ maxHeight: $u.addUnit(scrollViewHeight)
33
+ }"
34
+ scroll-y
35
+ @scroll="scrollHandler"
36
+ ref="uList"
37
+ >
38
+ <view v-if="$slots.header">
39
+ <slot name="header" />
40
+ </view>
41
+ <slot />
42
+ <view v-if="$slots.footer">
43
+ <slot name="footer" />
44
+ </view>
45
+ </scroll-view>
46
+ <!-- #endif -->
47
+ <view
48
+ class="u-index-list__letter"
49
+ ref="u-index-list__letter"
50
+ :style="{ top: $u.addUnit(letterInfo.top || 100) }"
51
+ @touchstart="touchStart"
52
+ @touchmove.stop.prevent="touchMove"
53
+ @touchend.stop.prevent="touchEnd"
54
+ @touchcancel.stop.prevent="touchEnd"
55
+ >
56
+ <view
57
+ class="u-index-list__letter__item"
58
+ v-for="(item, index) in uIndexList"
59
+ :key="index"
60
+ :style="{
61
+ backgroundColor: activeIndex === index ? activeColor : 'transparent'
62
+ }"
63
+ >
64
+ <text
65
+ class="u-index-list__letter__item__index"
66
+ :style="{color: activeIndex === index ? '#fff' : inactiveColor}"
67
+ >{{ item }}</text>
68
+ </view>
69
+ </view>
70
+ <u-transition
71
+ mode="fade"
72
+ :show="touching"
73
+ :customStyle="{
74
+ position: 'fixed',
75
+ right: '50px',
76
+ top: $u.addUnit(indicatorTop),
77
+ zIndex: 2
78
+ }"
79
+ >
80
+ <view
81
+ class="u-index-list__indicator"
82
+ :class="['u-index-list__indicator--show']"
83
+ :style="{
84
+ height: $u.addUnit(indicatorHeight),
85
+ width: $u.addUnit(indicatorHeight)
86
+ }"
87
+ >
88
+ <text class="u-index-list__indicator__text">{{ uIndexList[activeIndex] }}</text>
89
+ </view>
90
+ </u-transition>
91
+ </view>
92
+ </template>
93
+
94
+ <script>
95
+ const indexList = () => {
96
+ const indexList = [];
97
+ const charCodeOfA = 'A'.charCodeAt(0);
98
+ for (let i = 0; i < 26; i++) {
99
+ indexList.push(String.fromCharCode(charCodeOfA + i));
100
+ }
101
+ return indexList;
102
+ }
103
+ import props from './props.js';
104
+ // #ifdef APP-NVUE
105
+ // 由于weex为阿里的KPI业绩考核的产物,所以不支持百分比单位,这里需要通过dom查询组件的宽度
106
+ const dom = uni.requireNativePlugin('dom')
107
+ // #endif
108
+ /**
109
+ * IndexList 索引列表
110
+ * @description 通过折叠面板收纳内容区域
111
+ * @tutorial https://uviewui.com/components/indexList.html
112
+ * @property {String} inactiveColor 右边锚点非激活的颜色 ( 默认 '#606266' )
113
+ * @property {String} activeColor 右边锚点激活的颜色 ( 默认 '#5677fc' )
114
+ * @property {Array} indexList 索引字符列表,数组形式
115
+ * @property {Boolean} sticky 是否开启锚点自动吸顶 ( 默认 true )
116
+ * @property {String | Number} customNavHeight 自定义导航栏的高度 ( 默认 0 )
117
+ * */
118
+ export default {
119
+ name: 'u-index-list',
120
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
121
+ // #ifdef MP-WEIXIN
122
+ // 将自定义节点设置成虚拟的,更加接近Vue组件的表现,能更好的使用flex属性
123
+ options: {
124
+ virtualHost: true
125
+ },
126
+ // #endif
127
+ data() {
128
+ return {
129
+ // 当前正在被选中的字母索引
130
+ activeIndex: -1,
131
+ touchmoveIndex: 1,
132
+ // 索引字母的信息
133
+ letterInfo: {
134
+ height: 0,
135
+ itemHeight: 0,
136
+ top: 0
137
+ },
138
+ // 设置字母指示器的高度,后面为了让指示器跟随字母,并将尖角部分指向字母的中部,需要依赖此值
139
+ indicatorHeight: 50,
140
+ // 字母放大指示器的top值,为了让其指向当前激活的字母
141
+ // indicatorTop: 0
142
+ // 当前是否正在被触摸状态
143
+ touching: false,
144
+ // 滚动条顶部top值
145
+ scrollTop: 0,
146
+ // scroll-view的高度
147
+ scrollViewHeight: 0,
148
+ // 系统信息
149
+ sys: uni.$u.sys(),
150
+ scrolling: false,
151
+ scrollIntoView: '',
152
+ }
153
+ },
154
+ computed: {
155
+ // 如果有传入外部的indexList锚点数组则使用,否则使用内部生成A-Z字母
156
+ uIndexList() {
157
+ return this.indexList.length ? this.indexList : indexList()
158
+ },
159
+ // 字母放大指示器的top值,为了让其指向当前激活的字母
160
+ indicatorTop() {
161
+ const {
162
+ top,
163
+ itemHeight
164
+ } = this.letterInfo
165
+ return Math.floor(top + itemHeight * this.activeIndex + itemHeight / 2 - this.indicatorHeight / 2)
166
+ }
167
+ },
168
+ watch: {
169
+ // 监听字母索引的变化,重新设置尺寸
170
+ uIndexList: {
171
+ immediate: true,
172
+ handler() {
173
+ uni.$u.sleep().then(() => {
174
+ this.setIndexListLetterInfo()
175
+ })
176
+ }
177
+ }
178
+ },
179
+ created() {
180
+ this.children = []
181
+ this.anchors = []
182
+ this.init()
183
+ },
184
+ mounted() {
185
+ this.setIndexListLetterInfo()
186
+ },
187
+ methods: {
188
+ init() {
189
+ // 设置列表的高度为整个屏幕的高度
190
+ //减去this.customNavHeight,并将this.scrollViewHeight设置为maxHeight
191
+ //解决当u-index-list组件放在tabbar页面时,scroll-view内容较少时,还能滚动
192
+ this.scrollViewHeight = this.sys.windowHeight - this.customNavHeight
193
+ },
194
+ // 索引列表被触摸
195
+ touchStart(e) {
196
+ // 获取触摸点信息
197
+ const touchStart = e.changedTouches[0]
198
+ if (!touchStart) return
199
+ this.touching = true
200
+ const {
201
+ pageY
202
+ } = touchStart
203
+ // 根据当前触摸点的坐标,获取当前触摸的为第几个字母
204
+ const currentIndex = this.getIndexListLetter(pageY)
205
+ this.setValueForTouch(currentIndex)
206
+ },
207
+ // 索引字母列表被触摸滑动中
208
+ touchMove(e) {
209
+ // 获取触摸点信息
210
+ let touchMove = e.changedTouches[0]
211
+ if (!touchMove) return;
212
+
213
+ // 滑动结束后迅速开始第二次滑动时候 touching 为 false 造成不显示 indicator 问题
214
+ if (!this.touching) {
215
+ this.touching = true
216
+ }
217
+ const {
218
+ pageY
219
+ } = touchMove
220
+ const currentIndex = this.getIndexListLetter(pageY)
221
+ this.setValueForTouch(currentIndex)
222
+ },
223
+ // 触摸结束
224
+ touchEnd(e) {
225
+ // 延时一定时间后再隐藏指示器,为了让用户看的更直观,同时也是为了消除快速切换u-transition的show带来的影响
226
+ uni.$u.sleep(300).then(() => {
227
+ this.touching = false
228
+ })
229
+ },
230
+ // 获取索引列表的尺寸以及单个字符的尺寸信息
231
+ getIndexListLetterRect() {
232
+ return new Promise(resolve => {
233
+ // 延时一定时间,以获取dom尺寸
234
+ // #ifndef APP-NVUE
235
+ this.$uGetRect('.u-index-list__letter').then(size => {
236
+ resolve(size)
237
+ })
238
+ // #endif
239
+
240
+ // #ifdef APP-NVUE
241
+ const ref = this.$refs['u-index-list__letter']
242
+ dom.getComponentRect(ref, res => {
243
+ resolve(res.size)
244
+ })
245
+ // #endif
246
+ })
247
+ },
248
+ // 设置indexList索引的尺寸信息
249
+ setIndexListLetterInfo() {
250
+ this.getIndexListLetterRect().then(size => {
251
+ const {
252
+ height
253
+ } = size
254
+ const sys = uni.$u.sys()
255
+ const windowHeight = sys.windowHeight
256
+ let customNavHeight = 0
257
+ // 消除各端导航栏非原生和原生导致的差异,让索引列表字母对屏幕垂直居中
258
+ if (this.customNavHeight == 0) {
259
+ // #ifdef H5
260
+ customNavHeight = sys.windowTop
261
+ // #endif
262
+ // #ifndef H5
263
+ // 在非H5中,为原生导航栏,其高度不算在windowHeight内,这里设置为负值,后面相加时变成减去其高度的一半
264
+ customNavHeight = -(sys.statusBarHeight + 44)
265
+ // #endif
266
+ } else {
267
+ customNavHeight = uni.$u.getPx(this.customNavHeight)
268
+ }
269
+ this.letterInfo = {
270
+ height,
271
+ // 为了让字母列表对屏幕绝对居中,让其对导航栏进行修正,也即往上偏移导航栏的一半高度
272
+ top: (windowHeight - height) / 2 + customNavHeight / 2,
273
+ itemHeight: Math.floor(height / this.uIndexList.length)
274
+ }
275
+ })
276
+ },
277
+ // 获取当前被触摸的索引字母
278
+ getIndexListLetter(pageY) {
279
+ const {
280
+ top,
281
+ height,
282
+ itemHeight
283
+ } = this.letterInfo
284
+ // 对H5的pageY进行修正,这是由于uni-app自作多情在H5中将触摸点的坐标跟H5的导航栏结合导致的问题
285
+ // #ifdef H5
286
+ pageY += uni.$u.sys().windowTop
287
+ // #endif
288
+ // 对第一和最后一个字母做边界处理,因为用户可能在字母列表上触摸到两端的尽头后依然继续滑动
289
+ if (pageY < top) {
290
+ return 0
291
+ } else if (pageY >= top + height) {
292
+ // 如果超出了,取最后一个字母
293
+ return this.uIndexList.length - 1
294
+ } else {
295
+ // 将触摸点的Y轴偏移值,减去索引字母的top值,除以每个字母的高度,即可得到当前触摸点落在哪个字母上
296
+ return Math.floor((pageY - top) / itemHeight);
297
+ }
298
+ },
299
+ // 设置各项由触摸而导致变化的值
300
+ setValueForTouch(currentIndex) {
301
+ // 如果偏移量太小,前后得出的会是同一个索引字母,为了防抖,进行返回
302
+ if (currentIndex === this.activeIndex) return
303
+ this.activeIndex = currentIndex
304
+ // #ifndef APP-NVUE || MP-WEIXIN
305
+ // 在非nvue中,由于anchor和item都在u-index-item中,所以需要对index-item进行偏移
306
+ this.scrollIntoView = `u-index-item-${this.uIndexList[currentIndex].charCodeAt(0)}`
307
+ // #endif
308
+ // #ifdef MP-WEIXIN
309
+ // 微信小程序下,scroll-view的scroll-into-view属性无法对slot中的内容的id生效,只能通过设置scrollTop的形式去移动滚动条
310
+ this.scrollTop = this.children[currentIndex].top
311
+ // #endif
312
+ // #ifdef APP-NVUE
313
+ // 在nvue中,由于cell和header为同级元素,所以实际是需要对header(anchor)进行偏移
314
+ const anchor = `u-index-anchor-${this.uIndexList[currentIndex]}`
315
+ dom.scrollToElement(this.anchors[currentIndex].$refs[anchor], {
316
+ offset: 0,
317
+ animated: false
318
+ })
319
+ // #endif
320
+ },
321
+ getHeaderRect() {
322
+ // 获取header slot的高度,因为list组件中获取元素的尺寸是没有top值的
323
+ return new Promise(resolve => {
324
+ dom.getComponentRect(this.$refs.header, res => {
325
+ resolve(res.size)
326
+ })
327
+ })
328
+ },
329
+ // scroll-view的滚动事件
330
+ async scrollHandler(e) {
331
+ if (this.touching || this.scrolling) return
332
+ // 每过一定时间取样一次,减少资源损耗以及可能带来的卡顿
333
+ this.scrolling = true
334
+ uni.$u.sleep(10).then(() => {
335
+ this.scrolling = false
336
+ })
337
+ let scrollTop = 0
338
+ const len = this.children.length
339
+ let children = this.children
340
+ const anchors = this.anchors
341
+ // #ifdef APP-NVUE
342
+ // nvue下获取的滚动条偏移为负数,需要转为正数
343
+ scrollTop = Math.abs(e.contentOffset.y)
344
+ // 获取header slot的尺寸信息
345
+ const header = await this.getHeaderRect()
346
+ // item的top值,在nvue下,模拟出的anchor的top,类似非nvue下的index-item的top
347
+ let top = header.height
348
+ // 由于list组件无法获取cell的top值,这里通过header slot和各个item之间的height,模拟出类似非nvue下的位置信息
349
+ children = this.children.map((item, index) => {
350
+ const child = {
351
+ height: item.height,
352
+ top
353
+ }
354
+ // 进行累加,给下一个item提供计算依据
355
+ top += item.height + anchors[index].height
356
+ return child
357
+ })
358
+ // #endif
359
+ // #ifndef APP-NVUE
360
+ // 非nvue通过detail获取滚动条位移
361
+ scrollTop = e.detail.scrollTop
362
+ // #endif
363
+ for (let i = 0; i < len; i++) {
364
+ const item = children[i],
365
+ nextItem = children[i + 1]
366
+ // 如果滚动条高度小于第一个item的top值,此时无需设置任意字母为高亮
367
+ if (scrollTop <= children[0].top || scrollTop >= children[len - 1].top + children[len -
368
+ 1].height) {
369
+ this.activeIndex = -1
370
+ break
371
+ } else if (!nextItem) {
372
+ // 当不存在下一个item时,意味着历遍到了最后一个
373
+ this.activeIndex = len - 1
374
+ break
375
+ } else if (scrollTop > item.top && scrollTop < nextItem.top) {
376
+ this.activeIndex = i
377
+ break
378
+ }
379
+ }
380
+ },
381
+ },
382
+ }
383
+ </script>
384
+
385
+ <style lang="scss" scoped>
386
+ @import "../../libs/css/components.scss";
387
+
388
+ .u-index-list {
389
+
390
+ &__letter {
391
+ position: fixed;
392
+ right: 0;
393
+ text-align: center;
394
+ z-index: 3;
395
+ padding: 0 6px;
396
+
397
+ &__item {
398
+ width: 16px;
399
+ height: 16px;
400
+ border-radius: 100px;
401
+ margin: 1px 0;
402
+ @include flex;
403
+ align-items: center;
404
+ justify-content: center;
405
+
406
+ &--active {
407
+ background-color: $u-primary;
408
+ }
409
+
410
+ &__index {
411
+ font-size: 12px;
412
+ text-align: center;
413
+ line-height: 12px;
414
+ }
415
+ }
416
+ }
417
+
418
+ &__indicator {
419
+ width: 50px;
420
+ height: 50px;
421
+ border-radius: 100px 100px 0 100px;
422
+ text-align: center;
423
+ color: #ffffff;
424
+ background-color: #c9c9c9;
425
+ transform: rotate(-45deg);
426
+ @include flex;
427
+ justify-content: center;
428
+ align-items: center;
429
+
430
+ &__text {
431
+ font-size: 28px;
432
+ line-height: 28px;
433
+ font-weight: bold;
434
+ color: #fff;
435
+ transform: rotate(45deg);
436
+ text-align: center;
437
+ }
438
+ }
439
+ }
440
+ </style>
@@ -0,0 +1,187 @@
1
+ export default {
2
+ props: {
3
+ // 输入的值
4
+ value: {
5
+ type: [String, Number],
6
+ default: uni.$u.props.input.value
7
+ },
8
+ // 输入框类型
9
+ // number-数字输入键盘,app-vue下可以输入浮点数,app-nvue和小程序平台下只能输入整数
10
+ // idcard-身份证输入键盘,微信、支付宝、百度、QQ小程序
11
+ // digit-带小数点的数字键盘,App的nvue页面、微信、支付宝、百度、头条、QQ小程序
12
+ // text-文本输入键盘
13
+ type: {
14
+ type: String,
15
+ default: uni.$u.props.input.type
16
+ },
17
+ // 如果 textarea 是在一个 position:fixed 的区域,需要显示指定属性 fixed 为 true,
18
+ // 兼容性:微信小程序、百度小程序、字节跳动小程序、QQ小程序
19
+ fixed: {
20
+ type: Boolean,
21
+ default: uni.$u.props.input.fixed
22
+ },
23
+ // 是否禁用输入框
24
+ disabled: {
25
+ type: Boolean,
26
+ default: uni.$u.props.input.disabled
27
+ },
28
+ // 禁用状态时的背景色
29
+ disabledColor: {
30
+ type: String,
31
+ default: uni.$u.props.input.disabledColor
32
+ },
33
+ // 是否显示清除控件
34
+ clearable: {
35
+ type: Boolean,
36
+ default: uni.$u.props.input.clearable
37
+ },
38
+ // 是否密码类型
39
+ password: {
40
+ type: Boolean,
41
+ default: uni.$u.props.input.password
42
+ },
43
+ // 最大输入长度,设置为 -1 的时候不限制最大长度
44
+ maxlength: {
45
+ type: [String, Number],
46
+ default: uni.$u.props.input.maxlength
47
+ },
48
+ // 输入框为空时的占位符
49
+ placeholder: {
50
+ type: String,
51
+ default: uni.$u.props.input.placeholder
52
+ },
53
+ // 指定placeholder的样式类,注意页面或组件的style中写了scoped时,需要在类名前写/deep/
54
+ placeholderClass: {
55
+ type: String,
56
+ default: uni.$u.props.input.placeholderClass
57
+ },
58
+ // 指定placeholder的样式
59
+ placeholderStyle: {
60
+ type: [String, Object],
61
+ default: uni.$u.props.input.placeholderStyle
62
+ },
63
+ // 是否显示输入字数统计,只在 type ="text"或type ="textarea"时有效
64
+ showWordLimit: {
65
+ type: Boolean,
66
+ default: uni.$u.props.input.showWordLimit
67
+ },
68
+ // 设置右下角按钮的文字,有效值:send|search|next|go|done,兼容性详见uni-app文档
69
+ // https://uniapp.dcloud.io/component/input
70
+ // https://uniapp.dcloud.io/component/textarea
71
+ confirmType: {
72
+ type: String,
73
+ default: uni.$u.props.input.confirmType
74
+ },
75
+ // 点击键盘右下角按钮时是否保持键盘不收起,H5无效
76
+ confirmHold: {
77
+ type: Boolean,
78
+ default: uni.$u.props.input.confirmHold
79
+ },
80
+ // focus时,点击页面的时候不收起键盘,微信小程序有效
81
+ holdKeyboard: {
82
+ type: Boolean,
83
+ default: uni.$u.props.input.holdKeyboard
84
+ },
85
+ // 自动获取焦点
86
+ // 在 H5 平台能否聚焦以及软键盘是否跟随弹出,取决于当前浏览器本身的实现。nvue 页面不支持,需使用组件的 focus()、blur() 方法控制焦点
87
+ focus: {
88
+ type: Boolean,
89
+ default: uni.$u.props.input.focus
90
+ },
91
+ // 键盘收起时,是否自动失去焦点,目前仅App3.0.0+有效
92
+ autoBlur: {
93
+ type: Boolean,
94
+ default: uni.$u.props.input.autoBlur
95
+ },
96
+ // 是否去掉 iOS 下的默认内边距,仅微信小程序,且type=textarea时有效
97
+ disableDefaultPadding: {
98
+ type: Boolean,
99
+ default: uni.$u.props.input.disableDefaultPadding
100
+ },
101
+ // 指定focus时光标的位置
102
+ cursor: {
103
+ type: [String, Number],
104
+ default: uni.$u.props.input.cursor
105
+ },
106
+ // 输入框聚焦时底部与键盘的距离
107
+ cursorSpacing: {
108
+ type: [String, Number],
109
+ default: uni.$u.props.input.cursorSpacing
110
+ },
111
+ // 光标起始位置,自动聚集时有效,需与selection-end搭配使用
112
+ selectionStart: {
113
+ type: [String, Number],
114
+ default: uni.$u.props.input.selectionStart
115
+ },
116
+ // 光标结束位置,自动聚集时有效,需与selection-start搭配使用
117
+ selectionEnd: {
118
+ type: [String, Number],
119
+ default: uni.$u.props.input.selectionEnd
120
+ },
121
+ // 键盘弹起时,是否自动上推页面
122
+ adjustPosition: {
123
+ type: Boolean,
124
+ default: uni.$u.props.input.adjustPosition
125
+ },
126
+ // 输入框内容对齐方式,可选值为:left|center|right
127
+ inputAlign: {
128
+ type: String,
129
+ default: uni.$u.props.input.inputAlign
130
+ },
131
+ // 输入框字体的大小
132
+ fontSize: {
133
+ type: [String, Number],
134
+ default: uni.$u.props.input.fontSize
135
+ },
136
+ // 输入框字体颜色
137
+ color: {
138
+ type: String,
139
+ default: uni.$u.props.input.color
140
+ },
141
+ // 输入框前置图标
142
+ prefixIcon: {
143
+ type: String,
144
+ default: uni.$u.props.input.prefixIcon
145
+ },
146
+ // 前置图标样式,对象或字符串
147
+ prefixIconStyle: {
148
+ type: [String, Object],
149
+ default: uni.$u.props.input.prefixIconStyle
150
+ },
151
+ // 输入框后置图标
152
+ suffixIcon: {
153
+ type: String,
154
+ default: uni.$u.props.input.suffixIcon
155
+ },
156
+ // 后置图标样式,对象或字符串
157
+ suffixIconStyle: {
158
+ type: [String, Object],
159
+ default: uni.$u.props.input.suffixIconStyle
160
+ },
161
+ // 边框类型,surround-四周边框,bottom-底部边框,none-无边框
162
+ border: {
163
+ type: String,
164
+ default: uni.$u.props.input.border
165
+ },
166
+ // 是否只读,与disabled不同之处在于disabled会置灰组件,而readonly则不会
167
+ readonly: {
168
+ type: Boolean,
169
+ default: uni.$u.props.input.readonly
170
+ },
171
+ // 输入框形状,circle-圆形,square-方形
172
+ shape: {
173
+ type: String,
174
+ default: uni.$u.props.input.shape
175
+ },
176
+ // 用于处理或者过滤输入框内容的方法
177
+ formatter: {
178
+ type: [Function, null],
179
+ default: uni.$u.props.input.formatter
180
+ },
181
+ // 是否忽略组件内对文本合成系统事件的处理
182
+ ignoreCompositionEvent: {
183
+ type: Boolean,
184
+ default: true
185
+ }
186
+ }
187
+ }