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,116 @@
1
+ <template>
2
+ <!-- #ifdef APP-NVUE -->
3
+ <cell>
4
+ <!-- #endif -->
5
+ <view
6
+ class="u-list-item"
7
+ :ref="`u-list-item-${anchor}`"
8
+ :anchor="`u-list-item-${anchor}`"
9
+ :class="[`u-list-item-${anchor}`]"
10
+ >
11
+ <slot />
12
+ </view>
13
+ <!-- #ifdef APP-NVUE -->
14
+ </cell>
15
+ <!-- #endif -->
16
+ </template>
17
+
18
+ <script>
19
+ import props from './props.js';
20
+ // #ifdef APP-NVUE
21
+ const dom = uni.requireNativePlugin('dom')
22
+ // #endif
23
+ /**
24
+ * List 列表
25
+ * @description 该组件为高性能列表组件
26
+ * @tutorial https://www.uviewui.com/components/list.html
27
+ * @property {String | Number} anchor 用于滚动到指定item
28
+ * @example <u-list-ite v-for="(item, index) in indexList" :key="index" ></u-list-item>
29
+ */
30
+ export default {
31
+ name: 'u-list-item',
32
+ mixins: [uni.$u.mpMixin, uni.$u.mixin,props],
33
+ data() {
34
+ return {
35
+ // 节点信息
36
+ rect: {},
37
+ index: 0,
38
+ show: true,
39
+ sys: uni.$u.sys()
40
+ }
41
+ },
42
+ computed: {
43
+
44
+ },
45
+ inject: ['uList'],
46
+ watch: {
47
+ // #ifndef APP-NVUE
48
+ 'uList.innerScrollTop'(n) {
49
+ const preLoadScreen = this.uList.preLoadScreen
50
+ const windowHeight = this.sys.windowHeight
51
+ if(n <= windowHeight * preLoadScreen) {
52
+ this.parent.updateOffsetFromChild(0)
53
+ } else if (this.rect.top <= n - windowHeight * preLoadScreen) {
54
+ this.parent.updateOffsetFromChild(this.rect.top)
55
+ }
56
+ }
57
+ // #endif
58
+ },
59
+ created() {
60
+ this.parent = {}
61
+ },
62
+ mounted() {
63
+ this.init()
64
+ },
65
+ methods: {
66
+ init() {
67
+ // 初始化数据
68
+ this.updateParentData()
69
+ this.index = this.parent.children.indexOf(this)
70
+ this.resize()
71
+ },
72
+ updateParentData() {
73
+ // 此方法在mixin中
74
+ this.getParentData('u-list')
75
+ },
76
+ resize() {
77
+ this.queryRect(`u-list-item-${this.anchor}`).then(size => {
78
+ const lastChild = this.parent.children[this.index - 1]
79
+ this.rect = size
80
+ const preLoadScreen = this.uList.preLoadScreen
81
+ const windowHeight = this.sys.windowHeight
82
+ // #ifndef APP-NVUE
83
+ if (lastChild) {
84
+ this.rect.top = lastChild.rect.top + lastChild.rect.height
85
+ }
86
+ if (size.top >= this.uList.innerScrollTop + (1 + preLoadScreen) * windowHeight) this.show =
87
+ false
88
+ // #endif
89
+ })
90
+ },
91
+ // 查询元素尺寸
92
+ queryRect(el) {
93
+ return new Promise(resolve => {
94
+ // #ifndef APP-NVUE
95
+ this.$uGetRect(`.${el}`).then(size => {
96
+ resolve(size)
97
+ })
98
+ // #endif
99
+
100
+ // #ifdef APP-NVUE
101
+ const ref = this.$refs[el]
102
+ dom.getComponentRect(ref, res => {
103
+ resolve(res.size)
104
+ })
105
+ // #endif
106
+ })
107
+ }
108
+ }
109
+ }
110
+ </script>
111
+
112
+ <style lang="scss" scoped>
113
+ @import "../../libs/css/components.scss";
114
+
115
+ .u-list-item {}
116
+ </style>
@@ -0,0 +1,59 @@
1
+ export default {
2
+ props: {
3
+ // 是否显示组件
4
+ show: {
5
+ type: Boolean,
6
+ default: uni.$u.props.loadingIcon.show
7
+ },
8
+ // 颜色
9
+ color: {
10
+ type: String,
11
+ default: uni.$u.props.loadingIcon.color
12
+ },
13
+ // 提示文字颜色
14
+ textColor: {
15
+ type: String,
16
+ default: uni.$u.props.loadingIcon.textColor
17
+ },
18
+ // 文字和图标是否垂直排列
19
+ vertical: {
20
+ type: Boolean,
21
+ default: uni.$u.props.loadingIcon.vertical
22
+ },
23
+ // 模式选择,circle-圆形,spinner-花朵形,semicircle-半圆形
24
+ mode: {
25
+ type: String,
26
+ default: uni.$u.props.loadingIcon.mode
27
+ },
28
+ // 图标大小,单位默认px
29
+ size: {
30
+ type: [String, Number],
31
+ default: uni.$u.props.loadingIcon.size
32
+ },
33
+ // 文字大小
34
+ textSize: {
35
+ type: [String, Number],
36
+ default: uni.$u.props.loadingIcon.textSize
37
+ },
38
+ // 文字内容
39
+ text: {
40
+ type: [String, Number],
41
+ default: uni.$u.props.loadingIcon.text
42
+ },
43
+ // 动画模式
44
+ timingFunction: {
45
+ type: String,
46
+ default: uni.$u.props.loadingIcon.timingFunction
47
+ },
48
+ // 动画执行周期时间
49
+ duration: {
50
+ type: [String, Number],
51
+ default: uni.$u.props.loadingIcon.duration
52
+ },
53
+ // mode=circle时的暗边颜色
54
+ inactiveColor: {
55
+ type: String,
56
+ default: uni.$u.props.loadingIcon.inactiveColor
57
+ }
58
+ }
59
+ }
@@ -0,0 +1,343 @@
1
+ <template>
2
+ <view
3
+ class="u-loading-icon"
4
+ :style="[$u.addStyle(customStyle)]"
5
+ :class="[vertical && 'u-loading-icon--vertical']"
6
+ v-if="show"
7
+ >
8
+ <view
9
+ v-if="!webviewHide"
10
+ class="u-loading-icon__spinner"
11
+ :class="[`u-loading-icon__spinner--${mode}`]"
12
+ ref="ani"
13
+ :style="{
14
+ color: color,
15
+ width: $u.addUnit(size),
16
+ height: $u.addUnit(size),
17
+ borderTopColor: color,
18
+ borderBottomColor: otherBorderColor,
19
+ borderLeftColor: otherBorderColor,
20
+ borderRightColor: otherBorderColor,
21
+ 'animation-duration': `${duration}ms`,
22
+ 'animation-timing-function': mode === 'semicircle' || mode === 'circle' ? timingFunction : ''
23
+ }"
24
+ >
25
+ <block v-if="mode === 'spinner'">
26
+ <!-- #ifndef APP-NVUE -->
27
+ <view
28
+ v-for="(item, index) in array12"
29
+ :key="index"
30
+ class="u-loading-icon__dot"
31
+ >
32
+ </view>
33
+ <!-- #endif -->
34
+ <!-- #ifdef APP-NVUE -->
35
+ <!-- 此组件内部图标部分无法设置宽高,即使通过width和height配置了也无效 -->
36
+ <loading-indicator
37
+ v-if="!webviewHide"
38
+ class="u-loading-indicator"
39
+ :animating="true"
40
+ :style="{
41
+ color: color,
42
+ width: $u.addUnit(size),
43
+ height: $u.addUnit(size)
44
+ }"
45
+ />
46
+ <!-- #endif -->
47
+ </block>
48
+ </view>
49
+ <text
50
+ v-if="text"
51
+ class="u-loading-icon__text"
52
+ :style="{
53
+ fontSize: $u.addUnit(textSize),
54
+ color: textColor,
55
+ }"
56
+ >{{text}}</text>
57
+ </view>
58
+ </template>
59
+
60
+ <script>
61
+ import props from './props.js';
62
+ // #ifdef APP-NVUE
63
+ const animation = weex.requireModule('animation');
64
+ // #endif
65
+ /**
66
+ * loading 加载动画
67
+ * @description 警此组件为一个小动画,目前用在uView的loadmore加载更多和switch开关等组件的正在加载状态场景。
68
+ * @tutorial https://www.uviewui.com/components/loading.html
69
+ * @property {Boolean} show 是否显示组件 (默认 true)
70
+ * @property {String} color 动画活动区域的颜色,只对 mode = flower 模式有效(默认color['u-tips-color'])
71
+ * @property {String} textColor 提示文本的颜色(默认color['u-tips-color'])
72
+ * @property {Boolean} vertical 文字和图标是否垂直排列 (默认 false )
73
+ * @property {String} mode 模式选择,见官网说明(默认 'circle' )
74
+ * @property {String | Number} size 加载图标的大小,单位px (默认 24 )
75
+ * @property {String | Number} textSize 文字大小(默认 15 )
76
+ * @property {String | Number} text 文字内容
77
+ * @property {String} timingFunction 动画模式 (默认 'ease-in-out' )
78
+ * @property {String | Number} duration 动画执行周期时间(默认 1200)
79
+ * @property {String} inactiveColor mode=circle时的暗边颜色
80
+ * @property {Object} customStyle 定义需要用到的外部样式
81
+ * @example <u-loading mode="circle"></u-loading>
82
+ */
83
+ export default {
84
+ name: 'u-loading-icon',
85
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
86
+ data() {
87
+ return {
88
+ // Array.form可以通过一个伪数组对象创建指定长度的数组
89
+ // https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/from
90
+ array12: Array.from({
91
+ length: 12
92
+ }),
93
+ // 这里需要设置默认值为360,否则在安卓nvue上,会延迟一个duration周期后才执行
94
+ // 在iOS nvue上,则会一开始默认执行两个周期的动画
95
+ aniAngel: 360, // 动画旋转角度
96
+ webviewHide: false, // 监听webview的状态,如果隐藏了页面,则停止动画,以免性能消耗
97
+ loading: false, // 是否运行中,针对nvue使用
98
+ }
99
+ },
100
+ computed: {
101
+ // 当为circle类型时,给其另外三边设置一个更轻一些的颜色
102
+ // 之所以需要这么做的原因是,比如父组件传了color为红色,那么需要另外的三个边为浅红色
103
+ // 而不能是固定的某一个其他颜色(因为这个固定的颜色可能浅蓝,导致效果没有那么细腻良好)
104
+ otherBorderColor() {
105
+ const lightColor = uni.$u.colorGradient(this.color, '#ffffff', 100)[80]
106
+ if (this.mode === 'circle') {
107
+ return this.inactiveColor ? this.inactiveColor : lightColor
108
+ } else {
109
+ return 'transparent'
110
+ }
111
+ // return this.mode === 'circle' ? this.inactiveColor ? this.inactiveColor : lightColor : 'transparent'
112
+ }
113
+ },
114
+ watch: {
115
+ show(n) {
116
+ // nvue中,show为true,且为非loading状态,就重新执行动画模块
117
+ // #ifdef APP-NVUE
118
+ if (n && !this.loading) {
119
+ setTimeout(() => {
120
+ this.startAnimate()
121
+ }, 30)
122
+ }
123
+ // #endif
124
+ }
125
+ },
126
+ mounted() {
127
+ this.init()
128
+ },
129
+ methods: {
130
+ init() {
131
+ setTimeout(() => {
132
+ // #ifdef APP-NVUE
133
+ this.show && this.nvueAnimate()
134
+ // #endif
135
+ // #ifdef APP-PLUS
136
+ this.show && this.addEventListenerToWebview()
137
+ // #endif
138
+ }, 20)
139
+ },
140
+ // 监听webview的显示与隐藏
141
+ addEventListenerToWebview() {
142
+ // webview的堆栈
143
+ const pages = getCurrentPages()
144
+ // 当前页面
145
+ const page = pages[pages.length - 1]
146
+ // 当前页面的webview实例
147
+ const currentWebview = page.$getAppWebview()
148
+ // 监听webview的显示与隐藏,从而停止或者开始动画(为了性能)
149
+ currentWebview.addEventListener('hide', () => {
150
+ this.webviewHide = true
151
+ })
152
+ currentWebview.addEventListener('show', () => {
153
+ this.webviewHide = false
154
+ })
155
+ },
156
+ // #ifdef APP-NVUE
157
+ nvueAnimate() {
158
+ // nvue下,非spinner类型时才需要旋转,因为nvue的spinner类型,使用了weex的
159
+ // loading-indicator组件,自带旋转功能
160
+ this.mode !== 'spinner' && this.startAnimate()
161
+ },
162
+ // 执行nvue的animate模块动画
163
+ startAnimate() {
164
+ this.loading = true
165
+ const ani = this.$refs.ani
166
+ if (!ani) return
167
+ animation.transition(ani, {
168
+ // 进行角度旋转
169
+ styles: {
170
+ transform: `rotate(${this.aniAngel}deg)`,
171
+ transformOrigin: 'center center'
172
+ },
173
+ duration: this.duration,
174
+ timingFunction: this.timingFunction,
175
+ // delay: 10
176
+ }, () => {
177
+ // 每次增加360deg,为了让其重新旋转一周
178
+ this.aniAngel += 360
179
+ // 动画结束后,继续循环执行动画,需要同时判断webviewHide变量
180
+ // nvue安卓,页面隐藏后依然会继续执行startAnimate方法
181
+ this.show && !this.webviewHide ? this.startAnimate() : this.loading = false
182
+ })
183
+ }
184
+ // #endif
185
+ }
186
+ }
187
+ </script>
188
+
189
+ <style lang="scss" scoped>
190
+ @import "../../libs/css/components.scss";
191
+ $u-loading-icon-color: #c8c9cc !default;
192
+ $u-loading-icon-text-margin-left:4px !default;
193
+ $u-loading-icon-text-color:$u-content-color !default;
194
+ $u-loading-icon-text-font-size:14px !default;
195
+ $u-loading-icon-text-line-height:20px !default;
196
+ $u-loading-width:30px !default;
197
+ $u-loading-height:30px !default;
198
+ $u-loading-max-width:100% !default;
199
+ $u-loading-max-height:100% !default;
200
+ $u-loading-semicircle-border-width: 2px !default;
201
+ $u-loading-semicircle-border-color:transparent !default;
202
+ $u-loading-semicircle-border-top-right-radius: 100px !default;
203
+ $u-loading-semicircle-border-top-left-radius: 100px !default;
204
+ $u-loading-semicircle-border-bottom-left-radius: 100px !default;
205
+ $u-loading-semicircle-border-bottom-right-radiu: 100px !default;
206
+ $u-loading-semicircle-border-style: solid !default;
207
+ $u-loading-circle-border-top-right-radius: 100px !default;
208
+ $u-loading-circle-border-top-left-radius: 100px !default;
209
+ $u-loading-circle-border-bottom-left-radius: 100px !default;
210
+ $u-loading-circle-border-bottom-right-radiu: 100px !default;
211
+ $u-loading-circle-border-width:2px !default;
212
+ $u-loading-circle-border-top-color:#e5e5e5 !default;
213
+ $u-loading-circle-border-right-color:$u-loading-circle-border-top-color !default;
214
+ $u-loading-circle-border-bottom-color:$u-loading-circle-border-top-color !default;
215
+ $u-loading-circle-border-left-color:$u-loading-circle-border-top-color !default;
216
+ $u-loading-circle-border-style:solid !default;
217
+ $u-loading-icon-host-font-size:0px !default;
218
+ $u-loading-icon-host-line-height:1 !default;
219
+ $u-loading-icon-vertical-margin:6px 0 0 !default;
220
+ $u-loading-icon-dot-top:0 !default;
221
+ $u-loading-icon-dot-left:0 !default;
222
+ $u-loading-icon-dot-width:100% !default;
223
+ $u-loading-icon-dot-height:100% !default;
224
+ $u-loading-icon-dot-before-width:2px !default;
225
+ $u-loading-icon-dot-before-height:25% !default;
226
+ $u-loading-icon-dot-before-margin:0 auto !default;
227
+ $u-loading-icon-dot-before-background-color:currentColor !default;
228
+ $u-loading-icon-dot-before-border-radius:40% !default;
229
+
230
+ .u-loading-icon {
231
+ /* #ifndef APP-NVUE */
232
+ // display: inline-flex;
233
+ /* #endif */
234
+ flex-direction: row;
235
+ align-items: center;
236
+ justify-content: center;
237
+ color: $u-loading-icon-color;
238
+
239
+ &__text {
240
+ margin-left: $u-loading-icon-text-margin-left;
241
+ color: $u-loading-icon-text-color;
242
+ font-size: $u-loading-icon-text-font-size;
243
+ line-height: $u-loading-icon-text-line-height;
244
+ }
245
+
246
+ &__spinner {
247
+ width: $u-loading-width;
248
+ height: $u-loading-height;
249
+ position: relative;
250
+ /* #ifndef APP-NVUE */
251
+ box-sizing: border-box;
252
+ max-width: $u-loading-max-width;
253
+ max-height: $u-loading-max-height;
254
+ animation: u-rotate 1s linear infinite;
255
+ /* #endif */
256
+ }
257
+
258
+ &__spinner--semicircle {
259
+ border-width: $u-loading-semicircle-border-width;
260
+ border-color: $u-loading-semicircle-border-color;
261
+ border-top-right-radius: $u-loading-semicircle-border-top-right-radius;
262
+ border-top-left-radius: $u-loading-semicircle-border-top-left-radius;
263
+ border-bottom-left-radius: $u-loading-semicircle-border-bottom-left-radius;
264
+ border-bottom-right-radius: $u-loading-semicircle-border-bottom-right-radiu;
265
+ border-style: $u-loading-semicircle-border-style;
266
+ }
267
+
268
+ &__spinner--circle {
269
+ border-top-right-radius: $u-loading-circle-border-top-right-radius;
270
+ border-top-left-radius: $u-loading-circle-border-top-left-radius;
271
+ border-bottom-left-radius: $u-loading-circle-border-bottom-left-radius;
272
+ border-bottom-right-radius: $u-loading-circle-border-bottom-right-radiu;
273
+ border-width: $u-loading-circle-border-width;
274
+ border-top-color: $u-loading-circle-border-top-color;
275
+ border-right-color: $u-loading-circle-border-right-color;
276
+ border-bottom-color: $u-loading-circle-border-bottom-color;
277
+ border-left-color: $u-loading-circle-border-left-color;
278
+ border-style: $u-loading-circle-border-style;
279
+ }
280
+
281
+ &--vertical {
282
+ flex-direction: column
283
+ }
284
+ }
285
+
286
+ /* #ifndef APP-NVUE */
287
+ :host {
288
+ font-size: $u-loading-icon-host-font-size;
289
+ line-height: $u-loading-icon-host-line-height;
290
+ }
291
+
292
+ .u-loading-icon {
293
+ &__spinner--spinner {
294
+ animation-timing-function: steps(12)
295
+ }
296
+
297
+ &__text:empty {
298
+ display: none
299
+ }
300
+
301
+ &--vertical &__text {
302
+ margin: $u-loading-icon-vertical-margin;
303
+ color: $u-content-color;
304
+ }
305
+
306
+ &__dot {
307
+ position: absolute;
308
+ top: $u-loading-icon-dot-top;
309
+ left: $u-loading-icon-dot-left;
310
+ width: $u-loading-icon-dot-width;
311
+ height: $u-loading-icon-dot-height;
312
+
313
+ &:before {
314
+ display: block;
315
+ width: $u-loading-icon-dot-before-width;
316
+ height: $u-loading-icon-dot-before-height;
317
+ margin: $u-loading-icon-dot-before-margin;
318
+ background-color: $u-loading-icon-dot-before-background-color;
319
+ border-radius: $u-loading-icon-dot-before-border-radius;
320
+ content: " "
321
+ }
322
+ }
323
+ }
324
+
325
+ @for $i from 1 through 12 {
326
+ .u-loading-icon__dot:nth-of-type(#{$i}) {
327
+ transform: rotate($i * 30deg);
328
+ opacity: 1 - 0.0625 * ($i - 1);
329
+ }
330
+ }
331
+
332
+ @keyframes u-rotate {
333
+ 0% {
334
+ transform: rotate(0deg)
335
+ }
336
+
337
+ to {
338
+ transform: rotate(1turn)
339
+ }
340
+ }
341
+
342
+ /* #endif */
343
+ </style>
@@ -0,0 +1,49 @@
1
+ export default {
2
+ props: {
3
+ // 提示内容
4
+ loadingText: {
5
+ type: [String, Number],
6
+ default: uni.$u.props.loadingPage.loadingText
7
+ },
8
+ // 文字上方用于替换loading动画的图片
9
+ image: {
10
+ type: String,
11
+ default: uni.$u.props.loadingPage.image
12
+ },
13
+ // 加载动画的模式,circle-圆形,spinner-花朵形,semicircle-半圆形
14
+ loadingMode: {
15
+ type: String,
16
+ default: uni.$u.props.loadingPage.loadingMode
17
+ },
18
+ // 是否加载中
19
+ loading: {
20
+ type: Boolean,
21
+ default: uni.$u.props.loadingPage.loading
22
+ },
23
+ // 背景色
24
+ bgColor: {
25
+ type: String,
26
+ default: uni.$u.props.loadingPage.bgColor
27
+ },
28
+ // 文字颜色
29
+ color: {
30
+ type: String,
31
+ default: uni.$u.props.loadingPage.color
32
+ },
33
+ // 文字大小
34
+ fontSize: {
35
+ type: [String, Number],
36
+ default: uni.$u.props.loadingPage.fontSize
37
+ },
38
+ // 图标大小
39
+ iconSize: {
40
+ type: [String, Number],
41
+ default: uni.$u.props.loadingPage.fontSize
42
+ },
43
+ // 加载中图标的颜色,只能rgb或者十六进制颜色值
44
+ loadingColor: {
45
+ type: String,
46
+ default: uni.$u.props.loadingPage.loadingColor
47
+ }
48
+ }
49
+ }
@@ -0,0 +1,115 @@
1
+ <template>
2
+ <u-transition
3
+ :show="loading"
4
+ :custom-style="{
5
+ position: 'fixed',
6
+ top: 0,
7
+ left: 0,
8
+ right: 0,
9
+ bottom: 0,
10
+ backgroundColor: bgColor,
11
+ display: 'flex',
12
+ }"
13
+ >
14
+ <view class="u-loading-page">
15
+ <view class="u-loading-page__warpper">
16
+ <view class="u-loading-page__warpper__loading-icon">
17
+ <image
18
+ v-if="image"
19
+ :src="image"
20
+ class="u-loading-page__warpper__loading-icon__img"
21
+ mode="widthFit"
22
+ :style="{
23
+ width: $u.addUnit(iconSize),
24
+ height: $u.addUnit(iconSize)
25
+ }"
26
+ ></image>
27
+ <u-loading-icon
28
+ v-else
29
+ :mode="loadingMode"
30
+ :size="$u.addUnit(iconSize)"
31
+ :color="loadingColor"
32
+ ></u-loading-icon>
33
+ </view>
34
+ <slot>
35
+ <text
36
+ class="u-loading-page__warpper__text"
37
+ :style="{
38
+ fontSize: $u.addUnit(fontSize),
39
+ color: color,
40
+ }"
41
+ >{{ loadingText }}</text
42
+ >
43
+ </slot>
44
+ </view>
45
+ </view>
46
+ </u-transition>
47
+ </template>
48
+
49
+ <script>
50
+ import props from "./props.js";
51
+ /**
52
+ * loadingPage 加载动画
53
+ * @description 警此组件为一个小动画,目前用在uView的loadmore加载更多和switch开关等组件的正在加载状态场景。
54
+ * @tutorial https://www.uviewui.com/components/loading.html
55
+ * @property {String | Number} loadingText 提示内容 (默认 '正在加载' )
56
+ * @property {String} image 文字上方用于替换loading动画的图片
57
+ * @property {String} loadingMode 加载动画的模式,circle-圆形,spinner-花朵形,semicircle-半圆形 (默认 'circle' )
58
+ * @property {Boolean} loading 是否加载中 (默认 false )
59
+ * @property {String} bgColor 背景色 (默认 '#ffffff' )
60
+ * @property {String} color 文字颜色 (默认 '#C8C8C8' )
61
+ * @property {String | Number} fontSize 文字大小 (默认 19 )
62
+ * @property {String | Number} iconSize 图标大小 (默认 28 )
63
+ * @property {String} loadingColor 加载中图标的颜色,只能rgb或者十六进制颜色值 (默认 '#C8C8C8' )
64
+ * @property {Object} customStyle 自定义样式
65
+ * @example <u-loading mode="circle"></u-loading>
66
+ */
67
+ export default {
68
+ name: "u-loading-page",
69
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
70
+ data() {
71
+ return {};
72
+ },
73
+ methods: {},
74
+ };
75
+ </script>
76
+
77
+ <style lang="scss" scoped>
78
+ @import "../../libs/css/components.scss";
79
+
80
+ $text-color: rgb(200, 200, 200) !default;
81
+ $text-size: 19px !default;
82
+ $u-loading-icon-margin-bottom: 10px !default;
83
+
84
+ .u-loading-page {
85
+ @include flex(column);
86
+ flex: 1;
87
+ align-items: center;
88
+ justify-content: center;
89
+
90
+ &__warpper {
91
+ margin-top: -150px;
92
+ justify-content: center;
93
+ align-items: center;
94
+ /* #ifndef APP-NVUE */
95
+ color: $text-color;
96
+ font-size: $text-size;
97
+ /* #endif */
98
+ @include flex(column);
99
+
100
+ &__loading-icon {
101
+ margin-bottom: $u-loading-icon-margin-bottom;
102
+
103
+ &__img {
104
+ width: 40px;
105
+ height: 40px;
106
+ }
107
+ }
108
+
109
+ &__text {
110
+ font-size: $text-size;
111
+ color: $text-color;
112
+ }
113
+ }
114
+ }
115
+ </style>