@phelan/design 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 (676) hide show
  1. package/.changeset/README.md +8 -0
  2. package/.changeset/config.json +11 -0
  3. package/.specstory/history/2025-11-28_08-55Z-/345/210/235/345/247/213/345/214/226/345/211/215/347/253/257/347/273/204/344/273/266/345/272/223/351/241/271/347/233/256.md +4742 -0
  4. package/.specstory/history/2025-12-01_01-58Z-/345/210/235/345/247/213/345/214/226/345/211/215/347/253/257/347/273/204/344/273/266/345/272/223/351/241/271/347/233/256.md +14912 -0
  5. package/.specstory/history/2025-12-22_01-38Z-scss-/345/217/230/351/207/217/345/274/225/345/205/245/351/227/256/351/242/230.md +67163 -0
  6. package/.specstory/history/2026-01-08_03-51Z-pnpm-lines-88-95.md +304 -0
  7. package/README.en.md +36 -0
  8. package/README.md +37 -0
  9. package/SETUP_GUIDE.md +2530 -0
  10. package/docs/.vitepress/config.ts +298 -0
  11. package/docs/.vitepress/theme/index.ts +30 -0
  12. package/docs/.vitepress/theme/style.css +150 -0
  13. package/docs/CHANGELOG.md +7 -0
  14. package/docs/DEPLOY.md +183 -0
  15. package/docs/api-examples.md +49 -0
  16. package/docs/components/Changelog.vue +176 -0
  17. package/docs/components/ComponentOverview.vue +613 -0
  18. package/docs/components/ComponentSearch.vue +39 -0
  19. package/docs/components/basic/action-menu.md +63 -0
  20. package/docs/components/basic/arrow-steps.md +55 -0
  21. package/docs/components/basic/badge.md +22 -0
  22. package/docs/components/basic/batch-copy.md +44 -0
  23. package/docs/components/basic/batch-editor.md +52 -0
  24. package/docs/components/basic/border.md +22 -0
  25. package/docs/components/basic/breadcrumb.md +38 -0
  26. package/docs/components/basic/button.md +109 -0
  27. package/docs/components/basic/calendar.md +111 -0
  28. package/docs/components/basic/card.md +59 -0
  29. package/docs/components/basic/carousel.md +22 -0
  30. package/docs/components/basic/cascader.md +162 -0
  31. package/docs/components/basic/checkbox.md +171 -0
  32. package/docs/components/basic/collapse.md +22 -0
  33. package/docs/components/basic/column-table.md +123 -0
  34. package/docs/components/basic/date-picker.md +92 -0
  35. package/docs/components/basic/date-time-picker.md +110 -0
  36. package/docs/components/basic/demo.md +29 -0
  37. package/docs/components/basic/description.md +56 -0
  38. package/docs/components/basic/dialog.md +142 -0
  39. package/docs/components/basic/drawer.md +159 -0
  40. package/docs/components/basic/editor.md +76 -0
  41. package/docs/components/basic/empty.md +59 -0
  42. package/docs/components/basic/file-task-dialog.md +41 -0
  43. package/docs/components/basic/form.md +112 -0
  44. package/docs/components/basic/icon.md +53 -0
  45. package/docs/components/basic/image.md +110 -0
  46. package/docs/components/basic/import-dialog.md +54 -0
  47. package/docs/components/basic/independent-nav.md +45 -0
  48. package/docs/components/basic/input-number.md +61 -0
  49. package/docs/components/basic/input.md +98 -0
  50. package/docs/components/basic/layout.md +141 -0
  51. package/docs/components/basic/link.md +65 -0
  52. package/docs/components/basic/mention.md +22 -0
  53. package/docs/components/basic/message.md +167 -0
  54. package/docs/components/basic/nav.md +29 -0
  55. package/docs/components/basic/pagination.md +93 -0
  56. package/docs/components/basic/popover.md +116 -0
  57. package/docs/components/basic/progress.md +22 -0
  58. package/docs/components/basic/radio.md +152 -0
  59. package/docs/components/basic/result.md +22 -0
  60. package/docs/components/basic/scrollbar.md +105 -0
  61. package/docs/components/basic/search-panel.md +53 -0
  62. package/docs/components/basic/select.md +256 -0
  63. package/docs/components/basic/slider.md +22 -0
  64. package/docs/components/basic/space.md +140 -0
  65. package/docs/components/basic/steps.md +60 -0
  66. package/docs/components/basic/switch.md +115 -0
  67. package/docs/components/basic/table-grid.md +116 -0
  68. package/docs/components/basic/table-head-editor.md +135 -0
  69. package/docs/components/basic/table.md +433 -0
  70. package/docs/components/basic/tabs.md +62 -0
  71. package/docs/components/basic/tag.md +75 -0
  72. package/docs/components/basic/text.md +22 -0
  73. package/docs/components/basic/time-picker.md +77 -0
  74. package/docs/components/basic/time-select.md +65 -0
  75. package/docs/components/basic/tooltip.md +112 -0
  76. package/docs/components/basic/tour.md +22 -0
  77. package/docs/components/basic/tree-select.md +132 -0
  78. package/docs/components/basic/tree.md +163 -0
  79. package/docs/components/button.md +113 -0
  80. package/docs/components/calendar.md +111 -0
  81. package/docs/components/design/color.md +137 -0
  82. package/docs/components/index.md +3 -0
  83. package/docs/components/link.md +65 -0
  84. package/docs/components/search-panel.md +53 -0
  85. package/docs/components/table-grid.md +120 -0
  86. package/docs/components/table.md +433 -0
  87. package/docs/examples/action-menu/basic.vue +70 -0
  88. package/docs/examples/action-menu/default.vue +88 -0
  89. package/docs/examples/action-menu/index.vue +76 -0
  90. package/docs/examples/arrow-steps/index.vue +15 -0
  91. package/docs/examples/badge/index.vue +3 -0
  92. package/docs/examples/batch-copy/index.vue +30 -0
  93. package/docs/examples/batch-copy/validator.vue +73 -0
  94. package/docs/examples/batch-editor/basic.vue +120 -0
  95. package/docs/examples/batch-editor/customization.vue +167 -0
  96. package/docs/examples/border/index.vue +3 -0
  97. package/docs/examples/breadcrumb/index.vue +33 -0
  98. package/docs/examples/button/demo1.vue +119 -0
  99. package/docs/examples/button/demo2.vue +18 -0
  100. package/docs/examples/button/demo3.vue +32 -0
  101. package/docs/examples/button/demo4.vue +41 -0
  102. package/docs/examples/button/demo5.vue +46 -0
  103. package/docs/examples/button/demo6.vue +35 -0
  104. package/docs/examples/calendar/calendar01.vue +46 -0
  105. package/docs/examples/calendar/calendar02.vue +16 -0
  106. package/docs/examples/calendar/calendar03.vue +6 -0
  107. package/docs/examples/calendar/calendar04.vue +54 -0
  108. package/docs/examples/calendar/calendar05.vue +36 -0
  109. package/docs/examples/calendar/calendar06.vue +53 -0
  110. package/docs/examples/card/basic-card.vue +7 -0
  111. package/docs/examples/card/card-title.vue +6 -0
  112. package/docs/examples/card/collapsible-card.vue +26 -0
  113. package/docs/examples/card/title-card.vue +32 -0
  114. package/docs/examples/carousel/index.vue +3 -0
  115. package/docs/examples/cascader/clearable.vue +52 -0
  116. package/docs/examples/cascader/collapse-tags.vue +84 -0
  117. package/docs/examples/cascader/disabled-select.vue +52 -0
  118. package/docs/examples/cascader/disabled.vue +54 -0
  119. package/docs/examples/cascader/filterable.vue +82 -0
  120. package/docs/examples/cascader/index.vue +173 -0
  121. package/docs/examples/cascader/multiple.vue +74 -0
  122. package/docs/examples/cascader/show-all-levels.vue +63 -0
  123. package/docs/examples/cascader/sizes.vue +71 -0
  124. package/docs/examples/checkbox/basic.vue +47 -0
  125. package/docs/examples/checkbox/button-style.vue +73 -0
  126. package/docs/examples/checkbox/disabled.vue +20 -0
  127. package/docs/examples/checkbox/grouping.vue +32 -0
  128. package/docs/examples/checkbox/intermediate.vue +43 -0
  129. package/docs/examples/checkbox/limitation.vue +23 -0
  130. package/docs/examples/checkbox/with-border.vue +74 -0
  131. package/docs/examples/collapse/index.vue +3 -0
  132. package/docs/examples/column-table/basic.vue +47 -0
  133. package/docs/examples/column-table/column-title.vue +48 -0
  134. package/docs/examples/column-table/custom.vue +125 -0
  135. package/docs/examples/column-table/index.vue +209 -0
  136. package/docs/examples/column-table/nested.vue +123 -0
  137. package/docs/examples/column-table/no-header.vue +50 -0
  138. package/docs/examples/date-picker/default.vue +106 -0
  139. package/docs/examples/date-picker/index.vue +98 -0
  140. package/docs/examples/date-picker/otherUnits.vue +118 -0
  141. package/docs/examples/date-picker/periodTime.vue +108 -0
  142. package/docs/examples/date-time-picker/default.vue +83 -0
  143. package/docs/examples/date-time-picker/format.vue +90 -0
  144. package/docs/examples/date-time-picker/index.vue +110 -0
  145. package/docs/examples/date-time-picker/range.vue +111 -0
  146. package/docs/examples/date-time-picker/time-format.vue +78 -0
  147. package/docs/examples/demo/demo1.vue +3 -0
  148. package/docs/examples/demo/demo2.vue +3 -0
  149. package/docs/examples/description/custom-description.vue +30 -0
  150. package/docs/examples/description/index.vue +13 -0
  151. package/docs/examples/description/labelJustify.vue +58 -0
  152. package/docs/examples/description/merge-description.vue +15 -0
  153. package/docs/examples/design/color-palette.vue +225 -0
  154. package/docs/examples/dialog/align-center.vue +34 -0
  155. package/docs/examples/dialog/basic.vue +31 -0
  156. package/docs/examples/dialog/centered-content.vue +34 -0
  157. package/docs/examples/dialog/customization-content.vue +129 -0
  158. package/docs/examples/dialog/customization-header.vue +60 -0
  159. package/docs/examples/dialog/msg-dialog.vue +63 -0
  160. package/docs/examples/dialog/nested-dialog.vue +43 -0
  161. package/docs/examples/dialog/title-icon.vue +32 -0
  162. package/docs/examples/drawer/custom-content.vue +182 -0
  163. package/docs/examples/drawer/custom-header.vue +30 -0
  164. package/docs/examples/drawer/index.vue +101 -0
  165. package/docs/examples/drawer/modal.vue +40 -0
  166. package/docs/examples/drawer/nested.vue +44 -0
  167. package/docs/examples/drawer/no-title.vue +22 -0
  168. package/docs/examples/drawer/resizable.vue +28 -0
  169. package/docs/examples/editor/basic.vue +53 -0
  170. package/docs/examples/editor/customization-desc.vue +56 -0
  171. package/docs/examples/editor/more-demo.vue +54 -0
  172. package/docs/examples/editor/more-form.vue +56 -0
  173. package/docs/examples/editor/number-desc.vue +55 -0
  174. package/docs/examples/empty/basic.vue +4 -0
  175. package/docs/examples/empty/bottom-content.vue +5 -0
  176. package/docs/examples/empty/custom-image.vue +6 -0
  177. package/docs/examples/empty/image-size.vue +6 -0
  178. package/docs/examples/file-task-dialog/index.vue +52 -0
  179. package/docs/examples/form/accessibility.vue +48 -0
  180. package/docs/examples/form/alignment.vue +68 -0
  181. package/docs/examples/form/basic-form.vue +120 -0
  182. package/docs/examples/form/custom-validation.vue +121 -0
  183. package/docs/examples/form/form-items.vue +111 -0
  184. package/docs/examples/form/inline-form.vue +70 -0
  185. package/docs/examples/form/number-validate.vue +60 -0
  186. package/docs/examples/form/size-control.vue +140 -0
  187. package/docs/examples/form/validation.vue +265 -0
  188. package/docs/examples/icon/icon.vue +52 -0
  189. package/docs/examples/icon/index.vue +7 -0
  190. package/docs/examples/image/error.vue +69 -0
  191. package/docs/examples/image/index.vue +47 -0
  192. package/docs/examples/image/lazy.vue +39 -0
  193. package/docs/examples/image/placeholder.vue +69 -0
  194. package/docs/examples/image/preview.vue +37 -0
  195. package/docs/examples/import-dialog/multiple.vue +35 -0
  196. package/docs/examples/import-dialog/single.vue +37 -0
  197. package/docs/examples/independent-nav/icon-slot.vue +7 -0
  198. package/docs/examples/independent-nav/index.vue +12 -0
  199. package/docs/examples/input/icon.vue +26 -0
  200. package/docs/examples/input/index.vue +9 -0
  201. package/docs/examples/input-number/index.vue +19 -0
  202. package/docs/examples/layout/gutter.vue +51 -0
  203. package/docs/examples/layout/index.vue +97 -0
  204. package/docs/examples/layout/justify.vue +122 -0
  205. package/docs/examples/layout/mixed.vue +70 -0
  206. package/docs/examples/layout/offset.vue +70 -0
  207. package/docs/examples/layout/responsive.vue +69 -0
  208. package/docs/examples/link/index01.vue +20 -0
  209. package/docs/examples/link/index02.vue +41 -0
  210. package/docs/examples/link/index03.vue +43 -0
  211. package/docs/examples/link/index04.vue +131 -0
  212. package/docs/examples/mention/index.vue +3 -0
  213. package/docs/examples/message/closeable.vue +92 -0
  214. package/docs/examples/message/grouping.vue +22 -0
  215. package/docs/examples/message/html.vue +21 -0
  216. package/docs/examples/message/index.vue +34 -0
  217. package/docs/examples/message/placement.vue +96 -0
  218. package/docs/examples/message/plain.vue +80 -0
  219. package/docs/examples/message/types.vue +66 -0
  220. package/docs/examples/nav/index.vue +20 -0
  221. package/docs/examples/pagination/background-color.vue +17 -0
  222. package/docs/examples/pagination/basic.vue +43 -0
  223. package/docs/examples/pagination/disabled.vue +17 -0
  224. package/docs/examples/pagination/more.vue +43 -0
  225. package/docs/examples/pagination/number-of-pagers.vue +17 -0
  226. package/docs/examples/pagination/small.vue +17 -0
  227. package/docs/examples/popover/basic.vue +81 -0
  228. package/docs/examples/popover/index.vue +144 -0
  229. package/docs/examples/popover/nested.vue +36 -0
  230. package/docs/examples/popover/rich-content.vue +100 -0
  231. package/docs/examples/popover/virtual-trigger.vue +32 -0
  232. package/docs/examples/progress/index.vue +3 -0
  233. package/docs/examples/radio/basic-usage.vue +44 -0
  234. package/docs/examples/radio/button-fill-textcolor.vue +82 -0
  235. package/docs/examples/radio/button-style.vue +77 -0
  236. package/docs/examples/radio/disabled.vue +21 -0
  237. package/docs/examples/radio/radio-button-group.vue +13 -0
  238. package/docs/examples/radio/with-borders.vue +77 -0
  239. package/docs/examples/result/index.vue +3 -0
  240. package/docs/examples/scrollbar/horizontal.vue +39 -0
  241. package/docs/examples/scrollbar/index.vue +31 -0
  242. package/docs/examples/scrollbar/infinite.vue +43 -0
  243. package/docs/examples/scrollbar/manual.vue +68 -0
  244. package/docs/examples/scrollbar/max-height.vue +44 -0
  245. package/docs/examples/search-panel/index.vue +108 -0
  246. package/docs/examples/search-panel/nowrap.vue +115 -0
  247. package/docs/examples/select/allow-create.vue +36 -0
  248. package/docs/examples/select/clearable.vue +29 -0
  249. package/docs/examples/select/collapse-tags.vue +54 -0
  250. package/docs/examples/select/custom-template.vue +40 -0
  251. package/docs/examples/select/disabled-option.vue +29 -0
  252. package/docs/examples/select/disabled-select.vue +29 -0
  253. package/docs/examples/select/empty.vue +21 -0
  254. package/docs/examples/select/filterable.vue +37 -0
  255. package/docs/examples/select/grouping.vue +40 -0
  256. package/docs/examples/select/header-footer.vue +38 -0
  257. package/docs/examples/select/index.vue +28 -0
  258. package/docs/examples/select/loading.vue +41 -0
  259. package/docs/examples/select/multiple-limit.vue +36 -0
  260. package/docs/examples/select/multiple.vue +37 -0
  261. package/docs/examples/select/remote-search.vue +56 -0
  262. package/docs/examples/select/sizes.vue +62 -0
  263. package/docs/examples/select/value-key.vue +33 -0
  264. package/docs/examples/slider/index.vue +3 -0
  265. package/docs/examples/space/alignment.vue +47 -0
  266. package/docs/examples/space/custom-size.vue +58 -0
  267. package/docs/examples/space/fill-ratio.vue +77 -0
  268. package/docs/examples/space/fill.vue +57 -0
  269. package/docs/examples/space/index.vue +52 -0
  270. package/docs/examples/space/size.vue +70 -0
  271. package/docs/examples/space/spacer.vue +35 -0
  272. package/docs/examples/space/vertical.vue +52 -0
  273. package/docs/examples/space/wrap.vue +16 -0
  274. package/docs/examples/steps/index.vue +50 -0
  275. package/docs/examples/steps/navigation.vue +37 -0
  276. package/docs/examples/switch/disabled.vue +19 -0
  277. package/docs/examples/switch/icon.vue +21 -0
  278. package/docs/examples/switch/index.vue +17 -0
  279. package/docs/examples/switch/loading.vue +19 -0
  280. package/docs/examples/switch/size.vue +29 -0
  281. package/docs/examples/switch/text.vue +37 -0
  282. package/docs/examples/switch/validate-value.vue +16 -0
  283. package/docs/examples/table/basic.vue +60 -0
  284. package/docs/examples/table/check-strictly.vue +98 -0
  285. package/docs/examples/table/custom-column.vue +98 -0
  286. package/docs/examples/table/custom-header.vue +87 -0
  287. package/docs/examples/table/custom-index.vue +71 -0
  288. package/docs/examples/table/expandable-row.vue +285 -0
  289. package/docs/examples/table/filter.vue +116 -0
  290. package/docs/examples/table/fixed-column-and-group-header.vue +101 -0
  291. package/docs/examples/table/fixed-column-and-header.vue +101 -0
  292. package/docs/examples/table/fixed-column.vue +107 -0
  293. package/docs/examples/table/fixed-header-with-fluid-header.vue +114 -0
  294. package/docs/examples/table/fixed-header.vue +64 -0
  295. package/docs/examples/table/grouping-header.vue +103 -0
  296. package/docs/examples/table/multi-select.vue +116 -0
  297. package/docs/examples/table/rowspan-and-colspan.vue +147 -0
  298. package/docs/examples/table/show-overflow-tooltip.vue +64 -0
  299. package/docs/examples/table/single-select.vue +78 -0
  300. package/docs/examples/table/sort.vue +63 -0
  301. package/docs/examples/table/striped.vue +49 -0
  302. package/docs/examples/table/summary.vue +150 -0
  303. package/docs/examples/table/table-layout.vue +56 -0
  304. package/docs/examples/table/tooltip-formatter.vue +93 -0
  305. package/docs/examples/table/tree-and-lazy.vue +149 -0
  306. package/docs/examples/table/with-border.vue +49 -0
  307. package/docs/examples/table/with-status.vue +73 -0
  308. package/docs/examples/table-grid/basic.vue +51 -0
  309. package/docs/examples/table-grid/complete.vue +258 -0
  310. package/docs/examples/table-head-editor/grouping-header.vue +409 -0
  311. package/docs/examples/table-head-editor/index.vue +246 -0
  312. package/docs/examples/tabs/default.vue +47 -0
  313. package/docs/examples/tabs/index.vue +46 -0
  314. package/docs/examples/tag/basic.vue +20 -0
  315. package/docs/examples/tag/closable.vue +31 -0
  316. package/docs/examples/tag/dot.vue +21 -0
  317. package/docs/examples/tag/effect.vue +35 -0
  318. package/docs/examples/tag/icon.vue +21 -0
  319. package/docs/examples/text/index.vue +3 -0
  320. package/docs/examples/time-picker/disabled.vue +53 -0
  321. package/docs/examples/time-picker/index.vue +49 -0
  322. package/docs/examples/time-picker/range.vue +36 -0
  323. package/docs/examples/time-select/disabled.vue +30 -0
  324. package/docs/examples/time-select/index.vue +29 -0
  325. package/docs/examples/tooltip/disabled.vue +20 -0
  326. package/docs/examples/tooltip/index.vue +63 -0
  327. package/docs/examples/tooltip/more-content.vue +19 -0
  328. package/docs/examples/tooltip/theme.vue +32 -0
  329. package/docs/examples/tooltip/virtual-trigger.vue +31 -0
  330. package/docs/examples/tour/index.vue +3 -0
  331. package/docs/examples/tree/basic.vue +86 -0
  332. package/docs/examples/tree/checkable.vue +65 -0
  333. package/docs/examples/tree/custom-node.vue +123 -0
  334. package/docs/examples/tree/default-expanded.vue +73 -0
  335. package/docs/examples/tree/draggable.vue +123 -0
  336. package/docs/examples/tree/filter.vue +96 -0
  337. package/docs/examples/tree/index.vue +86 -0
  338. package/docs/examples/tree-select/basic.vue +96 -0
  339. package/docs/examples/tree-select/check-strictly.vue +109 -0
  340. package/docs/examples/tree-select/custom-content.vue +110 -0
  341. package/docs/examples/tree-select/disabled.vue +89 -0
  342. package/docs/examples/tree-select/filterable.vue +112 -0
  343. package/docs/examples/tree-select/index.vue +87 -0
  344. package/docs/examples/tree-select/lazy.vue +43 -0
  345. package/docs/examples/tree-select/multiple.vue +111 -0
  346. package/docs/examples/tree-select/node-key.vue +35 -0
  347. package/docs/guide/changelog.md +6 -0
  348. package/docs/guide/import-on-demand.md +49 -0
  349. package/docs/guide/index.md +55 -0
  350. package/docs/guide/introduction.md +21 -0
  351. package/docs/guide/quickstart.md +35 -0
  352. package/docs/guide/start.md +113 -0
  353. package/docs/index.md +27 -0
  354. package/docs/markdown-examples.md +85 -0
  355. package/docs/package.json +26 -0
  356. package/docs/postcss.config.mjs +9 -0
  357. package/docs/toolkit/domain.md +55 -0
  358. package/docs/toolkit/env.md +73 -0
  359. package/docs/toolkit/examples/domain-aim.vue +35 -0
  360. package/docs/toolkit/examples/domain-supplier.vue +34 -0
  361. package/docs/toolkit/examples/env-basic.vue +28 -0
  362. package/docs/toolkit/examples/env-constants.vue +39 -0
  363. package/docs/toolkit/examples/env-node-constants.vue +38 -0
  364. package/docs/toolkit/examples/env-node.vue +34 -0
  365. package/docs/toolkit/examples/monitor-init.vue +53 -0
  366. package/docs/toolkit/examples/monitor-vue-error.vue +31 -0
  367. package/docs/toolkit/examples/request-baseurl.vue +66 -0
  368. package/docs/toolkit/examples/request-basic.vue +48 -0
  369. package/docs/toolkit/examples/request-cache.vue +137 -0
  370. package/docs/toolkit/examples/wujie-logout.vue +42 -0
  371. package/docs/toolkit/examples/wujie-token.vue +63 -0
  372. package/docs/toolkit/monitor.md +69 -0
  373. package/docs/toolkit/request.md +127 -0
  374. package/docs/toolkit/start.md +110 -0
  375. package/docs/toolkit/wujie.md +34 -0
  376. package/docs/tsconfig.json +29 -0
  377. package/package.json +47 -0
  378. package/packages/components/CHANGELOG.md +81 -0
  379. package/packages/components/README.md +83 -0
  380. package/packages/components/package.json +36 -0
  381. package/packages/components/src/action-menu/index.ts +5 -0
  382. package/packages/components/src/action-menu/src/action-menu.ts +34 -0
  383. package/packages/components/src/action-menu/src/action-menu.vue +364 -0
  384. package/packages/components/src/arrow-steps/index.ts +11 -0
  385. package/packages/components/src/arrow-steps/src/arrow-step.ts +8 -0
  386. package/packages/components/src/arrow-steps/src/arrow-step.vue +90 -0
  387. package/packages/components/src/arrow-steps/src/arrow-steps.ts +16 -0
  388. package/packages/components/src/arrow-steps/src/arrow-steps.vue +42 -0
  389. package/packages/components/src/badge/index.ts +5 -0
  390. package/packages/components/src/badge/src/badge.ts +8 -0
  391. package/packages/components/src/badge/src/badge.vue +20 -0
  392. package/packages/components/src/batch-copy/index.ts +5 -0
  393. package/packages/components/src/batch-copy/src/batch-copy.ts +39 -0
  394. package/packages/components/src/batch-copy/src/batch-copy.vue +214 -0
  395. package/packages/components/src/batch-editor/index.ts +5 -0
  396. package/packages/components/src/batch-editor/src/batch-editor.ts +21 -0
  397. package/packages/components/src/batch-editor/src/batch-editor.vue +73 -0
  398. package/packages/components/src/border/index.ts +5 -0
  399. package/packages/components/src/border/src/border.ts +8 -0
  400. package/packages/components/src/border/src/border.vue +20 -0
  401. package/packages/components/src/breadcrumb/index.ts +8 -0
  402. package/packages/components/src/breadcrumb/src/breadcrumb-item.ts +8 -0
  403. package/packages/components/src/breadcrumb/src/breadcrumb-item.vue +20 -0
  404. package/packages/components/src/breadcrumb/src/breadcrumb.ts +8 -0
  405. package/packages/components/src/breadcrumb/src/breadcrumb.vue +20 -0
  406. package/packages/components/src/button/index.ts +5 -0
  407. package/packages/components/src/button/src/button.ts +12 -0
  408. package/packages/components/src/button/src/button.vue +132 -0
  409. package/packages/components/src/calendar/index.ts +5 -0
  410. package/packages/components/src/calendar/src/calendar.ts +36 -0
  411. package/packages/components/src/calendar/src/calendar.vue +962 -0
  412. package/packages/components/src/card/index.ts +8 -0
  413. package/packages/components/src/card/src/card.ts +29 -0
  414. package/packages/components/src/card/src/card.vue +106 -0
  415. package/packages/components/src/card/src/title.ts +8 -0
  416. package/packages/components/src/card/src/title.vue +14 -0
  417. package/packages/components/src/carousel/index.ts +5 -0
  418. package/packages/components/src/carousel/src/carousel.ts +8 -0
  419. package/packages/components/src/carousel/src/carousel.vue +20 -0
  420. package/packages/components/src/cascader/index.ts +5 -0
  421. package/packages/components/src/cascader/src/cascader.ts +3 -0
  422. package/packages/components/src/cascader/src/cascader.vue +62 -0
  423. package/packages/components/src/checkbox/index.ts +11 -0
  424. package/packages/components/src/checkbox/src/checkbox.vue +19 -0
  425. package/packages/components/src/collapse/index.ts +5 -0
  426. package/packages/components/src/collapse/src/collapse.ts +8 -0
  427. package/packages/components/src/collapse/src/collapse.vue +20 -0
  428. package/packages/components/src/column-table/index.ts +7 -0
  429. package/packages/components/src/column-table/src/column-table-row.ts +30 -0
  430. package/packages/components/src/column-table/src/column-table-row.vue +17 -0
  431. package/packages/components/src/column-table/src/column-table.ts +60 -0
  432. package/packages/components/src/column-table/src/column-table.vue +141 -0
  433. package/packages/components/src/column-table/src/tokens.ts +6 -0
  434. package/packages/components/src/date-picker/index.ts +5 -0
  435. package/packages/components/src/date-picker/src/date-picker.ts +3 -0
  436. package/packages/components/src/date-picker/src/date-picker.vue +14 -0
  437. package/packages/components/src/demo/index.ts +5 -0
  438. package/packages/components/src/demo/src/demo.ts +8 -0
  439. package/packages/components/src/demo/src/demo.vue +20 -0
  440. package/packages/components/src/description/index.ts +8 -0
  441. package/packages/components/src/description/src/description-item.ts +12 -0
  442. package/packages/components/src/description/src/description-item.vue +103 -0
  443. package/packages/components/src/description/src/description.ts +20 -0
  444. package/packages/components/src/description/src/description.vue +28 -0
  445. package/packages/components/src/dialog/index.ts +6 -0
  446. package/packages/components/src/dialog/src/dialog.ts +62 -0
  447. package/packages/components/src/dialog/src/dialog.vue +121 -0
  448. package/packages/components/src/dialog/src/msg-dialog.ts +84 -0
  449. package/packages/components/src/dialog/src/types.ts +8 -0
  450. package/packages/components/src/drawer/index.ts +5 -0
  451. package/packages/components/src/drawer/src/drawer.ts +8 -0
  452. package/packages/components/src/drawer/src/drawer.vue +24 -0
  453. package/packages/components/src/editor/index.ts +5 -0
  454. package/packages/components/src/editor/src/editor.ts +13 -0
  455. package/packages/components/src/editor/src/editor.vue +70 -0
  456. package/packages/components/src/empty/index.ts +5 -0
  457. package/packages/components/src/empty/src/empty.ts +3 -0
  458. package/packages/components/src/empty/src/empty.vue +37 -0
  459. package/packages/components/src/empty/src/img-empty.vue +39 -0
  460. package/packages/components/src/file-task-dialog/index.ts +5 -0
  461. package/packages/components/src/file-task-dialog/src/file-task-dialog.ts +32 -0
  462. package/packages/components/src/file-task-dialog/src/file-task-dialog.vue +228 -0
  463. package/packages/components/src/form/index.ts +3 -0
  464. package/packages/components/src/icon/index.ts +5 -0
  465. package/packages/components/src/icon/src/icon.ts +10 -0
  466. package/packages/components/src/icon/src/icon.vue +29 -0
  467. package/packages/components/src/image/index.ts +5 -0
  468. package/packages/components/src/image/src/image.ts +8 -0
  469. package/packages/components/src/image/src/image.vue +57 -0
  470. package/packages/components/src/import-dialog/index.ts +5 -0
  471. package/packages/components/src/import-dialog/src/import-dialog.ts +11 -0
  472. package/packages/components/src/import-dialog/src/import-dialog.vue +207 -0
  473. package/packages/components/src/independent-nav/index.ts +5 -0
  474. package/packages/components/src/independent-nav/src/independent-nav.ts +7 -0
  475. package/packages/components/src/independent-nav/src/independent-nav.vue +61 -0
  476. package/packages/components/src/index.ts +235 -0
  477. package/packages/components/src/input/index.ts +5 -0
  478. package/packages/components/src/input/src/input.ts +3 -0
  479. package/packages/components/src/input/src/input.vue +53 -0
  480. package/packages/components/src/input-number/index.ts +5 -0
  481. package/packages/components/src/input-number/src/input-number.ts +3 -0
  482. package/packages/components/src/input-number/src/input-number.vue +25 -0
  483. package/packages/components/src/layout/index.ts +7 -0
  484. package/packages/components/src/layout/src/col.vue +43 -0
  485. package/packages/components/src/layout/src/layout.ts +13 -0
  486. package/packages/components/src/layout/src/row.vue +43 -0
  487. package/packages/components/src/link/index.ts +5 -0
  488. package/packages/components/src/link/src/link.ts +13 -0
  489. package/packages/components/src/link/src/link.vue +74 -0
  490. package/packages/components/src/mention/index.ts +5 -0
  491. package/packages/components/src/mention/src/mention.ts +8 -0
  492. package/packages/components/src/mention/src/mention.vue +20 -0
  493. package/packages/components/src/message/index.ts +1 -0
  494. package/packages/components/src/message/src/message.ts +161 -0
  495. package/packages/components/src/nav/index.ts +7 -0
  496. package/packages/components/src/nav/src/nav.ts +19 -0
  497. package/packages/components/src/nav/src/nav.vue +66 -0
  498. package/packages/components/src/nav/src/types.ts +11 -0
  499. package/packages/components/src/pagination/index.ts +5 -0
  500. package/packages/components/src/pagination/src/pagination.ts +60 -0
  501. package/packages/components/src/pagination/src/pagination.vue +38 -0
  502. package/packages/components/src/popover/index.ts +5 -0
  503. package/packages/components/src/popover/src/popover.ts +14 -0
  504. package/packages/components/src/popover/src/popover.vue +60 -0
  505. package/packages/components/src/progress/index.ts +5 -0
  506. package/packages/components/src/progress/src/progress.ts +8 -0
  507. package/packages/components/src/progress/src/progress.vue +20 -0
  508. package/packages/components/src/radio/index.ts +11 -0
  509. package/packages/components/src/radio/src/radio.vue +13 -0
  510. package/packages/components/src/result/index.ts +5 -0
  511. package/packages/components/src/result/src/result.ts +8 -0
  512. package/packages/components/src/result/src/result.vue +20 -0
  513. package/packages/components/src/scrollbar/index.ts +5 -0
  514. package/packages/components/src/scrollbar/src/scrollbar.ts +8 -0
  515. package/packages/components/src/scrollbar/src/scrollbar.vue +54 -0
  516. package/packages/components/src/search-panel/index.ts +5 -0
  517. package/packages/components/src/search-panel/src/search-panel.ts +8 -0
  518. package/packages/components/src/search-panel/src/search-panel.vue +251 -0
  519. package/packages/components/src/select/index.ts +9 -0
  520. package/packages/components/src/select/src/select.ts +3 -0
  521. package/packages/components/src/select/src/select.vue +43 -0
  522. package/packages/components/src/slider/index.ts +5 -0
  523. package/packages/components/src/slider/src/slider.ts +8 -0
  524. package/packages/components/src/slider/src/slider.vue +20 -0
  525. package/packages/components/src/space/index.ts +5 -0
  526. package/packages/components/src/space/src/space.ts +8 -0
  527. package/packages/components/src/space/src/space.vue +43 -0
  528. package/packages/components/src/steps/index.ts +8 -0
  529. package/packages/components/src/steps/src/step.ts +15 -0
  530. package/packages/components/src/steps/src/step.vue +18 -0
  531. package/packages/components/src/steps/src/steps.ts +20 -0
  532. package/packages/components/src/steps/src/steps.vue +95 -0
  533. package/packages/components/src/steps/src/tokens.ts +6 -0
  534. package/packages/components/src/switch/index.ts +5 -0
  535. package/packages/components/src/switch/src/switch.ts +8 -0
  536. package/packages/components/src/switch/src/switch.vue +51 -0
  537. package/packages/components/src/table/index.ts +7 -0
  538. package/packages/components/src/table/src/table.ts +34 -0
  539. package/packages/components/src/table/src/table.vue +47 -0
  540. package/packages/components/src/table-grid/index.ts +7 -0
  541. package/packages/components/src/table-grid/src/render-cell.vue +44 -0
  542. package/packages/components/src/table-grid/src/table-grid.ts +159 -0
  543. package/packages/components/src/table-grid/src/table-grid.vue +334 -0
  544. package/packages/components/src/table-head-editor/index.ts +5 -0
  545. package/packages/components/src/table-head-editor/src/table-head-editor.ts +59 -0
  546. package/packages/components/src/table-head-editor/src/table-head-editor.vue +780 -0
  547. package/packages/components/src/table-head-editor/src/utils.ts +192 -0
  548. package/packages/components/src/tabs/index.ts +7 -0
  549. package/packages/components/src/tabs/src/tabs.ts +8 -0
  550. package/packages/components/src/tabs/src/tabs.vue +23 -0
  551. package/packages/components/src/tag/index.ts +5 -0
  552. package/packages/components/src/tag/src/tag.ts +47 -0
  553. package/packages/components/src/tag/src/tag.vue +60 -0
  554. package/packages/components/src/tag/src/types.ts +8 -0
  555. package/packages/components/src/text/index.ts +5 -0
  556. package/packages/components/src/text/src/text.ts +8 -0
  557. package/packages/components/src/text/src/text.vue +20 -0
  558. package/packages/components/src/time-picker/index.ts +5 -0
  559. package/packages/components/src/time-picker/src/time-picker.ts +3 -0
  560. package/packages/components/src/time-picker/src/time-picker.vue +14 -0
  561. package/packages/components/src/time-select/index.ts +5 -0
  562. package/packages/components/src/time-select/src/time-select.ts +5 -0
  563. package/packages/components/src/time-select/src/time-select.vue +14 -0
  564. package/packages/components/src/tooltip/index.ts +5 -0
  565. package/packages/components/src/tooltip/src/tooltip.ts +6 -0
  566. package/packages/components/src/tooltip/src/tooltip.vue +71 -0
  567. package/packages/components/src/tour/index.ts +5 -0
  568. package/packages/components/src/tour/src/tour.ts +8 -0
  569. package/packages/components/src/tour/src/tour.vue +20 -0
  570. package/packages/components/src/tree/index.ts +5 -0
  571. package/packages/components/src/tree/src/tree.ts +8 -0
  572. package/packages/components/src/tree/src/tree.vue +77 -0
  573. package/packages/components/src/tree-select/index.ts +3 -0
  574. package/packages/components/src/tree-select/src/tree-select.vue +96 -0
  575. package/packages/components/tsconfig.json +19 -0
  576. package/packages/components/vite.config.ts +32 -0
  577. package/packages/icons/CHANGELOG.md +45 -0
  578. package/packages/icons/README.md +86 -0
  579. package/packages/icons/package.json +30 -0
  580. package/packages/icons/src/components/arrow-down.vue +12 -0
  581. package/packages/icons/src/components/arrow-left.vue +12 -0
  582. package/packages/icons/src/components/arrow-right.vue +12 -0
  583. package/packages/icons/src/components/arrow-up.vue +12 -0
  584. package/packages/icons/src/components/circle-check.vue +15 -0
  585. package/packages/icons/src/components/circle-close.vue +15 -0
  586. package/packages/icons/src/components/close.vue +13 -0
  587. package/packages/icons/src/components/copy.vue +12 -0
  588. package/packages/icons/src/components/delete.vue +12 -0
  589. package/packages/icons/src/components/download.vue +15 -0
  590. package/packages/icons/src/components/edit.vue +12 -0
  591. package/packages/icons/src/components/error.vue +12 -0
  592. package/packages/icons/src/components/export.vue +17 -0
  593. package/packages/icons/src/components/file.vue +21 -0
  594. package/packages/icons/src/components/import.vue +19 -0
  595. package/packages/icons/src/components/index.ts +37 -0
  596. package/packages/icons/src/components/info.vue +13 -0
  597. package/packages/icons/src/components/list-process.vue +37 -0
  598. package/packages/icons/src/components/log.vue +17 -0
  599. package/packages/icons/src/components/minus.vue +13 -0
  600. package/packages/icons/src/components/money-bubble.vue +21 -0
  601. package/packages/icons/src/components/plane.vue +30 -0
  602. package/packages/icons/src/components/plus.vue +17 -0
  603. package/packages/icons/src/components/printer.vue +17 -0
  604. package/packages/icons/src/components/reset.vue +21 -0
  605. package/packages/icons/src/components/right.vue +21 -0
  606. package/packages/icons/src/components/search.vue +15 -0
  607. package/packages/icons/src/components/select.vue +17 -0
  608. package/packages/icons/src/components/semi-select.vue +17 -0
  609. package/packages/icons/src/components/setting.vue +25 -0
  610. package/packages/icons/src/components/stamp.vue +35 -0
  611. package/packages/icons/src/components/success.vue +13 -0
  612. package/packages/icons/src/components/tree-triangle.vue +17 -0
  613. package/packages/icons/src/components/upload.vue +21 -0
  614. package/packages/icons/src/components/view.vue +15 -0
  615. package/packages/icons/src/components/warning.vue +13 -0
  616. package/packages/icons/src/components/zoom-in.vue +27 -0
  617. package/packages/icons/src/components/zoom-out.vue +27 -0
  618. package/packages/icons/src/index.ts +9 -0
  619. package/packages/icons/tsconfig.json +10 -0
  620. package/packages/icons/vite.config.ts +33 -0
  621. package/packages/styles/CHANGELOG.md +99 -0
  622. package/packages/styles/README.md +107 -0
  623. package/packages/styles/package.json +23 -0
  624. package/packages/styles/src/action-menu.scss +103 -0
  625. package/packages/styles/src/arrow-step.scss +138 -0
  626. package/packages/styles/src/arrow-steps.scss +8 -0
  627. package/packages/styles/src/batch-copy.scss +40 -0
  628. package/packages/styles/src/batch-editor.scss +36 -0
  629. package/packages/styles/src/breadcrumb.scss +29 -0
  630. package/packages/styles/src/button.scss +127 -0
  631. package/packages/styles/src/calendar.scss +327 -0
  632. package/packages/styles/src/card.scss +85 -0
  633. package/packages/styles/src/cascader.scss +59 -0
  634. package/packages/styles/src/checkbox.scss +46 -0
  635. package/packages/styles/src/column-table.scss +13 -0
  636. package/packages/styles/src/date-picker.scss +547 -0
  637. package/packages/styles/src/description.scss +38 -0
  638. package/packages/styles/src/dialog.scss +120 -0
  639. package/packages/styles/src/drawer.scss +22 -0
  640. package/packages/styles/src/editor.scss +13 -0
  641. package/packages/styles/src/empty.scss +12 -0
  642. package/packages/styles/src/file-task-dialog.scss +13 -0
  643. package/packages/styles/src/image.scss +6 -0
  644. package/packages/styles/src/import-dialog.scss +122 -0
  645. package/packages/styles/src/independent-nav.scss +37 -0
  646. package/packages/styles/src/index.scss +46 -0
  647. package/packages/styles/src/input-number.scss +34 -0
  648. package/packages/styles/src/input.scss +28 -0
  649. package/packages/styles/src/link.scss +70 -0
  650. package/packages/styles/src/message.scss +12 -0
  651. package/packages/styles/src/mixins.scss +60 -0
  652. package/packages/styles/src/nav.scss +12 -0
  653. package/packages/styles/src/overrides.scss +25 -0
  654. package/packages/styles/src/pagination.scss +161 -0
  655. package/packages/styles/src/popover.scss +4 -0
  656. package/packages/styles/src/radio.scss +54 -0
  657. package/packages/styles/src/search-panel.scss +51 -0
  658. package/packages/styles/src/select.scss +44 -0
  659. package/packages/styles/src/steps.scss +336 -0
  660. package/packages/styles/src/switch.scss +35 -0
  661. package/packages/styles/src/table-grid.scss +37 -0
  662. package/packages/styles/src/table-head-editor.scss +112 -0
  663. package/packages/styles/src/table.scss +33 -0
  664. package/packages/styles/src/tabs.scss +45 -0
  665. package/packages/styles/src/tag.scss +29 -0
  666. package/packages/styles/src/theme.scss +101 -0
  667. package/packages/styles/src/time-picker.scss +225 -0
  668. package/packages/styles/src/time-select.scss +141 -0
  669. package/packages/styles/src/tooltip.scss +21 -0
  670. package/packages/styles/src/tree-select.scss +52 -0
  671. package/packages/styles/src/tree.scss +8 -0
  672. package/packages/styles/src/utilities.scss +81 -0
  673. package/packages/styles/src/variables.scss +56 -0
  674. package/packages/styles/vite.config.ts +28 -0
  675. package/pnpm-workspace.yaml +3 -0
  676. package/tsconfig.json +46 -0
