fusions-ui 1.2.7 → 1.2.8

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 (547) hide show
  1. package/LICENSE +1 -1
  2. package/changelog.md +2 -0
  3. package/components/avatar/index.ts +1 -0
  4. package/components/avatar/src/avatar.ts +131 -0
  5. package/components/avatar/src/avatar.vue +104 -0
  6. package/components/avatar/src/composables/index.ts +1 -0
  7. package/components/avatar/src/composables/use-avatar.ts +61 -0
  8. package/components/avatar-group/index.ts +1 -0
  9. package/components/avatar-group/src/avatar-group.ts +86 -0
  10. package/components/{fu-avatar-group/fu-avatar-group.vue → avatar-group/src/avatar-group.vue} +27 -34
  11. package/components/avatar-group/src/composables/index.ts +1 -0
  12. package/components/avatar-group/src/composables/use-avatar-group.ts +17 -0
  13. package/components/badge/index.ts +1 -0
  14. package/components/badge/src/badge.ts +126 -0
  15. package/components/{fu-badge/fu-badge.vue → badge/src/badge.vue} +26 -62
  16. package/components/badge/src/composables/badge-custom.ts +51 -0
  17. package/components/badge/src/composables/index.ts +1 -0
  18. package/components/banner-arc/index.ts +1 -0
  19. package/components/banner-arc/src/banner-arc.ts +41 -0
  20. package/components/banner-arc/src/banner-arc.vue +49 -0
  21. package/components/banner-arc/src/composables/banner-arc-custom.ts +19 -0
  22. package/components/banner-arc/src/composables/index.ts +1 -0
  23. package/components/button/index.ts +1 -0
  24. package/components/button/src/button.ts +332 -0
  25. package/components/{fu-button/fu-button.vue → button/src/button.vue} +57 -163
  26. package/components/button/src/composables/button-custom.ts +90 -0
  27. package/components/button/src/composables/index.ts +2 -0
  28. package/components/button/src/composables/use-button.ts +137 -0
  29. package/components/cell/index.ts +1 -0
  30. package/components/cell/src/cell.ts +167 -0
  31. package/components/{fu-cell/fu-cell.vue → cell/src/cell.vue} +29 -38
  32. package/components/cell/src/composables/index.ts +1 -0
  33. package/components/cell/src/composables/use-cell.ts +20 -0
  34. package/components/cell-group/index.ts +1 -0
  35. package/components/cell-group/src/cell-group.ts +23 -0
  36. package/components/{fu-cell-group/fu-cell-group.vue → cell-group/src/cell-group.vue} +8 -13
  37. package/components/checkbox/index.ts +1 -0
  38. package/components/checkbox/src/checkbox.ts +144 -0
  39. package/components/checkbox/src/checkbox.vue +270 -0
  40. package/components/checkbox/src/composables/checkbox-custom.ts +15 -0
  41. package/components/checkbox/src/composables/index.ts +2 -0
  42. package/components/checkbox/src/composables/use-checkbox.ts +200 -0
  43. package/components/code-input/index.ts +1 -0
  44. package/components/code-input/src/code-input.ts +157 -0
  45. package/components/code-input/src/code-input.vue +158 -0
  46. package/components/code-input/src/composables/code-input-custom.ts +74 -0
  47. package/components/code-input/src/composables/index.ts +2 -0
  48. package/components/code-input/src/composables/use-code-input.ts +67 -0
  49. package/components/code-verify/index.ts +1 -0
  50. package/components/code-verify/src/code-verify.ts +160 -0
  51. package/components/code-verify/src/code-verify.vue +87 -0
  52. package/components/code-verify/src/composables/code-verify-custom.ts +23 -0
  53. package/components/code-verify/src/composables/index.ts +2 -0
  54. package/components/code-verify/src/composables/use-code-verify.ts +132 -0
  55. package/components/collapse/index.ts +1 -0
  56. package/components/collapse/src/collapse.ts +41 -0
  57. package/components/collapse/src/collapse.vue +48 -0
  58. package/components/collapse/src/composables/index.ts +1 -0
  59. package/components/collapse/src/composables/use-collapse.ts +150 -0
  60. package/components/collapse-item/index.ts +1 -0
  61. package/components/collapse-item/src/collapse-item.ts +102 -0
  62. package/components/{fu-collapse-item/fu-collapse-item.vue → collapse-item/src/collapse-item.vue} +20 -159
  63. package/components/collapse-item/src/composables/index.ts +1 -0
  64. package/components/collapse-item/src/composables/use-collapse-item.ts +139 -0
  65. package/components/countdown/index.ts +1 -0
  66. package/components/countdown/src/composables/index.ts +1 -0
  67. package/components/countdown/src/composables/use-countdown.ts +133 -0
  68. package/components/countdown/src/countdown.ts +63 -0
  69. package/components/countdown/src/countdown.vue +60 -0
  70. package/components/{fu-countdown/util.js → countdown/src/util.ts} +5 -5
  71. package/components/datetime-picker/index.ts +1 -0
  72. package/components/datetime-picker/src/composables/index.ts +1 -0
  73. package/components/datetime-picker/src/composables/use-datetime-picker.ts +325 -0
  74. package/components/datetime-picker/src/datetime-picker.ts +223 -0
  75. package/components/datetime-picker/src/datetime-picker.vue +96 -0
  76. package/components/form/index.ts +1 -0
  77. package/components/form/src/composables/index.ts +1 -0
  78. package/components/form/src/composables/use-form.ts +256 -0
  79. package/components/form/src/form.ts +108 -0
  80. package/components/form/src/form.vue +64 -0
  81. package/components/{fu-form/utils.js → form/src/utils.ts} +49 -42
  82. package/components/{fu-form/validate.js → form/src/validate.ts} +58 -49
  83. package/components/form-item/index.ts +1 -0
  84. package/components/form-item/src/composables/index.ts +1 -0
  85. package/components/form-item/src/composables/use-form-item.ts +292 -0
  86. package/components/form-item/src/form-item.ts +81 -0
  87. package/components/form-item/src/form-item.vue +229 -0
  88. package/components/fusions-ui/src/fusions-ui.vue +8 -0
  89. package/components/grid/index.ts +1 -0
  90. package/components/grid/src/composables/index.ts +1 -0
  91. package/components/grid/src/composables/use-grid.ts +67 -0
  92. package/components/grid/src/grid.ts +54 -0
  93. package/components/grid/src/grid.vue +69 -0
  94. package/components/grid-item/index.ts +1 -0
  95. package/components/grid-item/src/composables/grid-item-custom.ts +16 -0
  96. package/components/grid-item/src/composables/index.ts +2 -0
  97. package/components/grid-item/src/composables/use-grid-item.ts +55 -0
  98. package/components/grid-item/src/grid-item.ts +15 -0
  99. package/components/grid-item/src/grid-item.vue +102 -0
  100. package/components/icon/index.ts +1 -0
  101. package/components/icon/src/composables/icon-custom.ts +41 -0
  102. package/components/icon/src/composables/index.ts +2 -0
  103. package/components/icon/src/composables/use-icon.ts +14 -0
  104. package/components/{fu-icon → icon/src}/fuicon.css +584 -584
  105. package/components/icon/src/fuicon.ts +1023 -0
  106. package/components/icon/src/icon.ts +84 -0
  107. package/components/icon/src/icon.vue +92 -0
  108. package/components/image/index.ts +1 -0
  109. package/components/image/src/composables/image-custom.ts +36 -0
  110. package/components/image/src/composables/index.ts +2 -0
  111. package/components/image/src/composables/use-image.ts +135 -0
  112. package/components/image/src/image.ts +185 -0
  113. package/components/image/src/image.vue +152 -0
  114. package/components/index-anchor/index.ts +1 -0
  115. package/components/index-anchor/src/composables/index.ts +1 -0
  116. package/components/index-anchor/src/composables/use-index-anchor.ts +44 -0
  117. package/components/index-anchor/src/index-anchor.ts +45 -0
  118. package/components/index-anchor/src/index-anchor.vue +60 -0
  119. package/components/index-item/index.ts +1 -0
  120. package/components/index-item/src/composables/index.ts +1 -0
  121. package/components/index-item/src/composables/use-index-item.ts +75 -0
  122. package/components/index-item/src/index-item.ts +13 -0
  123. package/components/index-item/src/index-item.vue +32 -0
  124. package/components/index-list/index.ts +1 -0
  125. package/components/index-list/src/composables/index.ts +1 -0
  126. package/components/index-list/src/composables/use-index-list.ts +297 -0
  127. package/components/index-list/src/index-list.ts +52 -0
  128. package/components/index-list/src/index-list.vue +178 -0
  129. package/components/index.ts +62 -0
  130. package/components/input/index.ts +1 -0
  131. package/components/input/src/composables/index.ts +2 -0
  132. package/components/input/src/composables/input-custom.ts +69 -0
  133. package/components/input/src/composables/use-input.ts +117 -0
  134. package/components/input/src/input.ts +360 -0
  135. package/components/input/src/input.vue +241 -0
  136. package/components/keyboard/index.ts +1 -0
  137. package/components/keyboard/src/composables/index.ts +3 -0
  138. package/components/keyboard/src/composables/use-keyboard-car.ts +99 -0
  139. package/components/keyboard/src/composables/use-keyboard-number.ts +81 -0
  140. package/components/keyboard/src/composables/use-keyboard.ts +61 -0
  141. package/components/keyboard/src/keyboard-car.ts +53 -0
  142. package/components/{fu-keyboard → keyboard/src}/keyboard-car.vue +37 -199
  143. package/components/keyboard/src/keyboard-number.ts +44 -0
  144. package/components/keyboard/src/keyboard-number.vue +108 -0
  145. package/components/keyboard/src/keyboard.ts +174 -0
  146. package/components/{fu-keyboard/fu-keyboard.vue → keyboard/src/keyboard.vue} +38 -63
  147. package/components/line/index.ts +1 -0
  148. package/components/line/src/composables/index.ts +1 -0
  149. package/components/line/src/composables/line-custom.ts +30 -0
  150. package/components/line/src/line.ts +82 -0
  151. package/components/line/src/line.vue +44 -0
  152. package/components/link/index.ts +1 -0
  153. package/components/link/src/composables/index.ts +2 -0
  154. package/components/link/src/composables/link-custom.ts +19 -0
  155. package/components/link/src/composables/use-link.ts +33 -0
  156. package/components/link/src/link.ts +61 -0
  157. package/components/link/src/link.vue +62 -0
  158. package/components/loading/index.ts +1 -0
  159. package/{libs/function/colorGradient.js → components/loading/src/composables/colorGradient.ts} +4 -4
  160. package/components/loading/src/composables/index.ts +2 -0
  161. package/components/loading/src/composables/loading-custom.ts +21 -0
  162. package/components/loading/src/composables/use-loading.ts +100 -0
  163. package/components/loading/src/loading.ts +77 -0
  164. package/components/{fu-loading/fu-loading.vue → loading/src/loading.vue} +23 -119
  165. package/components/loading-more/index.ts +1 -0
  166. package/components/loading-more/src/loading-more.ts +75 -0
  167. package/components/{fu-loading-more/fu-loading-more.vue → loading-more/src/loading-more.vue} +18 -19
  168. package/components/modal/index.ts +1 -0
  169. package/components/modal/src/composables/index.ts +2 -0
  170. package/components/modal/src/composables/modal-custom.ts +17 -0
  171. package/components/modal/src/composables/use-modal.ts +56 -0
  172. package/components/modal/src/modal.ts +152 -0
  173. package/components/{fu-modal/fu-modal.vue → modal/src/modal.vue} +41 -69
  174. package/components/navbar/index.ts +1 -0
  175. package/components/navbar/src/composables/index.ts +2 -0
  176. package/components/navbar/src/composables/navbar-custom.ts +62 -0
  177. package/components/navbar/src/composables/use-navbar.ts +42 -0
  178. package/components/navbar/src/navbar.ts +151 -0
  179. package/components/navbar/src/navbar.vue +249 -0
  180. package/components/notice-bar/index.ts +3 -0
  181. package/components/notice-bar/src/composables/index.ts +5 -0
  182. package/components/notice-bar/src/composables/notice-column-custom.ts +43 -0
  183. package/components/notice-bar/src/composables/notice-row-custom.ts +26 -0
  184. package/components/notice-bar/src/composables/use-notice-bar.ts +34 -0
  185. package/components/notice-bar/src/composables/use-notice-column.ts +31 -0
  186. package/components/notice-bar/src/composables/use-notice-row.ts +88 -0
  187. package/components/notice-bar/src/notice-bar.ts +197 -0
  188. package/components/{fu-notice-bar/fu-notice-bar.vue → notice-bar/src/notice-bar.vue} +28 -41
  189. package/components/notice-bar/src/notice-column.ts +172 -0
  190. package/components/notice-bar/src/notice-column.vue +129 -0
  191. package/components/notice-bar/src/notice-row.ts +155 -0
  192. package/components/notice-bar/src/notice-row.vue +135 -0
  193. package/components/number-box/index.ts +1 -0
  194. package/components/number-box/src/composables/index.ts +2 -0
  195. package/components/number-box/src/composables/number-box-custom.ts +16 -0
  196. package/components/number-box/src/composables/use-number-box.ts +84 -0
  197. package/components/number-box/src/number-box.ts +98 -0
  198. package/components/number-box/src/number-box.vue +123 -0
  199. package/components/parse/index.ts +1 -0
  200. package/components/parse/src/app-plus/html/js/handler.js +254 -0
  201. package/components/parse/src/app-plus/html/js/uni.webview.min.js +188 -0
  202. package/components/parse/src/app-plus/html/local.html +32 -0
  203. package/components/parse/src/composables/index.ts +1 -0
  204. package/components/parse/src/composables/use-parse.ts +428 -0
  205. package/components/parse/src/node/node.vue +635 -0
  206. package/components/parse/src/parse.ts +156 -0
  207. package/components/parse/src/parse.vue +131 -0
  208. package/components/parse/src/parser.ts +1402 -0
  209. package/components/picker/index.ts +1 -0
  210. package/components/picker/src/composables/index.ts +2 -0
  211. package/components/picker/src/composables/picker-custom.ts +40 -0
  212. package/components/picker/src/composables/use-picker.ts +179 -0
  213. package/components/picker/src/picker.ts +172 -0
  214. package/components/picker/src/picker.vue +197 -0
  215. package/components/popup/index.ts +1 -0
  216. package/components/popup/src/composables/index.ts +1 -0
  217. package/components/popup/src/composables/use-popup.ts +346 -0
  218. package/components/popup/src/keypress.ts +55 -0
  219. package/components/popup/src/popup.ts +101 -0
  220. package/components/popup/src/popup.vue +204 -0
  221. package/components/progress/index.ts +1 -0
  222. package/components/progress/src/composables/index.ts +2 -0
  223. package/components/progress/src/composables/progress-custom.ts +24 -0
  224. package/components/progress/src/composables/use-progress.ts +159 -0
  225. package/components/progress/src/progress.ts +84 -0
  226. package/components/progress/src/progress.vue +150 -0
  227. package/components/rate/index.ts +1 -0
  228. package/components/rate/src/composables/index.ts +1 -0
  229. package/components/rate/src/composables/use-rate.ts +196 -0
  230. package/components/rate/src/rate.ts +114 -0
  231. package/components/rate/src/rate.vue +113 -0
  232. package/components/read-more/index.ts +1 -0
  233. package/components/read-more/src/composables/index.ts +2 -0
  234. package/components/read-more/src/composables/read-more-custom.ts +46 -0
  235. package/components/read-more/src/composables/use-read-more.ts +72 -0
  236. package/components/read-more/src/read-more.ts +102 -0
  237. package/components/read-more/src/read-more.vue +104 -0
  238. package/components/safe-bottom/index.ts +1 -0
  239. package/components/safe-bottom/src/composables/index.ts +2 -0
  240. package/components/safe-bottom/src/composables/safe-bottom-custom.ts +18 -0
  241. package/components/safe-bottom/src/composables/use-safe-bottom.ts +17 -0
  242. package/components/safe-bottom/src/safe-bottom.ts +8 -0
  243. package/components/safe-bottom/src/safe-bottom.vue +43 -0
  244. package/components/scroll-list/index.ts +1 -0
  245. package/components/scroll-list/src/composables/index.ts +2 -0
  246. package/components/scroll-list/src/composables/scroll-list-custom.ts +41 -0
  247. package/components/scroll-list/src/composables/use-scroll-list.ts +126 -0
  248. package/components/scroll-list/src/scroll-list.ts +57 -0
  249. package/components/scroll-list/src/scroll-list.vue +143 -0
  250. package/components/{fu-scroll-list/scrollWxs.wxs → scroll-list/src/scroll-wxs.wxs} +2 -2
  251. package/components/search/index.ts +1 -0
  252. package/components/search/src/composables/index.ts +2 -0
  253. package/components/search/src/composables/search-custom.ts +25 -0
  254. package/components/search/src/composables/use-search.ts +106 -0
  255. package/components/search/src/search.ts +186 -0
  256. package/components/{fu-search/fu-search.vue → search/src/search.vue} +42 -154
  257. package/components/section/index.ts +1 -0
  258. package/components/section/src/composables/index.ts +1 -0
  259. package/components/section/src/composables/use-section.ts +19 -0
  260. package/components/section/src/section.ts +83 -0
  261. package/components/{fu-section/fu-section.vue → section/src/section.vue} +36 -35
  262. package/components/sign-board/index.ts +1 -0
  263. package/components/sign-board/src/composables/index.ts +1 -0
  264. package/components/sign-board/src/composables/use-sign-board.ts +552 -0
  265. package/components/sign-board/src/sign-board.ts +48 -0
  266. package/components/sign-board/src/sign-board.vue +191 -0
  267. package/components/skeleton/index.ts +1 -0
  268. package/components/skeleton/src/composables/index.ts +2 -0
  269. package/components/skeleton/src/composables/skeleton-custom.ts +23 -0
  270. package/components/skeleton/src/composables/use-skeleton.ts +102 -0
  271. package/components/skeleton/src/skeleton.ts +37 -0
  272. package/components/skeleton/src/skeleton.vue +147 -0
  273. package/components/status-bar/src/composables/index.ts +1 -0
  274. package/components/status-bar/src/composables/use-status-bar.ts +29 -0
  275. package/components/status-bar/src/status-bar.vue +21 -0
  276. package/components/steps/index.ts +1 -0
  277. package/components/steps/src/composables/index.ts +1 -0
  278. package/components/steps/src/composables/use-steps.ts +27 -0
  279. package/components/steps/src/steps.ts +65 -0
  280. package/components/steps/src/steps.vue +46 -0
  281. package/components/steps-item/index.ts +1 -0
  282. package/components/steps-item/src/composables/index.ts +2 -0
  283. package/components/steps-item/src/composables/steps-item-custom.ts +81 -0
  284. package/components/steps-item/src/composables/use-steps-item.ts +87 -0
  285. package/components/steps-item/src/steps-item.ts +38 -0
  286. package/components/steps-item/src/steps-item.vue +224 -0
  287. package/components/sticky/index.ts +1 -0
  288. package/components/sticky/src/composables/index.ts +2 -0
  289. package/components/sticky/src/composables/sticky-custom.ts +57 -0
  290. package/components/sticky/src/composables/use-sticky.ts +152 -0
  291. package/components/sticky/src/sticky.ts +62 -0
  292. package/components/sticky/src/sticky.vue +65 -0
  293. package/components/subsection/index.ts +1 -0
  294. package/components/subsection/src/composables/index.ts +2 -0
  295. package/components/subsection/src/composables/subsection-custom.ts +71 -0
  296. package/components/subsection/src/composables/use-subsection.ts +85 -0
  297. package/components/subsection/src/subsection.ts +107 -0
  298. package/components/subsection/src/subsection.vue +165 -0
  299. package/components/swipe-action/src/composables/index.ts +1 -0
  300. package/components/swipe-action/src/composables/use-swipe-action.ts +58 -0
  301. package/components/swipe-action/src/swipe-action.vue +81 -0
  302. package/components/swipe-action-item/index.ts +1 -0
  303. package/components/{fu-swipe-action-item/mpwxs.js → swipe-action-item/src/mpwxs.ts} +22 -27
  304. package/components/swipe-action-item/src/swipe-action-item.ts +68 -0
  305. package/components/{fu-swipe-action-item/fu-swipe-action-item.vue → swipe-action-item/src/swipe-action-item.vue} +24 -17
  306. package/components/{fu-swipe-action-item → swipe-action-item/src}/wx.wxs +2 -2
  307. package/components/swiper/index.ts +1 -0
  308. package/components/swiper/src/composables/index.ts +2 -0
  309. package/components/swiper/src/composables/swiper-custom.ts +40 -0
  310. package/components/swiper/src/composables/use-swiper.ts +75 -0
  311. package/components/swiper/src/swiper.ts +189 -0
  312. package/components/{fu-swiper/fu-swiper.vue → swiper/src/swiper.vue} +49 -118
  313. package/components/switch/index.ts +1 -0
  314. package/components/switch/src/composables/index.ts +2 -0
  315. package/components/switch/src/composables/switch-custom.ts +32 -0
  316. package/components/switch/src/composables/use-switch.ts +38 -0
  317. package/components/switch/src/switch.ts +115 -0
  318. package/components/{fu-switch/fu-switch.vue → switch/src/switch.vue} +25 -73
  319. package/components/tabs/index.ts +1 -0
  320. package/components/tabs/src/composables/index.ts +2 -0
  321. package/components/tabs/src/composables/tabs-custom.ts +43 -0
  322. package/components/tabs/src/composables/use-tabs.ts +210 -0
  323. package/components/tabs/src/tabs.ts +123 -0
  324. package/components/tabs/src/tabs.vue +153 -0
  325. package/components/tag/index.ts +1 -0
  326. package/components/tag/src/composables/index.ts +2 -0
  327. package/components/tag/src/composables/tag-custom.ts +61 -0
  328. package/components/tag/src/composables/use-tag.ts +23 -0
  329. package/components/tag/src/tag.ts +159 -0
  330. package/components/{fu-tag/fu-tag.vue → tag/src/tag.vue} +53 -93
  331. package/components/text/index.ts +1 -0
  332. package/components/text/src/composables/index.ts +2 -0
  333. package/components/text/src/composables/text-custom.ts +120 -0
  334. package/components/text/src/composables/use-text.ts +83 -0
  335. package/components/text/src/text.ts +261 -0
  336. package/components/text/src/text.vue +186 -0
  337. package/components/textarea/index.ts +1 -0
  338. package/components/textarea/src/composables/index.ts +2 -0
  339. package/components/textarea/src/composables/textarea-custom.ts +50 -0
  340. package/components/textarea/src/composables/use-textarea.ts +88 -0
  341. package/components/textarea/src/textarea.ts +250 -0
  342. package/components/textarea/src/textarea.vue +162 -0
  343. package/components/{fu-timeaxis/fu-timeaxis.vue → timeaxis/src/timeaxis.vue} +3 -9
  344. package/components/timeaxis-item/index.ts +1 -0
  345. package/components/timeaxis-item/src/timeaxis-item.ts +20 -0
  346. package/components/timeaxis-item/src/timeaxis-item.vue +50 -0
  347. package/components/transition/index.ts +1 -0
  348. package/components/transition/src/composables/createAnimation.ts +171 -0
  349. package/components/transition/src/composables/index.ts +2 -0
  350. package/components/transition/src/composables/transform-custom.ts +18 -0
  351. package/components/transition/src/composables/use-transition.ts +251 -0
  352. package/components/transition/src/transition.ts +64 -0
  353. package/components/transition/src/transition.vue +70 -0
  354. package/components/upload/index.ts +1 -0
  355. package/components/upload/src/composables/index.ts +5 -0
  356. package/components/upload/src/composables/upload-file-custom.ts +68 -0
  357. package/components/upload/src/composables/upload-image-custom.ts +76 -0
  358. package/components/upload/src/composables/use-upload-file.ts +27 -0
  359. package/components/upload/src/composables/use-upload-image.ts +38 -0
  360. package/components/upload/src/composables/use-upload.ts +388 -0
  361. package/components/upload/src/upload-file.ts +84 -0
  362. package/components/upload/src/upload-file.vue +193 -0
  363. package/components/upload/src/upload-image.ts +90 -0
  364. package/components/upload/src/upload-image.vue +158 -0
  365. package/components/upload/src/upload.ts +196 -0
  366. package/components/upload/src/upload.vue +151 -0
  367. package/components/{fu-upload/utils.js → upload/src/utils.ts} +12 -12
  368. package/components/vtabs/index.ts +1 -0
  369. package/components/vtabs/src/composables/index.ts +2 -0
  370. package/components/vtabs/src/composables/use-vtabs.ts +276 -0
  371. package/components/vtabs/src/composables/vtabs-custom.ts +54 -0
  372. package/components/vtabs/src/vtabs.ts +130 -0
  373. package/components/vtabs/src/vtabs.vue +189 -0
  374. package/components/vtabs-item/index.ts +1 -0
  375. package/components/vtabs-item/src/composables/index.ts +1 -0
  376. package/components/vtabs-item/src/composables/use-vtabs-item.ts +60 -0
  377. package/components/vtabs-item/src/vtabs-item.ts +10 -0
  378. package/components/vtabs-item/src/vtabs-item.vue +20 -0
  379. package/components/waterfall/index.ts +1 -0
  380. package/components/waterfall/src/composables/index.ts +2 -0
  381. package/components/waterfall/src/composables/use-waterfall.ts +139 -0
  382. package/components/waterfall/src/composables/waterfall-custom.ts +18 -0
  383. package/components/waterfall/src/waterfall.ts +114 -0
  384. package/components/waterfall/src/waterfall.vue +104 -0
  385. package/{libs/config/config.js → config/config.ts} +13 -7
  386. package/constants/images.ts +18 -0
  387. package/constants/index.ts +6 -0
  388. package/constants/open-types.ts +33 -0
  389. package/constants/props.ts +18 -0
  390. package/constants/shapes.ts +6 -0
  391. package/constants/types.ts +10 -0
  392. package/constants/z-index.ts +27 -0
  393. package/global.d.ts +103 -0
  394. package/hooks/index.ts +25 -0
  395. package/index.scss +3 -5
  396. package/index.ts +56 -0
  397. package/package.json +1 -1
  398. package/{libs/route/min.route.config.js → route/min.route.config.ts} +62 -23
  399. package/route/route.config.ts +93 -0
  400. package/style/color.scss +26 -0
  401. package/{libs/style → style}/common.scss +1 -14
  402. package/{libs/function/applyEven.js → utils/applyEven.ts} +21 -12
  403. package/utils/check.ts +276 -0
  404. package/{libs/function/chooseUploadFile.js → utils/chooseUploadFile.ts} +22 -26
  405. package/utils/common.ts +609 -0
  406. package/{libs/function/digit.js → utils/digit.ts} +63 -33
  407. package/{components/fu-swipe-action-item/isPC.js → utils/isPC.ts} +1 -1
  408. package/utils/toast.ts +42 -0
  409. package/components/fu-avatar/fu-avatar.vue +0 -157
  410. package/components/fu-avatar/props.js +0 -117
  411. package/components/fu-avatar-group/props.js +0 -74
  412. package/components/fu-badge/props.js +0 -112
  413. package/components/fu-banner-arc/fu-banner-arc.vue +0 -58
  414. package/components/fu-banner-arc/props.js +0 -35
  415. package/components/fu-button/props.js +0 -228
  416. package/components/fu-cell/props.js +0 -108
  417. package/components/fu-cell-group/props.js +0 -19
  418. package/components/fu-checkbox/fu-checkbox.vue +0 -469
  419. package/components/fu-checkbox/props.js +0 -126
  420. package/components/fu-code-input/fu-code-input.vue +0 -269
  421. package/components/fu-code-input/props.js +0 -136
  422. package/components/fu-code-verify/fu-code-verify.vue +0 -221
  423. package/components/fu-code-verify/props.js +0 -136
  424. package/components/fu-collapse/fu-collapse.vue +0 -143
  425. package/components/fu-collapse/props.js +0 -29
  426. package/components/fu-collapse-item/props.js +0 -101
  427. package/components/fu-countdown/fu-countdown.vue +0 -164
  428. package/components/fu-countdown/props.js +0 -35
  429. package/components/fu-datetime-picker/fu-datetime-picker.vue +0 -375
  430. package/components/fu-datetime-picker/props.js +0 -194
  431. package/components/fu-form/fu-form.vue +0 -284
  432. package/components/fu-form/props.js +0 -74
  433. package/components/fu-form-item/fu-form-item.vue +0 -535
  434. package/components/fu-form-item/props.js +0 -66
  435. package/components/fu-grid/fu-grid.vue +0 -113
  436. package/components/fu-grid/props.js +0 -44
  437. package/components/fu-grid-item/fu-grid-item.vue +0 -136
  438. package/components/fu-grid-item/props.js +0 -27
  439. package/components/fu-icon/fu-icon.vue +0 -110
  440. package/components/fu-icon/fuicon.js +0 -1031
  441. package/components/fu-icon/props.js +0 -55
  442. package/components/fu-image/fu-image.vue +0 -268
  443. package/components/fu-image/props.js +0 -145
  444. package/components/fu-index-anchor/fu-index-anchor.vue +0 -91
  445. package/components/fu-index-anchor/props.js +0 -43
  446. package/components/fu-index-item/fu-index-item.vue +0 -79
  447. package/components/fu-index-list/fu-index-list.vue +0 -426
  448. package/components/fu-index-list/props.js +0 -42
  449. package/components/fu-input/fu-input.vue +0 -393
  450. package/components/fu-input/props.js +0 -291
  451. package/components/fu-keyboard/keyboard-number.vue +0 -195
  452. package/components/fu-keyboard/props.js +0 -138
  453. package/components/fu-line/fu-line.vue +0 -64
  454. package/components/fu-line/props.js +0 -58
  455. package/components/fu-link/fu-link.vue +0 -91
  456. package/components/fu-link/props.js +0 -49
  457. package/components/fu-loading/props.js +0 -60
  458. package/components/fu-loading-more/props.js +0 -59
  459. package/components/fu-modal/props.js +0 -128
  460. package/components/fu-navbar/fu-navbar.vue +0 -271
  461. package/components/fu-navbar/props.js +0 -72
  462. package/components/fu-navbar/status-bar.vue +0 -27
  463. package/components/fu-notice-bar/notice-column.vue +0 -313
  464. package/components/fu-notice-bar/notice-row.vue +0 -363
  465. package/components/fu-notice-bar/props.js +0 -173
  466. package/components/fu-number-box/fu-number-box.vue +0 -210
  467. package/components/fu-number-box/props.js +0 -79
  468. package/components/fu-parse/fu-parse.vue +0 -508
  469. package/components/fu-parse/node/node.vue +0 -576
  470. package/components/fu-parse/parser.js +0 -1335
  471. package/components/fu-picker/fu-picker.vue +0 -347
  472. package/components/fu-picker/props.js +0 -150
  473. package/components/fu-popup/fu-popup.vue +0 -475
  474. package/components/fu-popup/keypress.js +0 -45
  475. package/components/fu-popup/props.js +0 -83
  476. package/components/fu-progress/fu-progress.vue +0 -292
  477. package/components/fu-progress/props.js +0 -76
  478. package/components/fu-rate/fu-rate.vue +0 -301
  479. package/components/fu-rate/props.js +0 -103
  480. package/components/fu-read-more/fu-read-more.vue +0 -191
  481. package/components/fu-read-more/props.js +0 -72
  482. package/components/fu-ribbon/fu-ribbon.vue +0 -106
  483. package/components/fu-ribbon/props.js +0 -35
  484. package/components/fu-safe-area/fu-safe-area.vue +0 -61
  485. package/components/fu-scroll-list/fu-scroll-list.vue +0 -196
  486. package/components/fu-scroll-list/nvue.js +0 -28
  487. package/components/fu-scroll-list/props.js +0 -43
  488. package/components/fu-search/props.js +0 -149
  489. package/components/fu-section/props.js +0 -59
  490. package/components/fu-sign-board/fu-sign-board.vue +0 -730
  491. package/components/fu-sign-board/props.js +0 -34
  492. package/components/fu-skeleton/fu-skeleton.vue +0 -238
  493. package/components/fu-skeleton/props.js +0 -35
  494. package/components/fu-steps/fu-steps.vue +0 -81
  495. package/components/fu-steps/props.js +0 -55
  496. package/components/fu-steps-item/fu-steps-item.vue +0 -274
  497. package/components/fu-steps-item/props.js +0 -34
  498. package/components/fu-sticky/fu-sticky.vue +0 -232
  499. package/components/fu-sticky/props.js +0 -54
  500. package/components/fu-subsection/fu-subsection.vue +0 -288
  501. package/components/fu-subsection/props.js +0 -88
  502. package/components/fu-swipe-action/fu-swipe-action.vue +0 -64
  503. package/components/fu-swipe-action-item/props.js +0 -54
  504. package/components/fu-swiper/props.js +0 -163
  505. package/components/fu-switch/props.js +0 -102
  506. package/components/fu-tabs/fu-tabs.vue +0 -361
  507. package/components/fu-tabs/props.js +0 -109
  508. package/components/fu-tag/props.js +0 -135
  509. package/components/fu-text/button.js +0 -13
  510. package/components/fu-text/fu-text.vue +0 -254
  511. package/components/fu-text/openType.js +0 -47
  512. package/components/fu-text/props.js +0 -173
  513. package/components/fu-text/value.js +0 -88
  514. package/components/fu-textarea/fu-textarea.vue +0 -288
  515. package/components/fu-textarea/props.js +0 -206
  516. package/components/fu-timeaxis-item/fu-timeaxis-item.vue +0 -68
  517. package/components/fu-transition/createAnimation.js +0 -131
  518. package/components/fu-transition/fu-transition.vue +0 -292
  519. package/components/fu-transition/props.js +0 -21
  520. package/components/fu-upload/fu-upload.vue +0 -563
  521. package/components/fu-upload/props.js +0 -171
  522. package/components/fu-upload/upload-file.vue +0 -332
  523. package/components/fu-upload/upload-image.vue +0 -304
  524. package/components/fu-vtabs/fu-vtabs.vue +0 -443
  525. package/components/fu-vtabs/props.js +0 -114
  526. package/components/fu-vtabs-item/fu-vtabs-item.vue +0 -71
  527. package/components/fu-waterfall/fu-waterfall.vue +0 -238
  528. package/components/fu-waterfall/props.js +0 -85
  529. package/index.js +0 -71
  530. package/libs/function/check.js +0 -215
  531. package/libs/function/common.js +0 -527
  532. package/libs/function/message.js +0 -47
  533. package/libs/mixin/button.js +0 -85
  534. package/libs/mixin/mixin.js +0 -94
  535. package/libs/mixin/mpMixin.js +0 -8
  536. package/libs/mixin/mpShare.js +0 -15
  537. package/libs/route/route.config.js +0 -66
  538. package/libs/style/color.scss +0 -24
  539. /package/components/{fu-icon → icon/src}/fuicon.ttf +0 -0
  540. /package/components/{fu-swipe-action-item → swipe-action-item/src}/bindingx.js +0 -0
  541. /package/components/{fu-swipe-action-item → swipe-action-item/src}/mpalipay.js +0 -0
  542. /package/components/{fu-swipe-action-item → swipe-action-item/src}/mpother.js +0 -0
  543. /package/components/{fu-swipe-action-item → swipe-action-item/src}/render.js +0 -0
  544. /package/{libs/style → style}/components.scss +0 -0
  545. /package/{libs/style → style}/style.h5.scss +0 -0
  546. /package/{libs/style → style}/style.mp.scss +0 -0
  547. /package/{libs/function → utils}/dayjs.js +0 -0
