uview-ui-wjf 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (368) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +71 -0
  3. package/changelog.md +388 -0
  4. package/components/u--form/u--form.vue +92 -0
  5. package/components/u--image/u--image.vue +73 -0
  6. package/components/u--input/u--input.vue +115 -0
  7. package/components/u--text/u--text.vue +72 -0
  8. package/components/u--textarea/u--textarea.vue +85 -0
  9. package/components/u-action-sheet/props.js +54 -0
  10. package/components/u-action-sheet/u-action-sheet.vue +278 -0
  11. package/components/u-album/props.js +59 -0
  12. package/components/u-album/u-album.vue +259 -0
  13. package/components/u-alert/props.js +44 -0
  14. package/components/u-alert/u-alert.vue +243 -0
  15. package/components/u-avatar/props.js +78 -0
  16. package/components/u-avatar/u-avatar.vue +173 -0
  17. package/components/u-avatar-group/props.js +52 -0
  18. package/components/u-avatar-group/u-avatar-group.vue +103 -0
  19. package/components/u-back-top/props.js +54 -0
  20. package/components/u-back-top/u-back-top.vue +129 -0
  21. package/components/u-badge/props.js +72 -0
  22. package/components/u-badge/u-badge.vue +171 -0
  23. package/components/u-button/nvue.scss +46 -0
  24. package/components/u-button/props.js +161 -0
  25. package/components/u-button/u-button.vue +495 -0
  26. package/components/u-button/vue.scss +80 -0
  27. package/components/u-calendar/header.vue +99 -0
  28. package/components/u-calendar/month.vue +579 -0
  29. package/components/u-calendar/props.js +144 -0
  30. package/components/u-calendar/u-calendar.vue +384 -0
  31. package/components/u-calendar/util.js +85 -0
  32. package/components/u-car-keyboard/props.js +14 -0
  33. package/components/u-car-keyboard/u-car-keyboard.vue +311 -0
  34. package/components/u-cell/props.js +110 -0
  35. package/components/u-cell/u-cell.vue +229 -0
  36. package/components/u-cell-group/props.js +14 -0
  37. package/components/u-cell-group/u-cell-group.vue +61 -0
  38. package/components/u-checkbox/props.js +69 -0
  39. package/components/u-checkbox/u-checkbox.vue +344 -0
  40. package/components/u-checkbox-group/props.js +82 -0
  41. package/components/u-checkbox-group/u-checkbox-group.vue +103 -0
  42. package/components/u-circle-progress/props.js +8 -0
  43. package/components/u-circle-progress/u-circle-progress.vue +198 -0
  44. package/components/u-code/props.js +34 -0
  45. package/components/u-code/u-code.vue +129 -0
  46. package/components/u-code-input/props.js +79 -0
  47. package/components/u-code-input/u-code-input.vue +252 -0
  48. package/components/u-col/props.js +29 -0
  49. package/components/u-col/u-col.vue +162 -0
  50. package/components/u-collapse/props.js +19 -0
  51. package/components/u-collapse/u-collapse.vue +90 -0
  52. package/components/u-collapse-item/props.js +59 -0
  53. package/components/u-collapse-item/u-collapse-item.vue +225 -0
  54. package/components/u-column-notice/props.js +55 -0
  55. package/components/u-column-notice/u-column-notice.vue +160 -0
  56. package/components/u-count-down/props.js +24 -0
  57. package/components/u-count-down/u-count-down.vue +163 -0
  58. package/components/u-count-down/utils.js +62 -0
  59. package/components/u-count-to/props.js +59 -0
  60. package/components/u-count-to/u-count-to.vue +184 -0
  61. package/components/u-datetime-picker/props.js +120 -0
  62. package/components/u-datetime-picker/u-datetime-picker.vue +361 -0
  63. package/components/u-divider/props.js +44 -0
  64. package/components/u-divider/u-divider.vue +116 -0
  65. package/components/u-dropdown/props.js +65 -0
  66. package/components/u-dropdown/u-dropdown.vue +127 -0
  67. package/components/u-dropdown-item/props.js +36 -0
  68. package/components/u-dropdown-item/u-dropdown-item.vue +127 -0
  69. package/components/u-empty/props.js +59 -0
  70. package/components/u-empty/u-empty.vue +128 -0
  71. package/components/u-form/props.js +45 -0
  72. package/components/u-form/u-form.vue +214 -0
  73. package/components/u-form-item/props.js +48 -0
  74. package/components/u-form-item/u-form-item.vue +235 -0
  75. package/components/u-gap/props.js +24 -0
  76. package/components/u-gap/u-gap.vue +38 -0
  77. package/components/u-grid/props.js +19 -0
  78. package/components/u-grid/u-grid.vue +97 -0
  79. package/components/u-grid-item/props.js +14 -0
  80. package/components/u-grid-item/u-grid-item.vue +209 -0
  81. package/components/u-icon/icons.js +214 -0
  82. package/components/u-icon/props.js +89 -0
  83. package/components/u-icon/u-icon.vue +237 -0
  84. package/components/u-image/props.js +84 -0
  85. package/components/u-image/u-image.vue +232 -0
  86. package/components/u-index-anchor/props.js +29 -0
  87. package/components/u-index-anchor/u-index-anchor.vue +91 -0
  88. package/components/u-index-item/props.js +5 -0
  89. package/components/u-index-item/u-index-item.vue +87 -0
  90. package/components/u-index-list/props.js +29 -0
  91. package/components/u-index-list/u-index-list.vue +440 -0
  92. package/components/u-input/props.js +187 -0
  93. package/components/u-input/u-input.vue +369 -0
  94. package/components/u-keyboard/props.js +84 -0
  95. package/components/u-keyboard/u-keyboard.vue +164 -0
  96. package/components/u-line/props.js +33 -0
  97. package/components/u-line/u-line.vue +62 -0
  98. package/components/u-line-progress/props.js +28 -0
  99. package/components/u-line-progress/u-line-progress.vue +144 -0
  100. package/components/u-link/props.js +39 -0
  101. package/components/u-link/u-link.vue +83 -0
  102. package/components/u-list/props.js +76 -0
  103. package/components/u-list/u-list.vue +157 -0
  104. package/components/u-list-item/props.js +9 -0
  105. package/components/u-list-item/u-list-item.vue +116 -0
  106. package/components/u-loading-icon/props.js +59 -0
  107. package/components/u-loading-icon/u-loading-icon.vue +343 -0
  108. package/components/u-loading-page/props.js +49 -0
  109. package/components/u-loading-page/u-loading-page.vue +115 -0
  110. package/components/u-loadmore/props.js +94 -0
  111. package/components/u-loadmore/u-loadmore.vue +150 -0
  112. package/components/u-modal/props.js +89 -0
  113. package/components/u-modal/u-modal.vue +228 -0
  114. package/components/u-navbar/props.js +84 -0
  115. package/components/u-navbar/u-navbar.vue +186 -0
  116. package/components/u-no-network/props.js +19 -0
  117. package/components/u-no-network/u-no-network.vue +220 -0
  118. package/components/u-notice-bar/props.js +70 -0
  119. package/components/u-notice-bar/u-notice-bar.vue +101 -0
  120. package/components/u-notify/props.js +49 -0
  121. package/components/u-notify/u-notify.vue +211 -0
  122. package/components/u-number-box/props.js +109 -0
  123. package/components/u-number-box/u-number-box.vue +416 -0
  124. package/components/u-number-keyboard/props.js +19 -0
  125. package/components/u-number-keyboard/u-number-keyboard.vue +196 -0
  126. package/components/u-overlay/props.js +24 -0
  127. package/components/u-overlay/u-overlay.vue +68 -0
  128. package/components/u-parse/node/node.vue +499 -0
  129. package/components/u-parse/parser.js +1075 -0
  130. package/components/u-parse/props.js +45 -0
  131. package/components/u-parse/u-parse.vue +366 -0
  132. package/components/u-picker/props.js +79 -0
  133. package/components/u-picker/u-picker.vue +286 -0
  134. package/components/u-picker-column/props.js +5 -0
  135. package/components/u-picker-column/u-picker-column.vue +27 -0
  136. package/components/u-popup/props.js +79 -0
  137. package/components/u-popup/u-popup.vue +304 -0
  138. package/components/u-radio/props.js +64 -0
  139. package/components/u-radio/u-radio.vue +339 -0
  140. package/components/u-radio-group/props.js +85 -0
  141. package/components/u-radio-group/u-radio-group.vue +108 -0
  142. package/components/u-rate/props.js +69 -0
  143. package/components/u-rate/u-rate.vue +306 -0
  144. package/components/u-read-more/props.js +61 -0
  145. package/components/u-read-more/u-read-more.vue +157 -0
  146. package/components/u-row/props.js +19 -0
  147. package/components/u-row/u-row.vue +93 -0
  148. package/components/u-row-notice/props.js +39 -0
  149. package/components/u-row-notice/u-row-notice.vue +330 -0
  150. package/components/u-safe-bottom/props.js +5 -0
  151. package/components/u-safe-bottom/u-safe-bottom.vue +56 -0
  152. package/components/u-scroll-list/nvue.js +28 -0
  153. package/components/u-scroll-list/other.js +0 -0
  154. package/components/u-scroll-list/props.js +34 -0
  155. package/components/u-scroll-list/scrollWxs.wxs +50 -0
  156. package/components/u-scroll-list/u-scroll-list.vue +224 -0
  157. package/components/u-search/props.js +118 -0
  158. package/components/u-search/u-search.vue +303 -0
  159. package/components/u-skeleton/props.js +59 -0
  160. package/components/u-skeleton/u-skeleton.vue +244 -0
  161. package/components/u-slider/mpother.js +113 -0
  162. package/components/u-slider/mpwxs.js +42 -0
  163. package/components/u-slider/mpwxs.wxs +121 -0
  164. package/components/u-slider/nvue - /345/211/257/346/234/254.js" +180 -0
  165. package/components/u-slider/nvue.js +193 -0
  166. package/components/u-slider/props.js +54 -0
  167. package/components/u-slider/u-slider.vue +55 -0
  168. package/components/u-status-bar/props.js +8 -0
  169. package/components/u-status-bar/u-status-bar.vue +46 -0
  170. package/components/u-steps/props.js +39 -0
  171. package/components/u-steps/u-steps.vue +80 -0
  172. package/components/u-steps-item/props.js +24 -0
  173. package/components/u-steps-item/u-steps-item.vue +316 -0
  174. package/components/u-sticky/props.js +40 -0
  175. package/components/u-sticky/u-sticky.vue +212 -0
  176. package/components/u-subsection/props.js +49 -0
  177. package/components/u-subsection/u-subsection.vue +299 -0
  178. package/components/u-swipe-action/props.js +9 -0
  179. package/components/u-swipe-action/u-swipe-action.vue +67 -0
  180. package/components/u-swipe-action-item/index - backup.wxs +256 -0
  181. package/components/u-swipe-action-item/index.wxs +225 -0
  182. package/components/u-swipe-action-item/nvue - backup.js +270 -0
  183. package/components/u-swipe-action-item/nvue.js +174 -0
  184. package/components/u-swipe-action-item/props.js +41 -0
  185. package/components/u-swipe-action-item/u-swipe-action-item.vue +190 -0
  186. package/components/u-swipe-action-item/wxs.js +15 -0
  187. package/components/u-swiper/props.js +125 -0
  188. package/components/u-swiper/u-swiper.vue +255 -0
  189. package/components/u-swiper-indicator/props.js +29 -0
  190. package/components/u-swiper-indicator/u-swiper-indicator.vue +110 -0
  191. package/components/u-switch/props.js +54 -0
  192. package/components/u-switch/u-switch.vue +177 -0
  193. package/components/u-tabbar/props.js +44 -0
  194. package/components/u-tabbar/u-tabbar.vue +141 -0
  195. package/components/u-tabbar-item/props.js +35 -0
  196. package/components/u-tabbar-item/u-tabbar-item.vue +142 -0
  197. package/components/u-table/props.js +5 -0
  198. package/components/u-table/u-table.vue +29 -0
  199. package/components/u-tabs/props.js +64 -0
  200. package/components/u-tabs/u-tabs.vue +363 -0
  201. package/components/u-tabs-item/props.js +5 -0
  202. package/components/u-tabs-item/u-tabs-item.vue +29 -0
  203. package/components/u-tag/props.js +84 -0
  204. package/components/u-tag/u-tag.vue +358 -0
  205. package/components/u-td/props.js +5 -0
  206. package/components/u-td/u-td.vue +31 -0
  207. package/components/u-text/props.js +110 -0
  208. package/components/u-text/u-text.vue +223 -0
  209. package/components/u-text/value.js +85 -0
  210. package/components/u-textarea/props.js +119 -0
  211. package/components/u-textarea/u-textarea.vue +239 -0
  212. package/components/u-toast/u-toast.vue +291 -0
  213. package/components/u-toolbar/props.js +34 -0
  214. package/components/u-toolbar/u-toolbar.vue +102 -0
  215. package/components/u-tooltip/clipboard.min.js +58 -0
  216. package/components/u-tooltip/props.js +59 -0
  217. package/components/u-tooltip/u-tooltip.vue +366 -0
  218. package/components/u-tr/props.js +5 -0
  219. package/components/u-tr/u-tr.vue +31 -0
  220. package/components/u-transition/nvue.ani-map.js +68 -0
  221. package/components/u-transition/props.js +24 -0
  222. package/components/u-transition/transition.js +157 -0
  223. package/components/u-transition/u-transition.vue +92 -0
  224. package/components/u-transition/vue.ani-style.scss +113 -0
  225. package/components/u-upload/mixin.js +21 -0
  226. package/components/u-upload/props.js +124 -0
  227. package/components/u-upload/u-upload.vue +566 -0
  228. package/components/u-upload/utils.js +151 -0
  229. package/components/uview-ui/uview-ui.vue +15 -0
  230. package/index.js +79 -0
  231. package/index.scss +23 -0
  232. package/libs/config/color.js +17 -0
  233. package/libs/config/config.js +34 -0
  234. package/libs/config/props/actionSheet.js +25 -0
  235. package/libs/config/props/album.js +25 -0
  236. package/libs/config/props/alert.js +22 -0
  237. package/libs/config/props/avatar.js +28 -0
  238. package/libs/config/props/avatarGroup.js +23 -0
  239. package/libs/config/props/backtop.js +27 -0
  240. package/libs/config/props/badge.js +27 -0
  241. package/libs/config/props/button.js +42 -0
  242. package/libs/config/props/calendar.js +42 -0
  243. package/libs/config/props/carKeyboard.js +15 -0
  244. package/libs/config/props/cell.js +35 -0
  245. package/libs/config/props/cellGroup.js +17 -0
  246. package/libs/config/props/checkbox.js +27 -0
  247. package/libs/config/props/checkboxGroup.js +29 -0
  248. package/libs/config/props/circleProgress.js +15 -0
  249. package/libs/config/props/code.js +21 -0
  250. package/libs/config/props/codeInput.js +29 -0
  251. package/libs/config/props/col.js +19 -0
  252. package/libs/config/props/collapse.js +17 -0
  253. package/libs/config/props/collapseItem.js +25 -0
  254. package/libs/config/props/columnNotice.js +24 -0
  255. package/libs/config/props/countDown.js +18 -0
  256. package/libs/config/props/countTo.js +25 -0
  257. package/libs/config/props/datetimePicker.js +37 -0
  258. package/libs/config/props/divider.js +23 -0
  259. package/libs/config/props/empty.js +26 -0
  260. package/libs/config/props/form.js +22 -0
  261. package/libs/config/props/formItem.js +23 -0
  262. package/libs/config/props/gap.js +19 -0
  263. package/libs/config/props/grid.js +17 -0
  264. package/libs/config/props/gridItem.js +16 -0
  265. package/libs/config/props/icon.js +36 -0
  266. package/libs/config/props/image.js +30 -0
  267. package/libs/config/props/indexAnchor.js +19 -0
  268. package/libs/config/props/indexList.js +19 -0
  269. package/libs/config/props/input.js +48 -0
  270. package/libs/config/props/keyboard.js +30 -0
  271. package/libs/config/props/line.js +20 -0
  272. package/libs/config/props/lineProgress.js +19 -0
  273. package/libs/config/props/link.js +26 -0
  274. package/libs/config/props/list.js +28 -0
  275. package/libs/config/props/listItem.js +15 -0
  276. package/libs/config/props/loadingIcon.js +30 -0
  277. package/libs/config/props/loadingPage.js +23 -0
  278. package/libs/config/props/loadmore.js +32 -0
  279. package/libs/config/props/modal.js +31 -0
  280. package/libs/config/props/navbar.js +32 -0
  281. package/libs/config/props/noNetwork.js +18 -0
  282. package/libs/config/props/noticeBar.js +27 -0
  283. package/libs/config/props/notify.js +22 -0
  284. package/libs/config/props/numberBox.js +35 -0
  285. package/libs/config/props/numberKeyboard.js +17 -0
  286. package/libs/config/props/overlay.js +18 -0
  287. package/libs/config/props/parse.js +22 -0
  288. package/libs/config/props/picker.js +29 -0
  289. package/libs/config/props/popup.js +29 -0
  290. package/libs/config/props/radio.js +27 -0
  291. package/libs/config/props/radioGroup.js +30 -0
  292. package/libs/config/props/rate.js +26 -0
  293. package/libs/config/props/readMore.js +22 -0
  294. package/libs/config/props/row.js +17 -0
  295. package/libs/config/props/rowNotice.js +21 -0
  296. package/libs/config/props/scrollList.js +20 -0
  297. package/libs/config/props/search.js +37 -0
  298. package/libs/config/props/section.js +24 -0
  299. package/libs/config/props/skeleton.js +25 -0
  300. package/libs/config/props/slider.js +25 -0
  301. package/libs/config/props/statusBar.js +15 -0
  302. package/libs/config/props/steps.js +21 -0
  303. package/libs/config/props/stepsItem.js +18 -0
  304. package/libs/config/props/sticky.js +20 -0
  305. package/libs/config/props/subsection.js +23 -0
  306. package/libs/config/props/swipeAction.js +15 -0
  307. package/libs/config/props/swipeActionItem.js +21 -0
  308. package/libs/config/props/swiper.js +39 -0
  309. package/libs/config/props/swipterIndicator.js +19 -0
  310. package/libs/config/props/switch.js +24 -0
  311. package/libs/config/props/tabbar.js +22 -0
  312. package/libs/config/props/tabbarItem.js +20 -0
  313. package/libs/config/props/tabs.js +32 -0
  314. package/libs/config/props/tag.js +29 -0
  315. package/libs/config/props/text.js +38 -0
  316. package/libs/config/props/textarea.js +36 -0
  317. package/libs/config/props/toast.js +30 -0
  318. package/libs/config/props/toolbar.js +21 -0
  319. package/libs/config/props/tooltip.js +25 -0
  320. package/libs/config/props/transition.js +18 -0
  321. package/libs/config/props/upload.js +36 -0
  322. package/libs/config/props.js +190 -0
  323. package/libs/config/zIndex.js +20 -0
  324. package/libs/css/color.scss +155 -0
  325. package/libs/css/common.scss +97 -0
  326. package/libs/css/components.scss +15 -0
  327. package/libs/css/flex.scss +257 -0
  328. package/libs/css/h5.scss +0 -0
  329. package/libs/css/mixin.scss +8 -0
  330. package/libs/css/mp.scss +0 -0
  331. package/libs/css/nvue.scss +0 -0
  332. package/libs/css/vue.scss +27 -0
  333. package/libs/function/colorGradient.js +134 -0
  334. package/libs/function/debounce.js +29 -0
  335. package/libs/function/digit.js +167 -0
  336. package/libs/function/index.js +731 -0
  337. package/libs/function/platform.js +75 -0
  338. package/libs/function/test.js +288 -0
  339. package/libs/function/throttle.js +30 -0
  340. package/libs/luch-request/adapters/index.js +97 -0
  341. package/libs/luch-request/core/InterceptorManager.js +50 -0
  342. package/libs/luch-request/core/Request.js +198 -0
  343. package/libs/luch-request/core/buildFullPath.js +20 -0
  344. package/libs/luch-request/core/defaults.js +29 -0
  345. package/libs/luch-request/core/dispatchRequest.js +3 -0
  346. package/libs/luch-request/core/mergeConfig.js +103 -0
  347. package/libs/luch-request/core/settle.js +16 -0
  348. package/libs/luch-request/helpers/buildURL.js +69 -0
  349. package/libs/luch-request/helpers/combineURLs.js +14 -0
  350. package/libs/luch-request/helpers/isAbsoluteURL.js +14 -0
  351. package/libs/luch-request/index.d.ts +116 -0
  352. package/libs/luch-request/index.js +3 -0
  353. package/libs/luch-request/utils/clone.js +264 -0
  354. package/libs/luch-request/utils.js +131 -0
  355. package/libs/mixin/button.js +13 -0
  356. package/libs/mixin/mixin.js +160 -0
  357. package/libs/mixin/mpMixin.js +8 -0
  358. package/libs/mixin/mpShare.js +13 -0
  359. package/libs/mixin/openType.js +25 -0
  360. package/libs/mixin/style.js +228 -0
  361. package/libs/mixin/touch.js +59 -0
  362. package/libs/util/async-validator.js +1343 -0
  363. package/libs/util/calendar.js +546 -0
  364. package/libs/util/dayjs.js +308 -0
  365. package/libs/util/emitter.js +51 -0
  366. package/libs/util/route.js +124 -0
  367. package/package.json +83 -0
  368. package/theme.scss +44 -0