@@ -0,0 +1,65 @@
1
+ # time-select 样例
2
+
3
+ 用于选择或输入日期
4
+
5
+ 可用时间范围是 00:00-23:59
6
+
7
+ ## 固定时间点
8
+
9
+ 提供几个固定的时间点供用户选择
10
+
11
+ 使用 m-time-select 标签,然后通过start、end和step指定起始时间,结束时间和步长。
12
+
13
+ :::preview
14
+
15
+ demo-preview=../../examples/time-select/index.vue
16
+
17
+ :::
18
+
19
+ ## 固定时间范围
20
+
21
+ 如果先选中了开始(或结束)时间,则结束(或开始)时间的状态也将会随之改变。
22
+
23
+ :::preview
24
+
25
+ demo-preview=../../examples/time-select/disabled.vue
26
+
27
+ :::
28
+
29
+ ## TimeSelect API
30
+
31
+ ### TimeSelect Attributes
32
+
33
+ | 属性名 | 说明 | 类型 | 默认值 |
34
+ | --------------------- | -------------------------------------- | ------------- | ------ |
35
+ | model-value / v-model | 选中项绑定值 | string | — |
36
+ | disabled | 禁用 | boolean | false |
37
+ | editable | 文本框可输入 | boolean | true |
38
+ | clearable | 是否显示清除按钮 | boolean | true |
39
+ | include-end-time | 是否在选项中包含end | boolean | false |
40
+ | placeholder | 非范围选择时的占位内容 | string | '' |
41
+ | name | 原生属性 | string | '-' |
42
+ | start | 开始时间 | string | 09:00 |
43
+ | end | 结束时间 | string | 18:00 |
44
+ | step | 间隔时间 | string | 00:30 |
45
+ | min-time | 最早时间点,早于该时间的时间段将被禁用 | string | - |
46
+ | max-time | 最晚时间点,晚于该时间的时间段将被禁用 | string | - |
47
+ | format | 时间格式化 | string | HH:mm |
48
+ | popper-class | TimePicker 下拉框的类名 | string | '' |
49
+ | popper-style | 为 TimePicke 的下拉菜单自定义样式 | string/object | - |
50
+
51
+ ### TimeSelect Events
52
+
53
+ | 事件名 | 说明 | 回调参数 |
54
+ | ------ | ---------------------------------------- | -------- |
55
+ | change | 用户确认选定的值时触发 | Function |
56
+ | blur | 在组件 Input 失去焦点时触发 | Function |
57
+ | focus | 在组件 Input 获得焦点时触发 | Function |
58
+ | clear | 可清空的单选模式下用户点击清空按钮时触发 | Function |
59
+
60
+ ### TimeSelect Exposes
61
+
62
+ | 方法名 | 说明 | 类型 |
63
+ | ------ | ----------------- | -------- |
64
+ | blur | 使 input 失去焦点 | Function |
65
+ | focus | 使 input 获取焦点 | Function |
@@ -0,0 +1,112 @@
1
+ # Tooltip 文字提示
2
+
3
+ 常用于展示鼠标 hover 时的提示信息。
4
+
5
+ ## 基础用法
6
+
7
+ 在这里我们提供 9 种不同方向的展示方式,可以通过以下完整示例来理解,选择你要的效果。
8
+
9
+ :::preview
10
+
11
+ demo-preview=../../examples/tooltip/index.vue
12
+
13
+ :::
14
+
15
+ ## 主题
16
+
17
+ Tooltip 组件提供了两个不同的主题:`dark` 和 `light`。
18
+
19
+ :::preview
20
+
21
+ demo-preview=../../examples/tooltip/theme.vue
22
+
23
+ :::
24
+
25
+ ## 更多内容
26
+
27
+ 展示多行文本或者是设置文本内容的格式
28
+
29
+ :::preview
30
+
31
+ demo-preview=../../examples/tooltip/more-content.vue
32
+
33
+ :::
34
+
35
+ ## 禁用状态
36
+
37
+ Tooltip 组件可以通过 `disabled` 属性来禁用。
38
+
39
+ :::preview
40
+
41
+ demo-preview=../../examples/tooltip/disabled.vue
42
+
43
+ :::
44
+
45
+ ## 虚拟触发
46
+
47
+ 像 Popover 一样,Tooltip 也可以由虚拟元素触发。
48
+
49
+ :::preview
50
+
51
+ demo-preview=../../examples/tooltip/virtual-trigger.vue
52
+
53
+ :::
54
+
55
+ ## API
56
+
57
+ ### Attributes
58
+
59
+ | 属性名 | 说明 | 类型 | Default |
60
+ | ------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | ------------------------- | -------------------------------------------------------------------------- |
61
+ | effect | 默认提供的主题 | enum / string | dark |
62
+ | content | 显示的内容,也可以通过写入默认 slot 修改显示内容 | string | '' |
63
+ | placement | Tooltip 组件出现的位置 | enum | bottom |
64
+ | model-value / v-model | Tooltip 显示状态,可以使用 v-model 双向绑定数据 | boolean | undefined |
65
+ | disabled | Tooltip 是否可用 | boolean | false |
66
+ | offset | 出现位置的偏移量 | number | 12 |
67
+ | transition | 定义渐变动画 | string | el-fade-in-linear |
68
+ | show-arrow | 是否显示 Tooltip 箭头 | boolean | true |
69
+ | popper-options | [popper.js](https://popper.js.org/docs/v2/) 的参数 | object | {modifiers: \[{name: 'computeStyles',options: {gpuAcceleration: false}}\]} |
70
+ | show-after | 延迟显示时间(以毫秒为单位) | number | 0 |
71
+ | hide-after | 延迟隐藏时间(以毫秒为单位) | number | 200 |
72
+ | auto-close | 隐藏提示框的超时时间(以毫秒为单位) | number | 0 |
73
+ | popper-class | 为 Tooltip 的 popper 添加类名 | string | — |
74
+ | popper-style | 为 Tooltip 的 popper 添加样式 | string / object | — |
75
+ | enterable | 鼠标是否可进入到 tooltip 中 | boolean | true |
76
+ | hide-after | Tooltip 出现前的延迟时长,单位毫秒 | number | 0 |
77
+ | teleported | 是否将 tooltip 的下拉列表插入至 body 元素 | boolean | true |
78
+ | trigger | 如何触发 Tooltip | enum / array | hover |
79
+ | trigger-keys | 当通过鼠标点击使触发元素获得焦点时,可以定义一组键盘按键代码,通过键盘控制气泡框的显示,在受控模式下无效。 | Array | \['Enter','Space'\] |
80
+ | virtual-triggering | 是否启用虚拟触发器 | boolean | — |
81
+ | virtual-ref | 代表 tooltip 所要附加的参照元素 | HTMLElement | — |
82
+ | append-to | 指示 Tooltip 的内容将附加在哪一个网页元素上 | CSSSelector / HTMLElement | body |
83
+ | persistent | 当 tooltip 组件长时间不触发且 persistent 属性设置为 false 时, tooltip 将会被删除 | boolean | true |
84
+
85
+ ### Slots
86
+
87
+ | 插槽名 | 说明 |
88
+ | -------- | ------------------------ |
89
+ | default | Tooltip 触发 & 引用的元素 |
90
+ | content | 自定义 Tooltip 的内容,此插槽会覆盖 `content` 属性 |
91
+
92
+ ### Events
93
+
94
+ | 事件名 | 说明 | Type |
95
+ | ------------ | ----------- | -------- |
96
+ | show | 显示时触发 | Function |
97
+ | hide | 隐藏时触发 | Function |
98
+ | before-enter | 显示动画播放前触发 | Function |
99
+ | after-enter | 显示动画播放完毕后触发 | Function |
100
+ | before-leave | 隐藏动画播放前触发 | Function |
101
+ | after-leave | 隐藏动画播放完毕后触发 | Function |
102
+
103
+ ### Exposes
104
+
105
+ | 名称 | 详情 | 类型 |
106
+ | ---- | ---------- | -------- |
107
+ | hide | 隐藏 tooltip | Function |
108
+ | show | 显示 tooltip | Function |
109
+
110
+ ## Owner
111
+
112
+ Aric.Li@aldi.cn
@@ -0,0 +1,22 @@
1
+ # tour 样例
2
+
3
+ 该组件提供了一个样例。
4
+
5
+ ## 基础用法
6
+
7
+ 这里需要说明组件tour功能和使用方式。
8
+
9
+ :::preview
10
+
11
+ demo-preview=../../examples/tour/index.vue
12
+
13
+ :::
14
+
15
+
16
+ ## Tour API
17
+
18
+ ### Tour Attributes
19
+
20
+ | 属性名 | 说明 | 类型 | 默认值 |
21
+ | ------ | ---- | -------- | ------ |
22
+ | xxx | xxx | `String` | — |
@@ -0,0 +1,132 @@
1
+ # TreeSelect 树形选择
2
+
3
+ 含有下拉菜单的树形选择器,结合了 `el-tree` 和 `el-select` 两个组件的功能。
4
+
5
+ ## 基础用法
6
+
7
+ 树状选择器
8
+
9
+ :::preview
10
+
11
+ demo-preview=../../examples/tree-select/basic.vue
12
+
13
+ :::
14
+
15
+ ## 选择任意级别
16
+
17
+ 当属性 `check-strictly=true` 时,任何节点都可以被选择,否则只有子节点可被选择。
18
+
19
+ :::preview
20
+
21
+ demo-preview=../../examples/tree-select/check-strictly.vue
22
+
23
+ :::
24
+
25
+ ## 多选
26
+
27
+ 通过点击或复选框选择多个选项。
28
+
29
+ :::preview
30
+
31
+ demo-preview=../../examples/tree-select/multiple.vue
32
+
33
+ :::
34
+
35
+ ## 禁用选项
36
+
37
+ 使用 disabled 字段禁用选项。
38
+
39
+ :::preview
40
+
41
+ demo-preview=../../examples/tree-select/disabled.vue
42
+
43
+ :::
44
+
45
+ ## 可筛选
46
+
47
+ 使用关键字筛选或自定义筛选方法。 `filterMethod`可以自定义数据筛选的方法, `filterNodeMethod`可以自定义节点数据筛选的方法。
48
+
49
+ :::preview
50
+
51
+ demo-preview=../../examples/tree-select/filterable.vue
52
+
53
+ :::
54
+
55
+ ## 自定义内容
56
+
57
+ 自定义树节点的内容。
58
+
59
+ :::preview
60
+
61
+ demo-preview=../../examples/tree-select/custom-content.vue
62
+
63
+ :::
64
+
65
+ ## 懒加载
66
+
67
+ 树节点懒加载,更加适合于数据量大的列表。
68
+
69
+ :::preview
70
+
71
+ demo-preview=../../examples/tree-select/lazy.vue
72
+
73
+ :::
74
+
75
+ ## 使用 node-key 属性
76
+
77
+ 默认情况下,`modelValue` 会查找 `value` 键。 对于其他数据结构,必须提供 `node-key` 才能正常工作。
78
+
79
+ :::preview
80
+
81
+ demo-preview=../../examples/tree-select/node-key.vue
82
+
83
+ :::
84
+
85
+ ## API
86
+
87
+ ### Attributes
88
+
89
+ 由于这个组件是`el-tree`和`el-select`的结合体,他们的原始属性未被更改,故不在此重复。请跳转查看原组件的相应文档。
90
+
91
+ | 属性 | 对外暴露的方法 | 事件 | 插槽 |
92
+ | ------------------------------------ | --------------------------------- | -------------------------------- | ------------------------------- |
93
+ | [tree](./tree#attributes) | [tree](./tree#exposes) | [tree](./tree#events) | [tree](./tree#slots) |
94
+ | [select](./select#select-attributes) | [select](./select#select-exposes) | [select](./select#select-events) | [select](./select#select-slots) |
95
+
96
+ #### Own Attributes
97
+
98
+ | 属性名 | 详情 | 类型 | 默认值 |
99
+ | ----------------- | ------------------------------- | ------ | ---- |
100
+ | cache-data 2.2.26 | 懒加载节点的缓存数据,结构与数据相同,用于获取未加载数据的标签 | object | \[\] |
101
+
102
+ ### 对外暴露的方法
103
+
104
+ | 事件名 | 详情 | Type |
105
+ | ------------------------------ | ----------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------- |
106
+ | filter | 过滤所有树节点,过滤后的节点将被隐藏 | 接收一个参数并指定为 filter-node-method 属性的第一个参数 |
107
+ | updateKeyChildren | 为节点设置新数据,只有当设置 node-key 属性的时候才可用 | (key, data) 接收两个参数: 1\. 节点的 key 2\. 新数据 |
108
+ | getCheckedNodes | 如果节点可以被选中,(show-checkbox 为 true), 本方法将返回当前选中节点的数组 | (leafOnly, includeHalfChecked) 接收两个布尔类型参数: 1\. 默认值为 false. 若参数为 true, 它将返回当前选中节点的子节点 2\. 默认值为 false. 如果参数为 true, 返回值包含半选中节点数据 |
109
+ | setCheckedNodes | 设置目前选中的节点,使用此方法必须设置 node-key 属性 | 要选中的节点构成的数组 |
110
+ | getCheckedKeys | 若节点可用被选中 (show-checkbox 为 true), 它将返回当前选中节点 key 的数组 | (leafOnly) 接收一个布尔类型参数,默认为 false. 若参数为 true, 它将返回当前选中节点的子节点 |
111
+ | setCheckedKeys | 设置目前选中的节点,使用此方法必须设置 node-key 属性 | (keys, leafOnly) 接收两个参数: 1\. 一个需要被选中的多节点 key 的数组 2\. 布尔类型的值 如果设置为 true,将只设置选中的叶子节点状态。 默认值是 false. |
112
+ | setChecked | 设置节点是否被选中, 使用此方法必须设置 node-key 属性 | (key/data, checked, deep) 接收三个参数: 1\. 要选中的节点的 key 或者数据 2\. 一个布尔类型参数表明是否选中. 3\. 一个布尔类型参数表明是否递归选中子节点 |
113
+ | getHalfCheckedNodes | 如果节点可用被选中 (show-checkbox 为 true), 它将返回当前半选中的节点组成的数组 | ::: |
114
+ | getHalfCheckedKeys | 若节点可被选中(show-checkbox 为 true),则返回目前半选中的节点的 key 所组成的数组 | ::: |
115
+ | getCurrentKey | 返回当前被选中节点的数据 (如果没有则返回 null) | ::: |
116
+ | getCurrentNode | 返回当前被选中节点的数据 (如果没有则返回 null) | ::: |
117
+ | setCurrentKey | 通过 key 设置某个节点的当前选中状态,使用此方法必须设置 node-key 属性 | (key, shouldAutoExpandParent=true) 1\. 待被选节点的 key, 如果为 null, 取消当前选中的节点 2\. 是否展开父节点 |
118
+ | setCurrentNode | 设置节点为选中状态,使用此方法必须设置 node-key 属性 | (node, shouldAutoExpandParent=true) 1\. 待被选中的节点 2\. 是否展开父节点 |
119
+ | getNode | 根据 data 或者 key 拿到 Tree 组件中的 node | (data) 节点的 data 或 key |
120
+ | remove | 删除 Tree 中的一个节点,使用此方法必须设置 node-key 属性 | (data) 要删除的节点的 data 或者 node 对象 |
121
+ | append | 为 Tree 中的一个节点追加一个子节点 | (data, parentNode) 1\. 要追加的子节点的 data 2\. 父节点的 data, key 或 node |
122
+ | insertBefore | 在 Tree 中给定节点前插入一个节点 | (data, refNode) 1\. 要增加的节点的 data 2\. 参考节点的 data, key 或 node |
123
+ | insertAfter | 在 Tree 中给定节点后插入一个节点 | (data, refNode) 1\. 要增加的节点的 data 2\. 参考节点的 data, key 或 node |
124
+ | focus | 使选择器的输入框获取焦点 | Function |
125
+ | blur | 使选择器的输入框失去焦点,并隐藏下拉框 | Function |
126
+
127
+ <!-- | treeRef 2.11.3 | Tree 组件实例 | TreeInstance |
128
+ | selectRef 2.11.3 | Select 组件实例 | SelectInstance | -->
129
+
130
+ ## Owner
131
+
132
+ Aric.Li@aldi.cn
@@ -0,0 +1,163 @@
1
+ # Tree 树形控件
2
+
3
+ 用清晰的层级结构展示信息,可展开或折叠。
4
+
5
+ ## 基础用法
6
+
7
+ 基础的树形结构展示。
8
+
9
+ :::preview
10
+
11
+ demo-preview=../../examples/tree/basic.vue
12
+
13
+ :::
14
+
15
+ ## 可选择
16
+
17
+ 适用于需要选择层级时使用。
18
+
19
+ 本例还展示了动态加载节点数据的方法。
20
+
21
+ :::preview
22
+
23
+ demo-preview=../../examples/tree/checkable.vue
24
+
25
+ :::
26
+
27
+ ## 默认展开以及默认选中
28
+
29
+ 树节点可以在初始化阶段被设置为展开和选中。
30
+
31
+ 分别通过 `default-expanded-keys` 和 `default-checked-keys` 设置默认展开和默认选中的节点。 需要注意的是,此时必须设置 `node-key`, 其值为节点数据中的一个字段名,该字段在整棵树中是唯一的。
32
+
33
+ :::preview
34
+
35
+ demo-preview=../../examples/tree/default-expanded.vue
36
+
37
+ :::
38
+
39
+ ## 自定义节点内容
40
+
41
+ 节点的内容支持自定义,可以在节点区添加按钮或图标等内容。
42
+
43
+ :::preview
44
+
45
+ demo-preview=../../examples/tree/custom-node.vue
46
+
47
+ :::
48
+
49
+ ## 树节点过滤
50
+
51
+ 树节点是可以被过滤的。
52
+
53
+ 调用 Tree 实例对象的 `filter` 方法来过滤树节点。 方法的参数就是过滤关键字。 需要注意的是,此时需要设置 `filter-node-method` 属性,其值为过滤函数。
54
+
55
+ :::preview
56
+
57
+ demo-preview=../../examples/tree/filter.vue
58
+
59
+ :::
60
+
61
+ ## 可拖拽节点
62
+
63
+ 通过 `draggable` 属性可让节点变为可拖拽。
64
+
65
+ :::preview
66
+
67
+ demo-preview=../../examples/tree/draggable.vue
68
+
69
+ :::
70
+
71
+ ## Tree API
72
+
73
+ ### Tree Attributes
74
+
75
+ | 属性名 | 说明 | 类型 | 默认值 |
76
+ | ------------------------- | ------------------------------------------------------------------------------------------------------------------- | ------------------ | ----- |
77
+ | data | 展示数据 | object | — |
78
+ | empty-text | 内容为空的时候展示的文本 | string | — |
79
+ | node-key | 每个树节点用来作为唯一标识的属性,整棵树应该是唯一的 | string | — |
80
+ | props | 配置选项,具体看下表 | object | — |
81
+ | render-after-expand | 是否在第一次展开某个树节点后才渲染其子节点 | boolean | true |
82
+ | load | 加载子树数据的方法,仅当 lazy 属性为true 时生效 | Function | — |
83
+ | render-content | 树节点的内容区的渲染 Function | Function | — |
84
+ | highlight-current | 是否高亮当前选中节点,默认值是 false。 | boolean | false |
85
+ | default-expand-all | 是否默认展开所有节点 | boolean | false |
86
+ | expand-on-click-node | 是否在点击节点的时候展开或者收缩节点, 默认值为 true,如果为 false,则只有点箭头图标的时候才会展开或者收缩节点。 | boolean | true |
87
+ | check-on-click-node | 是否在点击节点的时候选中节点,默认值为 false,即只有在点击复选框时才会选中节点。 | boolean | false |
88
+ | auto-expand-parent | 展开子节点的时候是否自动展开父节点 | boolean | true |
89
+ | default-expanded-keys | 默认展开的节点的 key 的数组 | object | — |
90
+ | show-checkbox | 节点是否可被选择 | boolean | false |
91
+ | check-strictly | 在显示复选框的情况下,是否严格的遵循父子不互相关联的做法,默认为 false | boolean | false |
92
+ | default-checked-keys | 默认勾选的节点的 key 的数组 | object | — |
93
+ | current-node-key | 当前选中的节点 | string / number | — |
94
+ | filter-node-method | 对树节点进行筛选时执行的方法, 返回 false 则表示这个节点会被隐藏 | Function | — |
95
+ | accordion | 是否每次只打开一个同级树节点展开 | boolean | false |
96
+ | indent | 相邻级节点间的水平缩进,单位为像素 | number | 18 |
97
+ | icon | 自定义树节点图标组件 | string / Component | — |
98
+ | lazy | 是否懒加载子节点,需与 load 方法结合使用 | boolean | false |
99
+ | draggable | 是否开启拖拽节点功能 | boolean | false |
100
+ | allow-drag | 判断节点能否被拖拽 如果返回 false ,节点不能被拖动 | Function | — |
101
+ | allow-drop | 拖拽时判定目标节点能否成为拖动目标位置。 如果返回 false ,拖动节点不能被拖放到目标节点。 type 参数有三种情况:'prev'、'inner' 和 'next',分别表示放置在目标节点前、插入至目标节点和放置在目标节点后 | Function | — |
102
+
103
+ <!-- | check-on-click-leaf | 点击叶节点(最后一个子节点)时是否选中或取消选中节点。 | boolean | true | -->
104
+
105
+ ### Props
106
+
107
+ | Props | 说明 | 类型 | 默认值 |
108
+ | -------- | ------------------------------- | ----------------- | --- |
109
+ | label | 指定节点标签为节点对象的某个属性值 | string / Function | — |
110
+ | children | 指定子树为节点对象的某个属性值 | string | — |
111
+ | disabled | 指定节点选择框是否禁用为节点对象的某个属性值 | string / Function | — |
112
+ | isLeaf | 指定节点是否为叶子节点,仅在指定了 lazy 属性的情况下生效 | string / Function | — |
113
+ | class | 自定义节点类名 | string / Function | — |
114
+
115
+ ### 方法
116
+
117
+ `Tree` 组件有以下方法,均返回当前选中的节点数组
118
+
119
+ | 方法 | 说明 | 回调参数 |
120
+ | ------------------- | ----------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------- |
121
+ | filter | 过滤所有树节点,过滤后的节点将被隐藏 | 接收一个参数并指定为 filter-node-method 属性的第一个参数 |
122
+ | updateKeyChildren | 为节点设置新数据,只有当设置 node-key 属性的时候才可用 | (key, data) 接收两个参数: 1\. 节点的 key 2\. 新数据 |
123
+ | getCheckedNodes | 如果节点可以被选中,(show-checkbox 为 true), 本方法将返回当前选中节点的数组 | (leafOnly, includeHalfChecked) 接收两个布尔类型参数: 1\. 默认值为 false. 若参数为 true, 它将返回当前选中节点的子节点 2\. 默认值为 false. 如果参数为 true, 返回值包含半选中节点数据 |
124
+ | setCheckedNodes | 设置目前选中的节点,使用此方法必须设置 node-key 属性 | (nodes, leafOnly) 接收两个参数: 1\. 要选中的节点对象构成的数组 2\. 布尔类型的值 如果设置为 true,将只设置选中的叶子节点状态。 默认值是 false. |
125
+ | getCheckedKeys | 若节点可用被选中 (show-checkbox 为 true), 它将返回当前选中节点 key 的数组 | (leafOnly) 接收一个布尔类型参数,默认为 false. 若参数为 true, 它将返回当前选中节点的子节点 |
126
+ | setCheckedKeys | 设置目前选中的节点,使用此方法必须设置 node-key 属性 | (keys, leafOnly) 接收两个参数: 1\. 一个需要被选中的多节点 key 的数组 2\. 布尔类型的值 如果设置为 true,将只设置选中的叶子节点状态。 默认值是 false. |
127
+ | setChecked | 设置节点是否被选中, 使用此方法必须设置 node-key 属性 | (key/data, checked, deep) 接收三个参数: 1\. 要选中的节点的 key 或者数据 2\. 一个布尔类型参数表明是否选中. 3\. 一个布尔类型的参数,用于指示是否为深层(deep)操作(注意:check-strictly 必须为 false)。 |
128
+ | getHalfCheckedNodes | 如果节点可用被选中 (show-checkbox 为 true), 它将返回当前半选中的节点组成的数组 | ::: |
129
+ | getHalfCheckedKeys | 若节点可被选中(show-checkbox 为 true),则返回目前半选中的节点的 key 所组成的数组 | ::: |
130
+ | getCurrentKey | 返回当前被选中节点的数据 (如果没有则返回 null) | ::: |
131
+ | getCurrentNode | 返回当前被选中节点的数据 (如果没有则返回 null) | ::: |
132
+ | setCurrentKey | 通过 key 设置某个节点的当前选中状态,使用此方法必须设置 node-key 属性 | (key, shouldAutoExpandParent=true) 1\. 待被选节点的 key, 如果为 null, 取消当前选中的节点 2\. 是否展开父节点 |
133
+ | setCurrentNode | 设置节点为选中状态,使用此方法必须设置 node-key 属性 | (node, shouldAutoExpandParent=true) 1\. 待被选中的节点 2\. 是否展开父节点 |
134
+ | getNode | 根据 data 或者 key 拿到 Tree 组件中的 node | (data) 节点的 data 或 key |
135
+ | remove | 删除 Tree 中的一个节点,使用此方法必须设置 node-key 属性 | (data) 要删除的节点的 data 或者 node 对象 |
136
+ | append | 为 Tree 中的一个节点追加一个子节点 | (data, parentNode) 1\. 要追加的子节点的 data 2\. 父节点的 data, key 或 node |
137
+ | insertBefore | 在 Tree 中给定节点前插入一个节点 | (data, refNode) 1\. 要增加的节点的 data 2\. 参考节点的 data, key 或 node |
138
+ | insertAfter | 在 Tree 中给定节点后插入一个节点 | (data, refNode) 1\. 要增加的节点的 data 2\. 参考节点的 data, key 或 node |
139
+
140
+ ### 事件
141
+
142
+ | 方法名 | 说明 | 类型 |
143
+ | ---------------- | -------------------------------- | --------------------------------------------------------------------------------------------------------------- |
144
+ | node-click | 当节点被点击的时候触发 | 四个参数:对应于节点点击的节点对象,TreeNode 的 node 属性, TreeNode和事件对象 |
145
+ | node-contextmenu | 当某一节点被鼠标右键点击时会触发该事件 | 共四个参数,依次为:event、传递给 data 属性的数组中该节点所对应的对象、节点对应的 Node、节点组件本身。 |
146
+ | check-change | 当复选框被点击的时候触发 | 共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点本身是否被选中、节点的子树中是否有被选中的节点 |
147
+ | check | 点击节点复选框之后触发 | 共两个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、树目前的选中状态对象,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性 |
148
+ | current-change | 当前选中节点变化时触发的事件 | 共两个参数,依次为:当前节点的数据,当前节点的 Node 对象 |
149
+ | node-expand | 节点被展开时触发的事件 | 共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点对应的 Node、节点组件本身 |
150
+ | node-collapse | 节点被关闭时触发的事件 | 共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点对应的 Node、节点组件本身 |
151
+ | node-drag-start | 节点开始拖拽时触发的事件 | 共两个参数,依次为:被拖拽节点对应的 Node、event |
152
+ | node-drag-enter | 拖拽进入其他节点时触发的事件 | 共三个参数,依次为:被拖拽节点对应的 Node、所进入节点对应的 Node、event |
153
+ | node-drag-leave | 拖拽离开某个节点时触发的事件 | 共三个参数,依次为:被拖拽节点对应的 Node、所离开节点对应的 Node、event |
154
+ | node-drag-over | 在拖拽节点时触发的事件(类似浏览器的 mouseover 事件) | 共三个参数,依次为:被拖拽节点对应的 Node、当前进入节点对应的 Node、event |
155
+ | node-drag-end | 拖拽结束时(可能未成功)触发的事件 | 共四个参数,依次为:被拖拽节点对应的 Node、结束拖拽时最后进入的节点(可能为空)、被拖拽节点的放置位置(before、after、inner)、event |
156
+ | node-drop | 拖拽成功完成时触发的事件 | 共四个参数,依次为:被拖拽节点对应的 Node、结束拖拽时最后进入的节点、被拖拽节点的放置位置(before、after、inner)、event |
157
+
158
+ ### 插槽
159
+
160
+ | 插槽名 | 描述 | Type |
161
+ | ------- | ---------- | ------ |
162
+ | default | 自定义树节点的内容。 | object |
163
+ | empty | 当数据为空时自定义的内容 | ::: |
@@ -0,0 +1,113 @@
1
+ # Button 按钮
2
+
3
+ 常用的操作按钮。
4
+
5
+ ## 基础用法
6
+
7
+ ### 基础按钮样式
8
+ 使用 type、plain 来定义按钮的样式。
9
+ round属性和circle为element-plus保留用法。
10
+
11
+ :::preview
12
+
13
+ demo-preview=../examples/button/demo1.vue
14
+
15
+ :::
16
+
17
+ ### 禁用按钮样式
18
+ 你可以使用 disabled 属性来定义按钮是否被禁用。
19
+
20
+ 使用 disabled 属性来控制按钮是否为禁用状态。 该属性接受一个 Boolean 类型的值。
21
+
22
+ :::preview
23
+
24
+ demo-preview=../examples/button/demo2.vue
25
+
26
+ :::
27
+
28
+ ### 文字按钮
29
+ 没有边框和背景色的按钮。
30
+
31
+ :::preview
32
+
33
+ demo-preview=../examples/button/demo3.vue
34
+
35
+ :::
36
+
37
+ ### 图标按钮​
38
+ 使用图标为按钮添加更多的含义。 你也可以单独使用图标不添加文字来节省显示区域占用。
39
+
40
+ 使用 icon 属性来为按钮添加图标。 您可以在我们的 Icon 组件中找到所需图标。 通过向右方添加`<i>`标签来添加图标, 你也可以使用自定义图标。
41
+
42
+ :::preview
43
+
44
+ demo-preview=../examples/button/demo4.vue
45
+
46
+ :::
47
+
48
+ ### 加载状态按钮
49
+ 点击按钮来加载数据,并向用户反馈加载状态。
50
+
51
+ 通过设置 loading 属性为 true 来显示加载中状态。
52
+
53
+
54
+ >TIP
55
+ >
56
+ >您可以使用 loading 插槽或 loadingIcon属性自定义您的loading图标
57
+ >
58
+ >ps: loading 插槽优先级高于loadingIcon属性
59
+ :::preview
60
+
61
+ demo-preview=../examples/button/demo5.vue
62
+
63
+ :::
64
+
65
+ ### 按钮尺寸
66
+ 除了默认的大小,按钮组件还提供了几种额外的尺寸可供选择,以便适配不同的场景。
67
+
68
+ 使用 size 属性额外配置尺寸,可使用 large。仍保留small用法。
69
+ :::preview
70
+
71
+ demo-preview=../examples/button/demo6.vue
72
+
73
+ :::
74
+
75
+
76
+ ## Button API
77
+
78
+ ### Button Attributes
79
+
80
+ | 属性名 | 说明 | 类型 | 默认值 |
81
+ | ------ | ---- | -------- | ------ |
82
+ | size | 尺寸 | `'large' \| 'default' \| 'small'` | `'default'` |
83
+ | type | 按钮类型,在设置 color 时,后者优先 | `'default' \| 'primary' \| 'success' \| 'warning' \| 'info' \| 'danger' \| 'text'` | `'default'` |
84
+ | plain | 是否为朴素按钮 | `boolean` | `false` |
85
+ | text | 是否为文字按钮 | `boolean` | `false` |
86
+ | bg | 是否显示文字按钮背景颜色 | `boolean` | `false` |
87
+ | link | 是否为链接按钮 | `boolean` | `false` |
88
+ | round | 是否为圆角按钮 | `boolean` | `false` |
89
+ | circle | 是否为圆形按钮 | `boolean` | `false` |
90
+ | loading | 是否为加载中状态 | `boolean` | `false` |
91
+ | loading-icon | 自定义加载中状态图标组件 | `string \| Component` | `Loading` |
92
+ | disabled | 按钮是否为禁用状态 | `boolean` | `false` |
93
+ | icon | 图标组件(支持字符串、组件对象,字符串时使用ad-icon渲染) | `string \| Component` | — |
94
+ | autofocus | 原生 autofocus 属性 | `boolean` | `false` |
95
+ | native-type | 原生 type 属性 | `'button' \| 'submit' \| 'reset'` | `'button'` |
96
+ | auto-insert-space | 两个中文字符之间自动插入空格(仅当文本长度为 2 且所有字符均为中文时才生效) | `boolean` | `false` |
97
+ | color | 自定义按钮颜色, 并自动计算 hover 和 active 触发后的颜色 | `string` | — |
98
+ | dark | dark 模式, 意味着自动设置 color 为 dark 模式的颜色 | `boolean` | `false` |
99
+ | tag | 自定义元素标签 | `string \| Component` | `'button'` |
100
+
101
+ ### Button Slots
102
+
103
+ | 插槽名 | 说明 |
104
+ | ------ | ---- |
105
+ | default | 按钮内容 |
106
+ | icon | 自定义图标 |
107
+
108
+ ### Button Events
109
+
110
+ | 事件名 | 说明 | 参数 |
111
+ | ------ | ---- | ---- |
112
+ | click | 点击按钮时触发 | `(event: MouseEvent) => void` |
113
+