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
@@ -4,7 +4,7 @@
4
4
  * @param {string} endColor 结束的颜色
5
5
  * @param {number} step 颜色等分的份额
6
6
  * */
7
- function colorGradient(startColor = 'rgb(0, 0, 0)', endColor = 'rgb(255, 255, 255)', step = 10) {
7
+ function colorGradient(startColor: string = 'rgb(0, 0, 0)', endColor: string = 'rgb(255, 255, 255)', step: number = 10) {
8
8
  const startRGB = hexToRgb(startColor, false); // 转换为rgb数组模式
9
9
  const startR = startRGB[0];
10
10
  const startG = startRGB[1];
@@ -34,7 +34,7 @@ function colorGradient(startColor = 'rgb(0, 0, 0)', endColor = 'rgb(255, 255, 25
34
34
  }
35
35
 
36
36
  // 将hex表示方式转换为rgb表示方式(这里返回rgb数组模式)
37
- function hexToRgb(sColor, str = true) {
37
+ function hexToRgb(sColor: string, str: boolean = true) {
38
38
  const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/
39
39
  sColor = String(sColor).toLowerCase()
40
40
  if (sColor && reg.test(sColor)) {
@@ -62,7 +62,7 @@ function hexToRgb(sColor, str = true) {
62
62
  }
63
63
 
64
64
  // 将rgb表示方式转换为hex表示方式
65
- function rgbToHex(rgb) {
65
+ function rgbToHex(rgb: string) {
66
66
  const _this = rgb
67
67
  const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/
68
68
  if (/^(rgb|RGB)/.test(_this)) {
@@ -101,7 +101,7 @@ function rgbToHex(rgb) {
101
101
  * sHex为传入的十六进制的色值
102
102
  * alpha为rgba的透明度
103
103
  */
104
- function colorToRgba(color, alpha) {
104
+ function colorToRgba(color: string, alpha: number) {
105
105
  color = rgbToHex(color)
106
106
  // 十六进制颜色值的正则表达式
107
107
  const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/
@@ -0,0 +1,2 @@
1
+ export * from './loading-custom'
2
+ export * from './use-loading'
@@ -0,0 +1,21 @@
1
+ import { computed } from 'vue';
2
+ import type { LoadingProps } from '../loading';
3
+ import { colorGradient } from './colorGradient';
4
+
5
+ export const userLoadingCustomStyle = (props: LoadingProps) => {
6
+ // 当为circle类型时,给其另外三边设置一个更轻一些的颜色
7
+ // 之所以需要这么做的原因是,比如父组件传了color为红色,那么需要另外的三个边为浅红色
8
+ // 而不能是固定的某一个其他颜色(因为这个固定的颜色可能浅蓝,导致效果没有那么细腻良好)
9
+ const otherBorderColor = computed(() => {
10
+ const lightColor = colorGradient(props.color, '#ffffff', 100)[80]
11
+ if (props.mode === 'circle') {
12
+ return props.inactiveColor ? props.inactiveColor : lightColor
13
+ } else {
14
+ return 'transparent'
15
+ }
16
+ })
17
+
18
+ return {
19
+ otherBorderColor
20
+ }
21
+ }
@@ -0,0 +1,100 @@
1
+ import { ref, onMounted, watch } from 'vue';
2
+ import type { LoadingProps } from '../loading';
3
+ // #ifdef APP-NVUE
4
+ // @ts-ignore
5
+ const animation = weex.requireModule('animation') as any;
6
+ // #endif
7
+
8
+ export const useLoading = (props: LoadingProps) => {
9
+ // Array.form可以通过一个伪数组对象创建指定长度的数组
10
+ // https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/from
11
+ const array12 = ref(Array.from({
12
+ length: 12
13
+ }));
14
+ // 这里需要设置默认值为360,否则在安卓nvue上,会延迟一个duration周期后才执行
15
+ // 在iOS nvue上,则会一开始默认执行两个周期的动画
16
+ const aniAngel = ref(360); // 动画旋转角度
17
+ const webviewHide = ref(false); // 监听webview的状态,如果隐藏了页面,则停止动画,以免性能消耗
18
+ const ani = ref(null);
19
+ const loading = ref(false); // 是否运行中,针对nvue使用
20
+
21
+ const init = () => {
22
+ setTimeout(() => {
23
+ // #ifdef APP-NVUE
24
+ props.show && nvueAnimate()
25
+ // #endif
26
+ // #ifdef APP-PLUS
27
+ props.show && addEventListenerToWebview()
28
+ // #endif
29
+ }, 20)
30
+ };
31
+
32
+ // 监听webview的显示与隐藏
33
+ const addEventListenerToWebview = () => {
34
+ // webview的堆栈
35
+ const pages = getCurrentPages();
36
+ // 获取当前页面
37
+ const presentPage = pages[pages.length - 1];
38
+ // 当前页面的webview实例
39
+ const currentWebview = presentPage.$getAppWebview();
40
+ // 监听webview的显示与隐藏,从而停止或者开始动画(为了性能)
41
+ currentWebview.addEventListener('hide', () => {
42
+ webviewHide.value = true;
43
+ })
44
+ currentWebview.addEventListener('show', () => {
45
+ webviewHide.value = false;
46
+ })
47
+ };
48
+
49
+ // #ifdef APP-NVUE
50
+ const nvueAnimate = () => {
51
+ // nvue下,非flower类型时才需要旋转,因为nvue的flower类型,使用了weex的
52
+ // loading-indicator组件,自带旋转功能
53
+ props.mode !== 'flower' && startAnimate()
54
+ };
55
+
56
+ // 执行nvue的animate模块动画
57
+ const startAnimate = () => {
58
+ loading.value = true;
59
+ if (!ani.value) return
60
+ animation.transition(ani.value, {
61
+ // 进行角度旋转
62
+ styles: {
63
+ transform: `rotate(${aniAngel.value}deg)`,
64
+ transformOrigin: 'center center'
65
+ },
66
+ duration: props.duration,
67
+ timingFunction: props.timingFunction,
68
+ delay: 10
69
+ }, () => {
70
+ // 每次增加360deg,为了让其重新旋转一周
71
+ aniAngel.value += 360;
72
+ // 动画结束后,继续循环执行动画,需要同时判断webviewHide变量
73
+ // nvue安卓,页面隐藏后依然会继续执行startAnimate方法
74
+ props.show && !webviewHide.value ? startAnimate() : loading.value = false;
75
+ })
76
+ }
77
+ // #endif
78
+
79
+ // 生命周期
80
+ onMounted(() => {
81
+ init()
82
+ });
83
+
84
+ // watch监听事件
85
+ watch(() => props.show, (newVal) => {
86
+ // nvue中,show为true,且为非loading状态,就重新执行动画模块
87
+ // #ifdef APP-NVUE
88
+ if (newVal && !loading.value) {
89
+ setTimeout(() => {
90
+ startAnimate()
91
+ }, 30)
92
+ }
93
+ // #endif
94
+ });
95
+
96
+ return {
97
+ array12,
98
+ webviewHide
99
+ }
100
+ }
@@ -0,0 +1,77 @@
1
+ import type { ExtractPropTypes } from 'vue';
2
+ import { componentProps } from '../../../constants';
3
+
4
+ /**
5
+ * 加载动画mode有效值
6
+ */
7
+ export const loadingModes = ['circle', 'semicircle', 'flower', 'over'] as const;
8
+
9
+ export const loadingProps = {
10
+ /**
11
+ * @description 是否显示
12
+ * @default true
13
+ * @example <fu-loading :show="false"></fu-loading>
14
+ */
15
+ show: {
16
+ type: Boolean,
17
+ default: true
18
+ },
19
+ /**
20
+ * @description 动画类型
21
+ * @values 'circle' - 圆圈形状, 'semicircle' - 半圆形状, 'flower' - 花朵形状, 'over' - 翻转效果
22
+ * @default 'flower'
23
+ * @example <fu-loading mode="circle"></fu-loading>
24
+ */
25
+ mode: {
26
+ type: String,
27
+ values: loadingModes,
28
+ default: 'flower'
29
+ },
30
+ /**
31
+ * @description 加载颜色
32
+ * @default '#a5a6a8'
33
+ * @example <fu-loading color="red"></fu-loading>
34
+ */
35
+ color: {
36
+ type: String,
37
+ default: '#a5a6a8'
38
+ },
39
+ /**
40
+ * @description 加载动画大小
41
+ * @default 20
42
+ * @example <fu-loading size="18"></fu-loading>
43
+ */
44
+ size: {
45
+ type: [String, Number],
46
+ default: 20
47
+ },
48
+ /**
49
+ * @description 动画模式
50
+ * @default 'linear'
51
+ * @example <fu-loading timingFunction="linear"></fu-loading>
52
+ */
53
+ timingFunction: {
54
+ type: String,
55
+ default: 'linear'
56
+ },
57
+ /**
58
+ * @description 动画执行周期时间
59
+ * @default 1200
60
+ * @example <fu-loading duration="2000"></fu-loading>
61
+ */
62
+ duration: {
63
+ type: [String, Number],
64
+ default: 1200
65
+ },
66
+ /**
67
+ * @description 暗边颜色(仅mode=circle时生效)
68
+ * @example <fu-loading inactiveColor="#eeeeee"></fu-loading>
69
+ */
70
+ inactiveColor: {
71
+ type: String,
72
+ default: ''
73
+ },
74
+ ...componentProps
75
+ }
76
+
77
+ export type LoadingProps = ExtractPropTypes<typeof loadingProps>;
@@ -14,12 +14,12 @@
14
14
  borderBottomColor: otherBorderColor,
15
15
  borderLeftColor: otherBorderColor,
16
16
  borderRightColor: otherBorderColor,
17
- 'animation-duration': `${duration}ms`,
18
- 'animation-timing-function': mode === 'semicircle' || mode === 'circle' ? timingFunction : ''
17
+ animationDuration: `${duration}ms`,
18
+ animationTimingFunction: mode === 'semicircle' || mode === 'circle' ? timingFunction : ''
19
19
  }" v-if="!webviewHide">
20
20
  <block v-if="mode === 'flower'">
21
21
  <!-- #ifndef APP-NVUE -->
22
- <view v-for="(item,index) in array12" :key="index" class="fu-loading__dot"></view>
22
+ <view v-for="(_,index) in array12" :key="index" class="fu-loading__dot"></view>
23
23
  <!-- #endif -->
24
24
  <!-- #ifdef APP-NVUE -->
25
25
  <!-- 此组件内部图标部分无法设置宽高,即使通过width和height配置了也无效 -->
@@ -31,17 +31,11 @@
31
31
  </fu-transition>
32
32
  </template>
33
33
 
34
- <script>
35
- import { colorGradient } from '../../libs/function/colorGradient.js'
36
- import mpMixin from '../../libs/mixin/mpMixin.js'
37
- import mixin from '../../libs/mixin/mixin.js'
38
- import props from './props.js'
39
- // #ifdef APP-NVUE
40
- const animation = weex.requireModule('animation');
41
- // #endif
34
+ <script lang="ts" setup>
42
35
  /**
43
36
  * Loading 加载动画
44
37
  * @description 此组件为一个小动画,目前用在fusionsUi的loadingMore加载更多和switch开关等组件的正在加载状态场景。
38
+ * @tutorial http://www.fusions.top/components/loading.html
45
39
  * @property {Boolean} show = [true|false] 是否显示 (默认 false)
46
40
  * @property {String} mode = [circle|semicircle|flower|over] 动画类型(默认 flower)
47
41
  * @value circle 圆圈形状
@@ -49,120 +43,30 @@
49
43
  * @value flower 花朵形状
50
44
  * @value over 翻转效果
51
45
  * @property {String} color 动画颜色
52
- * @property {String,Number} size 动画大小(默认 20)
53
- * @property {String,Number} duration 动画执行周期时间(默认 1200)
46
+ * @property {String | Number} size 动画大小(默认 20)
47
+ * @property {String | Number} duration 动画执行周期时间(默认 1200)
54
48
  * @property {String} inactiveColor 暗边颜色(仅mode=circle时有效)
55
49
  * @property {String} timingFunction 动画模式 (默认 'linear' )
56
50
  * @property {String} customClass 定义需要用到的外部样式类
57
- * @property {Object,String} customStyle 定义需要用到的外部样式
51
+ * @property {String | Object} customStyle 定义需要用到的外部样式
58
52
  *
59
53
  * @example <fu-loading></fu-loading>
60
54
  */
61
- export default {
62
- name: "FuLoading",
63
- mixins: [mpMixin, mixin, props],
64
- data() {
65
- return {
66
- // Array.form可以通过一个伪数组对象创建指定长度的数组
67
- // https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/from
68
- array12: Array.from({
69
- length: 12
70
- }),
71
- // 这里需要设置默认值为360,否则在安卓nvue上,会延迟一个duration周期后才执行
72
- // 在iOS nvue上,则会一开始默认执行两个周期的动画
73
- aniAngel: 360, // 动画旋转角度
74
- webviewHide: false, // 监听webview的状态,如果隐藏了页面,则停止动画,以免性能消耗
75
- loading: false, // 是否运行中,针对nvue使用
76
- };
77
- },
78
- computed: {
79
- // 当为circle类型时,给其另外三边设置一个更轻一些的颜色
80
- // 之所以需要这么做的原因是,比如父组件传了color为红色,那么需要另外的三个边为浅红色
81
- // 而不能是固定的某一个其他颜色(因为这个固定的颜色可能浅蓝,导致效果没有那么细腻良好)
82
- otherBorderColor() {
83
- const lightColor = colorGradient(this.color, '#ffffff', 100)[80]
84
- if (this.mode === 'circle') {
85
- return this.inactiveColor ? this.inactiveColor : lightColor
86
- } else {
87
- return 'transparent'
88
- }
89
- }
90
- },
91
- mounted() {
92
- this.init()
93
- },
94
- methods: {
95
- init() {
96
- setTimeout(() => {
97
- // #ifdef APP-NVUE
98
- this.show && this.nvueAnimate()
99
- // #endif
100
- // #ifdef APP-PLUS
101
- this.show && this.addEventListenerToWebview()
102
- // #endif
103
- }, 20)
104
- },
105
-
106
- // 监听webview的显示与隐藏
107
- addEventListenerToWebview() {
108
- // webview的堆栈
109
- const pages = getCurrentPages();
110
- // 获取当前页面
111
- const presentPage = pages[pages.length - 1];
112
- // 当前页面的webview实例
113
- const currentWebview = presentPage.$getAppWebview();
114
- // 监听webview的显示与隐藏,从而停止或者开始动画(为了性能)
115
- currentWebview.addEventListener('hide', () => {
116
- this.webviewHide = true;
117
- })
118
- currentWebview.addEventListener('show', () => {
119
- this.webviewHide = false;
120
- })
121
- },
122
-
123
- // #ifdef APP-NVUE
124
- nvueAnimate() {
125
- // nvue下,非flower类型时才需要旋转,因为nvue的flower类型,使用了weex的
126
- // loading-indicator组件,自带旋转功能
127
- this.mode !== 'flower' && this.startAnimate()
128
- },
129
- // 执行nvue的animate模块动画
130
- startAnimate() {
131
- this.loading = true;
132
- const ani = this.$refs.ani;
133
- if (!ani) return
134
- animation.transition(ani, {
135
- // 进行角度旋转
136
- styles: {
137
- transform: `rotate(${this.aniAngel}deg)`,
138
- transformOrigin: 'center center'
139
- },
140
- duration: this.duration,
141
- timingFunction: this.timingFunction,
142
- delay: 10
143
- }, () => {
144
- // 每次增加360deg,为了让其重新旋转一周
145
- this.aniAngel += 360;
146
- // 动画结束后,继续循环执行动画,需要同时判断webviewHide变量
147
- // nvue安卓,页面隐藏后依然会继续执行startAnimate方法
148
- this.show && !this.webviewHide ? this.startAnimate() : this.loading = false;
149
- })
150
- }
151
- // #endif
152
- },
153
- watch: {
154
- show(n) {
155
- // nvue中,show为true,且为非loading状态,就重新执行动画模块
156
- // #ifdef APP-NVUE
157
- if (n && !this.loading) {
158
- setTimeout(() => {
159
- this.startAnimate()
160
- }, 30)
161
- }
162
- // #endif
163
- }
164
- }
165
- }
55
+ import { loadingProps } from './loading';
56
+ import { useLoading, userLoadingCustomStyle } from './composables';
57
+
58
+ defineOptions({ name: 'FuLoading', options: { virtualHost: true } });
59
+
60
+ const props = defineProps(loadingProps);
61
+
62
+ const {
63
+ array12,
64
+ webviewHide
65
+ } = useLoading(props);
66
+
67
+ const {
68
+ otherBorderColor
69
+ } = userLoadingCustomStyle(props);
166
70
  </script>
167
71
 
168
72
  <style lang="scss" scoped>
@@ -0,0 +1 @@
1
+ export * from './src/loading-more'
@@ -0,0 +1,75 @@
1
+ import type { ExtractPropTypes } from 'vue';
2
+ import { componentProps } from '../../../constants';
3
+
4
+ /**
5
+ * 加载更多 mode 有效值
6
+ */
7
+ export const loadingMoreModes = ['circle', 'semicircle', 'flower', 'over'] as const;
8
+
9
+ export const loadingMoreProps = {
10
+ /**
11
+ * @description 加载状态
12
+ * @values 0 - loading前, 1 - loading中, 2 - 没有更多了
13
+ * @default 0
14
+ * @example <fu-loading-more :loadingType="1"></fu-loading-more>
15
+ */
16
+ loadingType: {
17
+ type: [String, Number],
18
+ default: 0
19
+ },
20
+ /**
21
+ * @description 动画类型
22
+ * @values 'circle' - 圆圈形状, 'semicircle' - 半圆形状, 'flower' - 花朵形状, 'over' - 翻转效果
23
+ * @default 'flower'
24
+ * @example <fu-loading-more mode="circle"></fu-loading-more>
25
+ */
26
+ mode: {
27
+ type: String,
28
+ values: loadingMoreModes,
29
+ default: 'flower'
30
+ },
31
+ /**
32
+ * @description 文本&字体颜色
33
+ * @default '#a5a6a8'
34
+ * @example <fu-loading-more color="red"></fu-loading-more>
35
+ */
36
+ color: {
37
+ type: String,
38
+ default: "#a5a6a8"
39
+ },
40
+ /**
41
+ * @description 字体大小
42
+ * @default 12
43
+ * @example <fu-loading-more size="14"></fu-loading-more>
44
+ */
45
+ size: {
46
+ type: [String, Number],
47
+ default: 12
48
+ },
49
+ /**
50
+ * @description 图标大小
51
+ * @default 18
52
+ * @example <fu-loading-more iconSize="20"></fu-loading-more>
53
+ */
54
+ iconSize: {
55
+ type: [String, Number],
56
+ default: 18
57
+ },
58
+ /**
59
+ * @description 文字描述
60
+ * @example <fu-loading-more :contentText="{contentdown: "上拉加载更多", contentrefresh: "正在加载", contentnomore: "没有更多了"}"></fu-loading-more>
61
+ */
62
+ contentText: {
63
+ type: Object,
64
+ default () {
65
+ return {
66
+ contentdown: "上拉显示更多",
67
+ contentrefresh: "正在努力加载",
68
+ contentnomore: "已经到底了"
69
+ }
70
+ }
71
+ },
72
+ ...componentProps
73
+ };
74
+
75
+ export type LoadingMoreProps = ExtractPropTypes<typeof loadingMoreProps>;
@@ -1,5 +1,5 @@
1
1
  <template>
2
- <view class="fu-loading-more" :class="[customClass]" :style="[$fu.addStyle(this.customStyle)]">
2
+ <view class="fu-loading-more" :class="customClass" :style="[$fu.addStyle(customStyle)]">
3
3
  <fu-loading
4
4
  :mode="mode"
5
5
  :color="color"
@@ -17,42 +17,41 @@
17
17
  </view>
18
18
  </template>
19
19
 
20
- <script>
21
- import mixin from '../../libs/mixin/mixin.js'
22
- import mpMixin from '../../libs/mixin/mpMixin.js'
23
- import props from './props.js'
20
+ <script lang="ts" setup>
24
21
  /**
25
22
  * LoadingMore加载更多
26
23
  * @description 此组件一般用于标识页面底部加载数据时的状态
27
- * @property {String,Number} loadingType = [0|1|2] 组件状态 默认0 上拉的状态:0-loading前;1-loading中;2-没有更多了
24
+ * @tutorial http://www.fusions.top/components/loading-more.html
25
+ * @property {String | Number} loadingType = [0|1|2] 组件状态(默认 0)
26
+ * @value 0 loading前
27
+ * @value 1 loading中
28
+ * @value 2 没有更多了
28
29
  * @property {String} color 定义颜色(默认 '#a5a6a8')
29
- * @property {String,Number} size 定义字体大小(默认 12)
30
- * @property {Object} contentText 定义文字描述 ( 默认{contentdown: "上拉显示更多", contentrefresh: "正在努力加载", contentnomore: "已经到底了"})
31
- * @property {String,Number} iconSize 定义图标大小(默认 18)
30
+ * @property {String | Number} size 定义字体大小(默认 12)
31
+ * @property {Object} contentText 定义文字描述 ( 默认 {contentdown: '上拉显示更多', contentrefresh: '正在努力加载', contentnomore: '已经到底了'}
32
+ * @property {String | Number} iconSize 定义图标大小(默认 18)
32
33
  * @property {String} mode = [circle|semicircle|flower|over] 动画类型(默认 flower)
33
34
  * @value circle 圆圈形状
34
35
  * @value semicircle 半圆形状
35
36
  * @value flower 花朵形状
36
37
  * @value over 翻转效果
37
38
  * @property {String} customClass 定义需要用到的外部类
38
- * @property {Object,String} customStyle 定义需要用到的外部样式
39
+ * @property {String | Object} customStyle 定义需要用到的外部样式
39
40
  *
40
41
  * @example <fu-loading-more :loadingType="1"></fu-loading-more>
41
42
  */
42
- export default {
43
- name: "FuLoadingMore",
44
- mixins: [mixin, mpMixin, props],
45
- data() {
46
- return {};
47
- }
48
- }
43
+ import { loadingMoreProps } from './loading-more';
44
+
45
+ defineOptions({ name: 'FuLoadingMore', options: { virtualHost: true } })
46
+
47
+ const props = defineProps(loadingMoreProps);
49
48
  </script>
50
49
 
51
50
  <style lang="scss" scoped>
52
- @import '../../libs/style/components.scss';
51
+ @use '../../../style/components.scss';
53
52
 
54
53
  .fu-loading-more {
55
- @include flex(row);
54
+ @include components.flex(row);
56
55
  align-items: center;
57
56
  justify-content: center;
58
57
  height: 40px;
@@ -0,0 +1 @@
1
+ export * from './src/modal'
@@ -0,0 +1,2 @@
1
+ export * from './modal-custom'
2
+ export * from './use-modal'
@@ -0,0 +1,17 @@
1
+ import { computed, type CSSProperties } from 'vue';
2
+ import type { ModalProps } from '../modal';
3
+
4
+ export const useModalCustomStyle = (props: ModalProps) => {
5
+ const nvueStyle = computed<CSSProperties>(() => {
6
+ const style: Record<string, any> = {};
7
+ // 避免nvue中不能换行的问题
8
+ // #ifdef APP-NVUE
9
+ style.width = uni.$fu.addUnit(uni.$fu.getPx(props.width) - 50, 'px');
10
+ // #endif
11
+ return style;
12
+ });
13
+
14
+ return {
15
+ nvueStyle
16
+ }
17
+ }
@@ -0,0 +1,56 @@
1
+ import { ref, nextTick, type SetupContext } from 'vue';
2
+ import type { ModalProps, ModalEmits } from '../modal';
3
+
4
+ export const useModal = (props: ModalProps, $emit: SetupContext<ModalEmits>['emit']) => {
5
+ const popupRef = ref();
6
+ const loading = ref(false);
7
+
8
+ const open = () => {
9
+ popupRef.value.open();
10
+ if (loading.value) loading.value = false;
11
+ };
12
+
13
+ const close = () => {
14
+ popupRef.value.close();
15
+ };
16
+
17
+ const popupChange = (e: any) => {
18
+ if (!e.show) $emit('close');
19
+ };
20
+
21
+ // 点击确定按钮
22
+ const confirmHandler = () => {
23
+ if (!loading.value) {
24
+ $emit('confirm');
25
+ }
26
+ // 如果配置了异步关闭,将按钮值为loading状态
27
+ if (props.asyncClose) {
28
+ loading.value = true;
29
+ } else {
30
+ close();
31
+ }
32
+ };
33
+
34
+ // 点击取消按钮
35
+ const cancelHandler = () => {
36
+ $emit('cancel');
37
+ close();
38
+ };
39
+
40
+ const closeLoading = () => {
41
+ nextTick(() => {
42
+ loading.value = false;
43
+ })
44
+ };
45
+
46
+ return {
47
+ popupRef,
48
+ loading,
49
+ open,
50
+ close,
51
+ popupChange,
52
+ confirmHandler,
53
+ cancelHandler,
54
+ closeLoading
55
+ }
56
+ }