oxy-uni-ui 1.0.1

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 (355) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +13 -0
  3. package/attributes.json +1 -0
  4. package/components/common/AbortablePromise.ts +28 -0
  5. package/components/common/abstracts/_config.scss +7 -0
  6. package/components/common/abstracts/_function.scss +89 -0
  7. package/components/common/abstracts/_mixin.scss +385 -0
  8. package/components/common/abstracts/variable.scss +974 -0
  9. package/components/common/base64.ts +29 -0
  10. package/components/common/canvasHelper.ts +49 -0
  11. package/components/common/clickoutside.ts +25 -0
  12. package/components/common/event.ts +8 -0
  13. package/components/common/interceptor.ts +43 -0
  14. package/components/common/props.ts +51 -0
  15. package/components/common/util.ts +778 -0
  16. package/components/composables/index.ts +11 -0
  17. package/components/composables/useCell.ts +13 -0
  18. package/components/composables/useChildren.ts +113 -0
  19. package/components/composables/useCountDown.ts +138 -0
  20. package/components/composables/useLockScroll.ts +37 -0
  21. package/components/composables/useParent.ts +41 -0
  22. package/components/composables/usePopover.ts +176 -0
  23. package/components/composables/useQueue.ts +52 -0
  24. package/components/composables/useRaf.ts +37 -0
  25. package/components/composables/useTouch.ts +43 -0
  26. package/components/composables/useTranslate.ts +12 -0
  27. package/components/composables/useUpload.ts +364 -0
  28. package/components/oxy-action-sheet/index.scss +204 -0
  29. package/components/oxy-action-sheet/oxy-action-sheet.vue +155 -0
  30. package/components/oxy-action-sheet/types.ts +118 -0
  31. package/components/oxy-backtop/index.scss +25 -0
  32. package/components/oxy-backtop/oxy-backtop.vue +45 -0
  33. package/components/oxy-backtop/types.ts +37 -0
  34. package/components/oxy-badge/index.scss +63 -0
  35. package/components/oxy-badge/oxy-badge.vue +61 -0
  36. package/components/oxy-badge/types.ts +41 -0
  37. package/components/oxy-button/index.scss +336 -0
  38. package/components/oxy-button/oxy-button.vue +195 -0
  39. package/components/oxy-button/types.ts +133 -0
  40. package/components/oxy-calendar/index.scss +158 -0
  41. package/components/oxy-calendar/oxy-calendar.vue +451 -0
  42. package/components/oxy-calendar/types.ts +217 -0
  43. package/components/oxy-calendar-view/index.scss +0 -0
  44. package/components/oxy-calendar-view/month/index.scss +162 -0
  45. package/components/oxy-calendar-view/month/month.vue +389 -0
  46. package/components/oxy-calendar-view/month/types.ts +20 -0
  47. package/components/oxy-calendar-view/monthPanel/index.scss +89 -0
  48. package/components/oxy-calendar-view/monthPanel/month-panel.vue +374 -0
  49. package/components/oxy-calendar-view/monthPanel/types.ts +48 -0
  50. package/components/oxy-calendar-view/oxy-calendar-view.vue +111 -0
  51. package/components/oxy-calendar-view/types.ts +109 -0
  52. package/components/oxy-calendar-view/utils.ts +429 -0
  53. package/components/oxy-calendar-view/year/index.scss +153 -0
  54. package/components/oxy-calendar-view/year/types.ts +20 -0
  55. package/components/oxy-calendar-view/year/year.vue +202 -0
  56. package/components/oxy-calendar-view/yearPanel/index.scss +24 -0
  57. package/components/oxy-calendar-view/yearPanel/types.ts +38 -0
  58. package/components/oxy-calendar-view/yearPanel/year-panel.vue +135 -0
  59. package/components/oxy-card/index.scss +71 -0
  60. package/components/oxy-card/oxy-card.vue +37 -0
  61. package/components/oxy-card/types.ts +30 -0
  62. package/components/oxy-cell/index.scss +206 -0
  63. package/components/oxy-cell/oxy-cell.vue +140 -0
  64. package/components/oxy-cell/types.ts +111 -0
  65. package/components/oxy-cell-group/index.scss +56 -0
  66. package/components/oxy-cell-group/oxy-cell-group.vue +45 -0
  67. package/components/oxy-cell-group/types.ts +32 -0
  68. package/components/oxy-checkbox/index.scss +285 -0
  69. package/components/oxy-checkbox/oxy-checkbox.vue +177 -0
  70. package/components/oxy-checkbox/types.ts +68 -0
  71. package/components/oxy-checkbox-group/index.scss +20 -0
  72. package/components/oxy-checkbox-group/oxy-checkbox-group.vue +100 -0
  73. package/components/oxy-checkbox-group/types.ts +59 -0
  74. package/components/oxy-circle/index.scss +18 -0
  75. package/components/oxy-circle/oxy-circle.vue +296 -0
  76. package/components/oxy-circle/types.ts +54 -0
  77. package/components/oxy-col/index.scss +19 -0
  78. package/components/oxy-col/oxy-col.vue +49 -0
  79. package/components/oxy-col/types.ts +15 -0
  80. package/components/oxy-col-picker/index.scss +168 -0
  81. package/components/oxy-col-picker/oxy-col-picker.vue +498 -0
  82. package/components/oxy-col-picker/types.ts +166 -0
  83. package/components/oxy-collapse/index.scss +55 -0
  84. package/components/oxy-collapse/oxy-collapse.vue +151 -0
  85. package/components/oxy-collapse/types.ts +58 -0
  86. package/components/oxy-collapse-item/index.scss +90 -0
  87. package/components/oxy-collapse-item/oxy-collapse-item.vue +171 -0
  88. package/components/oxy-collapse-item/types.ts +48 -0
  89. package/components/oxy-config-provider/oxy-config-provider.vue +73 -0
  90. package/components/oxy-config-provider/types.ts +1052 -0
  91. package/components/oxy-count-down/index.scss +15 -0
  92. package/components/oxy-count-down/oxy-count-down.vue +60 -0
  93. package/components/oxy-count-down/types.ts +41 -0
  94. package/components/oxy-count-down/utils.ts +52 -0
  95. package/components/oxy-count-to/index.scss +7 -0
  96. package/components/oxy-count-to/oxy-count-to.vue +125 -0
  97. package/components/oxy-count-to/types.ts +117 -0
  98. package/components/oxy-curtain/index.scss +85 -0
  99. package/components/oxy-curtain/oxy-curtain.vue +172 -0
  100. package/components/oxy-curtain/types.ts +73 -0
  101. package/components/oxy-datetime-picker/index.scss +164 -0
  102. package/components/oxy-datetime-picker/oxy-datetime-picker.vue +801 -0
  103. package/components/oxy-datetime-picker/types.ts +231 -0
  104. package/components/oxy-datetime-picker-view/oxy-datetime-picker-view.vue +499 -0
  105. package/components/oxy-datetime-picker-view/types.ts +120 -0
  106. package/components/oxy-datetime-picker-view/util.ts +30 -0
  107. package/components/oxy-design-uni/oxy-design-uni.vue +5 -0
  108. package/components/oxy-divider/index.scss +100 -0
  109. package/components/oxy-divider/oxy-divider.vue +52 -0
  110. package/components/oxy-divider/types.ts +35 -0
  111. package/components/oxy-drop-menu/index.scss +86 -0
  112. package/components/oxy-drop-menu/oxy-drop-menu.vue +166 -0
  113. package/components/oxy-drop-menu/types.ts +38 -0
  114. package/components/oxy-drop-menu-item/index.scss +66 -0
  115. package/components/oxy-drop-menu-item/oxy-drop-menu-item.vue +221 -0
  116. package/components/oxy-drop-menu-item/types.ts +94 -0
  117. package/components/oxy-fab/index.scss +116 -0
  118. package/components/oxy-fab/oxy-fab.vue +276 -0
  119. package/components/oxy-fab/types.ts +66 -0
  120. package/components/oxy-floating-panel/index.scss +64 -0
  121. package/components/oxy-floating-panel/oxy-floating-panel.vue +140 -0
  122. package/components/oxy-floating-panel/type.ts +32 -0
  123. package/components/oxy-form/oxy-form.vue +207 -0
  124. package/components/oxy-form/types.ts +76 -0
  125. package/components/oxy-form-item/index.scss +18 -0
  126. package/components/oxy-form-item/oxy-form-item.vue +56 -0
  127. package/components/oxy-form-item/types.ts +16 -0
  128. package/components/oxy-gap/index.scss +9 -0
  129. package/components/oxy-gap/oxy-gap.vue +36 -0
  130. package/components/oxy-gap/types.ts +17 -0
  131. package/components/oxy-grid/index.scss +9 -0
  132. package/components/oxy-grid/oxy-grid.vue +106 -0
  133. package/components/oxy-grid/types.ts +50 -0
  134. package/components/oxy-grid-item/index.scss +148 -0
  135. package/components/oxy-grid-item/oxy-grid-item.vue +176 -0
  136. package/components/oxy-grid-item/types.ts +77 -0
  137. package/components/oxy-icon/index.scss +1230 -0
  138. package/components/oxy-icon/oxy-icon.vue +53 -0
  139. package/components/oxy-icon/oxy-icons.ttf +0 -0
  140. package/components/oxy-icon/types.ts +21 -0
  141. package/components/oxy-img/index.scss +19 -0
  142. package/components/oxy-img/oxy-img.vue +81 -0
  143. package/components/oxy-img/types.ts +61 -0
  144. package/components/oxy-img-cropper/index.scss +231 -0
  145. package/components/oxy-img-cropper/oxy-img-cropper.vue +664 -0
  146. package/components/oxy-img-cropper/types.ts +76 -0
  147. package/components/oxy-index-anchor/index.scss +35 -0
  148. package/components/oxy-index-anchor/oxy-index-anchor.vue +55 -0
  149. package/components/oxy-index-anchor/type.ts +9 -0
  150. package/components/oxy-index-bar/index.scss +39 -0
  151. package/components/oxy-index-bar/oxy-index-bar.vue +156 -0
  152. package/components/oxy-index-bar/type.ts +23 -0
  153. package/components/oxy-input/index.scss +323 -0
  154. package/components/oxy-input/oxy-input.vue +300 -0
  155. package/components/oxy-input/placeholder.scss +21 -0
  156. package/components/oxy-input/types.ts +189 -0
  157. package/components/oxy-input-number/index.scss +132 -0
  158. package/components/oxy-input-number/oxy-input-number.vue +464 -0
  159. package/components/oxy-input-number/types.ts +101 -0
  160. package/components/oxy-keyboard/constants.ts +81 -0
  161. package/components/oxy-keyboard/index.scss +102 -0
  162. package/components/oxy-keyboard/key/index.scss +79 -0
  163. package/components/oxy-keyboard/key/index.vue +76 -0
  164. package/components/oxy-keyboard/key/types.ts +11 -0
  165. package/components/oxy-keyboard/oxy-keyboard.vue +206 -0
  166. package/components/oxy-keyboard/types.ts +92 -0
  167. package/components/oxy-loading/index.scss +37 -0
  168. package/components/oxy-loading/oxy-loading.vue +90 -0
  169. package/components/oxy-loading/types.ts +22 -0
  170. package/components/oxy-loadmore/index.scss +39 -0
  171. package/components/oxy-loadmore/oxy-loadmore.vue +59 -0
  172. package/components/oxy-loadmore/types.ts +30 -0
  173. package/components/oxy-message-box/index.scss +108 -0
  174. package/components/oxy-message-box/index.ts +87 -0
  175. package/components/oxy-message-box/oxy-message-box.vue +291 -0
  176. package/components/oxy-message-box/types.ts +132 -0
  177. package/components/oxy-navbar/index.scss +93 -0
  178. package/components/oxy-navbar/oxy-navbar.vue +111 -0
  179. package/components/oxy-navbar/types.ts +52 -0
  180. package/components/oxy-navbar-capsule/index.scss +66 -0
  181. package/components/oxy-navbar-capsule/oxy-navbar-capsule.vue +35 -0
  182. package/components/oxy-navbar-capsule/types.ts +8 -0
  183. package/components/oxy-notice-bar/index.scss +68 -0
  184. package/components/oxy-notice-bar/oxy-notice-bar.vue +266 -0
  185. package/components/oxy-notice-bar/types.ts +67 -0
  186. package/components/oxy-notify/index.scss +34 -0
  187. package/components/oxy-notify/index.ts +61 -0
  188. package/components/oxy-notify/oxy-notify.vue +85 -0
  189. package/components/oxy-notify/types.ts +66 -0
  190. package/components/oxy-number-keyboard/index.scss +78 -0
  191. package/components/oxy-number-keyboard/key/index.scss +81 -0
  192. package/components/oxy-number-keyboard/key/index.vue +78 -0
  193. package/components/oxy-number-keyboard/key/types.ts +11 -0
  194. package/components/oxy-number-keyboard/oxy-number-keyboard.vue +151 -0
  195. package/components/oxy-number-keyboard/types.ts +83 -0
  196. package/components/oxy-overlay/index.scss +17 -0
  197. package/components/oxy-overlay/oxy-overlay.vue +47 -0
  198. package/components/oxy-overlay/types.ts +25 -0
  199. package/components/oxy-pagination/index.scss +57 -0
  200. package/components/oxy-pagination/oxy-pagination.vue +110 -0
  201. package/components/oxy-pagination/types.ts +41 -0
  202. package/components/oxy-password-input/index.scss +124 -0
  203. package/components/oxy-password-input/oxy-password-input.vue +49 -0
  204. package/components/oxy-password-input/types.ts +33 -0
  205. package/components/oxy-picker/index.scss +110 -0
  206. package/components/oxy-picker/oxy-picker.vue +412 -0
  207. package/components/oxy-picker/types.ts +189 -0
  208. package/components/oxy-picker-view/index.scss +92 -0
  209. package/components/oxy-picker-view/oxy-picker-view.vue +369 -0
  210. package/components/oxy-picker-view/types.ts +152 -0
  211. package/components/oxy-popover/index.scss +116 -0
  212. package/components/oxy-popover/oxy-popover.vue +180 -0
  213. package/components/oxy-popover/types.ts +69 -0
  214. package/components/oxy-popup/index.scss +84 -0
  215. package/components/oxy-popup/oxy-popup.vue +169 -0
  216. package/components/oxy-popup/types.ts +95 -0
  217. package/components/oxy-progress/index.scss +68 -0
  218. package/components/oxy-progress/oxy-progress.vue +197 -0
  219. package/components/oxy-progress/types.ts +35 -0
  220. package/components/oxy-radio/index.scss +301 -0
  221. package/components/oxy-radio/oxy-radio.vue +118 -0
  222. package/components/oxy-radio/types.ts +42 -0
  223. package/components/oxy-radio-group/index.scss +23 -0
  224. package/components/oxy-radio-group/oxy-radio-group.vue +51 -0
  225. package/components/oxy-radio-group/types.ts +39 -0
  226. package/components/oxy-rate/index.scss +25 -0
  227. package/components/oxy-rate/oxy-rate.vue +178 -0
  228. package/components/oxy-rate/types.ts +103 -0
  229. package/components/oxy-resize/index.scss +27 -0
  230. package/components/oxy-resize/oxy-resize.vue +144 -0
  231. package/components/oxy-resize/types.ts +6 -0
  232. package/components/oxy-root-portal/oxy-root-portal.vue +50 -0
  233. package/components/oxy-row/index.scss +10 -0
  234. package/components/oxy-row/oxy-row.vue +42 -0
  235. package/components/oxy-row/types.ts +16 -0
  236. package/components/oxy-search/index.scss +148 -0
  237. package/components/oxy-search/oxy-search.vue +187 -0
  238. package/components/oxy-search/types.ts +93 -0
  239. package/components/oxy-segmented/index.scss +101 -0
  240. package/components/oxy-segmented/oxy-segmented.vue +143 -0
  241. package/components/oxy-segmented/types.ts +71 -0
  242. package/components/oxy-select-picker/index.scss +102 -0
  243. package/components/oxy-select-picker/oxy-select-picker.vue +432 -0
  244. package/components/oxy-select-picker/types.ts +123 -0
  245. package/components/oxy-sidebar/index.scss +25 -0
  246. package/components/oxy-sidebar/oxy-sidebar.vue +63 -0
  247. package/components/oxy-sidebar/types.ts +38 -0
  248. package/components/oxy-sidebar-item/index.scss +97 -0
  249. package/components/oxy-sidebar-item/oxy-sidebar-item.vue +116 -0
  250. package/components/oxy-sidebar-item/types.ts +31 -0
  251. package/components/oxy-signature/index.scss +31 -0
  252. package/components/oxy-signature/oxy-signature.vue +630 -0
  253. package/components/oxy-signature/types.ts +108 -0
  254. package/components/oxy-skeleton/index.scss +96 -0
  255. package/components/oxy-skeleton/index.ts +1 -0
  256. package/components/oxy-skeleton/oxy-skeleton.vue +110 -0
  257. package/components/oxy-skeleton/types.ts +69 -0
  258. package/components/oxy-slider/index.scss +98 -0
  259. package/components/oxy-slider/oxy-slider.vue +356 -0
  260. package/components/oxy-slider/types.ts +138 -0
  261. package/components/oxy-sort-button/index.scss +89 -0
  262. package/components/oxy-sort-button/oxy-sort-button.vue +69 -0
  263. package/components/oxy-sort-button/types.ts +43 -0
  264. package/components/oxy-status-tip/images/collect.png +0 -0
  265. package/components/oxy-status-tip/images/content.png +0 -0
  266. package/components/oxy-status-tip/images/network.png +0 -0
  267. package/components/oxy-status-tip/images/search.png +0 -0
  268. package/components/oxy-status-tip/index.scss +37 -0
  269. package/components/oxy-status-tip/oxy-status-tip.vue +71 -0
  270. package/components/oxy-status-tip/types.ts +50 -0
  271. package/components/oxy-step/index.scss +235 -0
  272. package/components/oxy-step/oxy-step.vue +150 -0
  273. package/components/oxy-step/types.ts +33 -0
  274. package/components/oxy-steps/index.scss +10 -0
  275. package/components/oxy-steps/oxy-steps.vue +28 -0
  276. package/components/oxy-steps/types.ts +50 -0
  277. package/components/oxy-sticky/index.scss +9 -0
  278. package/components/oxy-sticky/oxy-sticky.vue +190 -0
  279. package/components/oxy-sticky/types.ts +13 -0
  280. package/components/oxy-sticky-box/index.scss +6 -0
  281. package/components/oxy-sticky-box/oxy-sticky-box.vue +155 -0
  282. package/components/oxy-sticky-box/types.ts +11 -0
  283. package/components/oxy-swipe-action/index.scss +22 -0
  284. package/components/oxy-swipe-action/oxy-swipe-action.vue +294 -0
  285. package/components/oxy-swipe-action/types.ts +40 -0
  286. package/components/oxy-swiper/index.scss +53 -0
  287. package/components/oxy-swiper/oxy-swiper.vue +318 -0
  288. package/components/oxy-swiper/types.ts +264 -0
  289. package/components/oxy-swiper-nav/index.scss +159 -0
  290. package/components/oxy-swiper-nav/oxy-swiper-nav.vue +37 -0
  291. package/components/oxy-swiper-nav/types.ts +42 -0
  292. package/components/oxy-switch/index.scss +58 -0
  293. package/components/oxy-switch/oxy-switch.vue +83 -0
  294. package/components/oxy-switch/types.ts +58 -0
  295. package/components/oxy-tab/index.scss +16 -0
  296. package/components/oxy-tab/oxy-tab.vue +88 -0
  297. package/components/oxy-tab/types.ts +30 -0
  298. package/components/oxy-tabbar/index.scss +62 -0
  299. package/components/oxy-tabbar/oxy-tabbar.vue +91 -0
  300. package/components/oxy-tabbar/types.ts +73 -0
  301. package/components/oxy-tabbar-item/index.scss +55 -0
  302. package/components/oxy-tabbar-item/oxy-tabbar-item.vue +99 -0
  303. package/components/oxy-tabbar-item/types.ts +51 -0
  304. package/components/oxy-table/index.scss +163 -0
  305. package/components/oxy-table/oxy-table.vue +283 -0
  306. package/components/oxy-table/types.ts +58 -0
  307. package/components/oxy-table-col/index.scss +46 -0
  308. package/components/oxy-table-col/oxy-table-col.vue +149 -0
  309. package/components/oxy-table-col/types.ts +54 -0
  310. package/components/oxy-tabs/index.scss +299 -0
  311. package/components/oxy-tabs/oxy-tabs.vue +443 -0
  312. package/components/oxy-tabs/types.ts +107 -0
  313. package/components/oxy-tag/index.scss +115 -0
  314. package/components/oxy-tag/oxy-tag.vue +148 -0
  315. package/components/oxy-tag/types.ts +81 -0
  316. package/components/oxy-text/index.scss +37 -0
  317. package/components/oxy-text/oxy-text.vue +139 -0
  318. package/components/oxy-text/types.ts +98 -0
  319. package/components/oxy-textarea/index.scss +340 -0
  320. package/components/oxy-textarea/oxy-textarea.vue +296 -0
  321. package/components/oxy-textarea/placeholder.scss +20 -0
  322. package/components/oxy-textarea/types.ts +288 -0
  323. package/components/oxy-toast/index.scss +75 -0
  324. package/components/oxy-toast/index.ts +92 -0
  325. package/components/oxy-toast/oxy-toast.vue +198 -0
  326. package/components/oxy-toast/types.ts +181 -0
  327. package/components/oxy-tooltip/index.scss +66 -0
  328. package/components/oxy-tooltip/oxy-tooltip.vue +141 -0
  329. package/components/oxy-tooltip/types.ts +107 -0
  330. package/components/oxy-transition/index.scss +95 -0
  331. package/components/oxy-transition/oxy-transition.vue +232 -0
  332. package/components/oxy-transition/types.ts +98 -0
  333. package/components/oxy-upload/index.scss +175 -0
  334. package/components/oxy-upload/oxy-upload.vue +673 -0
  335. package/components/oxy-upload/types.ts +391 -0
  336. package/components/oxy-video-preview/index.scss +34 -0
  337. package/components/oxy-video-preview/oxy-video-preview.vue +72 -0
  338. package/components/oxy-video-preview/types.ts +23 -0
  339. package/components/oxy-watermark/index.scss +18 -0
  340. package/components/oxy-watermark/oxy-watermark.vue +486 -0
  341. package/components/oxy-watermark/types.ts +76 -0
  342. package/dayjs/constant.js +26 -0
  343. package/dayjs/index.d.ts +430 -0
  344. package/dayjs/index.js +542 -0
  345. package/dayjs/locale/en.js +13 -0
  346. package/dayjs/utils.js +59 -0
  347. package/global.d.ts +101 -0
  348. package/index.ts +12 -0
  349. package/locale/index.ts +32 -0
  350. package/locale/lang/ar-SA.ts +133 -0
  351. package/locale/lang/en-US.ts +133 -0
  352. package/locale/lang/zh-CN.ts +137 -0
  353. package/package.json +1 -0
  354. package/tags.json +1 -0
  355. package/web-types.json +1 -0
