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,144 @@
1
+ export default {
2
+ props: {
3
+ // 日历顶部标题
4
+ title: {
5
+ type: String,
6
+ default: uni.$u.props.calendar.title
7
+ },
8
+ // 是否显示标题
9
+ showTitle: {
10
+ type: Boolean,
11
+ default: uni.$u.props.calendar.showTitle
12
+ },
13
+ // 是否显示副标题
14
+ showSubtitle: {
15
+ type: Boolean,
16
+ default: uni.$u.props.calendar.showSubtitle
17
+ },
18
+ // 日期类型选择,single-选择单个日期,multiple-可以选择多个日期,range-选择日期范围
19
+ mode: {
20
+ type: String,
21
+ default: uni.$u.props.calendar.mode
22
+ },
23
+ // mode=range时,第一个日期底部的提示文字
24
+ startText: {
25
+ type: String,
26
+ default: uni.$u.props.calendar.startText
27
+ },
28
+ // mode=range时,最后一个日期底部的提示文字
29
+ endText: {
30
+ type: String,
31
+ default: uni.$u.props.calendar.endText
32
+ },
33
+ // 自定义列表
34
+ customList: {
35
+ type: Array,
36
+ default: uni.$u.props.calendar.customList
37
+ },
38
+ // 主题色,对底部按钮和选中日期有效
39
+ color: {
40
+ type: String,
41
+ default: uni.$u.props.calendar.color
42
+ },
43
+ // 最小的可选日期
44
+ minDate: {
45
+ type: [String, Number],
46
+ default: uni.$u.props.calendar.minDate
47
+ },
48
+ // 最大可选日期
49
+ maxDate: {
50
+ type: [String, Number],
51
+ default: uni.$u.props.calendar.maxDate
52
+ },
53
+ // 默认选中的日期,mode为multiple或range是必须为数组格式
54
+ defaultDate: {
55
+ type: [Array, String, Date, null],
56
+ default: uni.$u.props.calendar.defaultDate
57
+ },
58
+ // mode=multiple时,最多可选多少个日期
59
+ maxCount: {
60
+ type: [String, Number],
61
+ default: uni.$u.props.calendar.maxCount
62
+ },
63
+ // 日期行高
64
+ rowHeight: {
65
+ type: [String, Number],
66
+ default: uni.$u.props.calendar.rowHeight
67
+ },
68
+ // 日期格式化函数
69
+ formatter: {
70
+ type: [Function, null],
71
+ default: uni.$u.props.calendar.formatter
72
+ },
73
+ // 是否显示农历
74
+ showLunar: {
75
+ type: Boolean,
76
+ default: uni.$u.props.calendar.showLunar
77
+ },
78
+ // 是否显示月份背景色
79
+ showMark: {
80
+ type: Boolean,
81
+ default: uni.$u.props.calendar.showMark
82
+ },
83
+ // 确定按钮的文字
84
+ confirmText: {
85
+ type: String,
86
+ default: uni.$u.props.calendar.confirmText
87
+ },
88
+ // 确认按钮处于禁用状态时的文字
89
+ confirmDisabledText: {
90
+ type: String,
91
+ default: uni.$u.props.calendar.confirmDisabledText
92
+ },
93
+ // 是否显示日历弹窗
94
+ show: {
95
+ type: Boolean,
96
+ default: uni.$u.props.calendar.show
97
+ },
98
+ // 是否允许点击遮罩关闭日历
99
+ closeOnClickOverlay: {
100
+ type: Boolean,
101
+ default: uni.$u.props.calendar.closeOnClickOverlay
102
+ },
103
+ // 是否为只读状态,只读状态下禁止选择日期
104
+ readonly: {
105
+ type: Boolean,
106
+ default: uni.$u.props.calendar.readonly
107
+ },
108
+ // 是否展示确认按钮
109
+ showConfirm: {
110
+ type: Boolean,
111
+ default: uni.$u.props.calendar.showConfirm
112
+ },
113
+ // 日期区间最多可选天数,默认无限制,mode = range时有效
114
+ maxRange: {
115
+ type: [Number, String],
116
+ default: uni.$u.props.calendar.maxRange
117
+ },
118
+ // 范围选择超过最多可选天数时的提示文案,mode = range时有效
119
+ rangePrompt: {
120
+ type: String,
121
+ default: uni.$u.props.calendar.rangePrompt
122
+ },
123
+ // 范围选择超过最多可选天数时,是否展示提示文案,mode = range时有效
124
+ showRangePrompt: {
125
+ type: Boolean,
126
+ default: uni.$u.props.calendar.showRangePrompt
127
+ },
128
+ // 是否允许日期范围的起止时间为同一天,mode = range时有效
129
+ allowSameDay: {
130
+ type: Boolean,
131
+ default: uni.$u.props.calendar.allowSameDay
132
+ },
133
+ // 圆角值
134
+ round: {
135
+ type: [Boolean, String, Number],
136
+ default: uni.$u.props.calendar.round
137
+ },
138
+ // 最多展示月份数量
139
+ monthNum: {
140
+ type: [Number, String],
141
+ default: 3
142
+ }
143
+ }
144
+ }
@@ -0,0 +1,384 @@
1
+ <template>
2
+ <u-popup
3
+ :show="show"
4
+ mode="bottom"
5
+ closeable
6
+ @close="close"
7
+ :round="round"
8
+ :closeOnClickOverlay="closeOnClickOverlay"
9
+ >
10
+ <view class="u-calendar">
11
+ <uHeader
12
+ :title="title"
13
+ :subtitle="subtitle"
14
+ :showSubtitle="showSubtitle"
15
+ :showTitle="showTitle"
16
+ ></uHeader>
17
+ <scroll-view
18
+ :style="{
19
+ height: $u.addUnit(listHeight)
20
+ }"
21
+ scroll-y
22
+ @scroll="onScroll"
23
+ :scroll-top="scrollTop"
24
+ :scrollIntoView="scrollIntoView"
25
+ >
26
+ <uMonth
27
+ :color="color"
28
+ :rowHeight="rowHeight"
29
+ :showMark="showMark"
30
+ :months="months"
31
+ :mode="mode"
32
+ :maxCount="maxCount"
33
+ :startText="startText"
34
+ :endText="endText"
35
+ :defaultDate="defaultDate"
36
+ :minDate="innerMinDate"
37
+ :maxDate="innerMaxDate"
38
+ :maxMonth="monthNum"
39
+ :readonly="readonly"
40
+ :maxRange="maxRange"
41
+ :rangePrompt="rangePrompt"
42
+ :showRangePrompt="showRangePrompt"
43
+ :allowSameDay="allowSameDay"
44
+ ref="month"
45
+ @monthSelected="monthSelected"
46
+ @updateMonthTop="updateMonthTop"
47
+ ></uMonth>
48
+ </scroll-view>
49
+ <slot name="footer" v-if="showConfirm">
50
+ <view class="u-calendar__confirm">
51
+ <u-button
52
+ shape="circle"
53
+ :text="
54
+ buttonDisabled ? confirmDisabledText : confirmText
55
+ "
56
+ :color="color"
57
+ @click="confirm"
58
+ :disabled="buttonDisabled"
59
+ ></u-button>
60
+ </view>
61
+ </slot>
62
+ </view>
63
+ </u-popup>
64
+ </template>
65
+
66
+ <script>
67
+ import uHeader from './header.vue'
68
+ import uMonth from './month.vue'
69
+ import props from './props.js'
70
+ import util from './util.js'
71
+ import dayjs from '../../libs/util/dayjs.js'
72
+ import Calendar from '../../libs/util/calendar.js'
73
+ /**
74
+ * Calendar 日历
75
+ * @description 此组件用于单个选择日期,范围选择日期等,日历被包裹在底部弹起的容器中.
76
+ * @tutorial https://www.uviewui.com/components/calendar.html
77
+ *
78
+ * @property {String} title 标题内容 (默认 日期选择 )
79
+ * @property {Boolean} showTitle 是否显示标题 (默认 true )
80
+ * @property {Boolean} showSubtitle 是否显示副标题 (默认 true )
81
+ * @property {String} mode 日期类型选择 single-选择单个日期,multiple-可以选择多个日期,range-选择日期范围 ( 默认 'single' )
82
+ * @property {String} startText mode=range时,第一个日期底部的提示文字 (默认 '开始' )
83
+ * @property {String} endText mode=range时,最后一个日期底部的提示文字 (默认 '结束' )
84
+ * @property {Array} customList 自定义列表
85
+ * @property {String} color 主题色,对底部按钮和选中日期有效 (默认 ‘#3c9cff' )
86
+ * @property {String | Number} minDate 最小的可选日期 (默认 0 )
87
+ * @property {String | Number} maxDate 最大可选日期 (默认 0 )
88
+ * @property {Array | String| Date} defaultDate 默认选中的日期,mode为multiple或range是必须为数组格式
89
+ * @property {String | Number} maxCount mode=multiple时,最多可选多少个日期 (默认 Number.MAX_SAFE_INTEGER )
90
+ * @property {String | Number} rowHeight 日期行高 (默认 56 )
91
+ * @property {Function} formatter 日期格式化函数
92
+ * @property {Boolean} showLunar 是否显示农历 (默认 false )
93
+ * @property {Boolean} showMark 是否显示月份背景色 (默认 true )
94
+ * @property {String} confirmText 确定按钮的文字 (默认 '确定' )
95
+ * @property {String} confirmDisabledText 确认按钮处于禁用状态时的文字 (默认 '确定' )
96
+ * @property {Boolean} show 是否显示日历弹窗 (默认 false )
97
+ * @property {Boolean} closeOnClickOverlay 是否允许点击遮罩关闭日历 (默认 false )
98
+ * @property {Boolean} readonly 是否为只读状态,只读状态下禁止选择日期 (默认 false )
99
+ * @property {String | Number} maxRange 日期区间最多可选天数,默认无限制,mode = range时有效
100
+ * @property {String} rangePrompt 范围选择超过最多可选天数时的提示文案,mode = range时有效
101
+ * @property {Boolean} showRangePrompt 范围选择超过最多可选天数时,是否展示提示文案,mode = range时有效 (默认 true )
102
+ * @property {Boolean} allowSameDay 是否允许日期范围的起止时间为同一天,mode = range时有效 (默认 false )
103
+ * @property {Number|String} round 圆角值,默认无圆角 (默认 0 )
104
+ * @property {Number|String} monthNum 最多展示的月份数量 (默认 3 )
105
+ *
106
+ * @event {Function()} confirm 点击确定按钮时触发 选择日期相关的返回参数
107
+ * @event {Function()} close 日历关闭时触发 可定义页面关闭时的回调事件
108
+ * @example <u-calendar :defaultDate="defaultDateMultiple" :show="show" mode="multiple" @confirm="confirm">
109
+ </u-calendar>
110
+ * */
111
+ export default {
112
+ name: 'u-calendar',
113
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
114
+ components: {
115
+ uHeader,
116
+ uMonth
117
+ },
118
+ data() {
119
+ return {
120
+ // 需要显示的月份的数组
121
+ months: [],
122
+ // 在月份滚动区域中,当前视图中月份的index索引
123
+ monthIndex: 0,
124
+ // 月份滚动区域的高度
125
+ listHeight: 0,
126
+ // month组件中选择的日期数组
127
+ selected: [],
128
+ scrollIntoView: '',
129
+ scrollTop:0,
130
+ // 过滤处理方法
131
+ innerFormatter: (value) => value
132
+ }
133
+ },
134
+ watch: {
135
+ selectedChange: {
136
+ immediate: true,
137
+ handler(n) {
138
+ this.setMonth()
139
+ }
140
+ },
141
+ // 打开弹窗时,设置月份数据
142
+ show: {
143
+ immediate: true,
144
+ handler(n) {
145
+ this.setMonth()
146
+ }
147
+ }
148
+ },
149
+ computed: {
150
+ // 由于maxDate和minDate可以为字符串(2021-10-10),或者数值(时间戳),但是dayjs如果接受字符串形式的时间戳会有问题,这里进行处理
151
+ innerMaxDate() {
152
+ return uni.$u.test.number(this.maxDate)
153
+ ? Number(this.maxDate)
154
+ : this.maxDate
155
+ },
156
+ innerMinDate() {
157
+ return uni.$u.test.number(this.minDate)
158
+ ? Number(this.minDate)
159
+ : this.minDate
160
+ },
161
+ // 多个条件的变化,会引起选中日期的变化,这里统一管理监听
162
+ selectedChange() {
163
+ return [this.innerMinDate, this.innerMaxDate, this.defaultDate]
164
+ },
165
+ subtitle() {
166
+ // 初始化时,this.months为空数组,所以需要特别判断处理
167
+ if (this.months.length) {
168
+ return `${this.months[this.monthIndex].year}年${
169
+ this.months[this.monthIndex].month
170
+ }月`
171
+ } else {
172
+ return ''
173
+ }
174
+ },
175
+ buttonDisabled() {
176
+ // 如果为range类型,且选择的日期个数不足1个时,让底部的按钮出于disabled状态
177
+ if (this.mode === 'range') {
178
+ if (this.selected.length <= 1) {
179
+ return true
180
+ } else {
181
+ return false
182
+ }
183
+ } else {
184
+ return false
185
+ }
186
+ }
187
+ },
188
+ mounted() {
189
+ this.start = Date.now()
190
+ this.init()
191
+ },
192
+ methods: {
193
+ // 在微信小程序中,不支持将函数当做props参数,故只能通过ref形式调用
194
+ setFormatter(e) {
195
+ this.innerFormatter = e
196
+ },
197
+ // month组件内部选择日期后,通过事件通知给父组件
198
+ monthSelected(e) {
199
+ this.selected = e
200
+ if (!this.showConfirm) {
201
+ // 在不需要确认按钮的情况下,如果为单选,或者范围多选且已选长度大于2,则直接进行返还
202
+ if (
203
+ this.mode === 'multiple' ||
204
+ this.mode === 'single' ||
205
+ (this.mode === 'range' && this.selected.length >= 2)
206
+ ) {
207
+ this.$emit('confirm', this.selected)
208
+ }
209
+ }
210
+ },
211
+ init() {
212
+ // 校验maxDate,不能小于minDate
213
+ if (
214
+ this.innerMaxDate &&
215
+ this.innerMinDate &&
216
+ new Date(this.innerMaxDate).getTime() < new Date(this.innerMinDate).getTime()
217
+ ) {
218
+ return uni.$u.error('maxDate不能小于minDate')
219
+ }
220
+ // 滚动区域的高度
221
+ this.listHeight = this.rowHeight * 5 + 30
222
+ this.setMonth()
223
+ },
224
+ close() {
225
+ this.$emit('close')
226
+ },
227
+ // 点击确定按钮
228
+ confirm() {
229
+ if (!this.buttonDisabled) {
230
+ this.$emit('confirm', this.selected)
231
+ }
232
+ },
233
+ // 获得两个日期之间的月份数
234
+ getMonths(minDate, maxDate) {
235
+ const minYear = dayjs(minDate).year()
236
+ const minMonth = dayjs(minDate).month() + 1
237
+ const maxYear = dayjs(maxDate).year()
238
+ const maxMonth = dayjs(maxDate).month() + 1
239
+ return (maxYear - minYear) * 12 + (maxMonth - minMonth) + 1
240
+ },
241
+ // 设置月份数据
242
+ setMonth() {
243
+ // 最小日期的毫秒数
244
+ const minDate = this.innerMinDate || dayjs().valueOf()
245
+ // 如果没有指定最大日期,则往后推3个月
246
+ const maxDate =
247
+ this.innerMaxDate ||
248
+ dayjs(minDate)
249
+ .add(this.monthNum - 1, 'month')
250
+ .valueOf()
251
+ // 最大最小月份之间的共有多少个月份,
252
+ const months = uni.$u.range(
253
+ 1,
254
+ this.monthNum,
255
+ this.getMonths(minDate, maxDate)
256
+ )
257
+ // 先清空数组
258
+ this.months = []
259
+ for (let i = 0; i < months; i++) {
260
+ this.months.push({
261
+ date: new Array(
262
+ dayjs(minDate).add(i, 'month').daysInMonth()
263
+ )
264
+ .fill(1)
265
+ .map((item, index) => {
266
+ // 日期,取值1-31
267
+ let day = index + 1
268
+ // 星期,0-6,0为周日
269
+ const week = dayjs(minDate)
270
+ .add(i, 'month')
271
+ .date(day)
272
+ .day()
273
+ const date = dayjs(minDate)
274
+ .add(i, 'month')
275
+ .date(day)
276
+ .format('YYYY-MM-DD')
277
+ let bottomInfo = ''
278
+ if (this.showLunar) {
279
+ // 将日期转为农历格式
280
+ const lunar = Calendar.solar2lunar(
281
+ dayjs(date).year(),
282
+ dayjs(date).month() + 1,
283
+ dayjs(date).date()
284
+ )
285
+ bottomInfo = lunar.IDayCn
286
+ }
287
+ let config = {
288
+ day,
289
+ week,
290
+ // 小于最小允许的日期,或者大于最大的日期,则设置为disabled状态
291
+ disabled:
292
+ dayjs(date).isBefore(
293
+ dayjs(minDate).format('YYYY-MM-DD')
294
+ ) ||
295
+ dayjs(date).isAfter(
296
+ dayjs(maxDate).format('YYYY-MM-DD')
297
+ ),
298
+ // 返回一个日期对象,供外部的formatter获取当前日期的年月日等信息,进行加工处理
299
+ date: new Date(date),
300
+ bottomInfo,
301
+ dot: false,
302
+ month:
303
+ dayjs(minDate).add(i, 'month').month() + 1
304
+ }
305
+ const formatter =
306
+ this.formatter || this.innerFormatter
307
+ return formatter(config)
308
+ }),
309
+ // 当前所属的月份
310
+ month: dayjs(minDate).add(i, 'month').month() + 1,
311
+ // 当前年份
312
+ year: dayjs(minDate).add(i, 'month').year()
313
+ })
314
+ }
315
+
316
+ },
317
+ // 滚动到默认设置的月份
318
+ scrollIntoDefaultMonth(selected) {
319
+ // 查询默认日期在可选列表的下标
320
+ const _index = this.months.findIndex(({
321
+ year,
322
+ month
323
+ }) => {
324
+ month = uni.$u.padZero(month)
325
+ return `${year}-${month}` === selected
326
+ })
327
+ if (_index !== -1) {
328
+ // #ifndef MP-WEIXIN
329
+ this.$nextTick(() => {
330
+ this.scrollIntoView = `month-${_index}`
331
+ })
332
+ // #endif
333
+ // #ifdef MP-WEIXIN
334
+ this.scrollTop = this.months[_index].top || 0;
335
+ // #endif
336
+ }
337
+ },
338
+ // scroll-view滚动监听
339
+ onScroll(event) {
340
+ // 不允许小于0的滚动值,如果scroll-view到顶了,继续下拉,会出现负数值
341
+ const scrollTop = Math.max(0, event.detail.scrollTop)
342
+ // 将当前滚动条数值,除以滚动区域的高度,可以得出当前滚动到了哪一个月份的索引
343
+ for (let i = 0; i < this.months.length; i++) {
344
+ if (scrollTop >= (this.months[i].top || this.listHeight)) {
345
+ this.monthIndex = i
346
+ }
347
+ }
348
+ },
349
+ // 更新月份的top值
350
+ updateMonthTop(topArr = []) {
351
+ // 设置对应月份的top值,用于onScroll方法更新月份
352
+ topArr.map((item, index) => {
353
+ this.months[index].top = item
354
+ })
355
+
356
+ // 获取默认日期的下标
357
+ if (!this.defaultDate) {
358
+ // 如果没有设置默认日期,则将当天日期设置为默认选中的日期
359
+ const selected = dayjs().format("YYYY-MM")
360
+ this.scrollIntoDefaultMonth(selected)
361
+ return
362
+ }
363
+ let selected = dayjs().format("YYYY-MM");
364
+ // 单选模式,可以是字符串或数组,Date对象等
365
+ if (!uni.$u.test.array(this.defaultDate)) {
366
+ selected = dayjs(this.defaultDate).format("YYYY-MM")
367
+ } else {
368
+ selected = dayjs(this.defaultDate[0]).format("YYYY-MM");
369
+ }
370
+ this.scrollIntoDefaultMonth(selected)
371
+ }
372
+ }
373
+ }
374
+ </script>
375
+
376
+ <style lang="scss" scoped>
377
+ @import '../../libs/css/components.scss';
378
+
379
+ .u-calendar {
380
+ &__confirm {
381
+ padding: 7px 18px;
382
+ }
383
+ }
384
+ </style>
@@ -0,0 +1,85 @@
1
+ export default {
2
+ methods: {
3
+ // 设置月份数据
4
+ setMonth() {
5
+ // 月初是周几
6
+ const day = dayjs(this.date).date(1).day()
7
+ const start = day == 0 ? 6 : day - 1
8
+
9
+ // 本月天数
10
+ const days = dayjs(this.date).endOf('month').format('D')
11
+
12
+ // 上个月天数
13
+ const prevDays = dayjs(this.date).endOf('month').subtract(1, 'month').format('D')
14
+
15
+ // 日期数据
16
+ const arr = []
17
+ // 清空表格
18
+ this.month = []
19
+
20
+ // 添加上月数据
21
+ arr.push(
22
+ ...new Array(start).fill(1).map((e, i) => {
23
+ const day = prevDays - start + i + 1
24
+
25
+ return {
26
+ value: day,
27
+ disabled: true,
28
+ date: dayjs(this.date).subtract(1, 'month').date(day).format('YYYY-MM-DD')
29
+ }
30
+ })
31
+ )
32
+
33
+ // 添加本月数据
34
+ arr.push(
35
+ ...new Array(days - 0).fill(1).map((e, i) => {
36
+ const day = i + 1
37
+
38
+ return {
39
+ value: day,
40
+ date: dayjs(this.date).date(day).format('YYYY-MM-DD')
41
+ }
42
+ })
43
+ )
44
+
45
+ // 添加下个月
46
+ arr.push(
47
+ ...new Array(42 - days - start).fill(1).map((e, i) => {
48
+ const day = i + 1
49
+
50
+ return {
51
+ value: day,
52
+ disabled: true,
53
+ date: dayjs(this.date).add(1, 'month').date(day).format('YYYY-MM-DD')
54
+ }
55
+ })
56
+ )
57
+
58
+ // 分割数组
59
+ for (let n = 0; n < arr.length; n += 7) {
60
+ this.month.push(
61
+ arr.slice(n, n + 7).map((e, i) => {
62
+ e.index = i + n
63
+
64
+ // 自定义信息
65
+ const custom = this.customList.find((c) => c.date == e.date)
66
+
67
+ // 农历
68
+ if (this.lunar) {
69
+ const {
70
+ IDayCn,
71
+ IMonthCn
72
+ } = this.getLunar(e.date)
73
+ e.lunar = IDayCn == '初一' ? IMonthCn : IDayCn
74
+ }
75
+
76
+ return {
77
+ ...e,
78
+ ...custom
79
+ }
80
+ })
81
+ )
82
+ }
83
+ }
84
+ }
85
+ }
@@ -0,0 +1,14 @@
1
+ export default {
2
+ props: {
3
+ // 是否打乱键盘按键的顺序
4
+ random: {
5
+ type: Boolean,
6
+ default: false
7
+ },
8
+ // 输入一个中文后,是否自动切换到英文
9
+ autoChange: {
10
+ type: Boolean,
11
+ default: false
12
+ }
13
+ }
14
+ }