misp-ui-library-test 0.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 (373) hide show
  1. package/README.md +113 -0
  2. package/dist/theme-chalk/alert/index.scss +152 -0
  3. package/dist/theme-chalk/avatar/index.scss +51 -0
  4. package/dist/theme-chalk/backtop/index.scss +38 -0
  5. package/dist/theme-chalk/badge/index.scss +63 -0
  6. package/dist/theme-chalk/breadcrumb/index.scss +36 -0
  7. package/dist/theme-chalk/breadcrumb-item/index.scss +36 -0
  8. package/dist/theme-chalk/button/index.scss +157 -0
  9. package/dist/theme-chalk/card/index.scss +38 -0
  10. package/dist/theme-chalk/chart/index.scss +21 -0
  11. package/dist/theme-chalk/checkbox/index.scss +358 -0
  12. package/dist/theme-chalk/col/index.scss +131 -0
  13. package/dist/theme-chalk/container/index.scss +40 -0
  14. package/dist/theme-chalk/css/alert.css +484 -0
  15. package/dist/theme-chalk/css/avatar.css +409 -0
  16. package/dist/theme-chalk/css/backtop.css +401 -0
  17. package/dist/theme-chalk/css/badge.css +419 -0
  18. package/dist/theme-chalk/css/breadcrumb-item.css +395 -0
  19. package/dist/theme-chalk/css/breadcrumb.css +395 -0
  20. package/dist/theme-chalk/css/button.css +587 -0
  21. package/dist/theme-chalk/css/card.css +397 -0
  22. package/dist/theme-chalk/css/chart.css +386 -0
  23. package/dist/theme-chalk/css/checkbox.css +648 -0
  24. package/dist/theme-chalk/css/col.css +2111 -0
  25. package/dist/theme-chalk/css/container.css +404 -0
  26. package/dist/theme-chalk/css/dialog.css +505 -0
  27. package/dist/theme-chalk/css/divider.css +405 -0
  28. package/dist/theme-chalk/css/drawer.css +546 -0
  29. package/dist/theme-chalk/css/empty.css +394 -0
  30. package/dist/theme-chalk/css/form.css +561 -0
  31. package/dist/theme-chalk/css/icon.css +1534 -0
  32. package/dist/theme-chalk/css/image.css +400 -0
  33. package/dist/theme-chalk/css/input-number.css +424 -0
  34. package/dist/theme-chalk/css/input.css +721 -0
  35. package/dist/theme-chalk/css/link.css +424 -0
  36. package/dist/theme-chalk/css/loading.css +483 -0
  37. package/dist/theme-chalk/css/message-box.css +479 -0
  38. package/dist/theme-chalk/css/message.css +456 -0
  39. package/dist/theme-chalk/css/no-data.css +397 -0
  40. package/dist/theme-chalk/css/notification.css +431 -0
  41. package/dist/theme-chalk/css/page-header.css +396 -0
  42. package/dist/theme-chalk/css/pagination.css +565 -0
  43. package/dist/theme-chalk/css/popover.css +421 -0
  44. package/dist/theme-chalk/css/popper.css +454 -0
  45. package/dist/theme-chalk/css/progress.css +451 -0
  46. package/dist/theme-chalk/css/radio.css +626 -0
  47. package/dist/theme-chalk/css/rate.css +414 -0
  48. package/dist/theme-chalk/css/result.css +403 -0
  49. package/dist/theme-chalk/css/row.css +433 -0
  50. package/dist/theme-chalk/css/scrollbar.css +422 -0
  51. package/dist/theme-chalk/css/select.css +1897 -0
  52. package/dist/theme-chalk/css/skeleton-item.css +407 -0
  53. package/dist/theme-chalk/css/skeleton.css +390 -0
  54. package/dist/theme-chalk/css/slider.css +460 -0
  55. package/dist/theme-chalk/css/spinner.css +403 -0
  56. package/dist/theme-chalk/css/statistic.css +396 -0
  57. package/dist/theme-chalk/css/status-timeline-chart.css +388 -0
  58. package/dist/theme-chalk/css/step.css +496 -0
  59. package/dist/theme-chalk/css/steps.css +496 -0
  60. package/dist/theme-chalk/css/switch.css +507 -0
  61. package/dist/theme-chalk/css/tab-pane.css +457 -0
  62. package/dist/theme-chalk/css/table.css +461 -0
  63. package/dist/theme-chalk/css/tabs-navigation.css +925 -0
  64. package/dist/theme-chalk/css/tabs.css +457 -0
  65. package/dist/theme-chalk/css/tag.css +599 -0
  66. package/dist/theme-chalk/css/time-picker.css +683 -0
  67. package/dist/theme-chalk/css/timeline-item.css +459 -0
  68. package/dist/theme-chalk/css/timeline.css +459 -0
  69. package/dist/theme-chalk/css/tooltip.css +485 -0
  70. package/dist/theme-chalk/css/tree.css +473 -0
  71. package/dist/theme-chalk/css/upload.css +665 -0
  72. package/dist/theme-chalk/dialog/index.scss +168 -0
  73. package/dist/theme-chalk/divider/index.scss +46 -0
  74. package/dist/theme-chalk/drawer/index.scss +172 -0
  75. package/dist/theme-chalk/empty/index.scss +36 -0
  76. package/dist/theme-chalk/fonts/element-icons.ttf +0 -0
  77. package/dist/theme-chalk/fonts/element-icons.woff +0 -0
  78. package/dist/theme-chalk/form/index.scss +220 -0
  79. package/dist/theme-chalk/icon/index.scss +1171 -0
  80. package/dist/theme-chalk/image/index.scss +39 -0
  81. package/dist/theme-chalk/index.scss +127 -0
  82. package/dist/theme-chalk/input/index.scss +363 -0
  83. package/dist/theme-chalk/input-number/index.scss +71 -0
  84. package/dist/theme-chalk/link/index.scss +75 -0
  85. package/dist/theme-chalk/loading/index.scss +131 -0
  86. package/dist/theme-chalk/message/index.scss +100 -0
  87. package/dist/theme-chalk/message-box/index.scss +131 -0
  88. package/dist/theme-chalk/mixins.scss +203 -0
  89. package/dist/theme-chalk/no-data/index.scss +36 -0
  90. package/dist/theme-chalk/notification/index.scss +76 -0
  91. package/dist/theme-chalk/page-header/index.scss +36 -0
  92. package/dist/theme-chalk/pagination/index.scss +225 -0
  93. package/dist/theme-chalk/popover/index.scss +56 -0
  94. package/dist/theme-chalk/popper/index.scss +89 -0
  95. package/dist/theme-chalk/progress/index.scss +105 -0
  96. package/dist/theme-chalk/radio/index.scss +328 -0
  97. package/dist/theme-chalk/rate/index.scss +56 -0
  98. package/dist/theme-chalk/reset.scss +262 -0
  99. package/dist/theme-chalk/result/index.scss +46 -0
  100. package/dist/theme-chalk/row/index.scss +88 -0
  101. package/dist/theme-chalk/scrollbar/index.scss +67 -0
  102. package/dist/theme-chalk/select/index.scss +223 -0
  103. package/dist/theme-chalk/skeleton/index.scss +30 -0
  104. package/dist/theme-chalk/skeleton-item/index.scss +49 -0
  105. package/dist/theme-chalk/slider/index.scss +113 -0
  106. package/dist/theme-chalk/spinner/index.scss +40 -0
  107. package/dist/theme-chalk/statistic/index.scss +38 -0
  108. package/dist/theme-chalk/status-timeline-chart/index.scss +23 -0
  109. package/dist/theme-chalk/step/index.scss +160 -0
  110. package/dist/theme-chalk/steps/index.scss +160 -0
  111. package/dist/theme-chalk/switch/index.scss +153 -0
  112. package/dist/theme-chalk/tab-pane/index.scss +112 -0
  113. package/dist/theme-chalk/table/index.scss +110 -0
  114. package/dist/theme-chalk/tabs/index.scss +112 -0
  115. package/dist/theme-chalk/tabs-navigation/index.scss +631 -0
  116. package/dist/theme-chalk/tag/index.scss +138 -0
  117. package/dist/theme-chalk/themes/blue.scss +76 -0
  118. package/dist/theme-chalk/themes/dark.scss +99 -0
  119. package/dist/theme-chalk/themes/index.scss +260 -0
  120. package/dist/theme-chalk/themes/light.scss +99 -0
  121. package/dist/theme-chalk/time-picker/index.scss +332 -0
  122. package/dist/theme-chalk/timeline/index.scss +119 -0
  123. package/dist/theme-chalk/timeline-item/index.scss +119 -0
  124. package/dist/theme-chalk/tooltip/index.scss +122 -0
  125. package/dist/theme-chalk/tree/index.scss +125 -0
  126. package/dist/theme-chalk/upload/index.scss +348 -0
  127. package/dist/theme-chalk/variables.scss +93 -0
  128. package/dist/vue2-ui-library.cjs.temp.js.map +1 -0
  129. package/dist/vue2-ui-library.common.js +28 -0
  130. package/dist/vue2-ui-library.common.js.map +1 -0
  131. package/dist/vue2-ui-library.esm.js +29 -0
  132. package/dist/vue2-ui-library.umd.js +27 -0
  133. package/package.json +161 -0
  134. package/src/directives/clickoutside/index.js +111 -0
  135. package/src/directives/init/index.js +50 -0
  136. package/src/directives/resize/index.js +69 -0
  137. package/src/index.js +174 -0
  138. package/src/mixins/emitter.js +47 -0
  139. package/src/mixins/focus.js +42 -0
  140. package/src/mixins/locale.js +24 -0
  141. package/src/mixins/migrating.js +46 -0
  142. package/src/packages/alert/index.js +12 -0
  143. package/src/packages/alert/src/main.vue +98 -0
  144. package/src/packages/aside/index.js +12 -0
  145. package/src/packages/aside/src/main.vue +20 -0
  146. package/src/packages/auto-grid-layout/index.js +18 -0
  147. package/src/packages/auto-grid-layout/prop.js +92 -0
  148. package/src/packages/auto-grid-layout/src/components/GridItem.vue +759 -0
  149. package/src/packages/auto-grid-layout/src/components/GridLayout.vue +367 -0
  150. package/src/packages/auto-grid-layout/src/main.vue +287 -0
  151. package/src/packages/auto-grid-layout/src/utils/DOM.js +46 -0
  152. package/src/packages/auto-grid-layout/src/utils/interact.js +333 -0
  153. package/src/packages/auto-grid-layout/src/utils/responsiveUtils.js +75 -0
  154. package/src/packages/auto-grid-layout/src/utils/utils.js +339 -0
  155. package/src/packages/autocomplete/index.js +12 -0
  156. package/src/packages/autocomplete/src/main.vue +170 -0
  157. package/src/packages/avatar/index.js +12 -0
  158. package/src/packages/avatar/src/main.vue +87 -0
  159. package/src/packages/backtop/index.js +12 -0
  160. package/src/packages/backtop/src/main.vue +120 -0
  161. package/src/packages/badge/index.js +12 -0
  162. package/src/packages/badge/src/main.vue +53 -0
  163. package/src/packages/breadcrumb/index.js +12 -0
  164. package/src/packages/breadcrumb/src/main.vue +34 -0
  165. package/src/packages/breadcrumb-item/index.js +12 -0
  166. package/src/packages/breadcrumb-item/src/main.vue +41 -0
  167. package/src/packages/button/index.js +13 -0
  168. package/src/packages/button/src/main.vue +106 -0
  169. package/src/packages/calendar/index.js +12 -0
  170. package/src/packages/calendar/src/main.vue +173 -0
  171. package/src/packages/card/index.js +12 -0
  172. package/src/packages/card/src/main.vue +26 -0
  173. package/src/packages/carousel/index.js +12 -0
  174. package/src/packages/carousel/src/main.vue +186 -0
  175. package/src/packages/carousel-item/index.js +12 -0
  176. package/src/packages/carousel-item/src/main.vue +34 -0
  177. package/src/packages/cascader/index.js +12 -0
  178. package/src/packages/cascader/src/main.vue +232 -0
  179. package/src/packages/chart/index.js +7 -0
  180. package/src/packages/chart/src/axis-chart.js +700 -0
  181. package/src/packages/chart/src/main.vue +828 -0
  182. package/src/packages/chart/src/utils.js +21 -0
  183. package/src/packages/checkbox/index.js +44 -0
  184. package/src/packages/checkbox/src/main.vue +312 -0
  185. package/src/packages/col/index.js +12 -0
  186. package/src/packages/col/src/main.vue +85 -0
  187. package/src/packages/collapse/index.js +12 -0
  188. package/src/packages/collapse/src/main.vue +69 -0
  189. package/src/packages/collapse-item/index.js +12 -0
  190. package/src/packages/collapse-item/src/main.vue +75 -0
  191. package/src/packages/color-picker/index.js +12 -0
  192. package/src/packages/color-picker/src/main.vue +206 -0
  193. package/src/packages/container/index.js +12 -0
  194. package/src/packages/container/src/main.vue +33 -0
  195. package/src/packages/date-picker/index.js +12 -0
  196. package/src/packages/date-picker/src/main.vue +246 -0
  197. package/src/packages/descriptions/index.js +12 -0
  198. package/src/packages/descriptions/src/main.vue +89 -0
  199. package/src/packages/descriptions-item/index.js +12 -0
  200. package/src/packages/descriptions-item/src/main.vue +26 -0
  201. package/src/packages/dialog/index.js +12 -0
  202. package/src/packages/dialog/src/main.vue +336 -0
  203. package/src/packages/divider/index.js +12 -0
  204. package/src/packages/divider/src/main.vue +37 -0
  205. package/src/packages/drawer/index.js +7 -0
  206. package/src/packages/drawer/src/main.vue +310 -0
  207. package/src/packages/dropdown/index.js +12 -0
  208. package/src/packages/dropdown/src/main.vue +82 -0
  209. package/src/packages/dropdown-menu-item/index.js +12 -0
  210. package/src/packages/dropdown-menu-item/src/main.vue +29 -0
  211. package/src/packages/empty/index.js +12 -0
  212. package/src/packages/empty/src/img-empty.vue +12 -0
  213. package/src/packages/empty/src/main.vue +49 -0
  214. package/src/packages/footer/index.js +12 -0
  215. package/src/packages/footer/src/main.vue +20 -0
  216. package/src/packages/form/index.js +13 -0
  217. package/src/packages/form/src/form-field.vue +790 -0
  218. package/src/packages/form/src/form-item.vue +464 -0
  219. package/src/packages/form/src/label-wrap.vue +127 -0
  220. package/src/packages/form/src/main.vue +442 -0
  221. package/src/packages/form-item/index.js +11 -0
  222. package/src/packages/header/index.js +12 -0
  223. package/src/packages/header/src/main.vue +20 -0
  224. package/src/packages/icon/index.js +12 -0
  225. package/src/packages/icon/src/main.vue +48 -0
  226. package/src/packages/image/index.js +12 -0
  227. package/src/packages/image/src/main.vue +224 -0
  228. package/src/packages/input/index.js +13 -0
  229. package/src/packages/input/src/calcTextareaHeight.js +123 -0
  230. package/src/packages/input/src/main.vue +510 -0
  231. package/src/packages/input-number/index.js +12 -0
  232. package/src/packages/input-number/src/main.vue +121 -0
  233. package/src/packages/link/index.js +12 -0
  234. package/src/packages/link/src/main.vue +53 -0
  235. package/src/packages/loading/index.js +17 -0
  236. package/src/packages/loading/src/directive.js +54 -0
  237. package/src/packages/loading/src/main.vue +38 -0
  238. package/src/packages/loading/src/service.js +63 -0
  239. package/src/packages/main/index.js +12 -0
  240. package/src/packages/main/src/main.vue +12 -0
  241. package/src/packages/menu/index.js +12 -0
  242. package/src/packages/menu/src/main.vue +117 -0
  243. package/src/packages/menu-item/index.js +12 -0
  244. package/src/packages/menu-item/src/main.vue +61 -0
  245. package/src/packages/message/index.js +95 -0
  246. package/src/packages/message/src/main.vue +131 -0
  247. package/src/packages/message-box/index.js +75 -0
  248. package/src/packages/message-box/src/main.vue +207 -0
  249. package/src/packages/no-data/index.js +8 -0
  250. package/src/packages/no-data/src/main.vue +23 -0
  251. package/src/packages/notification/index.js +72 -0
  252. package/src/packages/notification/src/main.vue +139 -0
  253. package/src/packages/option/index.js +13 -0
  254. package/src/packages/page-header/index.js +12 -0
  255. package/src/packages/page-header/src/main.vue +27 -0
  256. package/src/packages/pagination/index.js +12 -0
  257. package/src/packages/pagination/src/main.vue +255 -0
  258. package/src/packages/popconfirm/index.js +12 -0
  259. package/src/packages/popconfirm/src/main.vue +89 -0
  260. package/src/packages/popover/index.js +12 -0
  261. package/src/packages/popover/src/main.vue +452 -0
  262. package/src/packages/progress/index.js +12 -0
  263. package/src/packages/progress/src/main.vue +236 -0
  264. package/src/packages/radio/index.js +44 -0
  265. package/src/packages/radio/src/main.vue +291 -0
  266. package/src/packages/rate/index.js +12 -0
  267. package/src/packages/rate/src/main.vue +129 -0
  268. package/src/packages/result/index.js +12 -0
  269. package/src/packages/result/src/main.vue +52 -0
  270. package/src/packages/row/index.js +12 -0
  271. package/src/packages/row/src/main.vue +57 -0
  272. package/src/packages/scrollbar/index.js +12 -0
  273. package/src/packages/scrollbar/src/bar.vue +116 -0
  274. package/src/packages/scrollbar/src/main.vue +124 -0
  275. package/src/packages/select/index.js +15 -0
  276. package/src/packages/select/src/clickoutside.js +20 -0
  277. package/src/packages/select/src/main.vue +1055 -0
  278. package/src/packages/select/src/navigation-mixin.js +49 -0
  279. package/src/packages/select/src/option.vue +249 -0
  280. package/src/packages/select/src/select-dropdown.vue +95 -0
  281. package/src/packages/select/src/utils.js +5 -0
  282. package/src/packages/skeleton/index.js +12 -0
  283. package/src/packages/skeleton/src/main.vue +76 -0
  284. package/src/packages/skeleton-item/index.js +12 -0
  285. package/src/packages/skeleton-item/src/img-placeholder.vue +13 -0
  286. package/src/packages/skeleton-item/src/main.vue +22 -0
  287. package/src/packages/slider/index.js +12 -0
  288. package/src/packages/slider/src/main.vue +176 -0
  289. package/src/packages/spinner/index.js +12 -0
  290. package/src/packages/spinner/src/main.vue +27 -0
  291. package/src/packages/statistic/index.js +12 -0
  292. package/src/packages/statistic/src/main.vue +100 -0
  293. package/src/packages/status-timeline-chart/index.js +7 -0
  294. package/src/packages/status-timeline-chart/src/constants.js +20 -0
  295. package/src/packages/status-timeline-chart/src/main.vue +499 -0
  296. package/src/packages/status-timeline-chart/src/option-builder.js +475 -0
  297. package/src/packages/step/index.js +12 -0
  298. package/src/packages/step/src/main.vue +183 -0
  299. package/src/packages/steps/index.js +12 -0
  300. package/src/packages/steps/src/main.vue +57 -0
  301. package/src/packages/submenu/index.js +12 -0
  302. package/src/packages/submenu/src/main.vue +68 -0
  303. package/src/packages/switch/index.js +12 -0
  304. package/src/packages/switch/src/main.vue +166 -0
  305. package/src/packages/tab-pane/index.js +12 -0
  306. package/src/packages/tab-pane/src/main.vue +74 -0
  307. package/src/packages/table/index.js +8 -0
  308. package/src/packages/table/src/components/PagePagination.vue +82 -0
  309. package/src/packages/table/src/main.vue +153 -0
  310. package/src/packages/tabs/index.js +12 -0
  311. package/src/packages/tabs/src/main.vue +167 -0
  312. package/src/packages/tabs-navigation/index.js +7 -0
  313. package/src/packages/tabs-navigation/src/main.vue +462 -0
  314. package/src/packages/tag/index.js +12 -0
  315. package/src/packages/tag/src/main.vue +194 -0
  316. package/src/packages/time-picker/index.js +17 -0
  317. package/src/packages/time-picker/src/date-utils.js +455 -0
  318. package/src/packages/time-picker/src/main.vue +321 -0
  319. package/src/packages/time-picker/src/pane/date-range.vue +193 -0
  320. package/src/packages/time-picker/src/pane/date-time-range.vue +362 -0
  321. package/src/packages/time-picker/src/pane/date-time.vue +362 -0
  322. package/src/packages/time-picker/src/pane/date.vue +441 -0
  323. package/src/packages/time-picker/src/pane/time.vue +260 -0
  324. package/src/packages/time-picker/src/time-input.vue +203 -0
  325. package/src/packages/time-picker/src/time-range-input.vue +170 -0
  326. package/src/packages/timeline/index.js +12 -0
  327. package/src/packages/timeline/src/main.vue +24 -0
  328. package/src/packages/timeline-item/index.js +12 -0
  329. package/src/packages/timeline-item/src/main.vue +78 -0
  330. package/src/packages/tooltip/index.js +12 -0
  331. package/src/packages/tooltip/src/main.js +367 -0
  332. package/src/packages/transfer/index.js +8 -0
  333. package/src/packages/transfer/src/main.vue +229 -0
  334. package/src/packages/transfer/src/transfer-panel.vue +245 -0
  335. package/src/packages/transitions/collapse-transition.js +75 -0
  336. package/src/packages/tree/index.js +12 -0
  337. package/src/packages/tree/src/main.vue +322 -0
  338. package/src/packages/tree/src/model/node.js +348 -0
  339. package/src/packages/tree/src/model/tree-store.js +354 -0
  340. package/src/packages/tree/src/model/util.js +10 -0
  341. package/src/packages/tree/src/tree-node.vue +262 -0
  342. package/src/packages/upload/index.js +9 -0
  343. package/src/packages/upload/src/main.vue +415 -0
  344. package/src/playground/mixins/element.js +98 -0
  345. package/src/playground/types/element.js +197 -0
  346. package/src/playground/types/layout.js +80 -0
  347. package/src/plugins/i18n.js +125 -0
  348. package/src/styles/fonts/element-icons.ttf +0 -0
  349. package/src/styles/fonts/element-icons.woff +0 -0
  350. package/src/styles/index.scss +138 -0
  351. package/src/styles/reset.scss +257 -0
  352. package/src/styles/themes/blue.scss +75 -0
  353. package/src/styles/themes/dark.scss +98 -0
  354. package/src/styles/themes/index.scss +34 -0
  355. package/src/styles/themes/light.scss +98 -0
  356. package/src/styles/themes/variables.scss +233 -0
  357. package/src/styles/variables.scss +146 -0
  358. package/src/utils/async-validator/index.js +659 -0
  359. package/src/utils/browser/index.js +39 -0
  360. package/src/utils/color.js +76 -0
  361. package/src/utils/dom/index.js +421 -0
  362. package/src/utils/dom/scrollbar-width.js +49 -0
  363. package/src/utils/draggable/core.js +379 -0
  364. package/src/utils/draggable/draggable.js +478 -0
  365. package/src/utils/draggable/index.js +61 -0
  366. package/src/utils/draggable/sortable.js +751 -0
  367. package/src/utils/lodash/index.js +2395 -0
  368. package/src/utils/moment/index.js +909 -0
  369. package/src/utils/playground/index.js +37 -0
  370. package/src/utils/popper/index.js +308 -0
  371. package/src/utils/popper/popper.js +1132 -0
  372. package/src/utils/popper/popup-manager.js +288 -0
  373. package/src/utils/popper/popup.js +344 -0
