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,186 @@
1
+ <template>
2
+ <view class="u-navbar">
3
+ <view
4
+ class="u-navbar__placeholder"
5
+ v-if="fixed && placeholder"
6
+ :style="{
7
+ height: $u.addUnit($u.getPx(height) + $u.sys().statusBarHeight,'px'),
8
+ }"
9
+ ></view>
10
+ <view :class="[fixed && 'u-navbar--fixed']">
11
+ <u-status-bar
12
+ v-if="safeAreaInsetTop"
13
+ :bgColor="bgColor"
14
+ ></u-status-bar>
15
+ <view
16
+ class="u-navbar__content"
17
+ :class="[border && 'u-border-bottom']"
18
+ :style="{
19
+ height: $u.addUnit(height),
20
+ backgroundColor: bgColor,
21
+ }"
22
+ >
23
+ <view
24
+ class="u-navbar__content__left"
25
+ hover-class="u-navbar__content__left--hover"
26
+ hover-start-time="150"
27
+ @tap="leftClick"
28
+ >
29
+ <slot name="left">
30
+ <u-icon
31
+ v-if="leftIcon"
32
+ :name="leftIcon"
33
+ :size="leftIconSize"
34
+ :color="leftIconColor"
35
+ ></u-icon>
36
+ <text
37
+ v-if="leftText"
38
+ :style="{
39
+ color: leftIconColor
40
+ }"
41
+ class="u-navbar__content__left__text"
42
+ >{{ leftText }}</text>
43
+ </slot>
44
+ </view>
45
+ <slot name="center">
46
+ <text
47
+ class="u-line-1 u-navbar__content__title"
48
+ :style="[{
49
+ width: $u.addUnit(titleWidth),
50
+ }, $u.addStyle(titleStyle)]"
51
+ >{{ title }}</text>
52
+ </slot>
53
+ <view
54
+ class="u-navbar__content__right"
55
+ v-if="$slots.right || rightIcon || rightText"
56
+ @tap="rightClick"
57
+ >
58
+ <slot name="right">
59
+ <u-icon
60
+ v-if="rightIcon"
61
+ :name="rightIcon"
62
+ size="20"
63
+ ></u-icon>
64
+ <text
65
+ v-if="rightText"
66
+ class="u-navbar__content__right__text"
67
+ >{{ rightText }}</text>
68
+ </slot>
69
+ </view>
70
+ </view>
71
+ </view>
72
+ </view>
73
+ </template>
74
+
75
+ <script>
76
+ import props from './props.js';
77
+ /**
78
+ * Navbar 自定义导航栏
79
+ * @description 此组件一般用于在特殊情况下,需要自定义导航栏的时候用到,一般建议使用uni-app带的导航栏。
80
+ * @tutorial https://www.uviewui.com/components/navbar.html
81
+ * @property {Boolean} safeAreaInsetTop 是否开启顶部安全区适配 (默认 true )
82
+ * @property {Boolean} placeholder 固定在顶部时,是否生成一个等高元素,以防止塌陷 (默认 false )
83
+ * @property {Boolean} fixed 导航栏是否固定在顶部 (默认 false )
84
+ * @property {Boolean} border 导航栏底部是否显示下边框 (默认 false )
85
+ * @property {String} leftIcon 左边返回图标的名称,只能为uView自带的图标 (默认 'arrow-left' )
86
+ * @property {String} leftText 左边的提示文字
87
+ * @property {String} rightText 右边的提示文字
88
+ * @property {String} rightIcon 右边返回图标的名称,只能为uView自带的图标
89
+ * @property {String} title 导航栏标题,如设置为空字符,将会隐藏标题占位区域
90
+ * @property {String} bgColor 导航栏背景设置 (默认 '#ffffff' )
91
+ * @property {String | Number} titleWidth 导航栏标题的最大宽度,内容超出会以省略号隐藏 (默认 '400rpx' )
92
+ * @property {String | Number} height 导航栏高度(不包括状态栏高度在内,内部自动加上)(默认 '44px' )
93
+ * @property {String | Number} leftIconSize 左侧返回图标的大小(默认 20px )
94
+ * @property {String | Number} leftIconColor 左侧返回图标的颜色(默认 #303133 )
95
+ * @property {Boolean} autoBack 点击左侧区域(返回图标),是否自动返回上一页(默认 false )
96
+ * @property {Object | String} titleStyle 标题的样式,对象或字符串
97
+ * @event {Function} leftClick 点击左侧区域
98
+ * @event {Function} rightClick 点击右侧区域
99
+ * @example <u-navbar title="剑未配妥,出门已是江湖" left-text="返回" right-text="帮助" @click-left="onClickBack" @click-right="onClickRight"></u-navbar>
100
+ */
101
+ export default {
102
+ name: 'u-navbar',
103
+ mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
104
+ data() {
105
+ return {
106
+
107
+ }
108
+ },
109
+ methods: {
110
+ // 点击左侧区域
111
+ leftClick() {
112
+ // 如果配置了autoBack,自动返回上一页
113
+ this.$emit('leftClick')
114
+ if(this.autoBack) {
115
+ uni.navigateBack()
116
+ }
117
+ },
118
+ // 点击右侧区域
119
+ rightClick() {
120
+ this.$emit('rightClick')
121
+ },
122
+ }
123
+ }
124
+ </script>
125
+
126
+ <style lang="scss" scoped>
127
+ @import "../../libs/css/components.scss";
128
+
129
+ .u-navbar {
130
+
131
+ &--fixed {
132
+ position: fixed;
133
+ left: 0;
134
+ right: 0;
135
+ top: 0;
136
+ z-index: 11;
137
+ }
138
+
139
+ &__content {
140
+ @include flex(row);
141
+ align-items: center;
142
+ height: 44px;
143
+ background-color: #9acafc;
144
+ position: relative;
145
+ justify-content: center;
146
+
147
+ &__left,
148
+ &__right {
149
+ padding: 0 13px;
150
+ position: absolute;
151
+ top: 0;
152
+ bottom: 0;
153
+ @include flex(row);
154
+ align-items: center;
155
+ }
156
+
157
+ &__left {
158
+ left: 0;
159
+
160
+ &--hover {
161
+ opacity: 0.7;
162
+ }
163
+
164
+ &__text {
165
+ font-size: 15px;
166
+ margin-left: 3px;
167
+ }
168
+ }
169
+
170
+ &__title {
171
+ text-align: center;
172
+ font-size: 16px;
173
+ color: $u-main-color;
174
+ }
175
+
176
+ &__right {
177
+ right: 0;
178
+
179
+ &__text {
180
+ font-size: 15px;
181
+ margin-left: 3px;
182
+ }
183
+ }
184
+ }
185
+ }
186
+ </style>
@@ -0,0 +1,19 @@
1
+ export default {
2
+ props: {
3
+ // 页面文字提示
4
+ tips: {
5
+ type: String,
6
+ default: uni.$u.props.noNetwork.tips
7
+ },
8
+ // 一个z-index值,用于设置没有网络这个组件的层次,因为页面可能会有其他定位的元素层级过高,导致此组件被覆盖
9
+ zIndex: {
10
+ type: [String, Number],
11
+ default: uni.$u.props.noNetwork.zIndex
12
+ },
13
+ // image 没有网络的图片提示
14
+ image: {
15
+ type: String,
16
+ default: uni.$u.props.noNetwork.image
17
+ }
18
+ }
19
+ }
@@ -0,0 +1,220 @@
1
+ <template>
2
+ <u-overlay
3
+ :show="!isConnected"
4
+ :zIndex="zIndex"
5
+ @touchmove.stop.prevent="noop"
6
+ :customStyle="{
7
+ backgroundColor: '#fff',
8
+ display: 'flex',
9
+ justifyContent: 'center',
10
+ }"
11
+ >
12
+ <view
13
+ class="u-no-network"
14
+ >
15
+ <u-icon
16
+ :name="image"
17
+ size="150"
18
+ imgMode="widthFit"
19
+ class="u-no-network__error-icon"
20
+ ></u-icon>
21
+ <text class="u-no-network__tips">{{tips}}</text>
22
+ <!-- 只有APP平台,才能跳转设置页,因为需要调用plus环境 -->
23
+ <!-- #ifdef APP-PLUS -->
24
+ <view class="u-no-network__app">
25
+ <text class="u-no-network__app__setting">请检查网络,或前往</text>
26
+ <text
27
+ class="u-no-network__app__to-setting"
28
+ @tap="openSettings"
29
+ >设置</text>
30
+ </view>
31
+ <!-- #endif -->
32
+ <view class="u-no-network__retry">
33
+ <u-button
34
+ size="mini"
35
+ text="重试"
36
+ type="primary"
37
+ plain
38
+ @click="retry"
39
+ ></u-button>
40
+ </view>
41
+ </view>
42
+ </u-overlay>
43
+ </template>
44
+
45
+ <script>
46
+ import props from './props.js';
47
+
48
+ /**
49
+ * noNetwork 无网络提示
50
+ * @description 该组件无需任何配置,引入即可,内部自动处理所有功能和事件。
51
+ * @tutorial https://www.uviewui.com/components/noNetwork.html
52
+ * @property {String} tips 没有网络时的提示语 (默认:'哎呀,网络信号丢失' )
53
+ * @property {String | Number} zIndex 组件的z-index值
54
+ * @property {String} image 无网络的图片提示,可用的src地址或base64图片
55
+ * @event {Function} retry 用户点击页面的"重试"按钮时触发
56
+ * @example <u-no-network></u-no-network>
57
+ */
58
+ export default {
59
+ name: "u-no-network",
60
+ mixins: [uni.$u.mpMixin, uni.$u.mixin,props],
61
+ data() {
62
+ return {
63
+ isConnected: true, // 是否有网络连接
64
+ networkType: "none", // 网络类型
65
+ }
66
+ },
67
+ mounted() {
68
+ this.isIOS = (uni.getSystemInfoSync().platform === 'ios')
69
+ uni.onNetworkStatusChange((res) => {
70
+ this.isConnected = res.isConnected
71
+ this.networkType = res.networkType
72
+ this.emitEvent(this.networkType)
73
+ })
74
+ uni.getNetworkType({
75
+ success: (res) => {
76
+ this.networkType = res.networkType
77
+ this.emitEvent(this.networkType)
78
+ if (res.networkType == 'none') {
79
+ this.isConnected = false
80
+ } else {
81
+ this.isConnected = true
82
+ }
83
+ }
84
+ })
85
+ },
86
+ methods: {
87
+ retry() {
88
+ // 重新检查网络
89
+ uni.getNetworkType({
90
+ success: (res) => {
91
+ this.networkType = res.networkType
92
+ this.emitEvent(this.networkType)
93
+ if (res.networkType == 'none') {
94
+ uni.$u.toast('无网络连接')
95
+ this.isConnected = false
96
+ } else {
97
+ uni.$u.toast('网络已连接')
98
+ this.isConnected = true
99
+ }
100
+ }
101
+ })
102
+ this.$emit('retry')
103
+ },
104
+ // 发出事件给父组件
105
+ emitEvent(networkType) {
106
+ this.$emit(networkType === 'none' ? 'disconnected' : 'connected')
107
+ },
108
+ async openSettings() {
109
+ if (this.networkType == "none") {
110
+ this.openSystemSettings()
111
+ return
112
+ }
113
+ },
114
+ openAppSettings() {
115
+ this.gotoAppSetting()
116
+ },
117
+ openSystemSettings() {
118
+ // 以下方法来自5+范畴,如需深究,请自行查阅相关文档
119
+ // https://ask.dcloud.net.cn/docs/
120
+ if (this.isIOS) {
121
+ this.gotoiOSSetting()
122
+ } else {
123
+ this.gotoAndroidSetting()
124
+ }
125
+ },
126
+ network() {
127
+ var result = null
128
+ var cellularData = plus.ios.newObject("CTCellularData")
129
+ var state = cellularData.plusGetAttribute("restrictedState")
130
+ if (state == 0) {
131
+ result = null
132
+ } else if (state == 2) {
133
+ result = 1
134
+ } else if (state == 1) {
135
+ result = 2
136
+ }
137
+ plus.ios.deleteObject(cellularData)
138
+ return result
139
+ },
140
+ gotoAppSetting() {
141
+ if (this.isIOS) {
142
+ var UIApplication = plus.ios.import("UIApplication")
143
+ var application2 = UIApplication.sharedApplication()
144
+ var NSURL2 = plus.ios.import("NSURL")
145
+ var setting2 = NSURL2.URLWithString("app-settings:")
146
+ application2.openURL(setting2)
147
+ plus.ios.deleteObject(setting2)
148
+ plus.ios.deleteObject(NSURL2)
149
+ plus.ios.deleteObject(application2)
150
+ } else {
151
+ var Intent = plus.android.importClass("android.content.Intent")
152
+ var Settings = plus.android.importClass("android.provider.Settings")
153
+ var Uri = plus.android.importClass("android.net.Uri")
154
+ var mainActivity = plus.android.runtimeMainActivity()
155
+ var intent = new Intent()
156
+ intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS)
157
+ var uri = Uri.fromParts("package", mainActivity.getPackageName(), null)
158
+ intent.setData(uri)
159
+ mainActivity.startActivity(intent)
160
+ }
161
+ },
162
+ gotoiOSSetting() {
163
+ var UIApplication = plus.ios.import("UIApplication")
164
+ var application2 = UIApplication.sharedApplication()
165
+ var NSURL2 = plus.ios.import("NSURL")
166
+ var setting2 = NSURL2.URLWithString("App-prefs:root=General")
167
+ application2.openURL(setting2)
168
+ plus.ios.deleteObject(setting2)
169
+ plus.ios.deleteObject(NSURL2)
170
+ plus.ios.deleteObject(application2)
171
+ },
172
+ gotoAndroidSetting() {
173
+ var Intent = plus.android.importClass("android.content.Intent")
174
+ var Settings = plus.android.importClass("android.provider.Settings")
175
+ var mainActivity = plus.android.runtimeMainActivity()
176
+ var intent = new Intent(Settings.ACTION_SETTINGS)
177
+ mainActivity.startActivity(intent)
178
+ }
179
+ }
180
+ }
181
+ </script>
182
+
183
+ <style lang="scss" scoped>
184
+ @import "../../libs/css/components.scss";
185
+
186
+ .u-no-network {
187
+ @include flex(column);
188
+ justify-content: center;
189
+ align-items: center;
190
+ margin-top: -100px;
191
+
192
+ &__tips {
193
+ color: $u-tips-color;
194
+ font-size: 14px;
195
+ margin-top: 15px;
196
+ }
197
+
198
+ &__app {
199
+ @include flex(row);
200
+ margin-top: 6px;
201
+
202
+ &__setting {
203
+ color: $u-light-color;
204
+ font-size: 13px;
205
+ }
206
+
207
+ &__to-setting {
208
+ font-size: 13px;
209
+ color: $u-primary;
210
+ margin-left: 3px;
211
+ }
212
+ }
213
+
214
+ &__retry {
215
+ @include flex(row);
216
+ justify-content: center;
217
+ margin-top: 15px;
218
+ }
219
+ }
220
+ </style>
@@ -0,0 +1,70 @@
1
+ export default {
2
+ props: {
3
+ // 显示的内容,数组
4
+ text: {
5
+ type: [Array, String],
6
+ default: uni.$u.props.noticeBar.text
7
+ },
8
+ // 通告滚动模式,row-横向滚动,column-竖向滚动
9
+ direction: {
10
+ type: String,
11
+ default: uni.$u.props.noticeBar.direction
12
+ },
13
+ // direction = row时,是否使用步进形式滚动
14
+ step: {
15
+ type: Boolean,
16
+ default: uni.$u.props.noticeBar.step
17
+ },
18
+ // 是否显示左侧的音量图标
19
+ icon: {
20
+ type: String,
21
+ default: uni.$u.props.noticeBar.icon
22
+ },
23
+ // 通告模式,link-显示右箭头,closable-显示右侧关闭图标
24
+ mode: {
25
+ type: String,
26
+ default: uni.$u.props.noticeBar.mode
27
+ },
28
+ // 文字颜色,各图标也会使用文字颜色
29
+ color: {
30
+ type: String,
31
+ default: uni.$u.props.noticeBar.color
32
+ },
33
+ // 背景颜色
34
+ bgColor: {
35
+ type: String,
36
+ default: uni.$u.props.noticeBar.bgColor
37
+ },
38
+ // 水平滚动时的滚动速度,即每秒滚动多少px(px),这有利于控制文字无论多少时,都能有一个恒定的速度
39
+ speed: {
40
+ type: [String, Number],
41
+ default: uni.$u.props.noticeBar.speed
42
+ },
43
+ // 字体大小
44
+ fontSize: {
45
+ type: [String, Number],
46
+ default: uni.$u.props.noticeBar.fontSize
47
+ },
48
+ // 滚动一个周期的时间长,单位ms
49
+ duration: {
50
+ type: [String, Number],
51
+ default: uni.$u.props.noticeBar.duration
52
+ },
53
+ // 是否禁止用手滑动切换
54
+ // 目前HX2.6.11,只支持App 2.5.5+、H5 2.5.5+、支付宝小程序、字节跳动小程序
55
+ disableTouch: {
56
+ type: Boolean,
57
+ default: uni.$u.props.noticeBar.disableTouch
58
+ },
59
+ // 跳转的页面路径
60
+ url: {
61
+ type: String,
62
+ default: uni.$u.props.noticeBar.url
63
+ },
64
+ // 页面跳转的类型
65
+ linkType: {
66
+ type: String,
67
+ default: uni.$u.props.noticeBar.linkType
68
+ }
69
+ }
70
+ }
@@ -0,0 +1,101 @@
1
+ <template>
2
+ <view
3
+ class="u-notice-bar"
4
+ v-if="show"
5
+ :style="[{
6
+ backgroundColor: bgColor
7
+ }, $u.addStyle(customStyle)]"
8
+ >
9
+ <template v-if="direction === 'column' || (direction === 'row' && step)">
10
+ <u-column-notice
11
+ :color="color"
12
+ :bgColor="bgColor"
13
+ :text="text"
14
+ :mode="mode"
15
+ :step="step"
16
+ :icon="icon"
17
+ :disable-touch="disableTouch"
18
+ :fontSize="fontSize"
19
+ :duration="duration"
20
+ @close="close"
21
+ @click="click"
22
+ ></u-column-notice>
23
+ </template>
24
+ <template v-else>
25
+ <u-row-notice
26
+ :color="color"
27
+ :bgColor="bgColor"
28
+ :text="text"
29
+ :mode="mode"
30
+ :fontSize="fontSize"
31
+ :speed="speed"
32
+ :url="url"
33
+ :linkType="linkType"
34
+ :icon="icon"
35
+ @close="close"
36
+ @click="click"
37
+ ></u-row-notice>
38
+ </template>
39
+ </view>
40
+ </template>
41
+ <script>
42
+ import props from './props.js';
43
+
44
+ /**
45
+ * noticeBar 滚动通知
46
+ * @description 该组件用于滚动通告场景,有多种模式可供选择
47
+ * @tutorial https://www.uviewui.com/components/noticeBar.html
48
+ * @property {Array | String} text 显示的内容,数组
49
+ * @property {String} direction 通告滚动模式,row-横向滚动,column-竖向滚动 ( 默认 'row' )
50
+ * @property {Boolean} step direction = row时,是否使用步进形式滚动 ( 默认 false )
51
+ * @property {String} icon 是否显示左侧的音量图标 ( 默认 'volume' )
52
+ * @property {String} mode 通告模式,link-显示右箭头,closable-显示右侧关闭图标
53
+ * @property {String} color 文字颜色,各图标也会使用文字颜色 ( 默认 '#f9ae3d' )
54
+ * @property {String} bgColor 背景颜色 ( 默认 '#fdf6ec' )
55
+ * @property {String | Number} speed 水平滚动时的滚动速度,即每秒滚动多少px(px),这有利于控制文字无论多少时,都能有一个恒定的速度 ( 默认 80 )
56
+ * @property {String | Number} fontSize 字体大小 ( 默认 14 )
57
+ * @property {String | Number} duration 滚动一个周期的时间长,单位ms ( 默认 2000 )
58
+ * @property {Boolean} disableTouch 是否禁止用手滑动切换 目前HX2.6.11,只支持App 2.5.5+、H5 2.5.5+、支付宝小程序、字节跳动小程序(默认34) ( 默认 true )
59
+ * @property {String} url 跳转的页面路径
60
+ * @property {String} linkType 页面跳转的类型 ( 默认 navigateTo )
61
+ * @property {Object} customStyle 定义需要用到的外部样式
62
+ *
63
+ * @event {Function} click 点击通告文字触发
64
+ * @event {Function} close 点击右侧关闭图标触发
65
+ * @example <u-notice-bar :more-icon="true" :list="list"></u-notice-bar>
66
+ */
67
+ export default {
68
+ name: "u-notice-bar",
69
+ mixins: [uni.$u.mpMixin, uni.$u.mixin,props],
70
+ data() {
71
+ return {
72
+ show: true
73
+ }
74
+ },
75
+ methods: {
76
+ // 点击通告栏
77
+ click(index) {
78
+ this.$emit('click', index)
79
+ if (this.url && this.linkType) {
80
+ // 此方法写在mixin中,另外跳转的url和linkType参数也在mixin的props中
81
+ this.openPage()
82
+ }
83
+ },
84
+ // 点击关闭按钮
85
+ close() {
86
+ this.show = false
87
+ this.$emit('close')
88
+ }
89
+ }
90
+ };
91
+ </script>
92
+
93
+ <style lang="scss" scoped>
94
+ @import "../../libs/css/components.scss";
95
+
96
+ .u-notice-bar {
97
+ overflow: hidden;
98
+ padding: 9px 12px;
99
+ flex: 1;
100
+ }
101
+ </style>
@@ -0,0 +1,49 @@
1
+ export default {
2
+ props: {
3
+ // 到顶部的距离
4
+ top: {
5
+ type: [String, Number],
6
+ default: uni.$u.props.notify.top
7
+ },
8
+ // 是否展示组件
9
+ // show: {
10
+ // type: Boolean,
11
+ // default: uni.$u.props.notify.show
12
+ // },
13
+ // type主题,primary,success,warning,error
14
+ type: {
15
+ type: String,
16
+ default: uni.$u.props.notify.type
17
+ },
18
+ // 字体颜色
19
+ color: {
20
+ type: String,
21
+ default: uni.$u.props.notify.color
22
+ },
23
+ // 背景颜色
24
+ bgColor: {
25
+ type: String,
26
+ default: uni.$u.props.notify.bgColor
27
+ },
28
+ // 展示的文字内容
29
+ message: {
30
+ type: String,
31
+ default: uni.$u.props.notify.message
32
+ },
33
+ // 展示时长,为0时不消失,单位ms
34
+ duration: {
35
+ type: [String, Number],
36
+ default: uni.$u.props.notify.duration
37
+ },
38
+ // 字体大小
39
+ fontSize: {
40
+ type: [String, Number],
41
+ default: uni.$u.props.notify.fontSize
42
+ },
43
+ // 是否留出顶部安全距离(状态栏高度)
44
+ safeAreaInsetTop: {
45
+ type: Boolean,
46
+ default: uni.$u.props.notify.safeAreaInsetTop
47
+ }
48
+ }
49
+ }