@@ -0,0 +1,299 @@
1
+ <template>
2
+ <view
3
+ class="u-subsection"
4
+ ref="u-subsection"
5
+ :class="[`u-subsection--${mode}`]"
6
+ :style="[$u.addStyle(customStyle), wrapperStyle]"
7
+ >
8
+ <view
9
+ class="u-subsection__bar"
10
+ ref="u-subsection__bar"
11
+ :style="[barStyle]"
12
+ :class="[
13
+ mode === 'button' && 'u-subsection--button__bar',
14
+ current === 0 &&
15
+ mode === 'subsection' &&
16
+ 'u-subsection__bar--first',
17
+ current > 0 &&
18
+ current < list.length - 1 &&
19
+ mode === 'subsection' &&
20
+ 'u-subsection__bar--center',
21
+ current === list.length - 1 &&
22
+ mode === 'subsection' &&
23
+ 'u-subsection__bar--last',
24
+ ]"
25
+ ></view>
26
+ <view
27
+ class="u-subsection__item"
28
+ :class="[
29
+ `u-subsection__item--${index}`,
30
+ index < list.length - 1 &&
31
+ 'u-subsection__item--no-border-right',
32
+ index === 0 && 'u-subsection__item--first',
33
+ index === list.length - 1 && 'u-subsection__item--last',
34
+ ]"
35
+ :ref="`u-subsection__item--${index}`"
36
+ :style="[itemStyle(index)]"
37
+ @tap="clickHandler(index)"
38
+ v-for="(item, index) in list"
39
+ :key="index"
40
+ >
41
+ <text
42
+ class="u-subsection__item__text"
43
+ :style="[textStyle(index)]"
44
+ >{{ getText(item) }}</text
45
+ >
46
+ </view>
47
+ </view>
48
+ </template>
49
+
50
+ <script>
51
+ // #ifdef APP-NVUE
52
+ const dom = uni.requireNativePlugin("dom");
53
+ const animation = uni.requireNativePlugin("animation");
54
+ // #endif
55
+ import props from "./props.js";
56
+ /**
57
+ * Subsection 分段器
58
+ * @description 该分段器一般用于用户从几个选项中选择某一个的场景
59
+ * @tutorial https://www.uviewui.com/components/subsection.html
60
+ * @property {Array} list tab的数据
61
+ * @property {String | Number} current 当前活动的tab的index(默认 0 )
62
+ * @property {String} activeColor 激活时的颜色(默认 '#3c9cff' )
63
+ * @property {String} inactiveColor 未激活时的颜色(默认 '#303133' )
64
+ * @property {String} mode 模式选择,mode=button为按钮形式,mode=subsection时为分段模式(默认 'button' )
65
+ * @property {String | Number} fontSize 字体大小,单位px(默认 12 )
66
+ * @property {Boolean} bold 激活选项的字体是否加粗(默认 true )
67
+ * @property {String} bgColor 组件背景颜色,mode为button时有效(默认 '#eeeeef' )
68
+ * @property {Object} customStyle 定义需要用到的外部样式
69
+ * @property {String} keyName 从`list`元素对象中读取的键名(默认 'name' )
70
+ *
71
+ * @event {Function} change 分段器选项发生改变时触发 回调 index:选项的index索引值,从0开始
72
+ * @example <u-subsection :list="list" :current="curNow" @change="sectionChange"></u-subsection>
73
+ */
74
+ export default {
75
+ name: "u-subsection",
76
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
77
+ data() {
78
+ return {
79
+ // 组件尺寸
80
+ itemRect: {
81
+ width: 0,
82
+ height: 0,
83
+ },
84
+ };
85
+ },
86
+ watch: {
87
+ list(newValue, oldValue) {
88
+ this.init();
89
+ },
90
+ current: {
91
+ immediate: true,
92
+ handler(n) {
93
+ // #ifdef APP-NVUE
94
+ // 在安卓nvue上,如果通过translateX进行位移,到最后一个时,会导致右侧无法绘制圆角
95
+ // 故用animation模块进行位移
96
+ const ref = this.$refs?.["u-subsection__bar"]?.ref;
97
+ // 不存在ref的时候(理解为第一次初始化时,需要渲染dom,进行一定延时再获取ref),这里的100ms是经过测试得出的结果(某些安卓需要延时久一点),勿随意修改
98
+ uni.$u.sleep(ref ? 0 : 100).then(() => {
99
+ animation.transition(this.$refs["u-subsection__bar"].ref, {
100
+ styles: {
101
+ transform: `translateX(${
102
+ n * this.itemRect.width
103
+ }px)`,
104
+ transformOrigin: "center center",
105
+ },
106
+ duration: 300,
107
+ });
108
+ });
109
+ // #endif
110
+ },
111
+ },
112
+ },
113
+ computed: {
114
+ wrapperStyle() {
115
+ const style = {};
116
+ // button模式时,设置背景色
117
+ if (this.mode === "button") {
118
+ style.backgroundColor = this.bgColor;
119
+ }
120
+ return style;
121
+ },
122
+ // 滑块的样式
123
+ barStyle() {
124
+ const style = {};
125
+ style.width = `${this.itemRect.width}px`;
126
+ style.height = `${this.itemRect.height}px`;
127
+ // 通过translateX移动滑块,其移动的距离为索引*item的宽度
128
+ // #ifndef APP-NVUE
129
+ style.transform = `translateX(${
130
+ this.current * this.itemRect.width
131
+ }px)`;
132
+ // #endif
133
+ if (this.mode === "subsection") {
134
+ // 在subsection模式下,需要动态设置滑块的圆角,因为移动滑块使用的是translateX,无法通过父元素设置overflow: hidden隐藏滑块的直角
135
+ style.backgroundColor = this.activeColor;
136
+ }
137
+ return style;
138
+ },
139
+ // 分段器item的样式
140
+ itemStyle(index) {
141
+ return (index) => {
142
+ const style = {};
143
+ if (this.mode === "subsection") {
144
+ // 设置border的样式
145
+ style.borderColor = this.activeColor;
146
+ style.borderWidth = "1px";
147
+ style.borderStyle = "solid";
148
+ }
149
+ return style;
150
+ };
151
+ },
152
+ // 分段器文字颜色
153
+ textStyle(index) {
154
+ return (index) => {
155
+ const style = {};
156
+ style.fontWeight =
157
+ this.bold && this.current === index ? "bold" : "normal";
158
+ style.fontSize = uni.$u.addUnit(this.fontSize);
159
+ // subsection模式下,激活时默认为白色的文字
160
+ if (this.mode === "subsection") {
161
+ style.color =
162
+ this.current === index ? "#fff" : this.inactiveColor;
163
+ } else {
164
+ // button模式下,激活时文字颜色默认为activeColor
165
+ style.color =
166
+ this.current === index
167
+ ? this.activeColor
168
+ : this.inactiveColor;
169
+ }
170
+ return style;
171
+ };
172
+ },
173
+ },
174
+ mounted() {
175
+ this.init();
176
+ },
177
+ methods: {
178
+ init() {
179
+ uni.$u.sleep().then(() => this.getRect());
180
+ },
181
+ // 判断展示文本
182
+ getText(item) {
183
+ return typeof item === 'object' ? item[this.keyName] : item
184
+ },
185
+ // 获取组件的尺寸
186
+ getRect() {
187
+ // #ifndef APP-NVUE
188
+ this.$uGetRect(".u-subsection__item--0").then((size) => {
189
+ this.itemRect = size;
190
+ });
191
+ // #endif
192
+
193
+ // #ifdef APP-NVUE
194
+ const ref = this.$refs["u-subsection__item--0"][0];
195
+ ref &&
196
+ dom.getComponentRect(ref, (res) => {
197
+ this.itemRect = res.size;
198
+ });
199
+ // #endif
200
+ },
201
+ clickHandler(index) {
202
+ this.$emit("change", index);
203
+ },
204
+ },
205
+ };
206
+ </script>
207
+
208
+ <style lang="scss" scoped>
209
+ @import "../../libs/css/components.scss";
210
+
211
+ .u-subsection {
212
+ @include flex;
213
+ position: relative;
214
+ overflow: hidden;
215
+ /* #ifndef APP-NVUE */
216
+ width: 100%;
217
+ box-sizing: border-box;
218
+ /* #endif */
219
+
220
+ &--button {
221
+ height: 32px;
222
+ background-color: rgb(238, 238, 239);
223
+ padding: 3px;
224
+ border-radius: 3px;
225
+ align-items: stretch;
226
+
227
+ &__bar {
228
+ background-color: #ffffff;
229
+ border-radius: 3px !important;
230
+ }
231
+ }
232
+
233
+ &--subsection {
234
+ height: 30px;
235
+ }
236
+
237
+ &__bar {
238
+ position: absolute;
239
+ /* #ifndef APP-NVUE */
240
+ transition-property: transform, color;
241
+ transition-duration: 0.3s;
242
+ transition-timing-function: ease-in-out;
243
+ /* #endif */
244
+
245
+ &--first {
246
+ border-top-left-radius: 3px;
247
+ border-bottom-left-radius: 3px;
248
+ border-top-right-radius: 0px;
249
+ border-bottom-right-radius: 0px;
250
+ }
251
+
252
+ &--center {
253
+ border-top-left-radius: 0px;
254
+ border-bottom-left-radius: 0px;
255
+ border-top-right-radius: 0px;
256
+ border-bottom-right-radius: 0px;
257
+ }
258
+
259
+ &--last {
260
+ border-top-left-radius: 0px;
261
+ border-bottom-left-radius: 0px;
262
+ border-top-right-radius: 3px;
263
+ border-bottom-right-radius: 3px;
264
+ }
265
+ }
266
+
267
+ &__item {
268
+ @include flex;
269
+ flex: 1;
270
+ justify-content: center;
271
+ align-items: center;
272
+ // vue环境下,需要设置相对定位,因为滑块为绝对定位,item需要在滑块的上面
273
+ position: relative;
274
+
275
+ &--no-border-right {
276
+ border-right-width: 0 !important;
277
+ }
278
+
279
+ &--first {
280
+ border-top-left-radius: 3px;
281
+ border-bottom-left-radius: 3px;
282
+ }
283
+
284
+ &--last {
285
+ border-top-right-radius: 3px;
286
+ border-bottom-right-radius: 3px;
287
+ }
288
+
289
+ &__text {
290
+ font-size: 12px;
291
+ line-height: 12px;
292
+ @include flex;
293
+ align-items: center;
294
+ transition-property: color;
295
+ transition-duration: 0.3s;
296
+ }
297
+ }
298
+ }
299
+ </style>
@@ -0,0 +1,9 @@
1
+ export default {
2
+ props: {
3
+ // 是否自动关闭其他swipe按钮组
4
+ autoClose: {
5
+ type: Boolean,
6
+ default: uni.$u.props.swipeAction.autoClose
7
+ }
8
+ }
9
+ }
@@ -0,0 +1,67 @@
1
+ <template>
2
+ <view class="u-swipe-action">
3
+ <slot></slot>
4
+ </view>
5
+ </template>
6
+
7
+ <script>
8
+ import props from './props.js';
9
+ /**
10
+ * SwipeAction 滑动单元格
11
+ * @description 该组件一般用于左滑唤出操作菜单的场景,用的最多的是左滑删除操作
12
+ * @tutorial https://www.uviewui.com/components/swipeAction.html
13
+ * @property {Boolean} autoClose 是否自动关闭其他swipe按钮组
14
+ * @event {Function(index)} click 点击组件时触发
15
+ * @example <u-swipe-action><u-swipe-action-item :rightOptions="options1" ></u-swipe-action-item></u-swipe-action>
16
+ */
17
+ export default {
18
+ name: 'u-swipe-action',
19
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
20
+ data() {
21
+ return {}
22
+ },
23
+ provide() {
24
+ return {
25
+ swipeAction: this
26
+ }
27
+ },
28
+ computed: {
29
+ // 这里computed的变量,都是子组件u-swipe-action-item需要用到的,由于头条小程序的兼容性差异,子组件无法实时监听父组件参数的变化
30
+ // 所以需要手动通知子组件,这里返回一个parentData变量,供watch监听,在其中去通知每一个子组件重新从父组件(u-swipe-action-item)
31
+ // 拉取父组件新的变化后的参数
32
+ parentData() {
33
+ return [this.autoClose]
34
+ }
35
+ },
36
+ watch: {
37
+ // 当父组件需要子组件需要共享的参数发生了变化,手动通知子组件
38
+ parentData() {
39
+ if (this.children.length) {
40
+ this.children.map(child => {
41
+ // 判断子组件(u-swipe-action-item)如果有updateParentData方法的话,就就执行(执行的结果是子组件重新从父组件拉取了最新的值)
42
+ typeof(child.updateParentData) === 'function' && child.updateParentData()
43
+ })
44
+ }
45
+ },
46
+ },
47
+ created() {
48
+ this.children = []
49
+ },
50
+ methods: {
51
+ closeOther(child) {
52
+ if (this.autoClose) {
53
+ // 历遍所有的单元格,找出非当前操作中的单元格,进行关闭
54
+ this.children.map((item, index) => {
55
+ if (child !== item) {
56
+ item.closeHandler()
57
+ }
58
+ })
59
+ }
60
+ }
61
+ }
62
+ }
63
+ </script>
64
+
65
+ <style lang="scss" scoped>
66
+
67
+ </style>
@@ -0,0 +1,256 @@
1
+ /**
2
+ * 此为wxs模块,只支持APP-VUE,微信和QQ小程序以及H5平台
3
+ * wxs内部不支持es6语法,变量只能使用var定义,无法使用解构,箭头函数等特性
4
+ */
5
+
6
+ // 开始触摸
7
+ function touchstart(event, ownerInstance) {
8
+ // 触发事件的组件的ComponentDescriptor实例
9
+ var instance = event.instance
10
+ // wxs内的局部变量快照,此快照是属于整个组件的,在touchstart和touchmove事件中都能获取到相同的结果
11
+ var state = instance.getState()
12
+ if (state.disable) return
13
+ var touches = event.touches
14
+ // 如果进行的是多指触控,不允许进行操作
15
+ if (touches && touches.length > 1) return
16
+ // 标识当前为滑动中状态
17
+ state.moving = true
18
+ // 记录触摸开始点的坐标值
19
+ state.startX = touches[0].pageX
20
+ state.startY = touches[0].pageY
21
+ }
22
+
23
+ // 触摸滑动
24
+ function touchmove(event, ownerInstance) {
25
+ // 触发事件的组件的ComponentDescriptor实例
26
+ var instance = event.instance
27
+ // wxs内的局部变量快照
28
+ var state = instance.getState()
29
+ if (state.disabled || !state.moving) return
30
+
31
+ var touches = event.touches
32
+ var pageX = touches[0].pageX
33
+ var pageY = touches[0].pageY
34
+ var moveX = pageX - state.startX
35
+ var moveY = pageY - state.startY
36
+ var buttonsWidth = state.buttonsWidth
37
+
38
+ // 移动的X轴距离大于Y轴距离,也即终点与起点位置连线,与X轴夹角小于45度时,禁止页面滚动
39
+ if (Math.abs(moveX) > Math.abs(moveY) || Math.abs(moveX) > state.threshold) {
40
+ event.preventDefault()
41
+ event.stopPropagation()
42
+ }
43
+ // 如果移动的X轴距离小于Y轴距离,也即终点位置与起点位置连线,与Y轴夹角小于45度时,认为是页面上下滑动,而不是左右滑动单元格
44
+ if (Math.abs(moveX) < Math.abs(moveY)) return
45
+
46
+ // 限制右滑的距离,不允许内容部分往右偏移,右滑会导致X轴偏移值大于0,以此做判断
47
+ // 此处不能直接return,因为滑动过程中会缺失某些关键点坐标,会导致错乱,最好的办法就是
48
+ // 在超出后,设置为0
49
+ if (state.status === 'open') {
50
+ // 在开启状态下,向左滑动,需忽略
51
+ if (moveX < 0) moveX = 0
52
+ // 想要收起菜单,最大能移动的距离为按钮的总宽度
53
+ if (moveX > buttonsWidth) moveX = buttonsWidth
54
+ // 如果是已经打开了的状态,向左滑动时,移动收起菜单
55
+ moveSwipeAction(-buttonsWidth + moveX, instance, ownerInstance)
56
+ } else {
57
+ // 关闭状态下,右滑动需忽略
58
+ if (moveX > 0) moveX = 0
59
+ // 滑动的距离不允许超过所有按钮的总宽度,此时只能是左滑,最终设置按钮的总宽度,同时为负数
60
+ if (Math.abs(moveX) > buttonsWidth) moveX = -buttonsWidth
61
+ // 只要是在滑过程中,就不断移动菜单的内容部分,从而使隐藏的菜单显示出来
62
+ moveSwipeAction(moveX, instance, ownerInstance)
63
+ }
64
+ }
65
+
66
+ // 触摸结束
67
+ function touchend(event, ownerInstance) {
68
+ // 触发事件的组件的ComponentDescriptor实例
69
+ var instance = event.instance
70
+ // wxs内的局部变量快照
71
+ var state = instance.getState()
72
+ if (!state.moving || state.disabled) return
73
+ var touches = event.changedTouches ? event.changedTouches[0] : {}
74
+ var pageX = touches.pageX
75
+ var pageY = touches.pageY
76
+ var moveX = pageX - state.startX
77
+ if (state.status === 'open') {
78
+ // 在展开的状态下,继续左滑,无需操作
79
+ if (moveX < 0) return
80
+ // 在开启状态下,点击一下内容区域,moveX为0,也即没有进行移动,这时执行收起菜单逻辑
81
+ if (moveX === 0) {
82
+ return closeSwipeAction(instance, ownerInstance)
83
+ }
84
+ // 在开启状态下,滑动距离小于阈值,则默认为不关闭,同时恢复原来的打开状态
85
+ if (Math.abs(moveX) < state.threshold) {
86
+ openSwipeAction(instance, ownerInstance)
87
+ } else {
88
+ // 如果滑动距离大于阈值,则执行收起逻辑
89
+ closeSwipeAction(instance, ownerInstance)
90
+ }
91
+ } else {
92
+ // 在关闭的状态下,右滑,无需操作
93
+ if (moveX > 0) return
94
+ // 理由同上
95
+ if (Math.abs(moveX) < state.threshold) {
96
+ closeSwipeAction(instance, ownerInstance)
97
+ } else {
98
+ openSwipeAction(instance, ownerInstance)
99
+ }
100
+ }
101
+ }
102
+
103
+ // 获取过渡时间
104
+ function getDuration(value) {
105
+ if (value.toString().indexOf('s') >= 0) return value
106
+ return value > 30 ? value + 'ms' : value + 's'
107
+ }
108
+
109
+ // 滑动结束时判断滑动的方向
110
+ function getMoveDirection(instance, ownerInstance) {
111
+ var state = instance.getState()
112
+ }
113
+
114
+ // 移动滑动选择器内容区域,同时显示出其隐藏的菜单
115
+ function moveSwipeAction(moveX, instance, ownerInstance) {
116
+ var state = instance.getState()
117
+ // 获取所有按钮的实例,需要通过它去设置按钮的位移
118
+ var buttons = ownerInstance.selectAllComponents('.u-swipe-action-item__right__button')
119
+ var len = buttons.length
120
+ var previewButtonsMoveX = 0
121
+
122
+ // 设置菜单内容部分的偏移
123
+ instance.requestAnimationFrame(function() {
124
+ instance.setStyle({
125
+ // 设置translateX的值
126
+ 'transition': 'none',
127
+ transform: 'translateX(' + moveX + 'px)',
128
+ '-webkit-transform': 'translateX(' + moveX + 'px)'
129
+ })
130
+ // 折叠按钮动画
131
+ for (var i = len - 1; i >= 0; i--) {
132
+ // 通过比例,得出元素自身该移动的距离
133
+ var translateX = state.buttons[i].width / state.buttonsWidth * moveX
134
+ // 最终移动的距离,是通过自身比例算出的距离,再加上在它之前所有按钮移动的距离之和
135
+ var realTranslateX = translateX + previewButtonsMoveX
136
+ buttons[i].setStyle({
137
+ // 在移动期间,不能使用过渡效果,否则会造成卡顿,本质原因是每次移动一点,就要花一定时间去过渡这个过程
138
+ 'transition': 'none',
139
+ 'transform': 'translateX(' + realTranslateX + 'px)',
140
+ '-webkit-transform': 'translateX(' + realTranslateX + 'px)'
141
+ })
142
+ // 记录本按钮之前的所有按钮的移动距离之和
143
+ previewButtonsMoveX += translateX
144
+ }
145
+ })
146
+ }
147
+
148
+ // 一次性展开滑动菜单
149
+ function openSwipeAction(instance, ownerInstance) {
150
+ var state = instance.getState()
151
+ // 获取所有按钮的实例,需要通过它去设置按钮的位移
152
+ var buttons = ownerInstance.selectAllComponents('.u-swipe-action-item__right__button')
153
+ var len = buttons.length
154
+ // 处理duration单位问题
155
+ const duration = getDuration(state.duration)
156
+ // 展开过程中,是向左移动,所以X的偏移应该为负值
157
+ var buttonsWidth = -state.buttonsWidth
158
+ var previewButtonsMoveX = 0
159
+ instance.requestAnimationFrame(function() {
160
+ // 设置菜单主体内容
161
+ instance.setStyle({
162
+ 'transition': 'transform ' + duration,
163
+ 'transform': 'translateX(' + buttonsWidth + 'px)',
164
+ '-webkit-transform': 'translateX(' + buttonsWidth + 'px)',
165
+ })
166
+ // 设置各个隐藏的按钮为展开的状态
167
+ for (var i = len - 1; i >= 0; i--) {
168
+ // 通过比例,得出元素自身该移动的距离
169
+ var translateX = state.buttons[i].width / state.buttonsWidth * buttonsWidth
170
+ // 最终移动的距离,是通过自身比例算出的距离,再加上在它之前所有按钮移动的距离之和
171
+ var realTranslateX = translateX + previewButtonsMoveX
172
+ buttons[i].setStyle({
173
+ // 在移动期间,需要加上动画效果
174
+ 'transition': 'transform ' + duration,
175
+ 'transform': 'translateX(' + realTranslateX + 'px)',
176
+ '-webkit-transform': 'translateX(' + realTranslateX + 'px)'
177
+ })
178
+ // 记录本按钮之前的所有按钮的移动距离之和
179
+ previewButtonsMoveX += translateX
180
+ }
181
+ })
182
+ setStatus('open', instance)
183
+ }
184
+
185
+ // 标记菜单的当前状态,open-已经打开,close-已经关闭
186
+ function setStatus(status, instance) {
187
+ var state = instance.getState()
188
+ state.status = status
189
+ }
190
+
191
+ // 一次性收起滑动菜单
192
+ function closeSwipeAction(instance, ownerInstance) {
193
+ var state = instance.getState()
194
+ // 获取所有按钮的实例,需要通过它去设置按钮的位移
195
+ var buttons = ownerInstance.selectAllComponents('.u-swipe-action-item__right__button')
196
+ var len = buttons.length
197
+ // 处理duration单位问题
198
+ const duration = getDuration(state.duration)
199
+ instance.requestAnimationFrame(function() {
200
+ // 设置菜单主体内容
201
+ instance.setStyle({
202
+ 'transition': 'transform ' + duration,
203
+ 'transform': 'translateX(0px)',
204
+ '-webkit-transform': 'translateX(0px)'
205
+ })
206
+ // 设置各个隐藏的按钮为收起的状态
207
+ for (var i = len - 1; i >= 0; i--) {
208
+ buttons[i].setStyle({
209
+ 'transition': 'transform ' + duration,
210
+ 'transform': 'translateX(0px)',
211
+ '-webkit-transform': 'translateX(0px)'
212
+ })
213
+ }
214
+ })
215
+ setStatus('close', instance)
216
+ }
217
+
218
+ // show的状态发生变化
219
+ function showChange(newValue, oldValue, ownerInstance, instance) {
220
+ var state = instance.getState()
221
+ if (state.disabled) return
222
+ // 打开或关闭单元格
223
+ if (newValue) {
224
+ openSwipeAction(instance, ownerInstance)
225
+ } else {
226
+ closeSwipeAction(instance, ownerInstance)
227
+ }
228
+ }
229
+
230
+ // 菜单尺寸发生变化
231
+ function sizeChange(newValue, oldValue, ownerInstance, instance) {
232
+ // wxs内的局部变量快照
233
+ var state = instance.getState()
234
+ state.disabled = newValue.disabled
235
+ state.duration = newValue.duration
236
+ state.show = newValue.show
237
+ state.threshold = newValue.threshold
238
+ state.buttons = newValue.buttons
239
+
240
+ var len = state.buttons.length
241
+ if (len) {
242
+ var buttonsWidth = 0
243
+ var buttons = newValue.buttons
244
+ for (var i = 0; i < len; i++) {
245
+ buttonsWidth += buttons[i].width
246
+ }
247
+ }
248
+ state.buttonsWidth = buttonsWidth
249
+ }
250
+
251
+ module.exports = {
252
+ touchstart: touchstart,
253
+ touchmove: touchmove,
254
+ touchend: touchend,
255
+ sizeChange: sizeChange
256
+ }