@@ -0,0 +1,44 @@
1
+ import { getCurrentInstance, inject, nextTick, onMounted, reactive } from 'vue';
2
+ import type { IndexAnchorProps } from '../index-anchor';
3
+
4
+ export const useIndexAnchor = (props: IndexAnchorProps) => {
5
+ const instance = getCurrentInstance();
6
+ const parentData = reactive({
7
+ sticky: true
8
+ });
9
+ const indexList = inject<any>('indexListContext', null);
10
+ const indexListItem = inject<any>('indexListItemContext', null);
11
+
12
+ const init = () => {
13
+ // 此处会活动父组件实例,并赋值给实例的parent属性
14
+ if (!indexList) {
15
+ return uni.$fu.error('fu-index-anchor必须要搭配fu-index-list组件使用')
16
+ }
17
+ parentData.sticky = indexList.sticky;
18
+ // 将当前实例放入到fu-index-list中
19
+ indexList.anchors.value.push({
20
+ text: props.text,
21
+ height: 0,
22
+ instance
23
+ })
24
+ // #ifndef APP-NVUE
25
+ // 只有在非nvue下,fu-index-anchor才是嵌套在fu-index-item中的
26
+ if (!indexListItem) {
27
+ return uni.$fu.error('fu-index-anchor必须要搭配fu-index-item组件使用')
28
+ }
29
+ // 设置fu-index-item的id为anchor的text标识符,因为非nvue下滚动列表需要依赖scroll-view滚动到元素的特性
30
+ indexListItem.id.value = String(props.text).charCodeAt(0);
31
+ // #endif
32
+ };
33
+
34
+ // 生命周期
35
+ onMounted(() => {
36
+ nextTick(() => {
37
+ init()
38
+ })
39
+ });
40
+
41
+ return {
42
+ parentData
43
+ }
44
+ }
@@ -0,0 +1,45 @@
1
+ import type { ExtractPropTypes } from 'vue';
2
+
3
+ export const indexAnchorProps = {
4
+ /**
5
+ * @description 列表锚点文本内容
6
+ */
7
+ text: {
8
+ type: [String, Number],
9
+ default: ''
10
+ },
11
+ /**
12
+ * @description 列表锚点文字颜色
13
+ * @default '#606266'
14
+ */
15
+ color: {
16
+ type: String,
17
+ default: '#606266'
18
+ },
19
+ /**
20
+ * @description 列表锚点文字大小
21
+ * @default 14
22
+ */
23
+ size: {
24
+ type: [String, Number],
25
+ default: 14
26
+ },
27
+ /**
28
+ * @description 列表锚点背景颜色
29
+ * @default '#f6f6f6'
30
+ */
31
+ bgColor: {
32
+ type: String,
33
+ default: '#f6f6f6'
34
+ },
35
+ /**
36
+ * @description 列表锚点高度
37
+ * @default 32
38
+ */
39
+ height: {
40
+ type: [String, Number],
41
+ default: 32
42
+ }
43
+ };
44
+
45
+ export type IndexAnchorProps = ExtractPropTypes<typeof indexAnchorProps>;
@@ -0,0 +1,60 @@
1
+ <template>
2
+ <!-- #ifdef APP-NVUE -->
3
+ <header>
4
+ <!-- #endif -->
5
+ <view
6
+ :ref="`fu-index-anchor-${text}`"
7
+ :class="['fu-index-anchor', {'fu-index-anchor-sticky': parentData.sticky}]"
8
+ :style="{
9
+ height: $fu.addUnit(height),
10
+ backgroundColor: bgColor
11
+ }">
12
+ <text class="fu-index-anchor__text" :style="{ fontSize: $fu.addUnit(size), color: color }">{{ text }}</text>
13
+ </view>
14
+ <!-- #ifdef APP-NVUE -->
15
+ </header>
16
+ <!-- #endif -->
17
+ </template>
18
+
19
+ <script lang="ts" setup>
20
+ /**
21
+ * IndexAnchor 列表锚点
22
+ * @description 此组件需配合fu-index-list组件一起使用
23
+ * @property {String | Number} text 列表锚点文本内容
24
+ * @property {String} color 列表锚点文字颜色 (默认 '#606266')
25
+ * @property {String | Number} size 列表锚点文字大小 (默认 14)
26
+ * @property {String} bgColor 列表锚点背景颜色 (默认 '#f6f6f6')
27
+ * @property {String | Number} height 列表锚点高度 (默认 32)
28
+ *
29
+ * @example <fu-index-anchor :text="indexList[index]"></fu-index-anchor>
30
+ */
31
+ import { indexAnchorProps } from './index-anchor';
32
+ import { useIndexAnchor } from './composables';
33
+
34
+ defineOptions({ name: 'FuIndexAnchor', options: { virtualHost: true } });
35
+
36
+ const props = defineProps(indexAnchorProps);
37
+
38
+ const {
39
+ parentData
40
+ } = useIndexAnchor(props);
41
+ </script>
42
+
43
+ <style lang="scss" scoped>
44
+ @use '../../../style/components.scss';
45
+
46
+ .fu-index-anchor {
47
+ @include components.flex;
48
+ align-items: center;
49
+ padding-left: 15px;
50
+ z-index: 1;
51
+ &-sticky {
52
+ position: sticky;
53
+ top: 0;
54
+ }
55
+ &__text {
56
+ @include components.flex;
57
+ align-items: center;
58
+ }
59
+ }
60
+ </style>
@@ -0,0 +1 @@
1
+ export * from './src/index-item'
@@ -0,0 +1 @@
1
+ export * from './use-index-item'
@@ -0,0 +1,75 @@
1
+ import { getCurrentInstance, ref, inject, onMounted, provide, nextTick } from 'vue';
2
+ import type { IndexItemProps } from '../index-item';
3
+ import { useCommon } from '../../../../hooks';
4
+ // #ifdef APP-NVUE
5
+ // 由于weex为阿里的KPI业绩考核的产物,所以不支持百分比单位,这里需要通过dom查询组件的宽度
6
+ const dom = uni.requireNativePlugin('dom')
7
+ // #endif
8
+
9
+ export const useIndexItem = (props: IndexItemProps) => {
10
+ const instance = getCurrentInstance();
11
+ const { getRect } = useCommon();
12
+ const top = ref(0);
13
+ const height = ref(0);
14
+ const id = ref(props.index || uni.$fu.uuid());
15
+ const indexList = inject<any>('indexListContext', null);
16
+
17
+ const init = () => {
18
+ if (!indexList) {
19
+ return uni.$fu.error('fu-index-item必须要搭配fu-index-list组件使用')
20
+ }
21
+
22
+ const childData = {
23
+ top,
24
+ height,
25
+ id: id.value,
26
+ instance: instance
27
+ };
28
+
29
+ const exists = indexList.children.value?.some((item: any) => item.id === id.value);
30
+ if(!exists) {
31
+ indexList.children.value.push(childData);
32
+ }
33
+
34
+ uni.$fu.sleep().then(() =>{
35
+ getIndexItemRect().then((size: any) => {
36
+ // 由于对象的引用特性,此处会同时生效到父组件的children数组中,供父组件判断读取
37
+ top.value = Math.ceil(size.top);
38
+ height.value = Math.ceil(size.height);
39
+ })
40
+ })
41
+ };
42
+
43
+ const getIndexItemRect = () => {
44
+ return new Promise(resolve => {
45
+ // #ifndef APP-NVUE
46
+ getRect('.fu-index-item').then(size => {
47
+ resolve(size)
48
+ })
49
+ // #endif
50
+
51
+ // #ifdef APP-NVUE
52
+ const ref = instance?.proxy?.$refs?.['fu-index-item'];
53
+ dom.getComponentRect(ref, (res : any) => {
54
+ resolve(res.size)
55
+ })
56
+ // #endif
57
+ })
58
+ };
59
+
60
+ // 生命周期
61
+ onMounted(() => {
62
+ nextTick(() => {
63
+ init()
64
+ })
65
+ });
66
+
67
+ // 提供上下文给子组件
68
+ provide('indexListItemContext', {
69
+ id
70
+ });
71
+
72
+ return {
73
+ id
74
+ }
75
+ }
@@ -0,0 +1,13 @@
1
+ import type { ExtractPropTypes } from 'vue';
2
+
3
+ export const indexItemProps = {
4
+ /**
5
+ * @description 索引标识符,用于生成唯一的ID
6
+ */
7
+ index: {
8
+ type: [Number, String],
9
+ default: 0
10
+ }
11
+ };
12
+
13
+ export type IndexItemProps = ExtractPropTypes<typeof indexItemProps>;
@@ -0,0 +1,32 @@
1
+ <template>
2
+ <!-- #ifdef APP-NVUE -->
3
+ <cell ref="fu-index-item">
4
+ <!-- #endif -->
5
+ <view :id="`fu-index-item-${id}`" class="fu-index-item" :class="[`fu-index-item-${id}`]">
6
+ <slot />
7
+ </view>
8
+ <!-- #ifdef APP-NVUE -->
9
+ </cell>
10
+ <!-- #endif -->
11
+ </template>
12
+
13
+ <script lang="ts" setup>
14
+ /**
15
+ * IndexItem 组件
16
+ * @description 此组件需配合fu-index-list组件一起使用
17
+ */
18
+ import { indexItemProps } from './index-item';
19
+ import { useIndexItem } from './composables';
20
+
21
+ defineOptions({ name: 'FuIndexItem', options: { virtualHost: true } })
22
+
23
+ const props = defineProps(indexItemProps);
24
+
25
+ const {
26
+ id
27
+ } = useIndexItem(props)
28
+ </script>
29
+
30
+ <style>
31
+
32
+ </style>
@@ -0,0 +1 @@
1
+ export * from './src/index-list'
@@ -0,0 +1 @@
1
+ export * from './use-index-list'
@@ -0,0 +1,297 @@
1
+ import { getCurrentInstance, computed, onMounted, ref, type SetupContext, nextTick, watch, provide } from 'vue';
2
+ import type { IndexListProps, IndexListEmits } from '../index-list';
3
+ import { useCommon } from '../../../../hooks';
4
+ // #ifdef APP-NVUE
5
+ // 由于weex为阿里的KPI业绩考核的产物,所以不支持百分比单位,这里需要通过dom查询组件的宽度
6
+ const dom = uni.requireNativePlugin('dom')
7
+ // #endif
8
+
9
+ const generateIndexList = () => {
10
+ const indexList = [];
11
+ const charCodeOfA = 'A'.charCodeAt(0);
12
+ for (let i = 0; i < 26; i++) {
13
+ indexList.push(String.fromCharCode(charCodeOfA + i));
14
+ }
15
+ return indexList;
16
+ }
17
+
18
+ export const useIndexList = (props: IndexListProps, $emit: SetupContext<IndexListEmits>['emit']) => {
19
+ const instance = getCurrentInstance();
20
+ const { getRect } = useCommon();
21
+ // 当前正在被选中的字母索引
22
+ const activeIndex = ref(-1);
23
+ // 索引字母的信息
24
+ const letterInfo = ref({
25
+ height: 0,
26
+ itemHeight: 0,
27
+ top: 0
28
+ });
29
+ // 设置字母指示器的高度,后面为了让指示器跟随字母,并将尖角部分指向字母的中部,需要依赖此值
30
+ const indicatorHeight = ref(50);
31
+ // 当前是否正在被触摸状态
32
+ const touching = ref(false);
33
+ // 滚动条顶部top值
34
+ const scrollTop = ref(0);
35
+ // scroll-view的高度
36
+ const scrollViewHeight = ref(0);
37
+ // 系统信息
38
+ const sys = ref(uni.$fu.sys());
39
+ const scrolling = ref(false);
40
+ const scrollIntoView = ref('');
41
+ const hasHeight = ref(0);
42
+ const timer = ref<any>(0);
43
+ const disTap = ref(false);
44
+ const children = ref<any[]>([])
45
+ const anchors = ref<any[]>([])
46
+
47
+ // 如果有传入外部的indexList锚点数组则使用,否则使用内部生成A-Z字母
48
+ const indexLetterList = computed(() => {
49
+ return props.indexList.length? props.indexList: generateIndexList()
50
+ });
51
+
52
+ // 字母放大指示器的top值,为了让其指向当前激活的字母
53
+ const indicatorTop = computed(() => {
54
+ const { top, itemHeight } = letterInfo.value;
55
+ return Math.floor(top + itemHeight * activeIndex.value + itemHeight / 2 - indicatorHeight.value / 2) - 8
56
+ });
57
+
58
+ // 初始化
59
+ const init = () => {
60
+ // 设置列表的高度为整个屏幕的高度
61
+ //减去this.customNavHeight,并将this.scrollViewHeight设置为maxHeight
62
+ //解决当fu-index-list组件放在tabbar页面时,scroll-view内容较少时,还能滚动
63
+ scrollViewHeight.value = sys.value.windowHeight - uni.$fu.getPx(props.customNavHeight)
64
+ };
65
+
66
+ // 获取索引列表的尺寸以及单个字符的尺寸信息
67
+ const getIndexListLetterRect = () => {
68
+ return new Promise(resolve => {
69
+ // 延时一定时间,以获取dom尺寸
70
+ // #ifndef APP-NVUE
71
+ getRect('.fu-index-list__letter').then(size => {
72
+ resolve(size)
73
+ })
74
+ // #endif
75
+
76
+ // #ifdef APP-NVUE
77
+ const ref = instance?.proxy?.$refs?.['fu-index-list__letter']
78
+ dom.getComponentRect(ref, (res: any) => {
79
+ resolve(res.size)
80
+ })
81
+ // #endif
82
+ })
83
+ };
84
+
85
+ // 设置indexList索引的尺寸信息
86
+ const setIndexListLetterInfo = async () => {
87
+ const size: any = await getIndexListLetterRect();
88
+ const { height } = size;
89
+ const windowHeight = sys.value.windowHeight;
90
+ let customNavHeight = 0;
91
+ // 消除各端导航栏非原生和原生导致的差异,让索引列表字母对屏幕垂直居中
92
+ if (props.customNavHeight == 0) {
93
+ // #ifdef H5
94
+ customNavHeight = sys.value.windowTop;
95
+ // #endif
96
+ // #ifndef H5
97
+ // 在非H5中,为原生导航栏,其高度不算在windowHeight内,这里设置为负值,后面相加时变成减去其高度的一半
98
+ customNavHeight = 0;
99
+ // #endif
100
+ } else {
101
+ customNavHeight = uni.$fu.getPx(props.customNavHeight);
102
+ }
103
+ letterInfo.value = {
104
+ height,
105
+ // 为了让字母列表对屏幕绝对居中,让其对导航栏进行修正,也即往上偏移导航栏的一半高度
106
+ top: (windowHeight - height) / 2 + customNavHeight / 2,
107
+ itemHeight: Math.floor(height / indexLetterList.value.length)
108
+ };
109
+ };
110
+
111
+ // 获取当前被触摸的索引字母
112
+ const getIndexListLetter = (pageY: number): number => {
113
+ const { top, height, itemHeight } = letterInfo.value;
114
+ // 对H5的pageY进行修正,这是由于uni-app自作多情在H5中将触摸点的坐标跟H5的导航栏结合导致的问题
115
+ // #ifdef H5
116
+ pageY += sys.value.windowTop;
117
+ // #endif
118
+ // #ifdef APP-NVUE
119
+ pageY += top;
120
+ // #endif
121
+ // 对第一和最后一个字母做边界处理,因为用户可能在字母列表上触摸到两端的尽头后依然继续滑动
122
+ if (pageY < top) {
123
+ return 0
124
+ } else if (pageY >= top + height) {
125
+ // 如果超出了,取最后一个字母
126
+ return indexLetterList.value.length - 1
127
+ } else {
128
+ // 将触摸点的Y轴偏移值,减去索引字母的top值,除以每个字母的高度,即可得到当前触摸点落在哪个字母上
129
+ return Math.floor((pageY - top) / itemHeight);
130
+ }
131
+ };
132
+
133
+ // 设置各项由触摸而导致变化的值
134
+ const setValueForTouch = (currentIndex: number) => {
135
+ // 如果偏移量太小,前后得出的会是同一个索引字母,为了防抖,进行返回
136
+ if (currentIndex === activeIndex.value) return
137
+ activeIndex.value = currentIndex;
138
+ // #ifndef APP-NVUE || MP-WEIXIN || MP-QQ
139
+ // 在非nvue中,由于anchor和item都在fu-index-item中,所以需要对index-item进行偏移
140
+ scrollIntoView.value = `fu-index-item-${indexLetterList.value[currentIndex].charCodeAt(0)}`;
141
+ // #endif
142
+ // #ifdef MP-WEIXIN || MP-QQ
143
+ // 微信小程序、QQ小程序下,scroll-view的scroll-into-view属性无法对slot中的内容的id生效,只能通过设置scrollTop的形式去移动滚动条
144
+ scrollTop.value = children.value[currentIndex].top;
145
+ // #endif
146
+ // #ifdef APP-NVUE
147
+ // 在nvue中,由于cell和header为同级元素,所以实际是需要对header(anchor)进行偏移
148
+ const anchor = `fu-index-anchor-${indexLetterList.value[currentIndex]}`;
149
+ dom.scrollToElement(anchors.value[currentIndex].$refs[anchor], {
150
+ offset: 0,
151
+ animated: false
152
+ })
153
+ // #endif
154
+ };
155
+
156
+ // 索引列表被触摸
157
+ const touchStart = (e: any) => {
158
+ // 获取触摸点信息
159
+ const touchStart = e.changedTouches[0];
160
+ if (!touchStart || disTap.value) return
161
+ touching.value = true;
162
+ const { pageY } = touchStart;
163
+ // 根据当前触摸点的坐标,获取当前触摸的为第几个字母
164
+ const currentIndex = getIndexListLetter(pageY);
165
+ setValueForTouch(currentIndex)
166
+ };
167
+
168
+ // 索引字母列表被触摸滑动中
169
+ const touchMove = (e: any) => {
170
+ // 获取触摸点信息
171
+ let touchMove = e.changedTouches[0];
172
+ if (!touchMove || disTap.value) return
173
+
174
+ // 滑动结束后迅速开始第二次滑动时候 touching 为 false 造成不显示 indicator 问题
175
+ if (!touching.value) {
176
+ touching.value = true;
177
+ }
178
+ const { pageY } = touchMove;
179
+ const currentIndex = getIndexListLetter(pageY);
180
+ setValueForTouch(currentIndex)
181
+ };
182
+
183
+ // 触摸结束
184
+ const touchEnd = () => {
185
+ // 延时一定时间后再隐藏指示器,为了让用户看的更直观,同时也是为了消除快速切换fu-transition的show带来的影响
186
+ uni.$fu.sleep(300).then(() => {
187
+ touching.value = false;
188
+ })
189
+ $emit('select', activeIndex.value);
190
+ };
191
+
192
+ const getHeaderRect = () => {
193
+ // 获取header slot的高度,因为list组件中获取元素的尺寸是没有top值的
194
+ return new Promise(resolve => {
195
+ dom.getComponentRect(instance?.refs?.header, (res: any) => {
196
+ resolve(res.size)
197
+ })
198
+ })
199
+ };
200
+
201
+ // scroll-view的滚动事件
202
+ const scrollHandler = async (e: any) => {
203
+ if (touching.value || scrolling.value) return
204
+
205
+ // 每过一定时间取样一次,减少资源损耗以及可能带来的卡顿
206
+ scrolling.value = true;
207
+ disTap.value = true;
208
+ clearTimeout(timer.value);
209
+ timer.value = setTimeout(() => {
210
+ disTap.value = false;
211
+ }, 200) as unknown as number
212
+ uni.$fu.sleep(30).then(() => {
213
+ scrolling.value = false;
214
+ })
215
+ let scrollTop = 0
216
+ const len = children.value.length;
217
+ let childrenData = children.value;
218
+ const anchorsData = anchors.value;
219
+ const customNavHeight = uni.$fu.getPx(props.customNavHeight);
220
+
221
+ // #ifdef APP-NVUE
222
+ // nvue下获取的滚动条偏移为负数,需要转为正数
223
+ scrollTop = Math.abs(e.contentOffset.y)
224
+ // 获取header slot的尺寸信息
225
+ const header = await getHeaderRect();
226
+ // item的top值,在nvue下,模拟出的anchor的top,类似非nvue下的index-item的top
227
+ let top: number = (header as any).height || 0;
228
+ // 由于list组件无法获取cell的top值,这里通过header slot和各个item之间的height,模拟出类似非nvue下的位置信息
229
+ childrenData = children.value.map((item, index) => {
230
+ if (item.height > 0) hasHeight.value = item.height;
231
+ item.height = item.height > 0? item.height: hasHeight.value;
232
+ const child = { height: item.height, top };
233
+ // 进行累加,给下一个item提供计算依据
234
+ top += item.height + anchorsData[index].height
235
+ return child
236
+ })
237
+ // #endif
238
+ // #ifndef APP-NVUE
239
+ // 非nvue通过detail获取滚动条位移
240
+ scrollTop = e.detail.scrollTop;
241
+ // #endif
242
+ for (let i = 0; i < len; i++) {
243
+ const item = childrenData[i], nextItem = childrenData[i + 1];
244
+ // 如果滚动条高度小于第一个item的top值,此时无需设置任意字母为高亮
245
+ if (scrollTop + customNavHeight <= childrenData[0].top || scrollTop >= childrenData[len - 1].top + childrenData[len - 1].height) {
246
+ activeIndex.value = -1;
247
+ break
248
+ } else if (!nextItem) {
249
+ // 当不存在下一个item时,意味着历遍到了最后一个
250
+ activeIndex.value = len - 1;
251
+ break
252
+ } else if (scrollTop + customNavHeight > item.top && scrollTop + customNavHeight < nextItem.top) {
253
+ activeIndex.value = i;
254
+ break
255
+ }
256
+ }
257
+ };
258
+
259
+ // 生命周期
260
+ onMounted(() => {
261
+ init()
262
+ nextTick(() => {
263
+ setIndexListLetterInfo()
264
+ })
265
+ });
266
+
267
+ // 监听事件
268
+ watch(() => indexLetterList.value, () => {
269
+ uni.$fu.sleep().then(() => {
270
+ setIndexListLetterInfo()
271
+ })
272
+ }, { immediate: true });
273
+
274
+ // 提供上下文给子组件
275
+ provide('indexListContext', {
276
+ children,
277
+ anchors,
278
+ sticky: props.sticky,
279
+ customNavHeight: props.customNavHeight
280
+ });
281
+
282
+ return {
283
+ activeIndex,
284
+ letterInfo,
285
+ touching,
286
+ scrollTop,
287
+ scrollViewHeight,
288
+ scrollIntoView,
289
+ indicatorHeight,
290
+ indexLetterList,
291
+ indicatorTop,
292
+ touchStart,
293
+ touchMove,
294
+ touchEnd,
295
+ scrollHandler
296
+ }
297
+ }
@@ -0,0 +1,52 @@
1
+ import type { ExtractPropTypes } from 'vue';
2
+
3
+ export const indexListProps = {
4
+ /**
5
+ * @description 右边锚点非激活的颜色
6
+ * @default '#606266'
7
+ */
8
+ inactiveColor: {
9
+ type: String,
10
+ default: '#606266'
11
+ },
12
+ /**
13
+ * @description 右边锚点激活的颜色
14
+ * @default '#2979ff'
15
+ */
16
+ activeColor: {
17
+ type: String,
18
+ default: '#2979ff'
19
+ },
20
+ /**
21
+ * @description 索引字符列表,数组形式
22
+ */
23
+ indexList: {
24
+ type: Array,
25
+ default: () => []
26
+ },
27
+ /**
28
+ * @description 是否开启锚点自动吸顶
29
+ * @default true
30
+ */
31
+ sticky: {
32
+ type: Boolean,
33
+ default: true
34
+ },
35
+ /**
36
+ * @description 自定义导航栏的高度
37
+ */
38
+ customNavHeight: {
39
+ type: [String, Number],
40
+ default: 0
41
+ }
42
+ };
43
+
44
+ export const indexListEmits = {
45
+ /**
46
+ * @description 选中右边索引字符时触发
47
+ */
48
+ select: (_e: any) => true
49
+ };
50
+
51
+ export type IndexListProps = ExtractPropTypes<typeof indexListProps>;
52
+ export type IndexListEmits = typeof indexListEmits;