@@ -0,0 +1,475 @@
1
+ /**
2
+ * ECharts 状态时序图(甘特条)配置构建
3
+ */
4
+ import { merge } from '../../../utils/lodash'
5
+ import { DEFAULT_STATUS_COLOR_PALETTE } from './constants'
6
+
7
+ /**
8
+ * @param {string|number} rootDateTime 根开始时间,如 "2026-04-17 00:00:00"
9
+ * @param {string} timePart 片段开始/结束,可为 "HH:mm:ss" 或完整日期时间
10
+ * @returns {number} 毫秒时间戳
11
+ */
12
+ export function toTimestamp(rootDateTime, timePart) {
13
+ if (timePart == null || timePart === '') return NaN
14
+ const t = String(timePart).trim()
15
+ if (Number.isFinite(Number(t)) && String(t) === String(Number(t))) {
16
+ return Number(t)
17
+ }
18
+ if (t.includes('T') || (t.includes('-') && t.split('-').length >= 3 && t.length >= 10)) {
19
+ const ms = new Date(t.replace(/-/g, '/')).getTime()
20
+ return ms
21
+ }
22
+ const datePart = String(rootDateTime || '').split(/\s+/)[0] || ''
23
+ if (!datePart) {
24
+ const ms = new Date(t.replace(/-/g, '/')).getTime()
25
+ return ms
26
+ }
27
+ return new Date(`${datePart} ${t}`.replace(/-/g, '/')).getTime()
28
+ }
29
+
30
+ /**
31
+ * @param {number} seconds
32
+ * @returns {string} 如 1小时0分0秒
33
+ */
34
+ export function formatDurationZh(seconds) {
35
+ const s = Math.max(0, Math.floor(Number(seconds) || 0))
36
+ const h = Math.floor(s / 3600)
37
+ const m = Math.floor((s % 3600) / 60)
38
+ const sec = s % 60
39
+ return `${h}小时${m}分${sec}秒`
40
+ }
41
+
42
+ function buildColorResolver(yAxis, colorMap, presetColors) {
43
+ const map =
44
+ colorMap && typeof colorMap === 'object' && !Array.isArray(colorMap) ? { ...colorMap } : {}
45
+ const palette =
46
+ Array.isArray(presetColors) && presetColors.length ? presetColors : DEFAULT_STATUS_COLOR_PALETTE
47
+
48
+ return statusCode => {
49
+ const key = String(statusCode)
50
+ if (map[key] != null && map[key] !== '') return map[key]
51
+ const idx = yAxis.findIndex(y => String(y.statusCode) === key)
52
+ if (idx >= 0) return palette[idx % palette.length]
53
+ let hash = 0
54
+ for (let i = 0; i < key.length; i++) hash = (hash + key.charCodeAt(i) * (i + 1)) % palette.length
55
+ return palette[Math.abs(hash) % palette.length]
56
+ }
57
+ }
58
+
59
+ function clipRange(start, end, winStart, winEnd) {
60
+ const s = Math.max(start, winStart)
61
+ const e = Math.min(end, winEnd)
62
+ if (e <= s) return null
63
+ return { start: s, end: e }
64
+ }
65
+
66
+ /**
67
+ * 将矩形裁剪到笛卡尔坐标系网格内,避免 DataZoom / 滚轮缩放后 custom 图形溢出画布
68
+ * @param {{ x: number, y: number, width: number, height: number }} shape
69
+ * @param {{ x: number, y: number, width: number, height: number }} gridRect coordSys
70
+ * @returns {{ x: number, y: number, width: number, height: number } | null}
71
+ */
72
+ function clipRectToGrid(shape, gridRect) {
73
+ if (
74
+ !gridRect ||
75
+ gridRect.width == null ||
76
+ gridRect.height == null ||
77
+ gridRect.x == null ||
78
+ gridRect.y == null
79
+ ) {
80
+ return shape
81
+ }
82
+ const x1 = Math.max(shape.x, gridRect.x)
83
+ const y1 = Math.max(shape.y, gridRect.y)
84
+ const x2 = Math.min(shape.x + shape.width, gridRect.x + gridRect.width)
85
+ const y2 = Math.min(shape.y + shape.height, gridRect.y + gridRect.height)
86
+ const w = x2 - x1
87
+ const h = y2 - y1
88
+ if (w < 0.5 || h < 0.5) return null
89
+ return { x: x1, y: y1, width: w, height: h }
90
+ }
91
+
92
+ function normalizeSummaries(payload, maxSegments) {
93
+ const { startTime, summaries = [] } = payload || {}
94
+ const list = (Array.isArray(summaries) ? summaries : [])
95
+ .map((s, i) => {
96
+ const st = toTimestamp(startTime, s.startTime)
97
+ const en = toTimestamp(startTime, s.endTime)
98
+ return {
99
+ ...s,
100
+ _i: i,
101
+ _start: st,
102
+ _end: en
103
+ }
104
+ })
105
+ .filter(s => Number.isFinite(s._start) && Number.isFinite(s._end) && s._end > s._start)
106
+ .sort((a, b) => a._start - b._start)
107
+
108
+ if (list.length > maxSegments) {
109
+ if (typeof console !== 'undefined' && console.warn) {
110
+ console.warn(
111
+ `[UiStatusTimelineChart] summaries 条数 ${list.length} 超过 maxSegments=${maxSegments},已截断以保障性能`
112
+ )
113
+ }
114
+ return list.slice(-maxSegments)
115
+ }
116
+ return list
117
+ }
118
+
119
+ function buildSummaryLaneItems(sorted, rangeStart, rangeEnd, yIndex, colorResolver, gapColor, fillGaps) {
120
+ const items = []
121
+ if (!fillGaps) {
122
+ for (const seg of sorted) {
123
+ const clipped = clipRange(seg._start, seg._end, rangeStart, rangeEnd)
124
+ if (!clipped) continue
125
+ items.push({
126
+ value: [yIndex, clipped.start, clipped.end],
127
+ itemStyle: { color: colorResolver(seg.statusCode) },
128
+ segmentRaw: seg,
129
+ isGap: false
130
+ })
131
+ }
132
+ return items
133
+ }
134
+
135
+ let cursor = rangeStart
136
+ for (const seg of sorted) {
137
+ const st = seg._start
138
+ const en = seg._end
139
+ if (st > cursor) {
140
+ const g0 = clipRange(cursor, st, rangeStart, rangeEnd)
141
+ if (g0) {
142
+ items.push({
143
+ value: [yIndex, g0.start, g0.end],
144
+ itemStyle: { color: gapColor },
145
+ isGap: true
146
+ })
147
+ }
148
+ }
149
+ const clipped = clipRange(st, en, rangeStart, rangeEnd)
150
+ if (clipped) {
151
+ items.push({
152
+ value: [yIndex, clipped.start, clipped.end],
153
+ itemStyle: { color: colorResolver(seg.statusCode) },
154
+ segmentRaw: seg,
155
+ isGap: false
156
+ })
157
+ }
158
+ cursor = Math.max(cursor, en)
159
+ }
160
+ if (cursor < rangeEnd) {
161
+ const g1 = clipRange(cursor, rangeEnd, rangeStart, rangeEnd)
162
+ if (g1) {
163
+ items.push({
164
+ value: [yIndex, g1.start, g1.end],
165
+ itemStyle: { color: gapColor },
166
+ isGap: true
167
+ })
168
+ }
169
+ }
170
+ return items
171
+ }
172
+
173
+ function buildStatusLaneItems(sorted, rangeStart, rangeEnd, yIndex, statusCode, colorResolver) {
174
+ const code = String(statusCode)
175
+ const items = []
176
+ for (const seg of sorted) {
177
+ if (String(seg.statusCode) !== code) continue
178
+ const clipped = clipRange(seg._start, seg._end, rangeStart, rangeEnd)
179
+ if (!clipped) continue
180
+ items.push({
181
+ value: [yIndex, clipped.start, clipped.end],
182
+ itemStyle: { color: colorResolver(seg.statusCode) },
183
+ segmentRaw: seg,
184
+ isGap: false
185
+ })
186
+ }
187
+ return items
188
+ }
189
+
190
+ function defaultDataZoom() {
191
+ return [
192
+ {
193
+ type: 'inside',
194
+ xAxisIndex: 0,
195
+ filterMode: 'weakFilter',
196
+ zoomOnMouseWheel: true,
197
+ moveOnMouseMove: true
198
+ },
199
+ {
200
+ type: 'slider',
201
+ xAxisIndex: 0,
202
+ height: 22,
203
+ bottom: 6,
204
+ filterMode: 'weakFilter'
205
+ }
206
+ ]
207
+ }
208
+
209
+ /**
210
+ * @param {object} params
211
+ * @returns {object} ECharts option
212
+ */
213
+ export function buildStatusTimelineOption(params) {
214
+ const {
215
+ payload,
216
+ showSummary = true,
217
+ summaryLabel = '汇总',
218
+ displayLegend = true,
219
+ /** 状态图例项数大于该值时启用 ECharts `scroll` 图例,单行可视约 N 项,两侧出现左右翻页箭头 */
220
+ legendMaxItemsPerRow = 6,
221
+ /** 估算每项图例占用宽度(px),用于计算 scroll 模式下的 `legend.width` */
222
+ legendItemApproxWidth = 88,
223
+ /** 覆盖 scroll 模式下的图例宽度(px 或百分比字符串);不传则按 `legendMaxItemsPerRow * legendItemApproxWidth + 按钮区` 估算 */
224
+ legendScrollWidth = null,
225
+ legendOption = {},
226
+ colorMap = {},
227
+ presetColors = DEFAULT_STATUS_COLOR_PALETTE,
228
+ dataZoom: dataZoomUser,
229
+ enableDataZoom = true,
230
+ xAxisOption = {},
231
+ yAxisOption = {},
232
+ grid: gridUser = {},
233
+ gapColor = '#E4E7ED',
234
+ fillSummaryGaps = true,
235
+ tooltipFormatter,
236
+ dynamicWindowMs = null,
237
+ animationDuration = 300,
238
+ animationDurationUpdate = 600,
239
+ echartsOption = {},
240
+ categories: categoriesOverride
241
+ } = params
242
+
243
+ const yAxis = Array.isArray(payload && payload.yAxis) ? payload.yAxis : []
244
+ const startTime = payload && payload.startTime
245
+ const endTime = payload && payload.endTime
246
+ let rangeStart = toTimestamp(startTime, startTime)
247
+ let rangeEnd = toTimestamp(startTime, endTime)
248
+
249
+ if (!Number.isFinite(rangeStart) || !Number.isFinite(rangeEnd)) {
250
+ return {
251
+ _invalid: true
252
+ }
253
+ }
254
+ if (rangeEnd <= rangeStart) {
255
+ rangeEnd = rangeStart + 3600000
256
+ }
257
+
258
+ const globalStart = rangeStart
259
+ const globalEnd = rangeEnd
260
+
261
+ const maxSegments = params.maxSegments != null ? params.maxSegments : 4000
262
+ const sorted = normalizeSummaries(payload, maxSegments)
263
+
264
+ if (typeof dynamicWindowMs === 'number' && dynamicWindowMs > 0) {
265
+ rangeEnd = globalEnd
266
+ rangeStart = Math.max(globalStart, globalEnd - dynamicWindowMs)
267
+ }
268
+
269
+ const colorResolver = buildColorResolver(yAxis, colorMap, presetColors)
270
+
271
+ /** 与 Y 轴类目轴文字默认一致,图例文字与之共用,避免深浅主题下色差 */
272
+ const categoryAxisLabelStyle = {
273
+ color: '#666',
274
+ fontSize: 12
275
+ }
276
+
277
+ const categories =
278
+ categoriesOverride ||
279
+ (showSummary ? [summaryLabel, ...yAxis.map(y => y.statusName || y.statusCode)] : yAxis.map(y => y.statusName || y.statusCode))
280
+
281
+ const customData = []
282
+ let summaryY = -1
283
+ if (showSummary) {
284
+ summaryY = 0
285
+ customData.push(...buildSummaryLaneItems(sorted, rangeStart, rangeEnd, summaryY, colorResolver, gapColor, fillSummaryGaps))
286
+ }
287
+
288
+ yAxis.forEach((row, i) => {
289
+ const yIndex = showSummary ? i + 1 : i
290
+ customData.push(...buildStatusLaneItems(sorted, rangeStart, rangeEnd, yIndex, row.statusCode, colorResolver))
291
+ })
292
+
293
+ /**
294
+ * ECharts 图例项需与某一 series 的 name 对应,否则「仅配置 legend.data」时图例往往不显示。
295
+ * 使用无数据的占位 line 系列仅用于图例色块与名称;真正绘制由下方 custom 系列完成。
296
+ */
297
+ const phantomSeriesForLegend = yAxis.map(y => {
298
+ const name = y.statusName || String(y.statusCode)
299
+ const color = colorResolver(y.statusCode)
300
+ return {
301
+ name,
302
+ type: 'line',
303
+ data: [],
304
+ silent: true,
305
+ legendHoverLink: false,
306
+ symbol: 'none',
307
+ lineStyle: { width: 0, opacity: 0, color },
308
+ itemStyle: { color },
309
+ emphasis: { disabled: true },
310
+ tooltip: { show: false }
311
+ }
312
+ })
313
+
314
+ const baseGrid = {
315
+ left: 72,
316
+ right: 24,
317
+ // 有图例时多留顶部区域,与 legend.top 配合拉开图例与绘图区的垂直间距
318
+ top: displayLegend ? 76 : 24,
319
+ // 底部多留空:避免最末一行状态条与 X 轴刻度/文字重叠(动态无 DataZoom 时尤其需要)
320
+ bottom: enableDataZoom ? 76 : 56,
321
+ containLabel: false
322
+ }
323
+
324
+ function renderItem(params, api) {
325
+ const yIndex = api.value(0)
326
+ const start = api.coord([api.value(1), yIndex])
327
+ const end = api.coord([api.value(2), yIndex])
328
+ if (!start || !end) return null
329
+ const height = Math.max(6, api.size([0, 1])[1] * 0.4)
330
+ const xLeft = Math.min(start[0], end[0])
331
+ const xRight = Math.max(start[0], end[0])
332
+ const width = xRight - xLeft
333
+ if (width < 0.5) return null
334
+ let shape = {
335
+ x: xLeft,
336
+ y: start[1] - height / 2,
337
+ width,
338
+ height
339
+ }
340
+ const cs = params.coordSys
341
+ if (cs && cs.width != null && cs.height != null) {
342
+ shape = clipRectToGrid(shape, { x: cs.x, y: cs.y, width: cs.width, height: cs.height })
343
+ if (!shape) return null
344
+ }
345
+ return {
346
+ type: 'rect',
347
+ shape,
348
+ style: api.style()
349
+ }
350
+ }
351
+
352
+ const legendCount = yAxis.length
353
+ const legendRowLimit = Math.max(1, Number(legendMaxItemsPerRow) || 6)
354
+ const approxW = Math.max(40, Number(legendItemApproxWidth) || 88)
355
+ const useLegendScroll = displayLegend && legendCount > legendRowLimit
356
+ let resolvedScrollWidth = legendScrollWidth
357
+ if (useLegendScroll && resolvedScrollWidth == null) {
358
+ resolvedScrollWidth = Math.round(legendRowLimit * approxW + 72)
359
+ }
360
+
361
+ const defaultTooltipFormatter = p => {
362
+ const d = p.data
363
+ if (!d || !d.segmentRaw) {
364
+ if (d && d.isGap) return '无状态 / 空档'
365
+ return ''
366
+ }
367
+ const seg = d.segmentRaw
368
+ const color = d.itemStyle && d.itemStyle.color ? d.itemStyle.color : '#999'
369
+ const name = seg.statusName || seg.statusCode
370
+ const dur = formatDurationZh(seg.duration)
371
+ const st = seg.startTime
372
+ const en = seg.endTime
373
+ return `
374
+ <div style="padding:4px 2px;line-height:1.6;">
375
+ <div><span style="display:inline-block;width:8px;height:8px;border-radius:2px;background:${color};margin-right:6px;vertical-align:middle;"></span>${name}</div>
376
+ <div>时间段:${st} - ${en}</div>
377
+ <div>持续时间:${dur}</div>
378
+ </div>`
379
+ }
380
+
381
+ const option = {
382
+ animation: true,
383
+ animationDuration,
384
+ animationDurationUpdate,
385
+ animationEasing: 'cubicOut',
386
+ animationEasingUpdate: 'cubicOut',
387
+ tooltip: {
388
+ trigger: 'item',
389
+ confine: true,
390
+ backgroundColor: 'rgba(40,40,40,0.92)',
391
+ borderWidth: 0,
392
+ textStyle: { color: '#fff', fontSize: 12 },
393
+ formatter: tooltipFormatter || defaultTooltipFormatter
394
+ },
395
+ legend: displayLegend
396
+ ? merge(
397
+ {
398
+ top: 10,
399
+ orient: 'horizontal',
400
+ type: useLegendScroll ? 'scroll' : 'plain',
401
+ icon: 'roundRect',
402
+ data: yAxis.map(y => y.statusName || String(y.statusCode)),
403
+ selectedMode: false,
404
+ padding: [0, 0, 10, 0],
405
+ textStyle: { ...categoryAxisLabelStyle },
406
+ ...(useLegendScroll
407
+ ? {
408
+ width: resolvedScrollWidth,
409
+ pageButtonItemGap: 6,
410
+ pageButtonGap: 10,
411
+ pageIconSize: 12,
412
+ pageIconColor: categoryAxisLabelStyle.color,
413
+ pageIconInactiveColor: '#c0c4cc',
414
+ pageTextStyle: { color: categoryAxisLabelStyle.color, fontSize: 12 },
415
+ animation: true,
416
+ animationDurationUpdate: 300
417
+ }
418
+ : {})
419
+ },
420
+ legendOption
421
+ )
422
+ : { show: false },
423
+ grid: merge(baseGrid, gridUser),
424
+ xAxis: merge(
425
+ {
426
+ type: 'time',
427
+ min: rangeStart,
428
+ max: rangeEnd,
429
+ axisLine: { lineStyle: { color: '#ccc' } },
430
+ axisLabel: {
431
+ color: '#666',
432
+ hideOverlap: true,
433
+ margin: 14
434
+ },
435
+ splitLine: { show: true, lineStyle: { type: 'dashed', color: '#eee' } }
436
+ },
437
+ xAxisOption
438
+ ),
439
+ yAxis: merge(
440
+ {
441
+ type: 'category',
442
+ data: categories,
443
+ inverse: false,
444
+ boundaryGap: ['10%', '16%'],
445
+ axisLine: { lineStyle: { color: '#ccc' } },
446
+ axisLabel: { ...categoryAxisLabelStyle },
447
+ splitLine: { show: false }
448
+ },
449
+ yAxisOption
450
+ ),
451
+ series: [
452
+ ...phantomSeriesForLegend,
453
+ {
454
+ type: 'custom',
455
+ name: '__statusTimeline',
456
+ legendHoverLink: false,
457
+ coordinateSystem: 'cartesian2d',
458
+ clip: true,
459
+ renderItem,
460
+ encode: { x: [1, 2], y: 0 },
461
+ data: customData,
462
+ z: 2
463
+ }
464
+ ]
465
+ }
466
+
467
+ if (enableDataZoom) {
468
+ let dz = dataZoomUser
469
+ if (dz === true || dz == null) dz = defaultDataZoom()
470
+ if (Array.isArray(dz)) option.dataZoom = dz
471
+ else if (typeof dz === 'object') option.dataZoom = [dz]
472
+ }
473
+
474
+ return merge(option, echartsOption)
475
+ }
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Step 步骤组件
3
+ */
4
+
5
+ import UiStep from './src/main.vue'
6
+
7
+ // 自动安装
8
+ UiStep.install = function(Vue) {
9
+ Vue.component(UiStep.name, UiStep)
10
+ }
11
+
12
+ export default UiStep
@@ -0,0 +1,183 @@
1
+ <template>
2
+ <div
3
+ class="ui-step"
4
+ :style="style"
5
+ :class="[
6
+ !isSimple && `is-${$parent.direction}`,
7
+ isSimple && 'is-simple',
8
+ isLast && !space && !isCenter && 'is-flex',
9
+ isCenter && !isVertical && !isSimple && 'is-center'
10
+ ]">
11
+ <!-- icon & line -->
12
+ <div
13
+ class="ui-step__head"
14
+ :class="`is-${currentStatus}`">
15
+ <div
16
+ class="ui-step__line"
17
+ :style="isLast ? '' : { marginRight: $parent.stepOffset + 'px' }"
18
+ >
19
+ <i class="ui-step__line-inner" :style="lineStyle"></i>
20
+ </div>
21
+
22
+ <div class="ui-step__icon" :class="`is-${icon ? 'icon' : 'text'}`">
23
+ <slot
24
+ v-if="currentStatus !== 'success' && currentStatus !== 'error'"
25
+ name="icon">
26
+ <i v-if="icon" class="ui-step__icon-inner" :class="[icon]"></i>
27
+ <div class="ui-step__icon-inner" v-if="!icon && !isSimple">{{ index + 1 }}</div>
28
+ </slot>
29
+ <i
30
+ v-else
31
+ :class="['icon-' + (currentStatus === 'success' ? 'check' : 'close')]"
32
+ class="ui-step__icon-inner is-status"
33
+ >
34
+ </i>
35
+ </div>
36
+ </div>
37
+ <!-- title & description -->
38
+ <div class="ui-step__main">
39
+ <div
40
+ class="ui-step__title"
41
+ ref="title"
42
+ :class="['is-' + currentStatus]">
43
+ <slot name="title">{{ title }}</slot>
44
+ </div>
45
+ <div v-if="isSimple" class="ui-step__arrow"></div>
46
+ <div
47
+ v-else
48
+ class="ui-step__description"
49
+ :class="['is-' + currentStatus]">
50
+ <slot name="description">{{ description }}</slot>
51
+ </div>
52
+ </div>
53
+ </div>
54
+ </template>
55
+
56
+ <script>
57
+ export default {
58
+ name: 'UiStep',
59
+
60
+ props: {
61
+ title: String,
62
+ icon: String,
63
+ description: String,
64
+ status: {
65
+ type: String,
66
+ validator: value => ['finish', 'success', 'error', 'process', 'wait'].includes(value)
67
+ }
68
+ },
69
+
70
+ data() {
71
+ return {
72
+ index: -1,
73
+ lineStyle: {},
74
+ internalStatus: ''
75
+ };
76
+ },
77
+
78
+ beforeCreate() {
79
+ this.$parent.steps.push(this);
80
+ },
81
+
82
+ beforeDestroy() {
83
+ const steps = this.$parent.steps;
84
+ const index = steps.indexOf(this);
85
+ if (index >= 0) {
86
+ steps.splice(index, 1);
87
+ }
88
+ },
89
+
90
+ computed: {
91
+ currentStatus() {
92
+ return this.status || this.internalStatus;
93
+ },
94
+ prevStatus() {
95
+ const prevStep = this.$parent.steps[this.index - 1];
96
+ return prevStep ? prevStep.currentStatus : 'wait';
97
+ },
98
+ isCenter() {
99
+ return this.$parent.alignCenter;
100
+ },
101
+ isVertical() {
102
+ return this.$parent.direction === 'vertical';
103
+ },
104
+ isSimple() {
105
+ return this.$parent.simple;
106
+ },
107
+ isLast() {
108
+ const parent = this.$parent;
109
+ return parent.steps[parent.steps.length - 1] === this;
110
+ },
111
+ stepsCount() {
112
+ return this.$parent.steps.length;
113
+ },
114
+ space() {
115
+ const { isSimple, $parent: { space } } = this;
116
+ return isSimple ? '' : space ;
117
+ },
118
+ style() {
119
+ const style = {};
120
+ const parent = this.$parent;
121
+ const len = parent.steps.length;
122
+
123
+ const space = (typeof this.space === 'number'
124
+ ? this.space + 'px'
125
+ : this.space
126
+ ? this.space
127
+ : 100 / (len - (this.isCenter ? 0 : 1)) + '%');
128
+ style.flexBasis = space;
129
+ if (this.isVertical) return style;
130
+ if (this.isLast) {
131
+ style.maxWidth = 100 / this.stepsCount + '%';
132
+ } else {
133
+ style.marginRight = -this.$parent.stepOffset + 'px';
134
+ }
135
+
136
+ return style;
137
+ }
138
+ },
139
+
140
+ methods: {
141
+ updateStatus(val) {
142
+ if (val > this.index) {
143
+ this.internalStatus = this.$parent.finishStatus;
144
+ } else if (val === this.index && this.prevStatus !== 'error') {
145
+ this.internalStatus = this.$parent.processStatus;
146
+ } else {
147
+ this.internalStatus = 'wait';
148
+ }
149
+ },
150
+
151
+ calcProgress(status) {
152
+ let step = 100;
153
+ const style = {};
154
+
155
+ style.transitionDelay = 150 * this.index + 'ms';
156
+ if (status === this.$parent.processStatus) {
157
+ step = this.currentStatus !== 'error' ? 0 : 0;
158
+ } else if (status === 'wait') {
159
+ step = 0;
160
+ style.transitionDelay = (-150 * this.index) + 'ms';
161
+ }
162
+
163
+ style.borderWidth = step && !this.isSimple ? '1px' : 0;
164
+ this.$parent.direction === 'vertical'
165
+ ? style.height = step + '%'
166
+ : style.width = step + '%';
167
+
168
+ this.lineStyle = style;
169
+ }
170
+ },
171
+
172
+ mounted() {
173
+ const unwatch = this.$watch('index', val => {
174
+ this.$watch('$parent.active', this.updateStatus, { immediate: true });
175
+ this.$watch('$parent.processStatus', () => {
176
+ const activeIndex = this.$parent.active;
177
+ this.updateStatus(activeIndex);
178
+ }, { immediate: true });
179
+ unwatch();
180
+ });
181
+ }
182
+ };
183
+ </script>
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Steps 步骤条组件
3
+ */
4
+
5
+ import UiSteps from './src/main.vue'
6
+
7
+ // 自动安装
8
+ UiSteps.install = function(Vue) {
9
+ Vue.component(UiSteps.name, UiSteps)
10
+ }
11
+
12
+ export default UiSteps