@@ -0,0 +1,71 @@
1
+ import type { ComponentPublicInstance, ExtractPropTypes, PropType } from 'vue'
2
+ import { baseProps, makeBooleanProp, makeRequiredProp, makeStringProp } from '../common/props'
3
+
4
+ export type SegmentedType = 'large' | 'middle' | 'small'
5
+
6
+ export interface SegmentedOption {
7
+ value: string | number // 选中值
8
+ disabled?: boolean // 是否禁用
9
+ payload?: any // 更多数据
10
+ }
11
+
12
+ export const segmentedProps = {
13
+ ...baseProps,
14
+
15
+ /**
16
+ * 当前选中的值
17
+ * 类型: string | number
18
+ * 最低版本: 0.1.23
19
+ */
20
+ value: makeRequiredProp([String, Number]),
21
+
22
+ /**
23
+ * 是否禁用分段器
24
+ * 类型: boolean
25
+ * 默认值: false
26
+ * 最低版本: 0.1.23
27
+ */
28
+ disabled: makeBooleanProp(false),
29
+
30
+ /**
31
+ * 控件尺寸
32
+ * 类型: string
33
+ * 可选值: 'large' | 'middle' | 'small'
34
+ * 默认值: 'middle'
35
+ * 最低版本: 0.1.23
36
+ */
37
+ size: makeStringProp<SegmentedType>('middle'),
38
+
39
+ /**
40
+ * 数据集合
41
+ * 类型: string[] | number[] | SegmentedOption[]
42
+ * 必需: 是
43
+ * 默认值: []
44
+ * 最低版本: 0.1.23
45
+ */
46
+ options: {
47
+ type: Array as PropType<string[] | number[] | SegmentedOption[]>,
48
+ required: true,
49
+ default: () => []
50
+ },
51
+
52
+ /**
53
+ * 切换选项时是否振动
54
+ * 类型: boolean
55
+ * 默认值: false
56
+ * 最低版本: 0.1.23
57
+ */
58
+ vibrateShort: makeBooleanProp(false)
59
+ }
60
+
61
+ export type SegmentedExpose = {
62
+ /**
63
+ * 更新滑块偏移量
64
+ * @param animation 是否开启动画,默认开启
65
+ */
66
+ updateActiveStyle: (animation?: boolean) => void
67
+ }
68
+
69
+ export type SegmentedProps = ExtractPropTypes<typeof segmentedProps>
70
+
71
+ export type SegmentedInstance = ComponentPublicInstance<SegmentedProps, SegmentedExpose>
@@ -0,0 +1,102 @@
1
+ @import '../common/abstracts/variable';
2
+ @import '../common/abstracts/mixin';
3
+
4
+ .oxy-theme-dark {
5
+ @include b(select-picker) {
6
+ :deep(.oxy-select-picker__arrow),
7
+ :deep(.oxy-select-picker__close),
8
+ :deep(.oxy-select-picker__clear) {
9
+ color: $-dark-color;
10
+ }
11
+
12
+ :deep(.oxy-select-picker__cell--placeholder) {
13
+ .oxy-cell__value {
14
+ color: $-dark-color-gray;
15
+ }
16
+ }
17
+ }
18
+ }
19
+
20
+ @include b(select-picker) {
21
+ @include edeep(cell) {
22
+ @include when(disabled) {
23
+ .oxy-cell__value {
24
+ color: $-input-disabled-color;
25
+ cursor: not-allowed;
26
+ }
27
+ }
28
+ @include when(error) {
29
+ .oxy-cell__value {
30
+ color: $-input-error-color;
31
+ }
32
+ .oxy-select-picker__arrow {
33
+ color: $-input-error-color;
34
+ }
35
+ }
36
+
37
+ @include m(placeholder) {
38
+ .oxy-cell__value {
39
+ color: $-input-placeholder-color;
40
+ }
41
+ }
42
+
43
+ @include when(large) {
44
+ .oxy-select-picker__arrow,
45
+ .oxy-select-picker__clear {
46
+ font-size: $-cell-icon-size-large;
47
+ }
48
+ }
49
+ }
50
+
51
+ @include edeep(arrow, clear) {
52
+ display: block;
53
+ font-size: $-cell-icon-size;
54
+ color: $-cell-arrow-color;
55
+ line-height: $-cell-line-height;
56
+ }
57
+
58
+ @include edeep(clear) {
59
+ color: $-cell-clear-color;
60
+ }
61
+
62
+ @include e(loading) {
63
+ position: absolute;
64
+ display: flex;
65
+ top: 0;
66
+ right: 0;
67
+ bottom: 0;
68
+ left: 0;
69
+ align-items: center;
70
+ justify-content: center;
71
+ z-index: 3;
72
+ background: $-picker-loading-bg;
73
+ }
74
+
75
+ @include edeep(header) {
76
+ height: 72px;
77
+ line-height: 72px;
78
+ }
79
+ @include e(wrapper) {
80
+ padding: 0 10px;
81
+ position: relative;
82
+ max-height: 356px;
83
+ box-sizing: border-box;
84
+ overflow: auto;
85
+
86
+ @include when(filterable) {
87
+ height: 314px;
88
+ max-height: 314px;
89
+ }
90
+
91
+ @include when(loading) {
92
+ overflow: hidden;
93
+ }
94
+ }
95
+ @include e(text-active) {
96
+ color: $-color-theme;
97
+ }
98
+
99
+ @include e(footer) {
100
+ padding: 24px 15px;
101
+ }
102
+ }
@@ -0,0 +1,432 @@
1
+ <template>
2
+ <view :class="`oxy-select-picker ${customClass}`" :style="customStyle">
3
+ <oxy-cell
4
+ v-if="!$slots.default"
5
+ :title="label"
6
+ :value="showValue || placeholder || translate('placeholder')"
7
+ :required="required"
8
+ :size="size"
9
+ :title-width="labelWidth"
10
+ :prop="prop"
11
+ :rules="rules"
12
+ :clickable="!disabled && !readonly"
13
+ :value-align="alignRight ? 'right' : 'left'"
14
+ :center="center"
15
+ :custom-class="cellClass"
16
+ :custom-style="customStyle"
17
+ :custom-title-class="customLabelClass"
18
+ :custom-value-class="customValueClass"
19
+ :ellipsis="ellipsis"
20
+ :use-title-slot="!!$slots.label"
21
+ :marker-side="markerSide"
22
+ @click="open"
23
+ >
24
+ <template v-if="$slots.label" #title>
25
+ <slot name="label"></slot>
26
+ </template>
27
+ <template #right-icon>
28
+ <oxy-icon v-if="showArrow" custom-class="oxy-select-picker__arrow" name="arrow-right" />
29
+ <view v-else-if="showClear" @click.stop="handleClear">
30
+ <oxy-icon custom-class="oxy-select-picker__clear" name="error-fill" />
31
+ </view>
32
+ </template>
33
+ </oxy-cell>
34
+ <view v-else @click="open">
35
+ <slot></slot>
36
+ </view>
37
+ <oxy-action-sheet
38
+ v-model="pickerShow"
39
+ :duration="250"
40
+ :title="title || translate('title')"
41
+ :close-on-click-modal="closeOnClickModal"
42
+ :z-index="zIndex"
43
+ :safe-area-inset-bottom="safeAreaInsetBottom"
44
+ :root-portal="rootPortal"
45
+ @close="close"
46
+ @opened="scrollIntoView ? setScrollIntoView() : ''"
47
+ custom-header-class="oxy-select-picker__header"
48
+ >
49
+ <oxy-search
50
+ v-if="filterable"
51
+ v-model="filterVal"
52
+ :placeholder="filterPlaceholder || translate('filterPlaceholder')"
53
+ hide-cancel
54
+ placeholder-left
55
+ @change="handleFilterChange"
56
+ />
57
+ <scroll-view
58
+ :class="`oxy-select-picker__wrapper ${filterable ? 'is-filterable' : ''} ${loading ? 'is-loading' : ''} ${customContentClass}`"
59
+ :scroll-y="!loading"
60
+ :scroll-top="scrollTop"
61
+ :scroll-with-animation="true"
62
+ >
63
+ <!-- 多选 -->
64
+ <view v-if="type === 'checkbox' && isArray(selectList)" id="oxy-checkbox-group">
65
+ <oxy-checkbox-group v-model="selectList" cell :size="selectSize" :checked-color="checkedColor" :min="min" :max="max" @change="handleChange">
66
+ <view v-for="item in filterColumns" :key="item[valueKey]" :id="'check' + item[valueKey]">
67
+ <oxy-checkbox :modelValue="item[valueKey]" :disabled="item.disabled">
68
+ <block v-if="filterable && filterVal">
69
+ <block v-for="text in item[labelKey]" :key="text.label">
70
+ <text v-if="text.type === 'active'" class="oxy-select-picker__text-active">{{ text.label }}</text>
71
+ <block v-else>{{ text.label }}</block>
72
+ </block>
73
+ </block>
74
+ <block v-else>
75
+ {{ item[labelKey] }}
76
+ </block>
77
+ </oxy-checkbox>
78
+ </view>
79
+ </oxy-checkbox-group>
80
+ </view>
81
+ <!-- 单选 -->
82
+ <view v-if="type === 'radio' && !isArray(selectList)" id="oxy-radio-group">
83
+ <oxy-radio-group v-model="selectList" cell :size="selectSize" :checked-color="checkedColor" @change="handleChange">
84
+ <view v-for="(item, index) in filterColumns" :key="index" :id="'radio' + item[valueKey]">
85
+ <oxy-radio :value="item[valueKey]" :disabled="item.disabled">
86
+ <block v-if="filterable && filterVal">
87
+ <block v-for="text in item[labelKey]" :key="text.label">
88
+ <text :class="`${text.type === 'active' ? 'oxy-select-picker__text-active' : ''}`">{{ text.label }}</text>
89
+ </block>
90
+ </block>
91
+ <block v-else>
92
+ {{ item[labelKey] }}
93
+ </block>
94
+ </oxy-radio>
95
+ </view>
96
+ </oxy-radio-group>
97
+ </view>
98
+ <view v-if="loading" class="oxy-select-picker__loading" @touchmove="noop">
99
+ <oxy-loading :color="loadingColor" />
100
+ </view>
101
+ </scroll-view>
102
+ <!-- 确认按钮 -->
103
+ <view v-if="showConfirm" class="oxy-select-picker__footer">
104
+ <oxy-button block size="large" @click="onConfirm" :disabled="loading">{{ confirmButtonText || translate('confirm') }}</oxy-button>
105
+ </view>
106
+ </oxy-action-sheet>
107
+ </view>
108
+ </template>
109
+ <script lang="ts">
110
+ export default {
111
+ name: 'oxy-select-picker',
112
+ options: {
113
+ addGlobalClass: true,
114
+ virtualHost: true,
115
+ styleIsolation: 'shared'
116
+ }
117
+ }
118
+ </script>
119
+
120
+ <script lang="ts" setup>
121
+ import OxyActionSheet from '../oxy-action-sheet/oxy-action-sheet.vue'
122
+ import OxyCheckbox from '../oxy-checkbox/oxy-checkbox.vue'
123
+ import OxyCheckboxGroup from '../oxy-checkbox-group/oxy-checkbox-group.vue'
124
+ import OxyRadio from '../oxy-radio/oxy-radio.vue'
125
+ import OxyRadioGroup from '../oxy-radio-group/oxy-radio-group.vue'
126
+ import OxyButton from '../oxy-button/oxy-button.vue'
127
+ import OxyLoading from '../oxy-loading/oxy-loading.vue'
128
+ import OxyCell from '../oxy-cell/oxy-cell.vue'
129
+
130
+ import { getCurrentInstance, onBeforeMount, ref, watch, nextTick, computed } from 'vue'
131
+ import { getRect, isArray, isDef, isFunction, pause } from '../common/util'
132
+ import { useTranslate } from '../composables/useTranslate'
133
+ import { selectPickerProps, type SelectPickerExpose } from './types'
134
+
135
+ const { translate } = useTranslate('select-picker')
136
+
137
+ const props = defineProps(selectPickerProps)
138
+ const emit = defineEmits(['change', 'cancel', 'confirm', 'clear', 'update:modelValue', 'open', 'close'])
139
+
140
+ const pickerShow = ref<boolean>(false)
141
+ const selectList = ref<Array<number | boolean | string> | number | boolean | string>([])
142
+ const isConfirm = ref<boolean>(false)
143
+ const lastSelectList = ref<Array<number | boolean | string> | number | boolean | string>([])
144
+ const filterVal = ref<string>('')
145
+ const filterColumns = ref<Array<Record<string, any>>>([])
146
+ const scrollTop = ref<number>(0) // 滚动位置
147
+
148
+ const showValue = computed(() => {
149
+ const value = valueFormat(props.modelValue)
150
+ let showValueTemp: string = ''
151
+
152
+ if (props.displayFormat) {
153
+ showValueTemp = props.displayFormat(value, props.columns)
154
+ } else {
155
+ const { type, labelKey } = props
156
+ if (type === 'checkbox') {
157
+ const selectedItems = (isArray(value) ? value : []).map((item) => {
158
+ return getSelectedItem(item)
159
+ })
160
+ showValueTemp = selectedItems
161
+ .map((item) => {
162
+ return item[labelKey]
163
+ })
164
+ .join(', ')
165
+ } else if (type === 'radio') {
166
+ const selectedItem = getSelectedItem(value as string | number | boolean)
167
+ showValueTemp = selectedItem[labelKey]
168
+ } else {
169
+ showValueTemp = value as string
170
+ }
171
+ }
172
+ return showValueTemp
173
+ })
174
+
175
+ const cellClass = computed(() => {
176
+ const classes = ['oxy-select-picker__cell']
177
+ if (props.disabled) classes.push('is-disabled')
178
+ if (props.readonly) classes.push('is-readonly')
179
+ if (props.error) classes.push('is-error')
180
+ if (!showValue.value) classes.push('oxy-select-picker__cell--placeholder')
181
+ return classes.join(' ')
182
+ })
183
+
184
+ watch(
185
+ () => props.modelValue,
186
+ (newValue) => {
187
+ if (newValue === selectList.value) return
188
+ selectList.value = valueFormat(newValue)
189
+ lastSelectList.value = valueFormat(newValue)
190
+ },
191
+ {
192
+ deep: true,
193
+ immediate: true
194
+ }
195
+ )
196
+
197
+ watch(
198
+ () => props.columns,
199
+ (newValue) => {
200
+ if (props.filterable && filterVal.value) {
201
+ formatFilterColumns(newValue, filterVal.value)
202
+ } else {
203
+ filterColumns.value = newValue
204
+ }
205
+ },
206
+ {
207
+ deep: true,
208
+ immediate: true
209
+ }
210
+ )
211
+
212
+ watch(
213
+ () => props.displayFormat,
214
+ (fn) => {
215
+ if (fn && !isFunction(fn)) {
216
+ console.error('The type of displayFormat must be Function')
217
+ }
218
+ },
219
+ {
220
+ deep: true,
221
+ immediate: true
222
+ }
223
+ )
224
+
225
+ watch(
226
+ () => props.beforeConfirm,
227
+ (fn) => {
228
+ if (fn && !isFunction(fn)) {
229
+ console.error('The type of beforeConfirm must be Function')
230
+ }
231
+ },
232
+ {
233
+ deep: true,
234
+ immediate: true
235
+ }
236
+ )
237
+
238
+ onBeforeMount(() => {
239
+ selectList.value = valueFormat(props.modelValue)
240
+ filterColumns.value = props.columns
241
+ })
242
+
243
+ const { proxy } = getCurrentInstance() as any
244
+
245
+ async function setScrollIntoView() {
246
+ let wraperSelector: string = ''
247
+ let selectorPromise: Promise<UniApp.NodeInfo>[] = []
248
+ if (isDef(selectList.value) && selectList.value !== '' && !isArray(selectList.value)) {
249
+ wraperSelector = '#oxy-radio-group'
250
+ selectorPromise = [getRect(`#radio${selectList.value}`, false, proxy)]
251
+ } else if (isArray(selectList.value) && selectList.value.length > 0) {
252
+ selectList.value.forEach((value) => {
253
+ selectorPromise.push(getRect(`#check${value}`, false, proxy))
254
+ })
255
+ wraperSelector = '#oxy-checkbox-group'
256
+ }
257
+ if (wraperSelector) {
258
+ await pause(2000 / 30)
259
+ Promise.all([getRect('.oxy-select-picker__wrapper', false, proxy), getRect(wraperSelector, false, proxy), ...selectorPromise]).then((res) => {
260
+ if (isDef(res) && isArray(res)) {
261
+ const scrollView = res[0]
262
+ const wraper = res[1]
263
+ const target = res.slice(2) || []
264
+ if (isDef(wraper) && isDef(scrollView)) {
265
+ const index = target.findIndex((item) => {
266
+ return item.bottom! > scrollView.top! && item.top! < scrollView.bottom!
267
+ })
268
+ if (index < 0) {
269
+ scrollTop.value = -1
270
+ nextTick(() => {
271
+ scrollTop.value = Math.max(0, target[0].top! - wraper.top! - scrollView.height! / 2)
272
+ })
273
+ }
274
+ }
275
+ }
276
+ })
277
+ }
278
+ }
279
+
280
+ function noop() {}
281
+
282
+ function getSelectedItem(value: string | number | boolean) {
283
+ const { valueKey, labelKey, columns } = props
284
+
285
+ const selecteds = columns.filter((item) => {
286
+ return item[valueKey] === value
287
+ })
288
+
289
+ if (selecteds.length > 0) {
290
+ return selecteds[0]
291
+ }
292
+
293
+ return {
294
+ [valueKey]: value,
295
+ [labelKey]: ''
296
+ }
297
+ }
298
+
299
+ function valueFormat(value: string | number | boolean | (string | number | boolean)[]) {
300
+ return props.type === 'checkbox' ? (isArray(value) ? value : []) : value
301
+ }
302
+
303
+ function handleChange({ value }: { value: string | number | boolean | (string | number | boolean)[] }) {
304
+ selectList.value = value
305
+ emit('change', { value })
306
+ if (props.type === 'radio' && !props.showConfirm) {
307
+ onConfirm()
308
+ }
309
+ }
310
+
311
+ function close() {
312
+ pickerShow.value = false
313
+ // 未确定选项时,数据还原复位
314
+ if (!isConfirm.value) {
315
+ selectList.value = valueFormat(lastSelectList.value)
316
+ }
317
+ emit('cancel')
318
+ emit('close')
319
+ }
320
+
321
+ function open() {
322
+ if (props.disabled || props.readonly) return
323
+ selectList.value = valueFormat(props.modelValue)
324
+ pickerShow.value = true
325
+ isConfirm.value = false
326
+ emit('open')
327
+ }
328
+
329
+ function onConfirm() {
330
+ if (props.loading) {
331
+ pickerShow.value = false
332
+ emit('confirm')
333
+ emit('close')
334
+ return
335
+ }
336
+ if (props.beforeConfirm) {
337
+ props.beforeConfirm(selectList.value, (isPass: boolean) => {
338
+ isPass && handleConfirm()
339
+ })
340
+ } else {
341
+ handleConfirm()
342
+ }
343
+ }
344
+
345
+ function handleConfirm() {
346
+ isConfirm.value = true
347
+ pickerShow.value = false
348
+ lastSelectList.value = valueFormat(selectList.value)
349
+ let selectedItems: Record<string, any> = {}
350
+ if (props.type === 'checkbox') {
351
+ selectedItems = (isArray(lastSelectList.value) ? lastSelectList.value : []).map((item) => {
352
+ return getSelectedItem(item)
353
+ })
354
+ } else {
355
+ selectedItems = getSelectedItem(lastSelectList.value as string | number | boolean)
356
+ }
357
+ emit('update:modelValue', lastSelectList.value)
358
+ emit('confirm', {
359
+ value: lastSelectList.value,
360
+ selectedItems
361
+ })
362
+ emit('close')
363
+ }
364
+
365
+ function getFilterText(label: string, filterVal: string) {
366
+ const reg = new RegExp(`(${filterVal})`, 'g')
367
+
368
+ return label.split(reg).map((text) => {
369
+ return {
370
+ type: text === filterVal ? 'active' : 'normal',
371
+ label: text
372
+ }
373
+ })
374
+ }
375
+
376
+ function handleFilterChange({ value }: { value: string }) {
377
+ if (value === '') {
378
+ filterColumns.value = []
379
+ filterVal.value = value
380
+ nextTick(() => {
381
+ filterColumns.value = props.columns
382
+ })
383
+ } else {
384
+ filterVal.value = value
385
+ formatFilterColumns(props.columns, value)
386
+ }
387
+ }
388
+
389
+ function formatFilterColumns(columns: Record<string, any>[], filterVal: string) {
390
+ const filterColumnsTemp = columns.filter((item) => {
391
+ return item[props.labelKey].indexOf(filterVal) > -1
392
+ })
393
+
394
+ const formatFilterColumns = filterColumnsTemp.map((item) => {
395
+ return {
396
+ ...item,
397
+ [props.labelKey]: getFilterText(item[props.labelKey], filterVal)
398
+ }
399
+ })
400
+ filterColumns.value = []
401
+ nextTick(() => {
402
+ filterColumns.value = formatFilterColumns
403
+ })
404
+ }
405
+
406
+ const showConfirm = computed(() => {
407
+ return (props.type === 'radio' && props.showConfirm) || props.type === 'checkbox'
408
+ })
409
+
410
+ // 是否展示清除按钮
411
+ const showClear = computed(() => {
412
+ return props.clearable && !props.disabled && !props.readonly && showValue.value.length
413
+ })
414
+
415
+ function handleClear() {
416
+ emit('update:modelValue', props.type === 'checkbox' ? [] : '')
417
+ emit('clear')
418
+ }
419
+
420
+ // 是否展示箭头
421
+ const showArrow = computed(() => {
422
+ return !props.disabled && !props.readonly && !showClear.value
423
+ })
424
+
425
+ defineExpose<SelectPickerExpose>({
426
+ close,
427
+ open
428
+ })
429
+ </script>
430
+ <style lang="scss" scoped>
431
+ @import './index.scss';
432
+ </style>