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,29 @@
1
+ export default {
2
+ props: {
3
+ // 占父容器宽度的多少等分,总分为12份
4
+ span: {
5
+ type: [String, Number],
6
+ default: uni.$u.props.col.span
7
+ },
8
+ // 指定栅格左侧的间隔数(总12栏)
9
+ offset: {
10
+ type: [String, Number],
11
+ default: uni.$u.props.col.offset
12
+ },
13
+ // 水平排列方式,可选值为`start`(或`flex-start`)、`end`(或`flex-end`)、`center`、`around`(或`space-around`)、`between`(或`space-between`)
14
+ justify: {
15
+ type: String,
16
+ default: uni.$u.props.col.justify
17
+ },
18
+ // 垂直对齐方式,可选值为top、center、bottom、stretch
19
+ align: {
20
+ type: String,
21
+ default: uni.$u.props.col.align
22
+ },
23
+ // 文字对齐方式
24
+ textAlign: {
25
+ type: String,
26
+ default: uni.$u.props.col.textAlign
27
+ }
28
+ }
29
+ }
@@ -0,0 +1,162 @@
1
+ <template>
2
+ <view
3
+ class="u-col"
4
+ ref="u-col"
5
+ :class="[
6
+ 'u-col-' + span
7
+ ]"
8
+ :style="[colStyle]"
9
+ @tap="clickHandler"
10
+ >
11
+ <slot></slot>
12
+ </view>
13
+ </template>
14
+
15
+ <script>
16
+ import props from './props.js';
17
+ /**
18
+ * CodeInput 栅格系统的列
19
+ * @description 该组件一般用于Layout 布局 通过基础的 12 分栏,迅速简便地创建布局
20
+ * @tutorial https://www.uviewui.com/components/Layout.html
21
+ * @property {String | Number} span 栅格占据的列数,总12等份 (默认 12 )
22
+ * @property {String | Number} offset 分栏左边偏移,计算方式与span相同 (默认 0 )
23
+ * @property {String} justify 水平排列方式,可选值为`start`(或`flex-start`)、`end`(或`flex-end`)、`center`、`around`(或`space-around`)、`between`(或`space-between`) (默认 'start' )
24
+ * @property {String} align 垂直对齐方式,可选值为top、center、bottom、stretch (默认 'stretch' )
25
+ * @property {String} textAlign 文字水平对齐方式 (默认 'left' )
26
+ * @property {Object} customStyle 定义需要用到的外部样式
27
+ * @event {Function} click col被点击,会阻止事件冒泡到row
28
+ * @example <u-col span="3" offset="3" > <view class="demo-layout bg-purple"></view> </u-col>
29
+ */
30
+ export default {
31
+ name: 'u-col',
32
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
33
+ data() {
34
+ return {
35
+ width: 0,
36
+ parentData: {
37
+ gutter: 0
38
+ },
39
+ gridNum: 12
40
+ }
41
+ },
42
+ computed: {
43
+ uJustify() {
44
+ if (this.justify == 'end' || this.justify == 'start') return 'flex-' + this.justify
45
+ else if (this.justify == 'around' || this.justify == 'between') return 'space-' + this.justify
46
+ else return this.justify
47
+ },
48
+ uAlignItem() {
49
+ if (this.align == 'top') return 'flex-start'
50
+ if (this.align == 'bottom') return 'flex-end'
51
+ else return this.align
52
+ },
53
+ colStyle() {
54
+ const style = {
55
+ // 这里写成"padding: 0 10px"的形式是因为nvue的需要
56
+ paddingLeft: uni.$u.addUnit(uni.$u.getPx(this.parentData.gutter)/2),
57
+ paddingRight: uni.$u.addUnit(uni.$u.getPx(this.parentData.gutter)/2),
58
+ alignItems: this.uAlignItem,
59
+ justifyContent: this.uJustify,
60
+ textAlign: this.textAlign,
61
+ // #ifndef APP-NVUE
62
+ // 在非nvue上,使用百分比形式
63
+ flex: `0 0 ${100 / this.gridNum * this.span}%`,
64
+ marginLeft: 100 / 12 * this.offset + '%',
65
+ // #endif
66
+ // #ifdef APP-NVUE
67
+ // 在nvue上,由于无法使用百分比单位,这里需要获取父组件的宽度,再计算得出该有对应的百分比尺寸
68
+ width: uni.$u.addUnit(Math.floor(this.width / this.gridNum * Number(this.span))),
69
+ marginLeft: uni.$u.addUnit(Math.floor(this.width / this.gridNum * Number(this.offset))),
70
+ // #endif
71
+ }
72
+ return uni.$u.deepMerge(style, uni.$u.addStyle(this.customStyle))
73
+ }
74
+ },
75
+ mounted() {
76
+ this.init()
77
+ },
78
+ methods: {
79
+ async init() {
80
+ // 支付宝小程序不支持provide/inject,所以使用这个方法获取整个父组件,在created定义,避免循环引用
81
+ this.updateParentData()
82
+ this.width = await this.parent.getComponentWidth()
83
+ },
84
+ updateParentData() {
85
+ this.getParentData('u-row')
86
+ },
87
+ clickHandler(e) {
88
+ this.$emit('click');
89
+ }
90
+ },
91
+ }
92
+ </script>
93
+
94
+ <style lang="scss" scoped>
95
+ @import "../../libs/css/components.scss";
96
+
97
+ .u-col {
98
+ padding: 0;
99
+ /* #ifndef APP-NVUE */
100
+ box-sizing:border-box;
101
+ /* #endif */
102
+ /* #ifdef MP */
103
+ display: block;
104
+ /* #endif */
105
+ }
106
+
107
+ // nvue下百分比无效
108
+ /* #ifndef APP-NVUE */
109
+ .u-col-0 {
110
+ width: 0;
111
+ }
112
+
113
+ .u-col-1 {
114
+ width: calc(100%/12);
115
+ }
116
+
117
+ .u-col-2 {
118
+ width: calc(100%/12 * 2);
119
+ }
120
+
121
+ .u-col-3 {
122
+ width: calc(100%/12 * 3);
123
+ }
124
+
125
+ .u-col-4 {
126
+ width: calc(100%/12 * 4);
127
+ }
128
+
129
+ .u-col-5 {
130
+ width: calc(100%/12 * 5);
131
+ }
132
+
133
+ .u-col-6 {
134
+ width: calc(100%/12 * 6);
135
+ }
136
+
137
+ .u-col-7 {
138
+ width: calc(100%/12 * 7);
139
+ }
140
+
141
+ .u-col-8 {
142
+ width: calc(100%/12 * 8);
143
+ }
144
+
145
+ .u-col-9 {
146
+ width: calc(100%/12 * 9);
147
+ }
148
+
149
+ .u-col-10 {
150
+ width: calc(100%/12 * 10);
151
+ }
152
+
153
+ .u-col-11 {
154
+ width: calc(100%/12 * 11);
155
+ }
156
+
157
+ .u-col-12 {
158
+ width: calc(100%/12 * 12);
159
+ }
160
+
161
+ /* #endif */
162
+ </style>
@@ -0,0 +1,19 @@
1
+ export default {
2
+ props: {
3
+ // 当前展开面板的name,非手风琴模式:[<string | number>],手风琴模式:string | number
4
+ value: {
5
+ type: [String, Number, Array, null],
6
+ default: uni.$u.props.collapse.value
7
+ },
8
+ // 是否手风琴模式
9
+ accordion: {
10
+ type: Boolean,
11
+ default: uni.$u.props.collapse.accordion
12
+ },
13
+ // 是否显示外边框
14
+ border: {
15
+ type: Boolean,
16
+ default: uni.$u.props.collapse.border
17
+ }
18
+ }
19
+ }
@@ -0,0 +1,90 @@
1
+ <template>
2
+ <view class="u-collapse">
3
+ <u-line v-if="border"></u-line>
4
+ <slot />
5
+ </view>
6
+ </template>
7
+
8
+ <script>
9
+ import props from './props.js';
10
+ /**
11
+ * collapse 折叠面板
12
+ * @description 通过折叠面板收纳内容区域
13
+ * @tutorial https://www.uviewui.com/components/collapse.html
14
+ * @property {String | Number | Array} value 当前展开面板的name,非手风琴模式:[<string | number>],手风琴模式:string | number
15
+ * @property {Boolean} accordion 是否手风琴模式( 默认 false )
16
+ * @property {Boolean} border 是否显示外边框 ( 默认 true )
17
+ * @event {Function} change 当前激活面板展开时触发(如果是手风琴模式,参数activeNames类型为String,否则为Array)
18
+ * @example <u-collapse></u-collapse>
19
+ */
20
+ export default {
21
+ name: "u-collapse",
22
+ mixins: [uni.$u.mpMixin, uni.$u.mixin,props],
23
+ watch: {
24
+ needInit() {
25
+ this.init()
26
+ }
27
+ },
28
+ created() {
29
+ this.children = []
30
+ },
31
+ computed: {
32
+ needInit() {
33
+ // 通过computed,同时监听accordion和value值的变化
34
+ // 再通过watch去执行init()方法,进行再一次的初始化
35
+ return [this.accordion, this.value]
36
+ }
37
+ },
38
+ watch: {
39
+ // 当父组件需要子组件需要共享的参数发生了变化,手动通知子组件
40
+ parentData() {
41
+ if (this.children.length) {
42
+ this.children.map(child => {
43
+ // 判断子组件(u-checkbox)如果有updateParentData方法的话,就就执行(执行的结果是子组件重新从父组件拉取了最新的值)
44
+ typeof(child.updateParentData) === 'function' && child.updateParentData()
45
+ })
46
+ }
47
+ },
48
+ },
49
+ methods: {
50
+ // 重新初始化一次内部的所有子元素
51
+ init() {
52
+ this.children.map(child => {
53
+ child.init()
54
+ })
55
+ },
56
+ /**
57
+ * collapse-item被点击时触发,由collapse统一处理各子组件的状态
58
+ * @param {Object} target 被操作的面板的实例
59
+ */
60
+ onChange(target) {
61
+ let changeArr = []
62
+ this.children.map((child, index) => {
63
+ // 如果是手风琴模式,将其他的折叠面板收起来
64
+ if (this.accordion) {
65
+ child.expanded = child === target ? !target.expanded : false
66
+ child.setContentAnimate()
67
+ } else {
68
+ if(child === target) {
69
+ child.expanded = !child.expanded
70
+ child.setContentAnimate()
71
+ }
72
+ }
73
+ // 拼接change事件中,数组元素的状态
74
+ changeArr.push({
75
+ // 如果没有定义name属性,则默认返回组件的index索引
76
+ name: child.name || index,
77
+ status: child.expanded ? 'open' : 'close'
78
+ })
79
+ })
80
+
81
+ this.$emit('change', changeArr)
82
+ this.$emit(target.expanded ? 'open' : 'close', target.name)
83
+ }
84
+ }
85
+ }
86
+ </script>
87
+
88
+ <style lang="scss" scoped>
89
+ @import "../../libs/css/components.scss";
90
+ </style>
@@ -0,0 +1,59 @@
1
+ export default {
2
+ props: {
3
+ // 标题
4
+ title: {
5
+ type: String,
6
+ default: uni.$u.props.collapseItem.title
7
+ },
8
+ // 标题右侧内容
9
+ value: {
10
+ type: String,
11
+ default: uni.$u.props.collapseItem.value
12
+ },
13
+ // 标题下方的描述信息
14
+ label: {
15
+ type: String,
16
+ default: uni.$u.props.collapseItem.label
17
+ },
18
+ // 是否禁用折叠面板
19
+ disabled: {
20
+ type: Boolean,
21
+ default: uni.$u.props.collapseItem.disabled
22
+ },
23
+ // 是否展示右侧箭头并开启点击反馈
24
+ isLink: {
25
+ type: Boolean,
26
+ default: uni.$u.props.collapseItem.isLink
27
+ },
28
+ // 是否开启点击反馈
29
+ clickable: {
30
+ type: Boolean,
31
+ default: uni.$u.props.collapseItem.clickable
32
+ },
33
+ // 是否显示内边框
34
+ border: {
35
+ type: Boolean,
36
+ default: uni.$u.props.collapseItem.border
37
+ },
38
+ // 标题的对齐方式
39
+ align: {
40
+ type: String,
41
+ default: uni.$u.props.collapseItem.align
42
+ },
43
+ // 唯一标识符
44
+ name: {
45
+ type: [String, Number],
46
+ default: uni.$u.props.collapseItem.name
47
+ },
48
+ // 标题左侧图片,可为绝对路径的图片或内置图标
49
+ icon: {
50
+ type: String,
51
+ default: uni.$u.props.collapseItem.icon
52
+ },
53
+ // 面板展开收起的过渡时间,单位ms
54
+ duration: {
55
+ type: Number,
56
+ default: uni.$u.props.collapseItem.duration
57
+ }
58
+ }
59
+ }
@@ -0,0 +1,225 @@
1
+ <template>
2
+ <view class="u-collapse-item">
3
+ <u-cell
4
+ :title="title"
5
+ :value="value"
6
+ :label="label"
7
+ :icon="icon"
8
+ :isLink="isLink"
9
+ :clickable="clickable"
10
+ :border="parentData.border && showBorder"
11
+ @click="clickHandler"
12
+ :arrowDirection="expanded ? 'up' : 'down'"
13
+ :disabled="disabled"
14
+ >
15
+ <!-- #ifndef MP-WEIXIN -->
16
+ <!-- 微信小程序不支持,因为微信中不支持 <slot name="title" slot="title" />的写法 -->
17
+ <template slot="title">
18
+ <slot name="title"></slot>
19
+ </template>
20
+ <template slot="icon">
21
+ <slot name="icon"></slot>
22
+ </template>
23
+ <template slot="value">
24
+ <slot name="value"></slot>
25
+ </template>
26
+ <template slot="right-icon">
27
+ <slot name="right-icon"></slot>
28
+ </template>
29
+ <!-- #endif -->
30
+ </u-cell>
31
+ <view
32
+ class="u-collapse-item__content"
33
+ :animation="animationData"
34
+ ref="animation"
35
+ >
36
+ <view
37
+ class="u-collapse-item__content__text content-class"
38
+ :id="elId"
39
+ :ref="elId"
40
+ ><slot /></view>
41
+ </view>
42
+ <u-line v-if="parentData.border"></u-line>
43
+ </view>
44
+ </template>
45
+
46
+ <script>
47
+ import props from './props.js';
48
+ // #ifdef APP-NVUE
49
+ const animation = uni.requireNativePlugin('animation')
50
+ const dom = uni.requireNativePlugin('dom')
51
+ // #endif
52
+ /**
53
+ * collapseItem 折叠面板Item
54
+ * @description 通过折叠面板收纳内容区域(搭配u-collapse使用)
55
+ * @tutorial https://www.uviewui.com/components/collapse.html
56
+ * @property {String} title 标题
57
+ * @property {String} value 标题右侧内容
58
+ * @property {String} label 标题下方的描述信息
59
+ * @property {Boolean} disbled 是否禁用折叠面板 ( 默认 false )
60
+ * @property {Boolean} isLink 是否展示右侧箭头并开启点击反馈 ( 默认 true )
61
+ * @property {Boolean} clickable 是否开启点击反馈 ( 默认 true )
62
+ * @property {Boolean} border 是否显示内边框 ( 默认 true )
63
+ * @property {String} align 标题的对齐方式 ( 默认 'left' )
64
+ * @property {String | Number} name 唯一标识符
65
+ * @property {String} icon 标题左侧图片,可为绝对路径的图片或内置图标
66
+ * @event {Function} change 某个item被打开或者收起时触发
67
+ * @example <u-collapse-item :title="item.head" v-for="(item, index) in itemList" :key="index">{{item.body}}</u-collapse-item>
68
+ */
69
+ export default {
70
+ name: "u-collapse-item",
71
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
72
+ data() {
73
+ return {
74
+ elId: uni.$u.guid(),
75
+ // uni.createAnimation的导出数据
76
+ animationData: {},
77
+ // 是否展开状态
78
+ expanded: false,
79
+ // 根据expanded确定是否显示border,为了控制展开时,cell的下划线更好的显示效果,进行一定时间的延时
80
+ showBorder: false,
81
+ // 是否动画中,如果是则不允许继续触发点击
82
+ animating: false,
83
+ // 父组件u-collapse的参数
84
+ parentData: {
85
+ accordion: false,
86
+ border: false
87
+ }
88
+ };
89
+ },
90
+ watch: {
91
+ expanded(n) {
92
+ clearTimeout(this.timer)
93
+ this.timer = null
94
+ // 这里根据expanded的值来进行一定的延时,是为了cell的下划线更好的显示效果
95
+ this.timer = setTimeout(() => {
96
+ this.showBorder = n
97
+ }, n ? 10 : 290)
98
+ }
99
+ },
100
+ mounted() {
101
+ this.init()
102
+ },
103
+ methods: {
104
+ // 异步获取内容,或者动态修改了内容时,需要重新初始化
105
+ init() {
106
+ // 初始化数据
107
+ this.updateParentData()
108
+ if (!this.parent) {
109
+ return uni.$u.error('u-collapse-item必须要搭配u-collapse组件使用')
110
+ }
111
+ const {
112
+ value,
113
+ accordion,
114
+ children = []
115
+ } = this.parent
116
+
117
+ if (accordion) {
118
+ if (uni.$u.test.array(value)) {
119
+ return uni.$u.error('手风琴模式下,u-collapse组件的value参数不能为数组')
120
+ }
121
+ this.expanded = this.name == value
122
+ } else {
123
+ if (!uni.$u.test.array(value) && value !== null) {
124
+ return uni.$u.error('非手风琴模式下,u-collapse组件的value参数必须为数组')
125
+ }
126
+ this.expanded = (value || []).some(item => item == this.name)
127
+ }
128
+ // 设置组件的展开或收起状态
129
+ this.$nextTick(function() {
130
+ this.setContentAnimate()
131
+ })
132
+ },
133
+ updateParentData() {
134
+ // 此方法在mixin中
135
+ this.getParentData('u-collapse')
136
+ },
137
+ async setContentAnimate() {
138
+ // 每次面板打开或者收起时,都查询元素尺寸
139
+ // 好处是,父组件从服务端获取内容后,变更折叠面板后可以获得最新的高度
140
+ const rect = await this.queryRect()
141
+ const height = this.expanded ? rect.height : 0
142
+ this.animating = true
143
+ // #ifdef APP-NVUE
144
+ const ref = this.$refs['animation'].ref
145
+ animation.transition(ref, {
146
+ styles: {
147
+ height: height + 'px'
148
+ },
149
+ duration: this.duration,
150
+ // 必须设置为true,否则会到面板收起或展开时,页面其他元素不会随之调整它们的布局
151
+ needLayout: true,
152
+ timingFunction: 'ease-in-out',
153
+ }, () => {
154
+ this.animating = false
155
+ })
156
+ // #endif
157
+
158
+ // #ifndef APP-NVUE
159
+ const animation = uni.createAnimation({
160
+ timingFunction: 'ease-in-out',
161
+ });
162
+ animation
163
+ .height(height)
164
+ .step({
165
+ duration: this.duration,
166
+ })
167
+ .step()
168
+ // 导出动画数据给面板的animationData值
169
+ this.animationData = animation.export()
170
+ // 标识动画结束
171
+ uni.$u.sleep(this.duration).then(() => {
172
+ this.animating = false
173
+ })
174
+ // #endif
175
+ },
176
+ // 点击collapsehead头部
177
+ clickHandler() {
178
+ if (this.disabled && this.animating) return
179
+ // 设置本组件为相反的状态
180
+ this.parent && this.parent.onChange(this)
181
+ },
182
+ // 查询内容高度
183
+ queryRect() {
184
+ // #ifndef APP-NVUE
185
+ // $uGetRect为uView自带的节点查询简化方法,详见文档介绍:https://www.uviewui.com/js/getRect.html
186
+ // 组件内部一般用this.$uGetRect,对外的为uni.$u.getRect,二者功能一致,名称不同
187
+ return new Promise(resolve => {
188
+ this.$uGetRect(`#${this.elId}`).then(size => {
189
+ resolve(size)
190
+ })
191
+ })
192
+ // #endif
193
+
194
+ // #ifdef APP-NVUE
195
+ // nvue下,使用dom模块查询元素高度
196
+ // 返回一个promise,让调用此方法的主体能使用then回调
197
+ return new Promise(resolve => {
198
+ dom.getComponentRect(this.$refs[this.elId], res => {
199
+ resolve(res.size)
200
+ })
201
+ })
202
+ // #endif
203
+ }
204
+ },
205
+ };
206
+ </script>
207
+
208
+ <style lang="scss" scoped>
209
+ @import "../../libs/css/components.scss";
210
+
211
+ .u-collapse-item {
212
+
213
+ &__content {
214
+ overflow: hidden;
215
+ height: 0;
216
+
217
+ &__text {
218
+ padding: 12px 15px;
219
+ color: $u-content-color;
220
+ font-size: 14px;
221
+ line-height: 18px;
222
+ }
223
+ }
224
+ }
225
+ </style>
@@ -0,0 +1,55 @@
1
+ export default {
2
+ props: {
3
+ // 显示的内容,字符串
4
+ text: {
5
+ type: [Array],
6
+ default: uni.$u.props.columnNotice.text
7
+ },
8
+ // 是否显示左侧的音量图标
9
+ icon: {
10
+ type: String,
11
+ default: uni.$u.props.columnNotice.icon
12
+ },
13
+ // 通告模式,link-显示右箭头,closable-显示右侧关闭图标
14
+ mode: {
15
+ type: String,
16
+ default: uni.$u.props.columnNotice.mode
17
+ },
18
+ // 文字颜色,各图标也会使用文字颜色
19
+ color: {
20
+ type: String,
21
+ default: uni.$u.props.columnNotice.color
22
+ },
23
+ // 背景颜色
24
+ bgColor: {
25
+ type: String,
26
+ default: uni.$u.props.columnNotice.bgColor
27
+ },
28
+ // 字体大小,单位px
29
+ fontSize: {
30
+ type: [String, Number],
31
+ default: uni.$u.props.columnNotice.fontSize
32
+ },
33
+ // 水平滚动时的滚动速度,即每秒滚动多少px(px),这有利于控制文字无论多少时,都能有一个恒定的速度
34
+ speed: {
35
+ type: [String, Number],
36
+ default: uni.$u.props.columnNotice.speed
37
+ },
38
+ // direction = row时,是否使用步进形式滚动
39
+ step: {
40
+ type: Boolean,
41
+ default: uni.$u.props.columnNotice.step
42
+ },
43
+ // 滚动一个周期的时间长,单位ms
44
+ duration: {
45
+ type: [String, Number],
46
+ default: uni.$u.props.columnNotice.duration
47
+ },
48
+ // 是否禁止用手滑动切换
49
+ // 目前HX2.6.11,只支持App 2.5.5+、H5 2.5.5+、支付宝小程序、字节跳动小程序
50
+ disableTouch: {
51
+ type: Boolean,
52
+ default: uni.$u.props.columnNotice.disableTouch
53
+ }
54
+ }
55
+ }