youwei-element-plus 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 (2687) hide show
  1. package/.editorconfig +10 -0
  2. package/.env +1 -0
  3. package/.gitattributes +6 -0
  4. package/.github/.git_commit_template.txt +2 -0
  5. package/.github/CONTRIBUTING.en-US.md +38 -0
  6. package/.github/CONTRIBUTING.es.md +38 -0
  7. package/.github/CONTRIBUTING.fr-FR.md +38 -0
  8. package/.github/CONTRIBUTING.zh-CN.md +38 -0
  9. package/.github/FUNDING.yml +12 -0
  10. package/.github/ISSUE_TEMPLATE/config.yml +8 -0
  11. package/.github/pull_request_template.md +5 -0
  12. package/.github/renovate.json5 +27 -0
  13. package/.github/triage.yml +13 -0
  14. package/.github/workflows/issue-duplicate.yml +16 -0
  15. package/.github/workflows/issue-inactive.yml +52 -0
  16. package/.github/workflows/issue-labeled.yml +42 -0
  17. package/.github/workflows/issue-open-check.yml +26 -0
  18. package/.github/workflows/issue-remove-inactive.yml +19 -0
  19. package/.github/workflows/lint-commit-message-post.yml +78 -0
  20. package/.github/workflows/lint-commit-message.yml +65 -0
  21. package/.github/workflows/lint-typecheck.yml +40 -0
  22. package/.github/workflows/pr-comment.yml +25 -0
  23. package/.github/workflows/pr-conflict.yml +77 -0
  24. package/.github/workflows/pr-docs-build.yml +86 -0
  25. package/.github/workflows/pr-docs-deploy.yml +102 -0
  26. package/.github/workflows/pr-docs-start.yml +18 -0
  27. package/.github/workflows/pr-welcome.yml +26 -0
  28. package/.github/workflows/publish-build-product.yml +58 -0
  29. package/.github/workflows/publish-docs-deploy-manual.yml +84 -0
  30. package/.github/workflows/publish-docs-deploy.yml +91 -0
  31. package/.github/workflows/publish-npm-nightly.yml +73 -0
  32. package/.github/workflows/publish-npm.yml +68 -0
  33. package/.github/workflows/publish-pr-commit-pkg.yml +57 -0
  34. package/.github/workflows/publish-size-report.yml +31 -0
  35. package/.github/workflows/staging-docs.yml +86 -0
  36. package/.github/workflows/test-coverage.yml +40 -0
  37. package/.github/workflows/test-ssr.yml +43 -0
  38. package/.github/workflows/test-unit.yml +43 -0
  39. package/.gitpod.yml +3 -0
  40. package/.husky/commit-msg +1 -0
  41. package/.husky/pre-commit +1 -0
  42. package/.markdownlint.json +4 -0
  43. package/.nvmrc +1 -0
  44. package/.prettierignore +7 -0
  45. package/.prettierrc +13 -0
  46. package/.vscode/extensions.json +12 -0
  47. package/.vscode/launch.json +27 -0
  48. package/.vscode/settings.json +47 -0
  49. package/CHANGELOG.en-US.md +6760 -0
  50. package/CODEOWNERS +1 -0
  51. package/CODE_OF_CONDUCT.md +76 -0
  52. package/CONTRIBUTING.md +118 -0
  53. package/LICENSE +21 -0
  54. package/README.md +147 -0
  55. package/breakings/2.2.0/button.yml +17 -0
  56. package/breakings/2.2.1/button.yml +12 -0
  57. package/breakings/2.2.1/input-number.yml +12 -0
  58. package/breakings/2.2.3/image.yml +12 -0
  59. package/breakings/breaking.yml.example +18 -0
  60. package/codecov.yml +9 -0
  61. package/commitlint.config.mjs +115 -0
  62. package/docs/.vitepress/build/crowdin-credentials.ts +31 -0
  63. package/docs/.vitepress/build/crowdin-generate.ts +113 -0
  64. package/docs/.vitepress/build/generate-llms.ts +139 -0
  65. package/docs/.vitepress/config/analytics.ts +15 -0
  66. package/docs/.vitepress/config/features.ts +1 -0
  67. package/docs/.vitepress/config/head.ts +105 -0
  68. package/docs/.vitepress/config/index.mts +116 -0
  69. package/docs/.vitepress/config/nav.ts +24 -0
  70. package/docs/.vitepress/config/plugins.ts +22 -0
  71. package/docs/.vitepress/config/sidebars.ts +51 -0
  72. package/docs/.vitepress/config/sponsors.ts +58 -0
  73. package/docs/.vitepress/config/vite.ts +126 -0
  74. package/docs/.vitepress/crowdin/en-US/component/anchor.json +14 -0
  75. package/docs/.vitepress/crowdin/en-US/component/api-typing.json +3 -0
  76. package/docs/.vitepress/crowdin/en-US/component/changelog.json +5 -0
  77. package/docs/.vitepress/crowdin/en-US/component/component-meta.json +5 -0
  78. package/docs/.vitepress/crowdin/en-US/component/demo-block.json +12 -0
  79. package/docs/.vitepress/crowdin/en-US/component/edit-link.json +4 -0
  80. package/docs/.vitepress/crowdin/en-US/component/footer.json +7 -0
  81. package/docs/.vitepress/crowdin/en-US/component/icons.json +4 -0
  82. package/docs/.vitepress/crowdin/en-US/component/last-update-at.json +3 -0
  83. package/docs/.vitepress/crowdin/en-US/component/navbar.json +4 -0
  84. package/docs/.vitepress/crowdin/en-US/component/overview.json +3 -0
  85. package/docs/.vitepress/crowdin/en-US/component/search.json +47 -0
  86. package/docs/.vitepress/crowdin/en-US/component/skip-link.json +3 -0
  87. package/docs/.vitepress/crowdin/en-US/component/sponsor.json +6 -0
  88. package/docs/.vitepress/crowdin/en-US/component/translation.json +4 -0
  89. package/docs/.vitepress/crowdin/en-US/pages/component.json +383 -0
  90. package/docs/.vitepress/crowdin/en-US/pages/guide.json +88 -0
  91. package/docs/.vitepress/crowdin/en-US/pages/home.json +29 -0
  92. package/docs/.vitepress/crowdin/en-US/pages/not-found.json +5 -0
  93. package/docs/.vitepress/crowdin/en-US/pages/resource.json +18 -0
  94. package/docs/.vitepress/crowdin/en-US/pages/sidebar.json +21 -0
  95. package/docs/.vitepress/env.d.ts +6 -0
  96. package/docs/.vitepress/i18n/component/anchor.json +16 -0
  97. package/docs/.vitepress/i18n/component/api-typing.json +5 -0
  98. package/docs/.vitepress/i18n/component/changelog.json +7 -0
  99. package/docs/.vitepress/i18n/component/component-meta.json +7 -0
  100. package/docs/.vitepress/i18n/component/demo-block.json +14 -0
  101. package/docs/.vitepress/i18n/component/edit-link.json +6 -0
  102. package/docs/.vitepress/i18n/component/footer.json +9 -0
  103. package/docs/.vitepress/i18n/component/icons.json +6 -0
  104. package/docs/.vitepress/i18n/component/last-update-at.json +5 -0
  105. package/docs/.vitepress/i18n/component/navbar.json +6 -0
  106. package/docs/.vitepress/i18n/component/overview.json +5 -0
  107. package/docs/.vitepress/i18n/component/search.json +49 -0
  108. package/docs/.vitepress/i18n/component/skip-link.json +5 -0
  109. package/docs/.vitepress/i18n/component/sponsor.json +8 -0
  110. package/docs/.vitepress/i18n/component/translation.json +6 -0
  111. package/docs/.vitepress/i18n/lang.json +1 -0
  112. package/docs/.vitepress/i18n/pages/component.json +385 -0
  113. package/docs/.vitepress/i18n/pages/guide.json +90 -0
  114. package/docs/.vitepress/i18n/pages/home.json +31 -0
  115. package/docs/.vitepress/i18n/pages/not-found.json +7 -0
  116. package/docs/.vitepress/i18n/pages/resource.json +20 -0
  117. package/docs/.vitepress/i18n/pages/sidebar.json +23 -0
  118. package/docs/.vitepress/plugins/api-table.ts +35 -0
  119. package/docs/.vitepress/plugins/component-changelog.ts +31 -0
  120. package/docs/.vitepress/plugins/demo.ts +60 -0
  121. package/docs/.vitepress/plugins/external-link-icon.ts +40 -0
  122. package/docs/.vitepress/plugins/headers.ts +29 -0
  123. package/docs/.vitepress/plugins/markdown-transform.ts +177 -0
  124. package/docs/.vitepress/plugins/table-wrapper.ts +6 -0
  125. package/docs/.vitepress/plugins/tag.ts +30 -0
  126. package/docs/.vitepress/plugins/tooltip.ts +29 -0
  127. package/docs/.vitepress/theme/index.ts +29 -0
  128. package/docs/.vitepress/theme/style.css +71 -0
  129. package/docs/.vitepress/utils/changelog-parser.ts +235 -0
  130. package/docs/.vitepress/utils/lang.ts +10 -0
  131. package/docs/.vitepress/utils/ts2js.ts +45 -0
  132. package/docs/.vitepress/utils/types.ts +1 -0
  133. package/docs/.vitepress/vitepress/components/common/vp-link.vue +36 -0
  134. package/docs/.vitepress/vitepress/components/common/vp-markdown.vue +36 -0
  135. package/docs/.vitepress/vitepress/components/common/vp-theme-toggler.vue +118 -0
  136. package/docs/.vitepress/vitepress/components/demo/vp-source-code.vue +31 -0
  137. package/docs/.vitepress/vitepress/components/dev/a11y-tag.vue +18 -0
  138. package/docs/.vitepress/vitepress/components/dev/deprecated-tag.vue +5 -0
  139. package/docs/.vitepress/vitepress/components/dev/version-tag.vue +11 -0
  140. package/docs/.vitepress/vitepress/components/doc-content/vp-edit-link.vue +34 -0
  141. package/docs/.vitepress/vitepress/components/doc-content/vp-page-footer.vue +35 -0
  142. package/docs/.vitepress/vitepress/components/doc-content/vp-page-nav.vue +93 -0
  143. package/docs/.vitepress/vitepress/components/doc-content/vp-table-of-content.vue +71 -0
  144. package/docs/.vitepress/vitepress/components/full-screen/vp-menu-link.vue +43 -0
  145. package/docs/.vitepress/vitepress/components/full-screen/vp-menu.vue +23 -0
  146. package/docs/.vitepress/vitepress/components/full-screen/vp-theme-toggler.vue +30 -0
  147. package/docs/.vitepress/vitepress/components/full-screen/vp-translation.vue +97 -0
  148. package/docs/.vitepress/vitepress/components/globals/contributors.vue +48 -0
  149. package/docs/.vitepress/vitepress/components/globals/design/consistency-svg.vue +73 -0
  150. package/docs/.vitepress/vitepress/components/globals/design/controllability-svg.vue +80 -0
  151. package/docs/.vitepress/vitepress/components/globals/design/efficiency-svg.vue +74 -0
  152. package/docs/.vitepress/vitepress/components/globals/design/feedback-svg.vue +52 -0
  153. package/docs/.vitepress/vitepress/components/globals/design-guide.vue +58 -0
  154. package/docs/.vitepress/vitepress/components/globals/icons-categories.json +332 -0
  155. package/docs/.vitepress/vitepress/components/globals/icons.vue +267 -0
  156. package/docs/.vitepress/vitepress/components/globals/main-color.vue +33 -0
  157. package/docs/.vitepress/vitepress/components/globals/neutral-color.vue +161 -0
  158. package/docs/.vitepress/vitepress/components/globals/overview.vue +219 -0
  159. package/docs/.vitepress/vitepress/components/globals/parallax-home.vue +397 -0
  160. package/docs/.vitepress/vitepress/components/globals/resource.vue +167 -0
  161. package/docs/.vitepress/vitepress/components/globals/resources/axure-components-svg.vue +169 -0
  162. package/docs/.vitepress/vitepress/components/globals/resources/figma-template-svg.vue +86 -0
  163. package/docs/.vitepress/vitepress/components/globals/resources/figma-ui-kit-svg.vue +164 -0
  164. package/docs/.vitepress/vitepress/components/globals/resources/figma-variables-svg.vue +193 -0
  165. package/docs/.vitepress/vitepress/components/globals/resources/master-go-ui-kit-svg.vue +337 -0
  166. package/docs/.vitepress/vitepress/components/globals/resources/sketch-template-svg.vue +82 -0
  167. package/docs/.vitepress/vitepress/components/globals/secondary-colors.vue +40 -0
  168. package/docs/.vitepress/vitepress/components/globals/vp-api-bool.vue +7 -0
  169. package/docs/.vitepress/vitepress/components/globals/vp-api-enum.vue +20 -0
  170. package/docs/.vitepress/vitepress/components/globals/vp-api-external.vue +33 -0
  171. package/docs/.vitepress/vitepress/components/globals/vp-api-function.vue +40 -0
  172. package/docs/.vitepress/vitepress/components/globals/vp-api-number.vue +7 -0
  173. package/docs/.vitepress/vitepress/components/globals/vp-api-primitive.vue +14 -0
  174. package/docs/.vitepress/vitepress/components/globals/vp-api-ref.vue +21 -0
  175. package/docs/.vitepress/vitepress/components/globals/vp-api-string.vue +7 -0
  176. package/docs/.vitepress/vitepress/components/globals/vp-api-typing.vue +46 -0
  177. package/docs/.vitepress/vitepress/components/globals/vp-changelog.vue +128 -0
  178. package/docs/.vitepress/vitepress/components/globals/vp-component-meta.vue +278 -0
  179. package/docs/.vitepress/vitepress/components/globals/vp-footer.vue +191 -0
  180. package/docs/.vitepress/vitepress/components/home/home-cards.vue +127 -0
  181. package/docs/.vitepress/vitepress/components/home/home-sponsors.vue +74 -0
  182. package/docs/.vitepress/vitepress/components/home/sponsor-list.vue +66 -0
  183. package/docs/.vitepress/vitepress/components/home/svg/component-svg.vue +83 -0
  184. package/docs/.vitepress/vitepress/components/home/svg/guide-svg.vue +52 -0
  185. package/docs/.vitepress/vitepress/components/home/svg/left-bottom-layer-svg.vue +114 -0
  186. package/docs/.vitepress/vitepress/components/home/svg/left-layer-svg.vue +51 -0
  187. package/docs/.vitepress/vitepress/components/home/svg/people-svg.vue +139 -0
  188. package/docs/.vitepress/vitepress/components/home/svg/resource-svg.vue +66 -0
  189. package/docs/.vitepress/vitepress/components/home/svg/right-layer-svg.vue +55 -0
  190. package/docs/.vitepress/vitepress/components/home/svg/screen-svg.vue +146 -0
  191. package/docs/.vitepress/vitepress/components/icons/back-to-top.vue +8 -0
  192. package/docs/.vitepress/vitepress/components/icons/codepen.vue +8 -0
  193. package/docs/.vitepress/vitepress/components/icons/dark.vue +8 -0
  194. package/docs/.vitepress/vitepress/components/icons/element-plus-logo.vue +8 -0
  195. package/docs/.vitepress/vitepress/components/icons/element-plus-text-logo.vue +24 -0
  196. package/docs/.vitepress/vitepress/components/icons/expand.vue +8 -0
  197. package/docs/.vitepress/vitepress/components/icons/light.vue +8 -0
  198. package/docs/.vitepress/vitepress/components/icons/playground.vue +15 -0
  199. package/docs/.vitepress/vitepress/components/icons/toggle-button.vue +14 -0
  200. package/docs/.vitepress/vitepress/components/nav/l1-categories.vue +55 -0
  201. package/docs/.vitepress/vitepress/components/nav/l2-categories.vue +82 -0
  202. package/docs/.vitepress/vitepress/components/nav/l3-categories.vue +61 -0
  203. package/docs/.vitepress/vitepress/components/nav/top-navigation-example.vue +37 -0
  204. package/docs/.vitepress/vitepress/components/navbar/vp-hamburger.vue +23 -0
  205. package/docs/.vitepress/vitepress/components/navbar/vp-menu-link.vue +83 -0
  206. package/docs/.vitepress/vitepress/components/navbar/vp-menu.vue +12 -0
  207. package/docs/.vitepress/vitepress/components/navbar/vp-search.vue +231 -0
  208. package/docs/.vitepress/vitepress/components/navbar/vp-social-link.vue +40 -0
  209. package/docs/.vitepress/vitepress/components/navbar/vp-social-links.vue +19 -0
  210. package/docs/.vitepress/vitepress/components/navbar/vp-theme-toggler.vue +34 -0
  211. package/docs/.vitepress/vitepress/components/navbar/vp-translation.vue +84 -0
  212. package/docs/.vitepress/vitepress/components/overview-icons/index.ts +162 -0
  213. package/docs/.vitepress/vitepress/components/overview-icons/ov-affix.vue +107 -0
  214. package/docs/.vitepress/vitepress/components/overview-icons/ov-alert.vue +265 -0
  215. package/docs/.vitepress/vitepress/components/overview-icons/ov-anchor.vue +69 -0
  216. package/docs/.vitepress/vitepress/components/overview-icons/ov-avatar.vue +60 -0
  217. package/docs/.vitepress/vitepress/components/overview-icons/ov-backtop.vue +55 -0
  218. package/docs/.vitepress/vitepress/components/overview-icons/ov-badge.vue +68 -0
  219. package/docs/.vitepress/vitepress/components/overview-icons/ov-border.vue +120 -0
  220. package/docs/.vitepress/vitepress/components/overview-icons/ov-breadcrumb.vue +47 -0
  221. package/docs/.vitepress/vitepress/components/overview-icons/ov-button.vue +62 -0
  222. package/docs/.vitepress/vitepress/components/overview-icons/ov-calendar.vue +327 -0
  223. package/docs/.vitepress/vitepress/components/overview-icons/ov-card.vue +104 -0
  224. package/docs/.vitepress/vitepress/components/overview-icons/ov-carousel.vue +199 -0
  225. package/docs/.vitepress/vitepress/components/overview-icons/ov-cascader.vue +236 -0
  226. package/docs/.vitepress/vitepress/components/overview-icons/ov-checkbox.vue +72 -0
  227. package/docs/.vitepress/vitepress/components/overview-icons/ov-collapse.vue +143 -0
  228. package/docs/.vitepress/vitepress/components/overview-icons/ov-color-picker-panel.vue +184 -0
  229. package/docs/.vitepress/vitepress/components/overview-icons/ov-color-picker.vue +217 -0
  230. package/docs/.vitepress/vitepress/components/overview-icons/ov-color.vue +32 -0
  231. package/docs/.vitepress/vitepress/components/overview-icons/ov-config-provider.vue +107 -0
  232. package/docs/.vitepress/vitepress/components/overview-icons/ov-container.vue +79 -0
  233. package/docs/.vitepress/vitepress/components/overview-icons/ov-date-picker-panel.vue +364 -0
  234. package/docs/.vitepress/vitepress/components/overview-icons/ov-date-picker.vue +391 -0
  235. package/docs/.vitepress/vitepress/components/overview-icons/ov-datetime-picker.vue +395 -0
  236. package/docs/.vitepress/vitepress/components/overview-icons/ov-descriptions.vue +120 -0
  237. package/docs/.vitepress/vitepress/components/overview-icons/ov-dialog.vue +104 -0
  238. package/docs/.vitepress/vitepress/components/overview-icons/ov-divider.vue +120 -0
  239. package/docs/.vitepress/vitepress/components/overview-icons/ov-drawer.vue +199 -0
  240. package/docs/.vitepress/vitepress/components/overview-icons/ov-dropdown.vue +109 -0
  241. package/docs/.vitepress/vitepress/components/overview-icons/ov-empty.vue +63 -0
  242. package/docs/.vitepress/vitepress/components/overview-icons/ov-form.vue +86 -0
  243. package/docs/.vitepress/vitepress/components/overview-icons/ov-icon.vue +186 -0
  244. package/docs/.vitepress/vitepress/components/overview-icons/ov-image.vue +101 -0
  245. package/docs/.vitepress/vitepress/components/overview-icons/ov-infinite-scroll.vue +108 -0
  246. package/docs/.vitepress/vitepress/components/overview-icons/ov-input-number.vue +73 -0
  247. package/docs/.vitepress/vitepress/components/overview-icons/ov-input-tag.vue +46 -0
  248. package/docs/.vitepress/vitepress/components/overview-icons/ov-input.vue +77 -0
  249. package/docs/.vitepress/vitepress/components/overview-icons/ov-layout.vue +99 -0
  250. package/docs/.vitepress/vitepress/components/overview-icons/ov-link.vue +24 -0
  251. package/docs/.vitepress/vitepress/components/overview-icons/ov-loading.vue +26 -0
  252. package/docs/.vitepress/vitepress/components/overview-icons/ov-mention.vue +104 -0
  253. package/docs/.vitepress/vitepress/components/overview-icons/ov-menu.vue +122 -0
  254. package/docs/.vitepress/vitepress/components/overview-icons/ov-message-box.vue +107 -0
  255. package/docs/.vitepress/vitepress/components/overview-icons/ov-message.vue +79 -0
  256. package/docs/.vitepress/vitepress/components/overview-icons/ov-notification.vue +79 -0
  257. package/docs/.vitepress/vitepress/components/overview-icons/ov-page-header.vue +38 -0
  258. package/docs/.vitepress/vitepress/components/overview-icons/ov-pagination.vue +254 -0
  259. package/docs/.vitepress/vitepress/components/overview-icons/ov-popconfirm.vue +97 -0
  260. package/docs/.vitepress/vitepress/components/overview-icons/ov-popover.vue +93 -0
  261. package/docs/.vitepress/vitepress/components/overview-icons/ov-progress.vue +31 -0
  262. package/docs/.vitepress/vitepress/components/overview-icons/ov-radio.vue +61 -0
  263. package/docs/.vitepress/vitepress/components/overview-icons/ov-rate.vue +181 -0
  264. package/docs/.vitepress/vitepress/components/overview-icons/ov-result.vue +123 -0
  265. package/docs/.vitepress/vitepress/components/overview-icons/ov-scrollbar.vue +71 -0
  266. package/docs/.vitepress/vitepress/components/overview-icons/ov-segmented.vue +91 -0
  267. package/docs/.vitepress/vitepress/components/overview-icons/ov-select-v2.vue +172 -0
  268. package/docs/.vitepress/vitepress/components/overview-icons/ov-select.vue +132 -0
  269. package/docs/.vitepress/vitepress/components/overview-icons/ov-skeleton.vue +44 -0
  270. package/docs/.vitepress/vitepress/components/overview-icons/ov-slider.vue +104 -0
  271. package/docs/.vitepress/vitepress/components/overview-icons/ov-space.vue +193 -0
  272. package/docs/.vitepress/vitepress/components/overview-icons/ov-splitter.vue +109 -0
  273. package/docs/.vitepress/vitepress/components/overview-icons/ov-statistic.vue +87 -0
  274. package/docs/.vitepress/vitepress/components/overview-icons/ov-steps.vue +97 -0
  275. package/docs/.vitepress/vitepress/components/overview-icons/ov-switch.vue +105 -0
  276. package/docs/.vitepress/vitepress/components/overview-icons/ov-table.vue +247 -0
  277. package/docs/.vitepress/vitepress/components/overview-icons/ov-tabs.vue +121 -0
  278. package/docs/.vitepress/vitepress/components/overview-icons/ov-tag.vue +66 -0
  279. package/docs/.vitepress/vitepress/components/overview-icons/ov-text.vue +23 -0
  280. package/docs/.vitepress/vitepress/components/overview-icons/ov-time-picker.vue +192 -0
  281. package/docs/.vitepress/vitepress/components/overview-icons/ov-time-select.vue +126 -0
  282. package/docs/.vitepress/vitepress/components/overview-icons/ov-timeline.vue +78 -0
  283. package/docs/.vitepress/vitepress/components/overview-icons/ov-tooltip.vue +42 -0
  284. package/docs/.vitepress/vitepress/components/overview-icons/ov-tour.vue +102 -0
  285. package/docs/.vitepress/vitepress/components/overview-icons/ov-transfer.vue +314 -0
  286. package/docs/.vitepress/vitepress/components/overview-icons/ov-tree-select.vue +135 -0
  287. package/docs/.vitepress/vitepress/components/overview-icons/ov-tree.vue +106 -0
  288. package/docs/.vitepress/vitepress/components/overview-icons/ov-typography.vue +59 -0
  289. package/docs/.vitepress/vitepress/components/overview-icons/ov-upload.vue +103 -0
  290. package/docs/.vitepress/vitepress/components/overview-icons/ov-watermark.vue +93 -0
  291. package/docs/.vitepress/vitepress/components/sidebar/vp-sidebar-link.vue +87 -0
  292. package/docs/.vitepress/vitepress/components/sponsors/right-big-logo-list.vue +46 -0
  293. package/docs/.vitepress/vitepress/components/sponsors/right-logo-small-list.vue +52 -0
  294. package/docs/.vitepress/vitepress/components/sponsors/right-richtext-list.vue +69 -0
  295. package/docs/.vitepress/vitepress/components/sponsors/sponsors-button.vue +28 -0
  296. package/docs/.vitepress/vitepress/components/subnav/toggle-sidebar-btn.vue +31 -0
  297. package/docs/.vitepress/vitepress/components/vp-app.vue +129 -0
  298. package/docs/.vitepress/vitepress/components/vp-content.vue +30 -0
  299. package/docs/.vitepress/vitepress/components/vp-demo.vue +274 -0
  300. package/docs/.vitepress/vitepress/components/vp-doc-content.vue +19 -0
  301. package/docs/.vitepress/vitepress/components/vp-hero-content.vue +26 -0
  302. package/docs/.vitepress/vitepress/components/vp-nav-full.vue +62 -0
  303. package/docs/.vitepress/vitepress/components/vp-nav.vue +27 -0
  304. package/docs/.vitepress/vitepress/components/vp-navbar.vue +108 -0
  305. package/docs/.vitepress/vitepress/components/vp-not-found.vue +30 -0
  306. package/docs/.vitepress/vitepress/components/vp-overlay.vue +11 -0
  307. package/docs/.vitepress/vitepress/components/vp-sidebar.vue +36 -0
  308. package/docs/.vitepress/vitepress/components/vp-skip-link.vue +67 -0
  309. package/docs/.vitepress/vitepress/components/vp-sponsor-large.vue +70 -0
  310. package/docs/.vitepress/vitepress/components/vp-sponsor-small.vue +63 -0
  311. package/docs/.vitepress/vitepress/components/vp-sponsors.vue +36 -0
  312. package/docs/.vitepress/vitepress/components/vp-subnav.vue +33 -0
  313. package/docs/.vitepress/vitepress/composables/back-top.ts +67 -0
  314. package/docs/.vitepress/vitepress/composables/dark.ts +7 -0
  315. package/docs/.vitepress/vitepress/composables/edit-link.ts +57 -0
  316. package/docs/.vitepress/vitepress/composables/feature-flag.ts +23 -0
  317. package/docs/.vitepress/vitepress/composables/fullscreen.ts +9 -0
  318. package/docs/.vitepress/vitepress/composables/lang.ts +19 -0
  319. package/docs/.vitepress/vitepress/composables/locale.ts +9 -0
  320. package/docs/.vitepress/vitepress/composables/lock-screen.ts +60 -0
  321. package/docs/.vitepress/vitepress/composables/nav.ts +12 -0
  322. package/docs/.vitepress/vitepress/composables/navbar-locale.ts +9 -0
  323. package/docs/.vitepress/vitepress/composables/page-nav.ts +50 -0
  324. package/docs/.vitepress/vitepress/composables/sidebar.ts +81 -0
  325. package/docs/.vitepress/vitepress/composables/social-links.ts +13 -0
  326. package/docs/.vitepress/vitepress/composables/source-code.ts +22 -0
  327. package/docs/.vitepress/vitepress/composables/toggle-widgets.ts +22 -0
  328. package/docs/.vitepress/vitepress/composables/translation.ts +66 -0
  329. package/docs/.vitepress/vitepress/composables/use-issue-count.ts +45 -0
  330. package/docs/.vitepress/vitepress/composables/use-playground.ts +74 -0
  331. package/docs/.vitepress/vitepress/composables/use-toc.ts +45 -0
  332. package/docs/.vitepress/vitepress/composables/useDynamicClass.ts +41 -0
  333. package/docs/.vitepress/vitepress/constant.ts +11 -0
  334. package/docs/.vitepress/vitepress/index.ts +44 -0
  335. package/docs/.vitepress/vitepress/styles/app.scss +9 -0
  336. package/docs/.vitepress/vitepress/styles/base.scss +333 -0
  337. package/docs/.vitepress/vitepress/styles/code.scss +294 -0
  338. package/docs/.vitepress/vitepress/styles/common/hamburger.scss +52 -0
  339. package/docs/.vitepress/vitepress/styles/common/helper.scss +24 -0
  340. package/docs/.vitepress/vitepress/styles/common/index.scss +3 -0
  341. package/docs/.vitepress/vitepress/styles/common/switch.scss +61 -0
  342. package/docs/.vitepress/vitepress/styles/content/doc-content.scss +34 -0
  343. package/docs/.vitepress/vitepress/styles/content/hero-content.scss +8 -0
  344. package/docs/.vitepress/vitepress/styles/content/table-of-content.scss +62 -0
  345. package/docs/.vitepress/vitepress/styles/content/tag-content.scss +30 -0
  346. package/docs/.vitepress/vitepress/styles/content.scss +38 -0
  347. package/docs/.vitepress/vitepress/styles/css-vars.scss +93 -0
  348. package/docs/.vitepress/vitepress/styles/mixins.scss +32 -0
  349. package/docs/.vitepress/vitepress/styles/nav/menu.scss +9 -0
  350. package/docs/.vitepress/vitepress/styles/navbar.scss +72 -0
  351. package/docs/.vitepress/vitepress/styles/overlay.scss +10 -0
  352. package/docs/.vitepress/vitepress/styles/scrollbar.scss +38 -0
  353. package/docs/.vitepress/vitepress/styles/sidebar.scss +68 -0
  354. package/docs/.vitepress/vitepress/styles/subnav.scss +33 -0
  355. package/docs/.vitepress/vitepress/styles/vars.scss +11 -0
  356. package/docs/.vitepress/vitepress/types.ts +6 -0
  357. package/docs/.vitepress/vitepress/utils/colors.ts +63 -0
  358. package/docs/.vitepress/vitepress/utils/index.ts +51 -0
  359. package/docs/components.d.ts +192 -0
  360. package/docs/crowdin.yml +131 -0
  361. package/docs/en-US/component/affix.md +71 -0
  362. package/docs/en-US/component/alert.md +105 -0
  363. package/docs/en-US/component/anchor.md +122 -0
  364. package/docs/en-US/component/autocomplete.md +129 -0
  365. package/docs/en-US/component/avatar.md +102 -0
  366. package/docs/en-US/component/backtop.md +51 -0
  367. package/docs/en-US/component/badge.md +80 -0
  368. package/docs/en-US/component/border.md +38 -0
  369. package/docs/en-US/component/breadcrumb.md +54 -0
  370. package/docs/en-US/component/button.md +198 -0
  371. package/docs/en-US/component/calendar.md +97 -0
  372. package/docs/en-US/component/card.md +70 -0
  373. package/docs/en-US/component/carousel.md +132 -0
  374. package/docs/en-US/component/cascader.md +421 -0
  375. package/docs/en-US/component/checkbox.md +201 -0
  376. package/docs/en-US/component/collapse.md +129 -0
  377. package/docs/en-US/component/color-picker-panel.md +82 -0
  378. package/docs/en-US/component/color-picker.md +86 -0
  379. package/docs/en-US/component/color.md +81 -0
  380. package/docs/en-US/component/config-provider.md +177 -0
  381. package/docs/en-US/component/container.md +144 -0
  382. package/docs/en-US/component/date-picker-panel.md +99 -0
  383. package/docs/en-US/component/date-picker.md +270 -0
  384. package/docs/en-US/component/datetime-picker.md +188 -0
  385. package/docs/en-US/component/descriptions.md +94 -0
  386. package/docs/en-US/component/dialog.md +254 -0
  387. package/docs/en-US/component/divider.md +62 -0
  388. package/docs/en-US/component/drawer.md +171 -0
  389. package/docs/en-US/component/dropdown.md +177 -0
  390. package/docs/en-US/component/empty.md +85 -0
  391. package/docs/en-US/component/form.md +306 -0
  392. package/docs/en-US/component/icon.md +235 -0
  393. package/docs/en-US/component/image.md +190 -0
  394. package/docs/en-US/component/infinite-scroll.md +42 -0
  395. package/docs/en-US/component/input-number.md +154 -0
  396. package/docs/en-US/component/input-tag.md +189 -0
  397. package/docs/en-US/component/input.md +232 -0
  398. package/docs/en-US/component/layout.md +148 -0
  399. package/docs/en-US/component/link.md +119 -0
  400. package/docs/en-US/component/loading.md +132 -0
  401. package/docs/en-US/component/mention.md +166 -0
  402. package/docs/en-US/component/menu.md +229 -0
  403. package/docs/en-US/component/message-box.md +204 -0
  404. package/docs/en-US/component/message.md +146 -0
  405. package/docs/en-US/component/notification.md +154 -0
  406. package/docs/en-US/component/overview.md +10 -0
  407. package/docs/en-US/component/page-header.md +126 -0
  408. package/docs/en-US/component/pagination.md +123 -0
  409. package/docs/en-US/component/popconfirm.md +90 -0
  410. package/docs/en-US/component/popover.md +129 -0
  411. package/docs/en-US/component/progress.md +105 -0
  412. package/docs/en-US/component/radio.md +163 -0
  413. package/docs/en-US/component/rate.md +126 -0
  414. package/docs/en-US/component/result.md +43 -0
  415. package/docs/en-US/component/scrollbar.md +96 -0
  416. package/docs/en-US/component/segmented.md +127 -0
  417. package/docs/en-US/component/select-v2.md +372 -0
  418. package/docs/en-US/component/select.md +372 -0
  419. package/docs/en-US/component/skeleton.md +147 -0
  420. package/docs/en-US/component/slider.md +141 -0
  421. package/docs/en-US/component/space.md +143 -0
  422. package/docs/en-US/component/splitter.md +118 -0
  423. package/docs/en-US/component/statistic.md +100 -0
  424. package/docs/en-US/component/steps.md +123 -0
  425. package/docs/en-US/component/switch.md +148 -0
  426. package/docs/en-US/component/table-v2.md +589 -0
  427. package/docs/en-US/component/table.md +510 -0
  428. package/docs/en-US/component/tabs.md +181 -0
  429. package/docs/en-US/component/tag.md +124 -0
  430. package/docs/en-US/component/text.md +66 -0
  431. package/docs/en-US/component/time-picker.md +121 -0
  432. package/docs/en-US/component/time-select.md +92 -0
  433. package/docs/en-US/component/timeline.md +112 -0
  434. package/docs/en-US/component/tooltip.md +233 -0
  435. package/docs/en-US/component/tour.md +142 -0
  436. package/docs/en-US/component/transfer.md +142 -0
  437. package/docs/en-US/component/tree-select.md +184 -0
  438. package/docs/en-US/component/tree-v2.md +201 -0
  439. package/docs/en-US/component/tree.md +272 -0
  440. package/docs/en-US/component/typography.md +40 -0
  441. package/docs/en-US/component/upload.md +206 -0
  442. package/docs/en-US/component/watermark.md +83 -0
  443. package/docs/en-US/guide/changelog.md +20 -0
  444. package/docs/en-US/guide/commit-examples.md +90 -0
  445. package/docs/en-US/guide/custom-defaults.md +55 -0
  446. package/docs/en-US/guide/dark-mode.md +80 -0
  447. package/docs/en-US/guide/design.md +42 -0
  448. package/docs/en-US/guide/dev-faq.md +41 -0
  449. package/docs/en-US/guide/dev-guide.md +77 -0
  450. package/docs/en-US/guide/i18n.md +145 -0
  451. package/docs/en-US/guide/installation.md +145 -0
  452. package/docs/en-US/guide/migration.md +25 -0
  453. package/docs/en-US/guide/namespace.md +67 -0
  454. package/docs/en-US/guide/nav.md +73 -0
  455. package/docs/en-US/guide/quickstart.md +218 -0
  456. package/docs/en-US/guide/ssr.md +147 -0
  457. package/docs/en-US/guide/theming.md +250 -0
  458. package/docs/en-US/guide/transitions.md +48 -0
  459. package/docs/en-US/guide/translation.md +39 -0
  460. package/docs/en-US/index.md +7 -0
  461. package/docs/en-US/resource/index.md +6 -0
  462. package/docs/examples/.eslintrc.json +7 -0
  463. package/docs/examples/affix/basic.vue +5 -0
  464. package/docs/examples/affix/fixed.vue +5 -0
  465. package/docs/examples/affix/target.vue +16 -0
  466. package/docs/examples/alert/basic.vue +18 -0
  467. package/docs/examples/alert/center.vue +18 -0
  468. package/docs/examples/alert/close-button.vue +23 -0
  469. package/docs/examples/alert/description.vue +9 -0
  470. package/docs/examples/alert/icon-description.vue +45 -0
  471. package/docs/examples/alert/icon.vue +27 -0
  472. package/docs/examples/alert/theme.vue +18 -0
  473. package/docs/examples/anchor/affix.vue +35 -0
  474. package/docs/examples/anchor/basic.vue +33 -0
  475. package/docs/examples/anchor/change.vue +37 -0
  476. package/docs/examples/anchor/horizontal.vue +22 -0
  477. package/docs/examples/anchor/scroll.vue +78 -0
  478. package/docs/examples/anchor/underline.vue +33 -0
  479. package/docs/examples/autocomplete/autocomplete-template.vue +87 -0
  480. package/docs/examples/autocomplete/autocomplete.vue +106 -0
  481. package/docs/examples/autocomplete/custom-header-footer.vue +106 -0
  482. package/docs/examples/autocomplete/custom-loading.vue +198 -0
  483. package/docs/examples/autocomplete/remote-search.vue +60 -0
  484. package/docs/examples/avatar/basic.vue +71 -0
  485. package/docs/examples/avatar/fallback.vue +13 -0
  486. package/docs/examples/avatar/fit.vue +47 -0
  487. package/docs/examples/avatar/group.vue +51 -0
  488. package/docs/examples/avatar/types.vue +33 -0
  489. package/docs/examples/backtop/basic.vue +4 -0
  490. package/docs/examples/backtop/custom.vue +18 -0
  491. package/docs/examples/badge/basic.vue +50 -0
  492. package/docs/examples/badge/customize.vue +37 -0
  493. package/docs/examples/badge/dot.vue +17 -0
  494. package/docs/examples/badge/max.vue +15 -0
  495. package/docs/examples/badge/offset.vue +12 -0
  496. package/docs/examples/border/border.vue +42 -0
  497. package/docs/examples/border/radius.vue +74 -0
  498. package/docs/examples/border/shadow.vue +54 -0
  499. package/docs/examples/breadcrumb/basic.vue +10 -0
  500. package/docs/examples/breadcrumb/icon.vue +12 -0
  501. package/docs/examples/button/basic.vue +78 -0
  502. package/docs/examples/button/custom.vue +27 -0
  503. package/docs/examples/button/disabled.vue +40 -0
  504. package/docs/examples/button/group.vue +33 -0
  505. package/docs/examples/button/icon.vue +15 -0
  506. package/docs/examples/button/link.vue +37 -0
  507. package/docs/examples/button/loading.vue +46 -0
  508. package/docs/examples/button/size.vue +27 -0
  509. package/docs/examples/button/tag.vue +13 -0
  510. package/docs/examples/button/text.vue +50 -0
  511. package/docs/examples/calendar/basic.vue +9 -0
  512. package/docs/examples/calendar/controller-type.vue +15 -0
  513. package/docs/examples/calendar/customize.vue +16 -0
  514. package/docs/examples/calendar/header.vue +35 -0
  515. package/docs/examples/calendar/range.vue +3 -0
  516. package/docs/examples/card/basic.vue +11 -0
  517. package/docs/examples/card/shadow.vue +7 -0
  518. package/docs/examples/card/simple.vue +5 -0
  519. package/docs/examples/card/with-images.vue +9 -0
  520. package/docs/examples/carousel/arrows.vue +25 -0
  521. package/docs/examples/carousel/auto-height.vue +43 -0
  522. package/docs/examples/carousel/basic.vue +42 -0
  523. package/docs/examples/carousel/card.vue +25 -0
  524. package/docs/examples/carousel/indicator.vue +25 -0
  525. package/docs/examples/carousel/motion-blur.vue +43 -0
  526. package/docs/examples/carousel/vertical.vue +37 -0
  527. package/docs/examples/cascader/any-level.vue +290 -0
  528. package/docs/examples/cascader/basic.vue +298 -0
  529. package/docs/examples/cascader/check-on-click-node.vue +114 -0
  530. package/docs/examples/cascader/clear-icon.vue +25 -0
  531. package/docs/examples/cascader/clearable.vue +274 -0
  532. package/docs/examples/cascader/custom-content.vue +279 -0
  533. package/docs/examples/cascader/custom-header-footer.vue +121 -0
  534. package/docs/examples/cascader/custom-suggestion-item.vue +278 -0
  535. package/docs/examples/cascader/custom-tag.vue +128 -0
  536. package/docs/examples/cascader/dynamic-loading.vue +24 -0
  537. package/docs/examples/cascader/filterable.vue +294 -0
  538. package/docs/examples/cascader/last-level.vue +274 -0
  539. package/docs/examples/cascader/multiple-selection.vue +119 -0
  540. package/docs/examples/cascader/option-disabling.vue +275 -0
  541. package/docs/examples/cascader/panel.vue +274 -0
  542. package/docs/examples/cascader/show-checked-strategy.vue +110 -0
  543. package/docs/examples/checkbox/basic.vue +25 -0
  544. package/docs/examples/checkbox/button-style.vue +51 -0
  545. package/docs/examples/checkbox/disabled.vue +11 -0
  546. package/docs/examples/checkbox/grouping.vue +19 -0
  547. package/docs/examples/checkbox/intermediate.vue +38 -0
  548. package/docs/examples/checkbox/limitation.vue +14 -0
  549. package/docs/examples/checkbox/options.vue +21 -0
  550. package/docs/examples/checkbox/with-border.vue +32 -0
  551. package/docs/examples/collapse/accordion.vue +56 -0
  552. package/docs/examples/collapse/basic.vue +61 -0
  553. package/docs/examples/collapse/custom-icon-position.vue +59 -0
  554. package/docs/examples/collapse/custom-icon.vue +74 -0
  555. package/docs/examples/collapse/customization.vue +74 -0
  556. package/docs/examples/collapse/prevent-collapsing.vue +79 -0
  557. package/docs/examples/color-picker/alpha.vue +9 -0
  558. package/docs/examples/color-picker/basic.vue +28 -0
  559. package/docs/examples/color-picker/predefined-color.vue +25 -0
  560. package/docs/examples/color-picker/sizes.vue +19 -0
  561. package/docs/examples/color-picker-panel/alpha.vue +9 -0
  562. package/docs/examples/color-picker-panel/basic.vue +9 -0
  563. package/docs/examples/color-picker-panel/border.vue +30 -0
  564. package/docs/examples/color-picker-panel/disabled.vue +23 -0
  565. package/docs/examples/color-picker-panel/predefined-color.vue +29 -0
  566. package/docs/examples/config-provider/button.vue +40 -0
  567. package/docs/examples/config-provider/card.vue +24 -0
  568. package/docs/examples/config-provider/dialog.vue +213 -0
  569. package/docs/examples/config-provider/empty-values.vue +69 -0
  570. package/docs/examples/config-provider/link.vue +40 -0
  571. package/docs/examples/config-provider/message.vue +22 -0
  572. package/docs/examples/config-provider/table.vue +77 -0
  573. package/docs/examples/config-provider/usage.vue +24 -0
  574. package/docs/examples/container/common-layout.scss +31 -0
  575. package/docs/examples/container/example.vue +128 -0
  576. package/docs/examples/container/layout-ahm.vue +11 -0
  577. package/docs/examples/container/layout-ahmf.vue +12 -0
  578. package/docs/examples/container/layout-am.vue +9 -0
  579. package/docs/examples/container/layout-ham.vue +11 -0
  580. package/docs/examples/container/layout-hamf.vue +14 -0
  581. package/docs/examples/container/layout-hm.vue +8 -0
  582. package/docs/examples/container/layout-hmf.vue +9 -0
  583. package/docs/examples/date-picker/custom-content.vue +105 -0
  584. package/docs/examples/date-picker/custom-icon.vue +290 -0
  585. package/docs/examples/date-picker/custom-prefix-icon.vue +49 -0
  586. package/docs/examples/date-picker/date-formats.vue +106 -0
  587. package/docs/examples/date-picker/date-range.vue +117 -0
  588. package/docs/examples/date-picker/default-time.vue +43 -0
  589. package/docs/examples/date-picker/default-value.vue +75 -0
  590. package/docs/examples/date-picker/enter-date.vue +107 -0
  591. package/docs/examples/date-picker/month-range.vue +99 -0
  592. package/docs/examples/date-picker/other-measurements.vue +126 -0
  593. package/docs/examples/date-picker/single-panel.vue +90 -0
  594. package/docs/examples/date-picker/year-range.vue +102 -0
  595. package/docs/examples/date-picker-panel/all-types.vue +48 -0
  596. package/docs/examples/date-picker-panel/basic.vue +11 -0
  597. package/docs/examples/date-picker-panel/border.vue +45 -0
  598. package/docs/examples/date-picker-panel/disabled.vue +17 -0
  599. package/docs/examples/datetime-picker/custom-icon.vue +162 -0
  600. package/docs/examples/datetime-picker/date-and-time-formats-panel.vue +78 -0
  601. package/docs/examples/datetime-picker/date-and-time-formats.vue +90 -0
  602. package/docs/examples/datetime-picker/date-and-time-range.vue +114 -0
  603. package/docs/examples/datetime-picker/date-and-time.vue +108 -0
  604. package/docs/examples/datetime-picker/default-time.vue +88 -0
  605. package/docs/examples/datetime-picker/single-panel.vue +38 -0
  606. package/docs/examples/descriptions/basic-usage.vue +13 -0
  607. package/docs/examples/descriptions/customized-style.vue +35 -0
  608. package/docs/examples/descriptions/rowspan.vue +52 -0
  609. package/docs/examples/descriptions/sizes.vue +144 -0
  610. package/docs/examples/descriptions/vertical-list.vue +68 -0
  611. package/docs/examples/dialog/align-center.vue +28 -0
  612. package/docs/examples/dialog/basic-usage.vue +39 -0
  613. package/docs/examples/dialog/centered-content.vue +26 -0
  614. package/docs/examples/dialog/custom-animation.vue +159 -0
  615. package/docs/examples/dialog/customization-content.vue +83 -0
  616. package/docs/examples/dialog/customization-header.vue +34 -0
  617. package/docs/examples/dialog/destroy-on-close.vue +35 -0
  618. package/docs/examples/dialog/draggable-dialog.vue +79 -0
  619. package/docs/examples/dialog/events.vue +37 -0
  620. package/docs/examples/dialog/fullscreen.vue +23 -0
  621. package/docs/examples/dialog/modal.vue +23 -0
  622. package/docs/examples/dialog/nested-dialog.vue +32 -0
  623. package/docs/examples/divider/basic-usage.vue +13 -0
  624. package/docs/examples/divider/custom-content.vue +19 -0
  625. package/docs/examples/divider/line-dashed.vue +11 -0
  626. package/docs/examples/divider/vertical-divider.vue +9 -0
  627. package/docs/examples/drawer/basic-usage.vue +78 -0
  628. package/docs/examples/drawer/customization-content.vue +131 -0
  629. package/docs/examples/drawer/customization-header.vue +22 -0
  630. package/docs/examples/drawer/modal.vue +23 -0
  631. package/docs/examples/drawer/nested-drawer.vue +35 -0
  632. package/docs/examples/drawer/no-title.vue +13 -0
  633. package/docs/examples/drawer/resizable.vue +21 -0
  634. package/docs/examples/dropdown/basic-usage.vue +32 -0
  635. package/docs/examples/dropdown/command-event.vue +34 -0
  636. package/docs/examples/dropdown/dropdown-methods.vue +62 -0
  637. package/docs/examples/dropdown/how-to-trigger.vue +86 -0
  638. package/docs/examples/dropdown/menu-hiding-behavior.vue +33 -0
  639. package/docs/examples/dropdown/placements.vue +64 -0
  640. package/docs/examples/dropdown/sizes.vue +43 -0
  641. package/docs/examples/dropdown/triggering-element.vue +51 -0
  642. package/docs/examples/dropdown/virtual-trigger.vue +83 -0
  643. package/docs/examples/empty/basic-usage.vue +3 -0
  644. package/docs/examples/empty/bottom-content.vue +5 -0
  645. package/docs/examples/empty/custom-image.vue +5 -0
  646. package/docs/examples/empty/image-size.vue +3 -0
  647. package/docs/examples/form/accessibility.vue +49 -0
  648. package/docs/examples/form/alignment.vue +50 -0
  649. package/docs/examples/form/basic-form.vue +85 -0
  650. package/docs/examples/form/custom-validation.vue +105 -0
  651. package/docs/examples/form/form-items.vue +104 -0
  652. package/docs/examples/form/inline-form.vue +52 -0
  653. package/docs/examples/form/number-validate.vue +56 -0
  654. package/docs/examples/form/size-control.vue +105 -0
  655. package/docs/examples/form/validation.vue +207 -0
  656. package/docs/examples/image/basic-usage.vue +44 -0
  657. package/docs/examples/image/custom-progress.vue +28 -0
  658. package/docs/examples/image/custom-toolbar.vue +83 -0
  659. package/docs/examples/image/image-preview.vue +42 -0
  660. package/docs/examples/image/lazy-load.vue +32 -0
  661. package/docs/examples/image/load-failed.vue +82 -0
  662. package/docs/examples/image/manually-preview.vue +52 -0
  663. package/docs/examples/image/placeholder.vue +59 -0
  664. package/docs/examples/infinite-scroll/basic.vue +35 -0
  665. package/docs/examples/infinite-scroll/disable-loading.vue +53 -0
  666. package/docs/examples/input/auto-sizing-textarea.vue +24 -0
  667. package/docs/examples/input/basic.vue +9 -0
  668. package/docs/examples/input/clear-icon.vue +33 -0
  669. package/docs/examples/input/clearable.vue +32 -0
  670. package/docs/examples/input/count-graphemes.vue +40 -0
  671. package/docs/examples/input/disabled.vue +14 -0
  672. package/docs/examples/input/formatter.vue +15 -0
  673. package/docs/examples/input/length-limiting.vue +46 -0
  674. package/docs/examples/input/mixed-input.vue +74 -0
  675. package/docs/examples/input/password.vue +40 -0
  676. package/docs/examples/input/textarea.vue +15 -0
  677. package/docs/examples/input/various-size.vue +74 -0
  678. package/docs/examples/input/with-icon.vue +91 -0
  679. package/docs/examples/input-number/basic.vue +12 -0
  680. package/docs/examples/input-number/controlled.vue +36 -0
  681. package/docs/examples/input-number/custom.vue +41 -0
  682. package/docs/examples/input-number/disabled.vue +9 -0
  683. package/docs/examples/input-number/precision.vue +9 -0
  684. package/docs/examples/input-number/size.vue +15 -0
  685. package/docs/examples/input-number/step-strictly.vue +9 -0
  686. package/docs/examples/input-number/steps.vue +9 -0
  687. package/docs/examples/input-number/with-prefix-suffix.vue +20 -0
  688. package/docs/examples/input-tag/basic.vue +13 -0
  689. package/docs/examples/input-tag/clear-icon.vue +15 -0
  690. package/docs/examples/input-tag/clearable.vue +9 -0
  691. package/docs/examples/input-tag/collapse.vue +36 -0
  692. package/docs/examples/input-tag/delimiter.vue +14 -0
  693. package/docs/examples/input-tag/disabled.vue +9 -0
  694. package/docs/examples/input-tag/draggable.vue +9 -0
  695. package/docs/examples/input-tag/max.vue +9 -0
  696. package/docs/examples/input-tag/prefix-suffix.vue +17 -0
  697. package/docs/examples/input-tag/size.vue +13 -0
  698. package/docs/examples/input-tag/tag.vue +42 -0
  699. package/docs/examples/input-tag/trigger.vue +16 -0
  700. package/docs/examples/layout/alignment.vue +49 -0
  701. package/docs/examples/layout/basic-layout.vue +79 -0
  702. package/docs/examples/layout/column-offset.vue +38 -0
  703. package/docs/examples/layout/column-spacing.vue +25 -0
  704. package/docs/examples/layout/hybrid-layout.vue +34 -0
  705. package/docs/examples/layout/index.scss +30 -0
  706. package/docs/examples/layout/responsive-layout.vue +27 -0
  707. package/docs/examples/link/basic.vue +16 -0
  708. package/docs/examples/link/disabled.vue +16 -0
  709. package/docs/examples/link/underline.vue +14 -0
  710. package/docs/examples/link/with-icon.vue +18 -0
  711. package/docs/examples/loading/basic.vue +40 -0
  712. package/docs/examples/loading/customization.vue +66 -0
  713. package/docs/examples/loading/fullscreen.vue +34 -0
  714. package/docs/examples/mention/basic.vue +33 -0
  715. package/docs/examples/mention/form.vue +77 -0
  716. package/docs/examples/mention/label.vue +40 -0
  717. package/docs/examples/mention/loading.vue +40 -0
  718. package/docs/examples/mention/prefix.vue +29 -0
  719. package/docs/examples/mention/props.vue +36 -0
  720. package/docs/examples/mention/textarea.vue +34 -0
  721. package/docs/examples/mention/whole.vue +47 -0
  722. package/docs/examples/menu/basic.vue +60 -0
  723. package/docs/examples/menu/collapse.vue +69 -0
  724. package/docs/examples/menu/left-and-right.vue +45 -0
  725. package/docs/examples/menu/popper-offset.vue +39 -0
  726. package/docs/examples/menu/vertical.vue +101 -0
  727. package/docs/examples/message/basic.vue +26 -0
  728. package/docs/examples/message/closable.vue +58 -0
  729. package/docs/examples/message/different-types.vue +35 -0
  730. package/docs/examples/message/grouping.vue +15 -0
  731. package/docs/examples/message/placement.vue +71 -0
  732. package/docs/examples/message/plain.vue +49 -0
  733. package/docs/examples/message/raw-html.vue +14 -0
  734. package/docs/examples/message-box/alert.vue +23 -0
  735. package/docs/examples/message-box/centered-content.vue +32 -0
  736. package/docs/examples/message-box/confirm.vue +31 -0
  737. package/docs/examples/message-box/customization.vue +40 -0
  738. package/docs/examples/message-box/customized-icon.vue +34 -0
  739. package/docs/examples/message-box/distinguishable-close-cancel.vue +36 -0
  740. package/docs/examples/message-box/draggable.vue +101 -0
  741. package/docs/examples/message-box/prompt.vue +29 -0
  742. package/docs/examples/message-box/use-html.vue +17 -0
  743. package/docs/examples/message-box/use-vnode.vue +36 -0
  744. package/docs/examples/notification/basic.vue +30 -0
  745. package/docs/examples/notification/different-types.vue +53 -0
  746. package/docs/examples/notification/no-close.vue +15 -0
  747. package/docs/examples/notification/offsetting.vue +15 -0
  748. package/docs/examples/notification/positioning.vue +43 -0
  749. package/docs/examples/notification/raw-html.vue +15 -0
  750. package/docs/examples/notification/use-vnode.vue +36 -0
  751. package/docs/examples/page-header/additional-sections.vue +24 -0
  752. package/docs/examples/page-header/basic.vue +13 -0
  753. package/docs/examples/page-header/breadcrumb.vue +18 -0
  754. package/docs/examples/page-header/complete.vue +69 -0
  755. package/docs/examples/page-header/custom-icon.vue +11 -0
  756. package/docs/examples/page-header/main-content.vue +11 -0
  757. package/docs/examples/page-header/no-icon.vue +7 -0
  758. package/docs/examples/pagination/auto-hide-pagination.vue +17 -0
  759. package/docs/examples/pagination/background-color.vue +3 -0
  760. package/docs/examples/pagination/basic-usage.vue +19 -0
  761. package/docs/examples/pagination/more-elements.vue +111 -0
  762. package/docs/examples/pagination/number-of-pagers.vue +8 -0
  763. package/docs/examples/pagination/small-pagination.vue +10 -0
  764. package/docs/examples/popconfirm/basic-usage.vue +7 -0
  765. package/docs/examples/popconfirm/customize.vue +34 -0
  766. package/docs/examples/popconfirm/placement.vue +139 -0
  767. package/docs/examples/popconfirm/trigger-event.vue +26 -0
  768. package/docs/examples/popover/basic-usage.vue +76 -0
  769. package/docs/examples/popover/directive-usage.vue +27 -0
  770. package/docs/examples/popover/nested-information.vue +79 -0
  771. package/docs/examples/popover/nested-operation.vue +20 -0
  772. package/docs/examples/popover/placement.vue +134 -0
  773. package/docs/examples/popover/virtual-triggering.vue +28 -0
  774. package/docs/examples/progress/circular-progress-bar.vue +15 -0
  775. package/docs/examples/progress/custom-color.vue +61 -0
  776. package/docs/examples/progress/customized-content.vue +48 -0
  777. package/docs/examples/progress/dashboard-progress-bar.vue +56 -0
  778. package/docs/examples/progress/indeterminate-progress.vue +30 -0
  779. package/docs/examples/progress/internal-percentage.vue +30 -0
  780. package/docs/examples/progress/linear-progress-bar.vue +20 -0
  781. package/docs/examples/progress/striped-progress.vue +60 -0
  782. package/docs/examples/radio/basic-usage.vue +28 -0
  783. package/docs/examples/radio/disabled.vue +12 -0
  784. package/docs/examples/radio/options.vue +25 -0
  785. package/docs/examples/radio/radio-button.vue +32 -0
  786. package/docs/examples/radio/radio-group.vue +13 -0
  787. package/docs/examples/radio/with-borders.vue +35 -0
  788. package/docs/examples/rate/allow-half.vue +9 -0
  789. package/docs/examples/rate/basic-usage.vue +38 -0
  790. package/docs/examples/rate/clearable.vue +9 -0
  791. package/docs/examples/rate/more-icons.vue +16 -0
  792. package/docs/examples/rate/readonly.vue +15 -0
  793. package/docs/examples/rate/sizes.vue +13 -0
  794. package/docs/examples/rate/text.vue +13 -0
  795. package/docs/examples/result/basic-usage.vue +60 -0
  796. package/docs/examples/result/customized-content.vue +12 -0
  797. package/docs/examples/scrollbar/basic-usage.vue +19 -0
  798. package/docs/examples/scrollbar/horizontal-scroll.vue +29 -0
  799. package/docs/examples/scrollbar/infinite-scroll.vue +38 -0
  800. package/docs/examples/scrollbar/manual-scroll.vue +58 -0
  801. package/docs/examples/scrollbar/max-height.vue +38 -0
  802. package/docs/examples/segmented/basic.vue +15 -0
  803. package/docs/examples/segmented/block.vue +21 -0
  804. package/docs/examples/segmented/custom-content.vue +61 -0
  805. package/docs/examples/segmented/custom-direction.vue +98 -0
  806. package/docs/examples/segmented/custom-style.vue +21 -0
  807. package/docs/examples/segmented/disabled.vue +45 -0
  808. package/docs/examples/segmented/props.vue +49 -0
  809. package/docs/examples/select/allow-create.vue +39 -0
  810. package/docs/examples/select/basic-usage.vue +39 -0
  811. package/docs/examples/select/clearable.vue +43 -0
  812. package/docs/examples/select/custom-footer.vue +89 -0
  813. package/docs/examples/select/custom-header.vue +94 -0
  814. package/docs/examples/select/custom-label.vue +71 -0
  815. package/docs/examples/select/custom-loading.vue +230 -0
  816. package/docs/examples/select/custom-tag.vue +64 -0
  817. package/docs/examples/select/custom-template.vue +53 -0
  818. package/docs/examples/select/disabled-option.vue +40 -0
  819. package/docs/examples/select/disabled.vue +38 -0
  820. package/docs/examples/select/empty-values.vue +56 -0
  821. package/docs/examples/select/filterable.vue +43 -0
  822. package/docs/examples/select/grouping.vue +58 -0
  823. package/docs/examples/select/multiple.vue +103 -0
  824. package/docs/examples/select/options.vue +47 -0
  825. package/docs/examples/select/remote-search.vue +134 -0
  826. package/docs/examples/select/size.vue +67 -0
  827. package/docs/examples/select/value-key.vue +38 -0
  828. package/docs/examples/select-v2/allow-create.vue +58 -0
  829. package/docs/examples/select-v2/basic-usage.vue +20 -0
  830. package/docs/examples/select-v2/clearable.vue +30 -0
  831. package/docs/examples/select-v2/custom-footer.vue +81 -0
  832. package/docs/examples/select-v2/custom-header.vue +70 -0
  833. package/docs/examples/select-v2/custom-label.vue +44 -0
  834. package/docs/examples/select-v2/custom-loading.vue +220 -0
  835. package/docs/examples/select-v2/custom-tag.vue +65 -0
  836. package/docs/examples/select-v2/custom-width.vue +43 -0
  837. package/docs/examples/select-v2/customized-option.vue +29 -0
  838. package/docs/examples/select-v2/disabled.vue +32 -0
  839. package/docs/examples/select-v2/empty-values.vue +35 -0
  840. package/docs/examples/select-v2/filterable.vue +22 -0
  841. package/docs/examples/select-v2/grouping.vue +29 -0
  842. package/docs/examples/select-v2/hide-extra-tags.vue +52 -0
  843. package/docs/examples/select-v2/multiple.vue +23 -0
  844. package/docs/examples/select-v2/props.vue +26 -0
  845. package/docs/examples/select-v2/remote-search.vue +118 -0
  846. package/docs/examples/select-v2/size.vue +42 -0
  847. package/docs/examples/select-v2/use-valueKey.vue +30 -0
  848. package/docs/examples/skeleton/animation.vue +3 -0
  849. package/docs/examples/skeleton/avoiding-rendering-bouncing.vue +55 -0
  850. package/docs/examples/skeleton/basic-usage.vue +9 -0
  851. package/docs/examples/skeleton/configurable-rows.vue +3 -0
  852. package/docs/examples/skeleton/customized-template.vue +20 -0
  853. package/docs/examples/skeleton/initial-rendering-loading.vue +55 -0
  854. package/docs/examples/skeleton/leading-trailing-without-bouncing.vue +55 -0
  855. package/docs/examples/skeleton/loading-state.vue +50 -0
  856. package/docs/examples/skeleton/rendering-with-data.vue +95 -0
  857. package/docs/examples/slider/basic-usage.vue +61 -0
  858. package/docs/examples/slider/discrete-values.vue +42 -0
  859. package/docs/examples/slider/placement.vue +35 -0
  860. package/docs/examples/slider/range-selection.vue +23 -0
  861. package/docs/examples/slider/restrict-value.vue +73 -0
  862. package/docs/examples/slider/show-marks.vue +43 -0
  863. package/docs/examples/slider/sizes.vue +27 -0
  864. package/docs/examples/slider/slider-with-input-box.vue +23 -0
  865. package/docs/examples/slider/vertical-mode.vue +23 -0
  866. package/docs/examples/space/alignment.vue +41 -0
  867. package/docs/examples/space/auto-wrapping.vue +7 -0
  868. package/docs/examples/space/basic.vue +15 -0
  869. package/docs/examples/space/control-size.vue +31 -0
  870. package/docs/examples/space/customized-size.vue +22 -0
  871. package/docs/examples/space/fill-ratio.vue +40 -0
  872. package/docs/examples/space/fill.vue +24 -0
  873. package/docs/examples/space/literal-type-spacer.vue +13 -0
  874. package/docs/examples/space/vertical-layout.vue +15 -0
  875. package/docs/examples/space/vnode-type-spacer.vue +15 -0
  876. package/docs/examples/splitter/basic.vue +23 -0
  877. package/docs/examples/splitter/collapsible.vue +49 -0
  878. package/docs/examples/splitter/disableDrag.vue +41 -0
  879. package/docs/examples/splitter/lazy.vue +26 -0
  880. package/docs/examples/splitter/size.vue +48 -0
  881. package/docs/examples/splitter/vertical.vue +23 -0
  882. package/docs/examples/statistic/basic.vue +44 -0
  883. package/docs/examples/statistic/card.vue +148 -0
  884. package/docs/examples/statistic/countdown.vue +50 -0
  885. package/docs/examples/steps/basic.vue +19 -0
  886. package/docs/examples/steps/centered.vue +7 -0
  887. package/docs/examples/steps/simple.vue +23 -0
  888. package/docs/examples/steps/vertical.vue +9 -0
  889. package/docs/examples/steps/with-description.vue +7 -0
  890. package/docs/examples/steps/with-icon.vue +11 -0
  891. package/docs/examples/steps/with-status.vue +12 -0
  892. package/docs/examples/switch/basic.vue +15 -0
  893. package/docs/examples/switch/custom-action-icon.vue +14 -0
  894. package/docs/examples/switch/custom-action-slot.vue +16 -0
  895. package/docs/examples/switch/custom-icons.vue +20 -0
  896. package/docs/examples/switch/disabled.vue +11 -0
  897. package/docs/examples/switch/extended-value-types.vue +16 -0
  898. package/docs/examples/switch/loading.vue +11 -0
  899. package/docs/examples/switch/prevent-switching.vue +45 -0
  900. package/docs/examples/switch/sizes.vue +23 -0
  901. package/docs/examples/switch/text-description.vue +58 -0
  902. package/docs/examples/table/basic.vue +32 -0
  903. package/docs/examples/table/check-strictly.vue +77 -0
  904. package/docs/examples/table/custom-column.vue +79 -0
  905. package/docs/examples/table/custom-header.vue +71 -0
  906. package/docs/examples/table/custom-index.vue +52 -0
  907. package/docs/examples/table/expandable-row.vue +259 -0
  908. package/docs/examples/table/filter.vue +105 -0
  909. package/docs/examples/table/fixed-column-and-group-header.vue +73 -0
  910. package/docs/examples/table/fixed-column-and-header.vue +71 -0
  911. package/docs/examples/table/fixed-column.vue +63 -0
  912. package/docs/examples/table/fixed-header-with-fluid-header.vue +75 -0
  913. package/docs/examples/table/fixed-header.vue +47 -0
  914. package/docs/examples/table/grouping-header.vue +75 -0
  915. package/docs/examples/table/multi-select.vue +104 -0
  916. package/docs/examples/table/rowspan-and-colspan.vue +122 -0
  917. package/docs/examples/table/show-overflow-tooltip.vue +46 -0
  918. package/docs/examples/table/single-select.vue +62 -0
  919. package/docs/examples/table/sort.vue +48 -0
  920. package/docs/examples/table/striped.vue +32 -0
  921. package/docs/examples/table/summary.vue +110 -0
  922. package/docs/examples/table/table-layout.vue +42 -0
  923. package/docs/examples/table/tooltip-formatter.vue +91 -0
  924. package/docs/examples/table/tree-and-lazy.vue +132 -0
  925. package/docs/examples/table/with-border.vue +32 -0
  926. package/docs/examples/table/with-status.vue +66 -0
  927. package/docs/examples/table-v2/auto-resizer.vue +47 -0
  928. package/docs/examples/table-v2/basic.vue +41 -0
  929. package/docs/examples/table-v2/cell-templating.vue +78 -0
  930. package/docs/examples/table-v2/colspan.vue +64 -0
  931. package/docs/examples/table-v2/controlled-sort.vue +61 -0
  932. package/docs/examples/table-v2/cross-hovering.vue +94 -0
  933. package/docs/examples/table-v2/detailed-view.vue +86 -0
  934. package/docs/examples/table-v2/dynamic-height.vue +99 -0
  935. package/docs/examples/table-v2/empty.vue +29 -0
  936. package/docs/examples/table-v2/filter.vue +151 -0
  937. package/docs/examples/table-v2/fixed-columns.vue +64 -0
  938. package/docs/examples/table-v2/footer.vue +56 -0
  939. package/docs/examples/table-v2/grouping-header.vue +131 -0
  940. package/docs/examples/table-v2/inline-editing.vue +128 -0
  941. package/docs/examples/table-v2/manual-scroll.vue +75 -0
  942. package/docs/examples/table-v2/overlay.vue +60 -0
  943. package/docs/examples/table-v2/row-class.vue +88 -0
  944. package/docs/examples/table-v2/rowspan.vue +61 -0
  945. package/docs/examples/table-v2/selection.vue +114 -0
  946. package/docs/examples/table-v2/sort.vue +61 -0
  947. package/docs/examples/table-v2/spans.vue +86 -0
  948. package/docs/examples/table-v2/sticky-rows.vue +71 -0
  949. package/docs/examples/table-v2/tree-data.vue +128 -0
  950. package/docs/examples/tabs/basic.vue +29 -0
  951. package/docs/examples/tabs/border-card.vue +8 -0
  952. package/docs/examples/tabs/card-style.vue +34 -0
  953. package/docs/examples/tabs/custom-tab.vue +36 -0
  954. package/docs/examples/tabs/customized-add-button-icon.vue +84 -0
  955. package/docs/examples/tabs/customized-trigger.vue +80 -0
  956. package/docs/examples/tabs/default-value.vue +47 -0
  957. package/docs/examples/tabs/dynamic-tabs.vue +79 -0
  958. package/docs/examples/tabs/tab-position.vue +37 -0
  959. package/docs/examples/tag/basic.vue +9 -0
  960. package/docs/examples/tag/checkable.vue +72 -0
  961. package/docs/examples/tag/editable.vue +55 -0
  962. package/docs/examples/tag/removable.vue +26 -0
  963. package/docs/examples/tag/rounded.vue +51 -0
  964. package/docs/examples/tag/sizes.vue +7 -0
  965. package/docs/examples/tag/theme.vue +51 -0
  966. package/docs/examples/text/basic.vue +8 -0
  967. package/docs/examples/text/mixed.vue +26 -0
  968. package/docs/examples/text/override.vue +19 -0
  969. package/docs/examples/text/sizes.vue +5 -0
  970. package/docs/examples/text/truncated.vue +13 -0
  971. package/docs/examples/time-picker/basic-range.vue +49 -0
  972. package/docs/examples/time-picker/basic.vue +23 -0
  973. package/docs/examples/time-picker/range.vue +42 -0
  974. package/docs/examples/time-select/basic.vue +16 -0
  975. package/docs/examples/time-select/time-formats.vue +17 -0
  976. package/docs/examples/time-select/time-range.vue +29 -0
  977. package/docs/examples/timeline/basic.vue +28 -0
  978. package/docs/examples/timeline/center.vue +22 -0
  979. package/docs/examples/timeline/custom-node.vue +56 -0
  980. package/docs/examples/timeline/custom-timestamp.vue +22 -0
  981. package/docs/examples/timeline/mode.vue +41 -0
  982. package/docs/examples/timeline/reverse.vue +33 -0
  983. package/docs/examples/tooltip/advanced-usage.vue +18 -0
  984. package/docs/examples/tooltip/animations.vue +23 -0
  985. package/docs/examples/tooltip/append-to.vue +27 -0
  986. package/docs/examples/tooltip/basic.vue +128 -0
  987. package/docs/examples/tooltip/controlled.vue +16 -0
  988. package/docs/examples/tooltip/html-content.vue +8 -0
  989. package/docs/examples/tooltip/rich-content.vue +6 -0
  990. package/docs/examples/tooltip/singleton.vue +49 -0
  991. package/docs/examples/tooltip/theme.vue +25 -0
  992. package/docs/examples/tooltip/virtual-trigger.vue +43 -0
  993. package/docs/examples/tour/basic.vue +45 -0
  994. package/docs/examples/tour/indicator.vue +45 -0
  995. package/docs/examples/tour/mask.vue +59 -0
  996. package/docs/examples/tour/non-modal.vue +42 -0
  997. package/docs/examples/tour/placement.vue +34 -0
  998. package/docs/examples/tour/target.vue +37 -0
  999. package/docs/examples/transfer/basic.vue +28 -0
  1000. package/docs/examples/transfer/customizable.vue +109 -0
  1001. package/docs/examples/transfer/empty-content.vue +34 -0
  1002. package/docs/examples/transfer/filterable.vue +48 -0
  1003. package/docs/examples/transfer/prop-alias.vue +35 -0
  1004. package/docs/examples/transitions/collapse.vue +33 -0
  1005. package/docs/examples/transitions/fade.vue +41 -0
  1006. package/docs/examples/transitions/zoom.vue +55 -0
  1007. package/docs/examples/tree/accordion.vue +82 -0
  1008. package/docs/examples/tree/basic.vue +82 -0
  1009. package/docs/examples/tree/checking-tree.vue +119 -0
  1010. package/docs/examples/tree/custom-leaf.vue +45 -0
  1011. package/docs/examples/tree/custom-node-class.vue +98 -0
  1012. package/docs/examples/tree/customized-node.vue +177 -0
  1013. package/docs/examples/tree/default-state.vue +68 -0
  1014. package/docs/examples/tree/disabled.vue +56 -0
  1015. package/docs/examples/tree/draggable.vue +124 -0
  1016. package/docs/examples/tree/filtering.vue +95 -0
  1017. package/docs/examples/tree/multiple-times-load.vue +34 -0
  1018. package/docs/examples/tree/selectable.vue +66 -0
  1019. package/docs/examples/tree-select/basic.vue +94 -0
  1020. package/docs/examples/tree-select/check-strictly.vue +107 -0
  1021. package/docs/examples/tree-select/disabled.vue +83 -0
  1022. package/docs/examples/tree-select/filterable.vue +110 -0
  1023. package/docs/examples/tree-select/lazy.vue +54 -0
  1024. package/docs/examples/tree-select/multiple.vue +109 -0
  1025. package/docs/examples/tree-select/node-key.vue +33 -0
  1026. package/docs/examples/tree-select/slots.vue +104 -0
  1027. package/docs/examples/tree-v2/basic.vue +51 -0
  1028. package/docs/examples/tree-v2/custom-icon.vue +69 -0
  1029. package/docs/examples/tree-v2/custom-node-class.vue +85 -0
  1030. package/docs/examples/tree-v2/custom-node.vue +75 -0
  1031. package/docs/examples/tree-v2/default-state.vue +69 -0
  1032. package/docs/examples/tree-v2/disabled.vue +55 -0
  1033. package/docs/examples/tree-v2/filter.vue +69 -0
  1034. package/docs/examples/tree-v2/selectable.vue +52 -0
  1035. package/docs/examples/typography/convention.vue +64 -0
  1036. package/docs/examples/typography/font.vue +31 -0
  1037. package/docs/examples/typography/line-height.vue +20 -0
  1038. package/docs/examples/upload/avatar.vue +71 -0
  1039. package/docs/examples/upload/basic.vue +63 -0
  1040. package/docs/examples/upload/custom-thumbnail.vue +61 -0
  1041. package/docs/examples/upload/directory.vue +25 -0
  1042. package/docs/examples/upload/drag-and-drop.vue +22 -0
  1043. package/docs/examples/upload/file-list-with-thumbnail.vue +42 -0
  1044. package/docs/examples/upload/file-list.vue +36 -0
  1045. package/docs/examples/upload/limit-cover.vue +42 -0
  1046. package/docs/examples/upload/manual.vue +34 -0
  1047. package/docs/examples/upload/photo-wall.vue +69 -0
  1048. package/docs/examples/watermark/basic.vue +26 -0
  1049. package/docs/examples/watermark/custom.vue +114 -0
  1050. package/docs/examples/watermark/image.vue +9 -0
  1051. package/docs/examples/watermark/multi-line.vue +26 -0
  1052. package/docs/index.md +7 -0
  1053. package/docs/package.json +46 -0
  1054. package/docs/public/.nojekyll +0 -0
  1055. package/docs/public/CORS +1 -0
  1056. package/docs/public/images/CRMEB-l.jpg +0 -0
  1057. package/docs/public/images/CRMEB.png +0 -0
  1058. package/docs/public/images/Module.svg +62 -0
  1059. package/docs/public/images/baidayun-logo.png +0 -0
  1060. package/docs/public/images/baidayun.png +0 -0
  1061. package/docs/public/images/bit-l.png +0 -0
  1062. package/docs/public/images/bit.svg +27 -0
  1063. package/docs/public/images/buildadmin-l.png +0 -0
  1064. package/docs/public/images/buildadmin.png +0 -0
  1065. package/docs/public/images/cloud-1.png +0 -0
  1066. package/docs/public/images/cloud-2.png +0 -0
  1067. package/docs/public/images/compo-1.png +0 -0
  1068. package/docs/public/images/compo-2.png +0 -0
  1069. package/docs/public/images/compo-3.png +0 -0
  1070. package/docs/public/images/duohui.svg +24 -0
  1071. package/docs/public/images/element-demo.jpeg +0 -0
  1072. package/docs/public/images/element-plus-logo-small.svg +1 -0
  1073. package/docs/public/images/element-plus-logo.svg +1 -0
  1074. package/docs/public/images/element-plus-og-image.png +0 -0
  1075. package/docs/public/images/fantastic-admin-l.png +0 -0
  1076. package/docs/public/images/fantastic-admin.png +0 -0
  1077. package/docs/public/images/figure-1.png +0 -0
  1078. package/docs/public/images/figure-2.png +0 -0
  1079. package/docs/public/images/formmaking.png +0 -0
  1080. package/docs/public/images/frsimple-l.png +0 -0
  1081. package/docs/public/images/frsimple.png +0 -0
  1082. package/docs/public/images/hamburger.png +0 -0
  1083. package/docs/public/images/home/left-bottom-layer.svg +28 -0
  1084. package/docs/public/images/intro-theme-b.png +0 -0
  1085. package/docs/public/images/jeeplus.png +0 -0
  1086. package/docs/public/images/jeeplus_banner.jpg +0 -0
  1087. package/docs/public/images/jnpf_index.png +0 -0
  1088. package/docs/public/images/jnpfsoft.png +0 -0
  1089. package/docs/public/images/js-design-banner.jpg +0 -0
  1090. package/docs/public/images/js-design.png +0 -0
  1091. package/docs/public/images/mele-banner.png +0 -0
  1092. package/docs/public/images/mele.png +0 -0
  1093. package/docs/public/images/misboot-left.png +0 -0
  1094. package/docs/public/images/misboot-logo.png +0 -0
  1095. package/docs/public/images/plant-1.png +0 -0
  1096. package/docs/public/images/plant-2.png +0 -0
  1097. package/docs/public/images/qrcode.png +0 -0
  1098. package/docs/public/images/renren.png +0 -0
  1099. package/docs/public/images/resource-placeholder.svg +23 -0
  1100. package/docs/public/images/search-by-algolia.svg +1 -0
  1101. package/docs/public/images/theme-index-blue-dark.png +0 -0
  1102. package/docs/public/images/theme-index-blue.png +0 -0
  1103. package/docs/public/images/theme-index-icon.svg +1 -0
  1104. package/docs/public/images/theme-intro.png +0 -0
  1105. package/docs/public/images/typography/line-height-dark.png +0 -0
  1106. package/docs/public/images/typography/line-height.png +0 -0
  1107. package/docs/public/images/typography/term-arial-dark.png +0 -0
  1108. package/docs/public/images/typography/term-arial.png +0 -0
  1109. package/docs/public/images/typography/term-helvetica-dark.png +0 -0
  1110. package/docs/public/images/typography/term-helvetica.png +0 -0
  1111. package/docs/public/images/typography/term-hiragino-dark.png +0 -0
  1112. package/docs/public/images/typography/term-hiragino.png +0 -0
  1113. package/docs/public/images/typography/term-microsoft-dark.png +0 -0
  1114. package/docs/public/images/typography/term-microsoft.png +0 -0
  1115. package/docs/public/images/typography/term-pingfang-dark.png +0 -0
  1116. package/docs/public/images/typography/term-pingfang.png +0 -0
  1117. package/docs/public/images/typography.png +0 -0
  1118. package/docs/public/images/vform-banner.png +0 -0
  1119. package/docs/public/images/vform.png +0 -0
  1120. package/docs/public/images/web.png +0 -0
  1121. package/docs/public/sw.js +12 -0
  1122. package/docs/public/vercel.json +4 -0
  1123. package/docs/stub/types__react/index.d.ts +1 -0
  1124. package/docs/tsconfig.json +25 -0
  1125. package/docs/unocss.config.ts +32 -0
  1126. package/eslint.config.mjs +1 -0
  1127. package/internal/build/build.config.ts +10 -0
  1128. package/internal/build/buildfile.ts +90 -0
  1129. package/internal/build/package.json +35 -0
  1130. package/internal/build/src/build-info.ts +59 -0
  1131. package/internal/build/src/index.ts +3 -0
  1132. package/internal/build/src/plugins/element-plus-alias.ts +24 -0
  1133. package/internal/build/src/plugins/supply-validator.ts +132 -0
  1134. package/internal/build/src/tasks/full-bundle.ts +129 -0
  1135. package/internal/build/src/tasks/helper.ts +220 -0
  1136. package/internal/build/src/tasks/index.ts +4 -0
  1137. package/internal/build/src/tasks/modules.ts +86 -0
  1138. package/internal/build/src/tasks/types-definitions.ts +57 -0
  1139. package/internal/build/src/utils/index.ts +2 -0
  1140. package/internal/build/src/utils/process.ts +28 -0
  1141. package/internal/build/src/utils/rolldown.ts +30 -0
  1142. package/internal/build-constants/build.config.ts +10 -0
  1143. package/internal/build-constants/package.json +27 -0
  1144. package/internal/build-constants/src/index.ts +2 -0
  1145. package/internal/build-constants/src/pkg.ts +5 -0
  1146. package/internal/build-constants/src/repo.ts +4 -0
  1147. package/internal/build-utils/build.config.ts +10 -0
  1148. package/internal/build-utils/package.json +33 -0
  1149. package/internal/build-utils/src/fs.ts +9 -0
  1150. package/internal/build-utils/src/index.ts +4 -0
  1151. package/internal/build-utils/src/log.ts +33 -0
  1152. package/internal/build-utils/src/paths.ts +44 -0
  1153. package/internal/build-utils/src/pkg.ts +38 -0
  1154. package/internal/eslint-config/index.js +558 -0
  1155. package/internal/eslint-config/package.json +38 -0
  1156. package/internal/metadata/package.json +36 -0
  1157. package/internal/metadata/src/contributor.ts +203 -0
  1158. package/package.json +131 -0
  1159. package/packages/components/affix/__tests__/affix.test.tsx +232 -0
  1160. package/packages/components/affix/index.ts +9 -0
  1161. package/packages/components/affix/src/affix.ts +99 -0
  1162. package/packages/components/affix/src/affix.vue +181 -0
  1163. package/packages/components/affix/style/css.ts +2 -0
  1164. package/packages/components/affix/style/index.ts +2 -0
  1165. package/packages/components/alert/__tests__/alert.test.tsx +89 -0
  1166. package/packages/components/alert/index.ts +10 -0
  1167. package/packages/components/alert/src/alert.ts +102 -0
  1168. package/packages/components/alert/src/alert.vue +96 -0
  1169. package/packages/components/alert/src/instance.ts +3 -0
  1170. package/packages/components/alert/style/css.ts +2 -0
  1171. package/packages/components/alert/style/index.ts +2 -0
  1172. package/packages/components/anchor/__tests__/__snapshots__/anchor.test.tsx.snap +45 -0
  1173. package/packages/components/anchor/__tests__/anchor.test.tsx +136 -0
  1174. package/packages/components/anchor/index.ts +16 -0
  1175. package/packages/components/anchor/src/anchor-link.ts +35 -0
  1176. package/packages/components/anchor/src/anchor-link.vue +86 -0
  1177. package/packages/components/anchor/src/anchor.ts +118 -0
  1178. package/packages/components/anchor/src/anchor.vue +257 -0
  1179. package/packages/components/anchor/src/constants.ts +18 -0
  1180. package/packages/components/anchor/style/css.ts +2 -0
  1181. package/packages/components/anchor/style/index.ts +2 -0
  1182. package/packages/components/anchor-link/style/css.ts +2 -0
  1183. package/packages/components/anchor-link/style/index.ts +2 -0
  1184. package/packages/components/aside/style/css.ts +2 -0
  1185. package/packages/components/aside/style/index.ts +2 -0
  1186. package/packages/components/autocomplete/__tests__/autocomplete.test.tsx +720 -0
  1187. package/packages/components/autocomplete/index.ts +11 -0
  1188. package/packages/components/autocomplete/src/autocomplete.ts +231 -0
  1189. package/packages/components/autocomplete/src/autocomplete.vue +512 -0
  1190. package/packages/components/autocomplete/style/css.ts +5 -0
  1191. package/packages/components/autocomplete/style/index.ts +5 -0
  1192. package/packages/components/avatar/__tests__/avatar.test.tsx +161 -0
  1193. package/packages/components/avatar/index.ts +19 -0
  1194. package/packages/components/avatar/src/avatar-group-props.ts +78 -0
  1195. package/packages/components/avatar/src/avatar-group.tsx +77 -0
  1196. package/packages/components/avatar/src/avatar.ts +101 -0
  1197. package/packages/components/avatar/src/avatar.vue +82 -0
  1198. package/packages/components/avatar/src/constants.ts +11 -0
  1199. package/packages/components/avatar/src/instance.ts +5 -0
  1200. package/packages/components/avatar/style/css.ts +2 -0
  1201. package/packages/components/avatar/style/index.ts +2 -0
  1202. package/packages/components/avatar-group/style/css.ts +3 -0
  1203. package/packages/components/avatar-group/style/index.ts +3 -0
  1204. package/packages/components/backtop/__tests__/backtop.test.tsx +49 -0
  1205. package/packages/components/backtop/index.ts +10 -0
  1206. package/packages/components/backtop/src/backtop.ts +64 -0
  1207. package/packages/components/backtop/src/backtop.vue +48 -0
  1208. package/packages/components/backtop/src/instance.ts +3 -0
  1209. package/packages/components/backtop/src/use-backtop.ts +48 -0
  1210. package/packages/components/backtop/style/css.ts +2 -0
  1211. package/packages/components/backtop/style/index.ts +2 -0
  1212. package/packages/components/badge/__tests__/badge.test.tsx +180 -0
  1213. package/packages/components/badge/index.ts +10 -0
  1214. package/packages/components/badge/src/badge.ts +117 -0
  1215. package/packages/components/badge/src/badge.vue +71 -0
  1216. package/packages/components/badge/src/instance.ts +3 -0
  1217. package/packages/components/badge/style/css.ts +2 -0
  1218. package/packages/components/badge/style/index.ts +2 -0
  1219. package/packages/components/base/style/css.ts +1 -0
  1220. package/packages/components/base/style/index.ts +1 -0
  1221. package/packages/components/breadcrumb/__tests__/breadcrumb.test.tsx +107 -0
  1222. package/packages/components/breadcrumb/index.ts +22 -0
  1223. package/packages/components/breadcrumb/src/breadcrumb-item.ts +39 -0
  1224. package/packages/components/breadcrumb/src/breadcrumb-item.vue +46 -0
  1225. package/packages/components/breadcrumb/src/breadcrumb.ts +41 -0
  1226. package/packages/components/breadcrumb/src/breadcrumb.vue +39 -0
  1227. package/packages/components/breadcrumb/src/constants.ts +5 -0
  1228. package/packages/components/breadcrumb/src/instances.ts +6 -0
  1229. package/packages/components/breadcrumb/style/css.ts +2 -0
  1230. package/packages/components/breadcrumb/style/index.ts +2 -0
  1231. package/packages/components/breadcrumb-item/style/css.ts +2 -0
  1232. package/packages/components/breadcrumb-item/style/index.ts +2 -0
  1233. package/packages/components/button/__tests__/button.test.tsx +399 -0
  1234. package/packages/components/button/index.ts +18 -0
  1235. package/packages/components/button/src/button-custom.ts +121 -0
  1236. package/packages/components/button/src/button-group.ts +49 -0
  1237. package/packages/components/button/src/button-group.vue +29 -0
  1238. package/packages/components/button/src/button.ts +239 -0
  1239. package/packages/components/button/src/button.vue +101 -0
  1240. package/packages/components/button/src/constants.ts +11 -0
  1241. package/packages/components/button/src/instance.ts +5 -0
  1242. package/packages/components/button/src/use-button.ts +104 -0
  1243. package/packages/components/button/style/css.ts +2 -0
  1244. package/packages/components/button/style/index.ts +2 -0
  1245. package/packages/components/button-group/style/css.ts +2 -0
  1246. package/packages/components/button-group/style/index.ts +2 -0
  1247. package/packages/components/calendar/__tests__/calendar.test.tsx +333 -0
  1248. package/packages/components/calendar/index.ts +14 -0
  1249. package/packages/components/calendar/src/calendar.ts +86 -0
  1250. package/packages/components/calendar/src/calendar.vue +109 -0
  1251. package/packages/components/calendar/src/date-table.ts +63 -0
  1252. package/packages/components/calendar/src/date-table.vue +84 -0
  1253. package/packages/components/calendar/src/instance.ts +6 -0
  1254. package/packages/components/calendar/src/select-controller.ts +41 -0
  1255. package/packages/components/calendar/src/select-controller.vue +89 -0
  1256. package/packages/components/calendar/src/use-calendar.ts +198 -0
  1257. package/packages/components/calendar/src/use-date-table.ts +128 -0
  1258. package/packages/components/calendar/style/css.ts +5 -0
  1259. package/packages/components/calendar/style/index.ts +5 -0
  1260. package/packages/components/card/__tests__/card.test.tsx +86 -0
  1261. package/packages/components/card/index.ts +10 -0
  1262. package/packages/components/card/src/card.ts +92 -0
  1263. package/packages/components/card/src/card.vue +40 -0
  1264. package/packages/components/card/src/instance.ts +3 -0
  1265. package/packages/components/card/style/css.ts +2 -0
  1266. package/packages/components/card/style/index.ts +2 -0
  1267. package/packages/components/carousel/__tests__/carousel.test.tsx +471 -0
  1268. package/packages/components/carousel/index.ts +22 -0
  1269. package/packages/components/carousel/src/carousel-item.ts +38 -0
  1270. package/packages/components/carousel/src/carousel-item.vue +70 -0
  1271. package/packages/components/carousel/src/carousel.ts +172 -0
  1272. package/packages/components/carousel/src/carousel.vue +207 -0
  1273. package/packages/components/carousel/src/constants.ts +38 -0
  1274. package/packages/components/carousel/src/instance.ts +5 -0
  1275. package/packages/components/carousel/src/use-carousel-item.ts +170 -0
  1276. package/packages/components/carousel/src/use-carousel.ts +350 -0
  1277. package/packages/components/carousel/style/css.ts +2 -0
  1278. package/packages/components/carousel/style/index.ts +2 -0
  1279. package/packages/components/carousel-item/style/css.ts +2 -0
  1280. package/packages/components/carousel-item/style/index.ts +2 -0
  1281. package/packages/components/cascader/__tests__/cascader.test.tsx +1306 -0
  1282. package/packages/components/cascader/index.ts +11 -0
  1283. package/packages/components/cascader/src/cascader.ts +334 -0
  1284. package/packages/components/cascader/src/cascader.vue +882 -0
  1285. package/packages/components/cascader/src/instances.ts +3 -0
  1286. package/packages/components/cascader/style/css.ts +6 -0
  1287. package/packages/components/cascader/style/index.ts +6 -0
  1288. package/packages/components/cascader-panel/__tests__/cascader-panel.test.tsx +1176 -0
  1289. package/packages/components/cascader-panel/index.ts +12 -0
  1290. package/packages/components/cascader-panel/src/config.ts +150 -0
  1291. package/packages/components/cascader-panel/src/index.vue +424 -0
  1292. package/packages/components/cascader-panel/src/instance.ts +5 -0
  1293. package/packages/components/cascader-panel/src/menu.vue +119 -0
  1294. package/packages/components/cascader-panel/src/node-content.tsx +35 -0
  1295. package/packages/components/cascader-panel/src/node.ts +196 -0
  1296. package/packages/components/cascader-panel/src/node.vue +183 -0
  1297. package/packages/components/cascader-panel/src/store.ts +101 -0
  1298. package/packages/components/cascader-panel/src/types.ts +81 -0
  1299. package/packages/components/cascader-panel/src/utils.ts +41 -0
  1300. package/packages/components/cascader-panel/style/css.ts +5 -0
  1301. package/packages/components/cascader-panel/style/index.ts +5 -0
  1302. package/packages/components/check-tag/__tests__/check-tag.test.tsx +72 -0
  1303. package/packages/components/check-tag/index.ts +9 -0
  1304. package/packages/components/check-tag/src/check-tag.ts +55 -0
  1305. package/packages/components/check-tag/src/check-tag.vue +38 -0
  1306. package/packages/components/check-tag/style/css.ts +2 -0
  1307. package/packages/components/check-tag/style/index.ts +2 -0
  1308. package/packages/components/checkbox/__tests__/checkbox.test.tsx +916 -0
  1309. package/packages/components/checkbox/index.ts +24 -0
  1310. package/packages/components/checkbox/src/checkbox-button.vue +94 -0
  1311. package/packages/components/checkbox/src/checkbox-group.ts +156 -0
  1312. package/packages/components/checkbox/src/checkbox-group.vue +120 -0
  1313. package/packages/components/checkbox/src/checkbox.ts +216 -0
  1314. package/packages/components/checkbox/src/checkbox.vue +104 -0
  1315. package/packages/components/checkbox/src/composables/index.ts +5 -0
  1316. package/packages/components/checkbox/src/composables/use-checkbox-disabled.ts +41 -0
  1317. package/packages/components/checkbox/src/composables/use-checkbox-event.ts +88 -0
  1318. package/packages/components/checkbox/src/composables/use-checkbox-model.ts +48 -0
  1319. package/packages/components/checkbox/src/composables/use-checkbox-status.ts +65 -0
  1320. package/packages/components/checkbox/src/composables/use-checkbox.ts +101 -0
  1321. package/packages/components/checkbox/src/constants.ts +21 -0
  1322. package/packages/components/checkbox/style/css.ts +2 -0
  1323. package/packages/components/checkbox/style/index.ts +2 -0
  1324. package/packages/components/checkbox-button/style/css.ts +2 -0
  1325. package/packages/components/checkbox-button/style/index.ts +2 -0
  1326. package/packages/components/checkbox-group/style/css.ts +3 -0
  1327. package/packages/components/checkbox-group/style/index.ts +3 -0
  1328. package/packages/components/col/__tests__/layout.test.tsx +118 -0
  1329. package/packages/components/col/index.ts +9 -0
  1330. package/packages/components/col/src/col.ts +137 -0
  1331. package/packages/components/col/src/col.vue +77 -0
  1332. package/packages/components/col/style/css.ts +2 -0
  1333. package/packages/components/col/style/index.ts +2 -0
  1334. package/packages/components/collapse/__tests__/collapse.test.tsx +500 -0
  1335. package/packages/components/collapse/index.ts +19 -0
  1336. package/packages/components/collapse/src/collapse-item.ts +63 -0
  1337. package/packages/components/collapse/src/collapse-item.vue +85 -0
  1338. package/packages/components/collapse/src/collapse.ts +82 -0
  1339. package/packages/components/collapse/src/collapse.vue +32 -0
  1340. package/packages/components/collapse/src/constants.ts +10 -0
  1341. package/packages/components/collapse/src/instance.ts +5 -0
  1342. package/packages/components/collapse/src/use-collapse-item.ts +97 -0
  1343. package/packages/components/collapse/src/use-collapse.ts +111 -0
  1344. package/packages/components/collapse/style/css.ts +2 -0
  1345. package/packages/components/collapse/style/index.ts +2 -0
  1346. package/packages/components/collapse-item/style/css.ts +2 -0
  1347. package/packages/components/collapse-item/style/index.ts +2 -0
  1348. package/packages/components/collapse-transition/index.ts +9 -0
  1349. package/packages/components/collapse-transition/src/collapse-transition.vue +90 -0
  1350. package/packages/components/collapse-transition/style/css.ts +2 -0
  1351. package/packages/components/collapse-transition/style/index.ts +2 -0
  1352. package/packages/components/collection/__tests__/collection-item.test.ts +80 -0
  1353. package/packages/components/collection/__tests__/collection.test.ts +52 -0
  1354. package/packages/components/collection/index.ts +3 -0
  1355. package/packages/components/collection/src/collection-item.vue +12 -0
  1356. package/packages/components/collection/src/collection.ts +83 -0
  1357. package/packages/components/collection/src/collection.vue +11 -0
  1358. package/packages/components/collection/src/tokens.ts +15 -0
  1359. package/packages/components/collection/test-helper/index.ts +37 -0
  1360. package/packages/components/color-picker/__tests__/color-picker.test.tsx +613 -0
  1361. package/packages/components/color-picker/index.ts +10 -0
  1362. package/packages/components/color-picker/src/color-picker.ts +202 -0
  1363. package/packages/components/color-picker/src/color-picker.vue +399 -0
  1364. package/packages/components/color-picker/style/css.ts +5 -0
  1365. package/packages/components/color-picker/style/index.ts +5 -0
  1366. package/packages/components/color-picker-panel/index.ts +10 -0
  1367. package/packages/components/color-picker-panel/src/__tests__/color-picker-panel.test.tsx +707 -0
  1368. package/packages/components/color-picker-panel/src/color-picker-panel.ts +140 -0
  1369. package/packages/components/color-picker-panel/src/color-picker-panel.vue +156 -0
  1370. package/packages/components/color-picker-panel/src/components/alpha-slider.vue +86 -0
  1371. package/packages/components/color-picker-panel/src/components/hue-slider.vue +78 -0
  1372. package/packages/components/color-picker-panel/src/components/predefine.vue +38 -0
  1373. package/packages/components/color-picker-panel/src/components/sv-panel.vue +72 -0
  1374. package/packages/components/color-picker-panel/src/composables/use-common-color.ts +40 -0
  1375. package/packages/components/color-picker-panel/src/composables/use-predefine.ts +73 -0
  1376. package/packages/components/color-picker-panel/src/composables/use-slider.ts +237 -0
  1377. package/packages/components/color-picker-panel/src/composables/use-sv-panel.ts +175 -0
  1378. package/packages/components/color-picker-panel/src/props/predefine.ts +35 -0
  1379. package/packages/components/color-picker-panel/src/props/slider.ts +37 -0
  1380. package/packages/components/color-picker-panel/src/props/sv-panel.ts +25 -0
  1381. package/packages/components/color-picker-panel/src/utils/color.ts +116 -0
  1382. package/packages/components/color-picker-panel/src/utils/draggable.ts +47 -0
  1383. package/packages/components/color-picker-panel/style/css.ts +3 -0
  1384. package/packages/components/color-picker-panel/style/index.ts +3 -0
  1385. package/packages/components/config-provider/__tests__/config-loading.test.tsx +28 -0
  1386. package/packages/components/config-provider/__tests__/config-provider.test.tsx +654 -0
  1387. package/packages/components/config-provider/index.ts +13 -0
  1388. package/packages/components/config-provider/src/config-provider-props.ts +101 -0
  1389. package/packages/components/config-provider/src/config-provider.ts +30 -0
  1390. package/packages/components/config-provider/src/constants.ts +8 -0
  1391. package/packages/components/config-provider/src/hooks/use-global-config.ts +139 -0
  1392. package/packages/components/config-provider/style/css.ts +2 -0
  1393. package/packages/components/config-provider/style/index.ts +2 -0
  1394. package/packages/components/container/__tests__/container.test.tsx +99 -0
  1395. package/packages/components/container/index.ts +32 -0
  1396. package/packages/components/container/src/aside.vue +32 -0
  1397. package/packages/components/container/src/container.vue +45 -0
  1398. package/packages/components/container/src/footer.vue +35 -0
  1399. package/packages/components/container/src/header.vue +36 -0
  1400. package/packages/components/container/src/main.vue +15 -0
  1401. package/packages/components/container/style/css.ts +6 -0
  1402. package/packages/components/container/style/index.ts +6 -0
  1403. package/packages/components/countdown/__tests__/countdown.test.tsx +73 -0
  1404. package/packages/components/countdown/index.ts +10 -0
  1405. package/packages/components/countdown/src/countdown.ts +84 -0
  1406. package/packages/components/countdown/src/countdown.vue +91 -0
  1407. package/packages/components/countdown/src/utils.ts +36 -0
  1408. package/packages/components/countdown/style/css.ts +2 -0
  1409. package/packages/components/countdown/style/index.ts +2 -0
  1410. package/packages/components/date-picker/__tests__/date-picker.test.ts +3112 -0
  1411. package/packages/components/date-picker/__tests__/date-time-picker.test.tsx +1323 -0
  1412. package/packages/components/date-picker/index.ts +11 -0
  1413. package/packages/components/date-picker/src/date-picker.tsx +89 -0
  1414. package/packages/components/date-picker/src/instance.ts +11 -0
  1415. package/packages/components/date-picker/src/props.ts +21 -0
  1416. package/packages/components/date-picker/style/css.ts +4 -0
  1417. package/packages/components/date-picker/style/index.ts +4 -0
  1418. package/packages/components/date-picker-panel/__tests__/date-picker-panel.test.tsx +1120 -0
  1419. package/packages/components/date-picker-panel/index.ts +13 -0
  1420. package/packages/components/date-picker-panel/src/composables/use-basic-date-table.ts +487 -0
  1421. package/packages/components/date-picker-panel/src/composables/use-month-range-header.ts +66 -0
  1422. package/packages/components/date-picker-panel/src/composables/use-panel-date-range.ts +164 -0
  1423. package/packages/components/date-picker-panel/src/composables/use-range-picker.ts +166 -0
  1424. package/packages/components/date-picker-panel/src/composables/use-shortcut.ts +43 -0
  1425. package/packages/components/date-picker-panel/src/composables/use-year-range-header.ts +67 -0
  1426. package/packages/components/date-picker-panel/src/constants.ts +12 -0
  1427. package/packages/components/date-picker-panel/src/date-picker-com/basic-cell-render.tsx +22 -0
  1428. package/packages/components/date-picker-panel/src/date-picker-com/basic-date-table.vue +102 -0
  1429. package/packages/components/date-picker-panel/src/date-picker-com/basic-month-table.vue +301 -0
  1430. package/packages/components/date-picker-panel/src/date-picker-com/basic-year-table.vue +289 -0
  1431. package/packages/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue +883 -0
  1432. package/packages/components/date-picker-panel/src/date-picker-com/panel-date-range.vue +951 -0
  1433. package/packages/components/date-picker-panel/src/date-picker-com/panel-month-range.vue +292 -0
  1434. package/packages/components/date-picker-panel/src/date-picker-com/panel-year-range.vue +309 -0
  1435. package/packages/components/date-picker-panel/src/date-picker-panel.tsx +91 -0
  1436. package/packages/components/date-picker-panel/src/instance.ts +4 -0
  1437. package/packages/components/date-picker-panel/src/panel-utils.ts +24 -0
  1438. package/packages/components/date-picker-panel/src/props/basic-cell.ts +13 -0
  1439. package/packages/components/date-picker-panel/src/props/basic-date-table.ts +37 -0
  1440. package/packages/components/date-picker-panel/src/props/basic-month-table.ts +14 -0
  1441. package/packages/components/date-picker-panel/src/props/basic-year-table.ts +14 -0
  1442. package/packages/components/date-picker-panel/src/props/date-picker-panel.ts +134 -0
  1443. package/packages/components/date-picker-panel/src/props/panel-date-pick.ts +25 -0
  1444. package/packages/components/date-picker-panel/src/props/panel-date-range.ts +14 -0
  1445. package/packages/components/date-picker-panel/src/props/panel-month-range.ts +19 -0
  1446. package/packages/components/date-picker-panel/src/props/panel-year-range.ts +19 -0
  1447. package/packages/components/date-picker-panel/src/props/shared.ts +123 -0
  1448. package/packages/components/date-picker-panel/src/types.ts +35 -0
  1449. package/packages/components/date-picker-panel/src/utils.ts +228 -0
  1450. package/packages/components/date-picker-panel/style/css.ts +5 -0
  1451. package/packages/components/date-picker-panel/style/index.ts +5 -0
  1452. package/packages/components/descriptions/__tests__/descriptions.test.tsx +317 -0
  1453. package/packages/components/descriptions/index.ts +19 -0
  1454. package/packages/components/descriptions/src/constants.ts +1 -0
  1455. package/packages/components/descriptions/src/description-item.ts +95 -0
  1456. package/packages/components/descriptions/src/description.ts +100 -0
  1457. package/packages/components/descriptions/src/description.vue +135 -0
  1458. package/packages/components/descriptions/src/descriptions-cell.ts +151 -0
  1459. package/packages/components/descriptions/src/descriptions-row.ts +17 -0
  1460. package/packages/components/descriptions/src/descriptions-row.vue +42 -0
  1461. package/packages/components/descriptions/src/descriptions.type.ts +24 -0
  1462. package/packages/components/descriptions/src/token.ts +5 -0
  1463. package/packages/components/descriptions/style/css.ts +3 -0
  1464. package/packages/components/descriptions/style/index.ts +3 -0
  1465. package/packages/components/descriptions-item/style/css.ts +2 -0
  1466. package/packages/components/descriptions-item/style/index.ts +2 -0
  1467. package/packages/components/dialog/__tests__/dialog.test.tsx +591 -0
  1468. package/packages/components/dialog/index.ts +11 -0
  1469. package/packages/components/dialog/src/constants.ts +16 -0
  1470. package/packages/components/dialog/src/dialog-content.ts +144 -0
  1471. package/packages/components/dialog/src/dialog-content.vue +84 -0
  1472. package/packages/components/dialog/src/dialog.ts +265 -0
  1473. package/packages/components/dialog/src/dialog.vue +166 -0
  1474. package/packages/components/dialog/src/use-dialog.ts +327 -0
  1475. package/packages/components/dialog/style/css.ts +3 -0
  1476. package/packages/components/dialog/style/index.ts +3 -0
  1477. package/packages/components/divider/__tests__/divider.test.tsx +58 -0
  1478. package/packages/components/divider/index.ts +9 -0
  1479. package/packages/components/divider/src/divider.ts +57 -0
  1480. package/packages/components/divider/src/divider.vue +37 -0
  1481. package/packages/components/divider/style/css.ts +2 -0
  1482. package/packages/components/divider/style/index.ts +2 -0
  1483. package/packages/components/drawer/__tests__/drawer.test.ts +773 -0
  1484. package/packages/components/drawer/index.ts +9 -0
  1485. package/packages/components/drawer/src/composables/useResizable.ts +112 -0
  1486. package/packages/components/drawer/src/drawer.ts +81 -0
  1487. package/packages/components/drawer/src/drawer.vue +204 -0
  1488. package/packages/components/drawer/style/css.ts +3 -0
  1489. package/packages/components/drawer/style/index.ts +3 -0
  1490. package/packages/components/dropdown/__tests__/dropdown.test.ts +1126 -0
  1491. package/packages/components/dropdown/index.ts +22 -0
  1492. package/packages/components/dropdown/src/dropdown-item-impl.vue +116 -0
  1493. package/packages/components/dropdown/src/dropdown-item.vue +115 -0
  1494. package/packages/components/dropdown/src/dropdown-menu.vue +112 -0
  1495. package/packages/components/dropdown/src/dropdown.ts +218 -0
  1496. package/packages/components/dropdown/src/dropdown.vue +254 -0
  1497. package/packages/components/dropdown/src/instance.ts +3 -0
  1498. package/packages/components/dropdown/src/tokens.ts +17 -0
  1499. package/packages/components/dropdown/src/useDropdown.ts +17 -0
  1500. package/packages/components/dropdown/style/css.ts +6 -0
  1501. package/packages/components/dropdown/style/index.ts +6 -0
  1502. package/packages/components/dropdown-item/style/css.ts +2 -0
  1503. package/packages/components/dropdown-item/style/index.ts +2 -0
  1504. package/packages/components/dropdown-menu/style/css.ts +2 -0
  1505. package/packages/components/dropdown-menu/style/index.ts +2 -0
  1506. package/packages/components/empty/__tests__/empty.test.tsx +64 -0
  1507. package/packages/components/empty/index.ts +10 -0
  1508. package/packages/components/empty/src/empty.ts +47 -0
  1509. package/packages/components/empty/src/empty.vue +45 -0
  1510. package/packages/components/empty/src/img-empty.vue +121 -0
  1511. package/packages/components/empty/src/instance.ts +3 -0
  1512. package/packages/components/empty/style/css.ts +2 -0
  1513. package/packages/components/empty/style/index.ts +2 -0
  1514. package/packages/components/focus-trap/__tests__/focus-trap.test.ts +354 -0
  1515. package/packages/components/focus-trap/__tests__/utils.test.ts +91 -0
  1516. package/packages/components/focus-trap/index.ts +7 -0
  1517. package/packages/components/focus-trap/src/focus-trap.vue +343 -0
  1518. package/packages/components/focus-trap/src/tokens.ts +24 -0
  1519. package/packages/components/focus-trap/src/utils.ts +199 -0
  1520. package/packages/components/footer/style/css.ts +2 -0
  1521. package/packages/components/footer/style/index.ts +2 -0
  1522. package/packages/components/form/__tests__/form-item.test.tsx +322 -0
  1523. package/packages/components/form/__tests__/form.test.tsx +1240 -0
  1524. package/packages/components/form/__tests__/mock-data.tsx +122 -0
  1525. package/packages/components/form/__tests__/use-form-item.test.tsx +77 -0
  1526. package/packages/components/form/index.ts +23 -0
  1527. package/packages/components/form/src/constants.ts +7 -0
  1528. package/packages/components/form/src/form-item.ts +152 -0
  1529. package/packages/components/form/src/form-item.vue +462 -0
  1530. package/packages/components/form/src/form-label-wrap.tsx +118 -0
  1531. package/packages/components/form/src/form.ts +206 -0
  1532. package/packages/components/form/src/form.vue +300 -0
  1533. package/packages/components/form/src/hooks/index.ts +2 -0
  1534. package/packages/components/form/src/hooks/use-form-common-props.ts +46 -0
  1535. package/packages/components/form/src/hooks/use-form-item.ts +110 -0
  1536. package/packages/components/form/src/types.ts +86 -0
  1537. package/packages/components/form/src/utils.ts +62 -0
  1538. package/packages/components/form/style/css.ts +2 -0
  1539. package/packages/components/form/style/index.ts +2 -0
  1540. package/packages/components/form-item/style/css.ts +2 -0
  1541. package/packages/components/form-item/style/index.ts +2 -0
  1542. package/packages/components/header/style/css.ts +2 -0
  1543. package/packages/components/header/style/index.ts +2 -0
  1544. package/packages/components/icon/__tests__/icon.test.tsx +11 -0
  1545. package/packages/components/icon/index.ts +9 -0
  1546. package/packages/components/icon/src/icon.ts +39 -0
  1547. package/packages/components/icon/src/icon.vue +32 -0
  1548. package/packages/components/icon/style/css.ts +1 -0
  1549. package/packages/components/icon/style/index.ts +1 -0
  1550. package/packages/components/image/__tests__/image.test.tsx +389 -0
  1551. package/packages/components/image/index.ts +9 -0
  1552. package/packages/components/image/src/image.ts +226 -0
  1553. package/packages/components/image/src/image.vue +277 -0
  1554. package/packages/components/image/style/css.ts +3 -0
  1555. package/packages/components/image/style/index.ts +3 -0
  1556. package/packages/components/image-viewer/__tests__/image-viewer.test.tsx +129 -0
  1557. package/packages/components/image-viewer/index.ts +10 -0
  1558. package/packages/components/image-viewer/src/image-viewer.ts +180 -0
  1559. package/packages/components/image-viewer/src/image-viewer.vue +512 -0
  1560. package/packages/components/image-viewer/style/css.ts +2 -0
  1561. package/packages/components/image-viewer/style/index.ts +2 -0
  1562. package/packages/components/index.ts +88 -0
  1563. package/packages/components/infinite-scroll/__tests__/infinite-scroll.test.ts +262 -0
  1564. package/packages/components/infinite-scroll/index.ts +14 -0
  1565. package/packages/components/infinite-scroll/src/index.ts +195 -0
  1566. package/packages/components/infinite-scroll/style/css.ts +2 -0
  1567. package/packages/components/infinite-scroll/style/index.ts +2 -0
  1568. package/packages/components/input/__tests__/input.test.tsx +1113 -0
  1569. package/packages/components/input/index.ts +10 -0
  1570. package/packages/components/input/src/input.ts +414 -0
  1571. package/packages/components/input/src/input.vue +730 -0
  1572. package/packages/components/input/src/instance.ts +3 -0
  1573. package/packages/components/input/src/utils.ts +132 -0
  1574. package/packages/components/input/style/css.ts +2 -0
  1575. package/packages/components/input/style/index.ts +2 -0
  1576. package/packages/components/input-number/__tests__/input-number.test.tsx +727 -0
  1577. package/packages/components/input-number/index.ts +10 -0
  1578. package/packages/components/input-number/src/input-number.ts +244 -0
  1579. package/packages/components/input-number/src/input-number.vue +432 -0
  1580. package/packages/components/input-number/style/css.ts +3 -0
  1581. package/packages/components/input-number/style/index.ts +3 -0
  1582. package/packages/components/input-tag/__tests__/input-tag.test.tsx +601 -0
  1583. package/packages/components/input-tag/index.ts +10 -0
  1584. package/packages/components/input-tag/src/composables/index.ts +4 -0
  1585. package/packages/components/input-tag/src/composables/use-drag-tag.ts +136 -0
  1586. package/packages/components/input-tag/src/composables/use-hovering.ts +19 -0
  1587. package/packages/components/input-tag/src/composables/use-input-tag-dom.ts +129 -0
  1588. package/packages/components/input-tag/src/composables/use-input-tag.ts +271 -0
  1589. package/packages/components/input-tag/src/input-tag.ts +302 -0
  1590. package/packages/components/input-tag/src/input-tag.vue +250 -0
  1591. package/packages/components/input-tag/src/instance.ts +3 -0
  1592. package/packages/components/input-tag/style/css.ts +4 -0
  1593. package/packages/components/input-tag/style/index.ts +4 -0
  1594. package/packages/components/link/__tests__/link.test.tsx +81 -0
  1595. package/packages/components/link/index.ts +9 -0
  1596. package/packages/components/link/src/link.ts +98 -0
  1597. package/packages/components/link/src/link.vue +70 -0
  1598. package/packages/components/link/style/css.ts +2 -0
  1599. package/packages/components/link/style/index.ts +2 -0
  1600. package/packages/components/loading/__tests__/loading.test.tsx +321 -0
  1601. package/packages/components/loading/index.ts +27 -0
  1602. package/packages/components/loading/src/directive.ts +115 -0
  1603. package/packages/components/loading/src/loading.ts +172 -0
  1604. package/packages/components/loading/src/service.ts +172 -0
  1605. package/packages/components/loading/src/types.ts +52 -0
  1606. package/packages/components/loading/style/css.ts +2 -0
  1607. package/packages/components/loading/style/index.ts +2 -0
  1608. package/packages/components/main/style/css.ts +2 -0
  1609. package/packages/components/main/style/index.ts +2 -0
  1610. package/packages/components/mention/__tests__/mention.test.tsx +371 -0
  1611. package/packages/components/mention/index.ts +9 -0
  1612. package/packages/components/mention/src/helper.ts +222 -0
  1613. package/packages/components/mention/src/mention-dropdown.ts +29 -0
  1614. package/packages/components/mention/src/mention-dropdown.vue +154 -0
  1615. package/packages/components/mention/src/mention.ts +225 -0
  1616. package/packages/components/mention/src/mention.vue +345 -0
  1617. package/packages/components/mention/src/types.ts +16 -0
  1618. package/packages/components/mention/style/css.ts +5 -0
  1619. package/packages/components/mention/style/index.ts +5 -0
  1620. package/packages/components/menu/__tests__/menu.test.ts +594 -0
  1621. package/packages/components/menu/index.ts +32 -0
  1622. package/packages/components/menu/src/instance.ts +15 -0
  1623. package/packages/components/menu/src/menu-collapse-transition.vue +55 -0
  1624. package/packages/components/menu/src/menu-item-group.ts +25 -0
  1625. package/packages/components/menu/src/menu-item-group.vue +24 -0
  1626. package/packages/components/menu/src/menu-item.ts +63 -0
  1627. package/packages/components/menu/src/menu-item.vue +122 -0
  1628. package/packages/components/menu/src/menu.ts +582 -0
  1629. package/packages/components/menu/src/sub-menu.ts +498 -0
  1630. package/packages/components/menu/src/tokens.ts +3 -0
  1631. package/packages/components/menu/src/types.ts +42 -0
  1632. package/packages/components/menu/src/use-menu-color.ts +12 -0
  1633. package/packages/components/menu/src/use-menu-css-var.ts +19 -0
  1634. package/packages/components/menu/src/use-menu.ts +33 -0
  1635. package/packages/components/menu/src/utils/menu-bar.ts +22 -0
  1636. package/packages/components/menu/src/utils/menu-item.ts +63 -0
  1637. package/packages/components/menu/src/utils/submenu.ts +73 -0
  1638. package/packages/components/menu/style/css.ts +3 -0
  1639. package/packages/components/menu/style/index.ts +3 -0
  1640. package/packages/components/menu-item/style/css.ts +2 -0
  1641. package/packages/components/menu-item/style/index.ts +2 -0
  1642. package/packages/components/menu-item-group/style/css.ts +2 -0
  1643. package/packages/components/menu-item-group/style/index.ts +2 -0
  1644. package/packages/components/message/__tests__/message-manager.test.tsx +279 -0
  1645. package/packages/components/message/__tests__/message.test.ts +259 -0
  1646. package/packages/components/message/index.ts +7 -0
  1647. package/packages/components/message/src/instance.ts +54 -0
  1648. package/packages/components/message/src/message.ts +300 -0
  1649. package/packages/components/message/src/message.vue +189 -0
  1650. package/packages/components/message/src/method.ts +260 -0
  1651. package/packages/components/message/style/css.ts +3 -0
  1652. package/packages/components/message/style/index.ts +3 -0
  1653. package/packages/components/message-box/__tests__/message-box.test.ts +475 -0
  1654. package/packages/components/message-box/index.ts +20 -0
  1655. package/packages/components/message-box/src/index.vue +519 -0
  1656. package/packages/components/message-box/src/message-box.type.ts +247 -0
  1657. package/packages/components/message-box/src/messageBox.ts +244 -0
  1658. package/packages/components/message-box/style/css.ts +5 -0
  1659. package/packages/components/message-box/style/index.ts +5 -0
  1660. package/packages/components/notification/__tests__/notification.test.tsx +272 -0
  1661. package/packages/components/notification/__tests__/notify.test.tsx +233 -0
  1662. package/packages/components/notification/index.ts +7 -0
  1663. package/packages/components/notification/src/notification.ts +260 -0
  1664. package/packages/components/notification/src/notification.vue +154 -0
  1665. package/packages/components/notification/src/notify.ts +184 -0
  1666. package/packages/components/notification/style/css.ts +2 -0
  1667. package/packages/components/notification/style/index.ts +2 -0
  1668. package/packages/components/option/style/css.ts +2 -0
  1669. package/packages/components/option/style/index.ts +2 -0
  1670. package/packages/components/option-group/style/css.ts +2 -0
  1671. package/packages/components/option-group/style/index.ts +2 -0
  1672. package/packages/components/overlay/__tests__/overlay.test.tsx +69 -0
  1673. package/packages/components/overlay/index.ts +6 -0
  1674. package/packages/components/overlay/src/overlay.ts +95 -0
  1675. package/packages/components/overlay/style/css.ts +2 -0
  1676. package/packages/components/overlay/style/index.ts +2 -0
  1677. package/packages/components/package.json +34 -0
  1678. package/packages/components/page-header/__tests__/page-header.test.tsx +141 -0
  1679. package/packages/components/page-header/index.ts +10 -0
  1680. package/packages/components/page-header/src/page-header.ts +59 -0
  1681. package/packages/components/page-header/src/page-header.vue +80 -0
  1682. package/packages/components/page-header/style/css.ts +3 -0
  1683. package/packages/components/page-header/style/index.ts +3 -0
  1684. package/packages/components/pagination/__tests__/pagination.test.tsx +427 -0
  1685. package/packages/components/pagination/index.ts +11 -0
  1686. package/packages/components/pagination/src/components/jumper.ts +21 -0
  1687. package/packages/components/pagination/src/components/jumper.vue +50 -0
  1688. package/packages/components/pagination/src/components/next.ts +29 -0
  1689. package/packages/components/pagination/src/components/next.vue +39 -0
  1690. package/packages/components/pagination/src/components/pager.ts +27 -0
  1691. package/packages/components/pagination/src/components/pager.vue +225 -0
  1692. package/packages/components/pagination/src/components/prev.ts +29 -0
  1693. package/packages/components/pagination/src/components/prev.vue +35 -0
  1694. package/packages/components/pagination/src/components/sizes.ts +40 -0
  1695. package/packages/components/pagination/src/components/sizes.vue +71 -0
  1696. package/packages/components/pagination/src/components/total.ts +18 -0
  1697. package/packages/components/pagination/src/components/total.vue +25 -0
  1698. package/packages/components/pagination/src/constants.ts +12 -0
  1699. package/packages/components/pagination/src/pagination.ts +481 -0
  1700. package/packages/components/pagination/src/usePagination.ts +4 -0
  1701. package/packages/components/pagination/style/css.ts +4 -0
  1702. package/packages/components/pagination/style/index.ts +4 -0
  1703. package/packages/components/popconfirm/__tests__/popconfirm.test.tsx +234 -0
  1704. package/packages/components/popconfirm/index.ts +10 -0
  1705. package/packages/components/popconfirm/src/popconfirm.ts +184 -0
  1706. package/packages/components/popconfirm/src/popconfirm.vue +130 -0
  1707. package/packages/components/popconfirm/style/css.ts +4 -0
  1708. package/packages/components/popconfirm/style/index.ts +4 -0
  1709. package/packages/components/popover/__tests__/directive.test.ts +70 -0
  1710. package/packages/components/popover/__tests__/directive.test.tsx +74 -0
  1711. package/packages/components/popover/__tests__/popover.test.tsx +220 -0
  1712. package/packages/components/popover/index.ts +17 -0
  1713. package/packages/components/popover/src/directive.ts +21 -0
  1714. package/packages/components/popover/src/popover.ts +284 -0
  1715. package/packages/components/popover/src/popover.vue +121 -0
  1716. package/packages/components/popover/style/css.ts +3 -0
  1717. package/packages/components/popover/style/index.ts +3 -0
  1718. package/packages/components/popper/__tests__/arrow.test.tsx +46 -0
  1719. package/packages/components/popper/__tests__/content.test.tsx +170 -0
  1720. package/packages/components/popper/__tests__/popper.test.tsx +32 -0
  1721. package/packages/components/popper/__tests__/trigger.test.tsx +112 -0
  1722. package/packages/components/popper/index.ts +20 -0
  1723. package/packages/components/popper/src/arrow.ts +43 -0
  1724. package/packages/components/popper/src/arrow.vue +36 -0
  1725. package/packages/components/popper/src/composables/index.ts +3 -0
  1726. package/packages/components/popper/src/composables/use-content-dom.ts +62 -0
  1727. package/packages/components/popper/src/composables/use-content.ts +119 -0
  1728. package/packages/components/popper/src/composables/use-focus-trap.ts +65 -0
  1729. package/packages/components/popper/src/constants.ts +30 -0
  1730. package/packages/components/popper/src/content.ts +223 -0
  1731. package/packages/components/popper/src/content.vue +175 -0
  1732. package/packages/components/popper/src/popper.ts +61 -0
  1733. package/packages/components/popper/src/popper.vue +53 -0
  1734. package/packages/components/popper/src/trigger.ts +63 -0
  1735. package/packages/components/popper/src/trigger.vue +176 -0
  1736. package/packages/components/popper/src/utils.ts +76 -0
  1737. package/packages/components/popper/style/css.ts +2 -0
  1738. package/packages/components/popper/style/index.ts +2 -0
  1739. package/packages/components/progress/__tests__/progress.test.tsx +164 -0
  1740. package/packages/components/progress/index.ts +9 -0
  1741. package/packages/components/progress/src/progress.ts +171 -0
  1742. package/packages/components/progress/src/progress.vue +245 -0
  1743. package/packages/components/progress/style/css.ts +2 -0
  1744. package/packages/components/progress/style/index.ts +2 -0
  1745. package/packages/components/radio/__tests__/radio.test.tsx +548 -0
  1746. package/packages/components/radio/index.ts +24 -0
  1747. package/packages/components/radio/src/constants.ts +9 -0
  1748. package/packages/components/radio/src/radio-button.ts +35 -0
  1749. package/packages/components/radio/src/radio-button.vue +65 -0
  1750. package/packages/components/radio/src/radio-group.ts +170 -0
  1751. package/packages/components/radio/src/radio-group.vue +118 -0
  1752. package/packages/components/radio/src/radio.ts +123 -0
  1753. package/packages/components/radio/src/radio.vue +64 -0
  1754. package/packages/components/radio/src/use-radio.ts +73 -0
  1755. package/packages/components/radio/style/css.ts +2 -0
  1756. package/packages/components/radio/style/index.ts +2 -0
  1757. package/packages/components/radio-button/style/css.ts +2 -0
  1758. package/packages/components/radio-button/style/index.ts +2 -0
  1759. package/packages/components/radio-group/style/css.ts +3 -0
  1760. package/packages/components/radio-group/style/index.ts +3 -0
  1761. package/packages/components/rate/__tests__/rate.test.tsx +260 -0
  1762. package/packages/components/rate/index.ts +9 -0
  1763. package/packages/components/rate/src/rate.ts +257 -0
  1764. package/packages/components/rate/src/rate.vue +351 -0
  1765. package/packages/components/rate/style/css.ts +2 -0
  1766. package/packages/components/rate/style/index.ts +2 -0
  1767. package/packages/components/result/__tests__/result.test.tsx +101 -0
  1768. package/packages/components/result/index.ts +10 -0
  1769. package/packages/components/result/src/result.ts +79 -0
  1770. package/packages/components/result/src/result.vue +58 -0
  1771. package/packages/components/result/style/css.ts +2 -0
  1772. package/packages/components/result/style/index.ts +2 -0
  1773. package/packages/components/roving-focus-group/__tests__/roving-focus-group.test.ts +155 -0
  1774. package/packages/components/roving-focus-group/__tests__/roving-focus-item.test.ts +237 -0
  1775. package/packages/components/roving-focus-group/__tests__/util.test.ts +74 -0
  1776. package/packages/components/roving-focus-group/index.ts +16 -0
  1777. package/packages/components/roving-focus-group/src/roving-focus-group-impl.vue +195 -0
  1778. package/packages/components/roving-focus-group/src/roving-focus-group.ts +53 -0
  1779. package/packages/components/roving-focus-group/src/roving-focus-group.vue +21 -0
  1780. package/packages/components/roving-focus-group/src/roving-focus-item.vue +100 -0
  1781. package/packages/components/roving-focus-group/src/tokens.ts +34 -0
  1782. package/packages/components/roving-focus-group/src/utils.ts +66 -0
  1783. package/packages/components/row/index.ts +10 -0
  1784. package/packages/components/row/src/constants.ts +7 -0
  1785. package/packages/components/row/src/row.ts +75 -0
  1786. package/packages/components/row/src/row.vue +47 -0
  1787. package/packages/components/row/style/css.ts +2 -0
  1788. package/packages/components/row/style/index.ts +2 -0
  1789. package/packages/components/scrollbar/__tests__/scrollbar.test.tsx +394 -0
  1790. package/packages/components/scrollbar/index.ts +13 -0
  1791. package/packages/components/scrollbar/src/bar.ts +30 -0
  1792. package/packages/components/scrollbar/src/bar.vue +71 -0
  1793. package/packages/components/scrollbar/src/constants.ts +10 -0
  1794. package/packages/components/scrollbar/src/scrollbar.ts +204 -0
  1795. package/packages/components/scrollbar/src/scrollbar.vue +283 -0
  1796. package/packages/components/scrollbar/src/thumb.ts +33 -0
  1797. package/packages/components/scrollbar/src/thumb.vue +180 -0
  1798. package/packages/components/scrollbar/src/util.ts +38 -0
  1799. package/packages/components/scrollbar/style/css.ts +2 -0
  1800. package/packages/components/scrollbar/style/index.ts +2 -0
  1801. package/packages/components/segmented/__tests__/segmented.test.tsx +256 -0
  1802. package/packages/components/segmented/index.ts +7 -0
  1803. package/packages/components/segmented/src/segmented.ts +149 -0
  1804. package/packages/components/segmented/src/segmented.vue +198 -0
  1805. package/packages/components/segmented/src/types.ts +1 -0
  1806. package/packages/components/segmented/style/css.ts +2 -0
  1807. package/packages/components/segmented/style/index.ts +2 -0
  1808. package/packages/components/select/__tests__/options.test.tsx +91 -0
  1809. package/packages/components/select/__tests__/select.test.ts +4576 -0
  1810. package/packages/components/select/index.ts +27 -0
  1811. package/packages/components/select/src/option-group.vue +109 -0
  1812. package/packages/components/select/src/option.ts +23 -0
  1813. package/packages/components/select/src/option.vue +135 -0
  1814. package/packages/components/select/src/options.ts +54 -0
  1815. package/packages/components/select/src/select-dropdown.vue +63 -0
  1816. package/packages/components/select/src/select.ts +344 -0
  1817. package/packages/components/select/src/select.vue +602 -0
  1818. package/packages/components/select/src/token.ts +8 -0
  1819. package/packages/components/select/src/type.ts +77 -0
  1820. package/packages/components/select/src/useOption.ts +126 -0
  1821. package/packages/components/select/src/useSelect.ts +1007 -0
  1822. package/packages/components/select/style/css.ts +7 -0
  1823. package/packages/components/select/style/index.ts +7 -0
  1824. package/packages/components/select-v2/__tests__/select.test.ts +3068 -0
  1825. package/packages/components/select-v2/index.ts +9 -0
  1826. package/packages/components/select-v2/src/defaults.ts +397 -0
  1827. package/packages/components/select-v2/src/group-item.vue +34 -0
  1828. package/packages/components/select-v2/src/option-item.vue +68 -0
  1829. package/packages/components/select-v2/src/select-dropdown.tsx +302 -0
  1830. package/packages/components/select-v2/src/select.types.ts +29 -0
  1831. package/packages/components/select-v2/src/select.vue +405 -0
  1832. package/packages/components/select-v2/src/token.ts +20 -0
  1833. package/packages/components/select-v2/src/useAllowCreate.ts +113 -0
  1834. package/packages/components/select-v2/src/useOption.ts +19 -0
  1835. package/packages/components/select-v2/src/useProps.ts +49 -0
  1836. package/packages/components/select-v2/src/useSelect.ts +1095 -0
  1837. package/packages/components/select-v2/style/css.ts +7 -0
  1838. package/packages/components/select-v2/style/index.ts +7 -0
  1839. package/packages/components/skeleton/__tests__/skeleton-item.test.tsx +17 -0
  1840. package/packages/components/skeleton/__tests__/skeleton.test.tsx +103 -0
  1841. package/packages/components/skeleton/index.ts +17 -0
  1842. package/packages/components/skeleton/src/skeleton-item.ts +53 -0
  1843. package/packages/components/skeleton/src/skeleton-item.vue +20 -0
  1844. package/packages/components/skeleton/src/skeleton.ts +72 -0
  1845. package/packages/components/skeleton/src/skeleton.vue +48 -0
  1846. package/packages/components/skeleton/style/css.ts +3 -0
  1847. package/packages/components/skeleton/style/index.ts +3 -0
  1848. package/packages/components/skeleton-item/style/css.ts +2 -0
  1849. package/packages/components/skeleton-item/style/index.ts +2 -0
  1850. package/packages/components/slider/__tests__/slider.test.tsx +1003 -0
  1851. package/packages/components/slider/index.ts +10 -0
  1852. package/packages/components/slider/src/button.ts +54 -0
  1853. package/packages/components/slider/src/button.vue +92 -0
  1854. package/packages/components/slider/src/composables/index.ts +6 -0
  1855. package/packages/components/slider/src/composables/use-lifecycle.ts +45 -0
  1856. package/packages/components/slider/src/composables/use-marks.ts +52 -0
  1857. package/packages/components/slider/src/composables/use-slide.ts +217 -0
  1858. package/packages/components/slider/src/composables/use-slider-button.ts +391 -0
  1859. package/packages/components/slider/src/composables/use-stops.ts +58 -0
  1860. package/packages/components/slider/src/composables/use-watch.ts +111 -0
  1861. package/packages/components/slider/src/constants.ts +16 -0
  1862. package/packages/components/slider/src/marker.ts +50 -0
  1863. package/packages/components/slider/src/slider.ts +189 -0
  1864. package/packages/components/slider/src/slider.vue +270 -0
  1865. package/packages/components/slider/style/css.ts +4 -0
  1866. package/packages/components/slider/style/index.ts +4 -0
  1867. package/packages/components/slot/__tests__/only-child.test.tsx +138 -0
  1868. package/packages/components/slot/index.ts +2 -0
  1869. package/packages/components/slot/src/only-child.tsx +86 -0
  1870. package/packages/components/space/__tests__/space.test.tsx +159 -0
  1871. package/packages/components/space/index.ts +11 -0
  1872. package/packages/components/space/src/item.ts +31 -0
  1873. package/packages/components/space/src/space.ts +256 -0
  1874. package/packages/components/space/src/use-space.ts +74 -0
  1875. package/packages/components/space/style/css.ts +2 -0
  1876. package/packages/components/space/style/index.ts +2 -0
  1877. package/packages/components/splitter/__tests__/__mocks__/vueuse.ts +23 -0
  1878. package/packages/components/splitter/__tests__/splitter.test.tsx +436 -0
  1879. package/packages/components/splitter/index.ts +18 -0
  1880. package/packages/components/splitter/src/hooks/index.ts +3 -0
  1881. package/packages/components/splitter/src/hooks/useContainer.ts +15 -0
  1882. package/packages/components/splitter/src/hooks/usePanel.ts +34 -0
  1883. package/packages/components/splitter/src/hooks/useResize.ts +171 -0
  1884. package/packages/components/splitter/src/hooks/useSize.ts +80 -0
  1885. package/packages/components/splitter/src/split-bar.vue +163 -0
  1886. package/packages/components/splitter/src/split-panel.ts +47 -0
  1887. package/packages/components/splitter/src/split-panel.vue +209 -0
  1888. package/packages/components/splitter/src/splitter.ts +39 -0
  1889. package/packages/components/splitter/src/splitter.vue +123 -0
  1890. package/packages/components/splitter/src/type.ts +34 -0
  1891. package/packages/components/splitter/style/css.ts +2 -0
  1892. package/packages/components/splitter/style/index.ts +2 -0
  1893. package/packages/components/splitter-panel/style/css.ts +2 -0
  1894. package/packages/components/splitter-panel/style/index.ts +2 -0
  1895. package/packages/components/statistic/__tests__/statistic.test.tsx +48 -0
  1896. package/packages/components/statistic/index.ts +10 -0
  1897. package/packages/components/statistic/src/statistic.ts +108 -0
  1898. package/packages/components/statistic/src/statistic.vue +69 -0
  1899. package/packages/components/statistic/style/css.ts +2 -0
  1900. package/packages/components/statistic/style/index.ts +2 -0
  1901. package/packages/components/step/style/css.ts +2 -0
  1902. package/packages/components/step/style/index.ts +2 -0
  1903. package/packages/components/steps/__tests__/steps.test.tsx +321 -0
  1904. package/packages/components/steps/index.ts +17 -0
  1905. package/packages/components/steps/src/item.ts +67 -0
  1906. package/packages/components/steps/src/item.vue +229 -0
  1907. package/packages/components/steps/src/steps.ts +112 -0
  1908. package/packages/components/steps/src/steps.vue +53 -0
  1909. package/packages/components/steps/src/tokens.ts +1 -0
  1910. package/packages/components/steps/style/css.ts +2 -0
  1911. package/packages/components/steps/style/index.ts +2 -0
  1912. package/packages/components/sub-menu/style/css.ts +2 -0
  1913. package/packages/components/sub-menu/style/index.ts +2 -0
  1914. package/packages/components/switch/__tests__/switch.test.tsx +446 -0
  1915. package/packages/components/switch/index.ts +9 -0
  1916. package/packages/components/switch/src/switch.ts +245 -0
  1917. package/packages/components/switch/src/switch.vue +264 -0
  1918. package/packages/components/switch/style/css.ts +2 -0
  1919. package/packages/components/switch/style/index.ts +2 -0
  1920. package/packages/components/tab-pane/style/css.ts +2 -0
  1921. package/packages/components/tab-pane/style/index.ts +2 -0
  1922. package/packages/components/table/__tests__/table-column.test.ts +1877 -0
  1923. package/packages/components/table/__tests__/table-test-common.ts +141 -0
  1924. package/packages/components/table/__tests__/table.test.ts +2857 -0
  1925. package/packages/components/table/index.ts +36 -0
  1926. package/packages/components/table/src/composables/use-scrollbar.ts +30 -0
  1927. package/packages/components/table/src/config.ts +295 -0
  1928. package/packages/components/table/src/filter-panel.vue +328 -0
  1929. package/packages/components/table/src/h-helper.ts +43 -0
  1930. package/packages/components/table/src/layout-observer.ts +77 -0
  1931. package/packages/components/table/src/store/current.ts +84 -0
  1932. package/packages/components/table/src/store/expand.ts +91 -0
  1933. package/packages/components/table/src/store/helper.ts +91 -0
  1934. package/packages/components/table/src/store/index.ts +251 -0
  1935. package/packages/components/table/src/store/tree.ts +255 -0
  1936. package/packages/components/table/src/store/watcher.ts +596 -0
  1937. package/packages/components/table/src/table/defaults.ts +466 -0
  1938. package/packages/components/table/src/table/key-render-helper.ts +28 -0
  1939. package/packages/components/table/src/table/style-helper.ts +347 -0
  1940. package/packages/components/table/src/table/utils-helper.ts +55 -0
  1941. package/packages/components/table/src/table-body/defaults.ts +49 -0
  1942. package/packages/components/table/src/table-body/events-helper.ts +215 -0
  1943. package/packages/components/table/src/table-body/index.ts +121 -0
  1944. package/packages/components/table/src/table-body/render-helper.ts +306 -0
  1945. package/packages/components/table/src/table-body/styles-helper.ts +165 -0
  1946. package/packages/components/table/src/table-body/td-wrapper.vue +20 -0
  1947. package/packages/components/table/src/table-column/defaults.ts +252 -0
  1948. package/packages/components/table/src/table-column/index.ts +224 -0
  1949. package/packages/components/table/src/table-column/render-helper.ts +243 -0
  1950. package/packages/components/table/src/table-column/watcher-helper.ts +129 -0
  1951. package/packages/components/table/src/table-footer/index.ts +133 -0
  1952. package/packages/components/table/src/table-footer/mapState-helper.ts +33 -0
  1953. package/packages/components/table/src/table-footer/style-helper.ts +53 -0
  1954. package/packages/components/table/src/table-header/event-helper.ts +249 -0
  1955. package/packages/components/table/src/table-header/index.ts +331 -0
  1956. package/packages/components/table/src/table-header/style.helper.ts +122 -0
  1957. package/packages/components/table/src/table-header/utils-helper.ts +95 -0
  1958. package/packages/components/table/src/table-layout.ts +261 -0
  1959. package/packages/components/table/src/table.vue +422 -0
  1960. package/packages/components/table/src/tableColumn.ts +3 -0
  1961. package/packages/components/table/src/tokens.ts +5 -0
  1962. package/packages/components/table/src/util.ts +696 -0
  1963. package/packages/components/table/style/css.ts +5 -0
  1964. package/packages/components/table/style/index.ts +5 -0
  1965. package/packages/components/table-column/style/css.ts +4 -0
  1966. package/packages/components/table-column/style/index.ts +4 -0
  1967. package/packages/components/table-v2/__tests__/table-v2.test.tsx +402 -0
  1968. package/packages/components/table-v2/index.ts +31 -0
  1969. package/packages/components/table-v2/src/auto-resizer.ts +18 -0
  1970. package/packages/components/table-v2/src/cell.ts +25 -0
  1971. package/packages/components/table-v2/src/common.ts +55 -0
  1972. package/packages/components/table-v2/src/components/auto-resizer.tsx +30 -0
  1973. package/packages/components/table-v2/src/components/cell.tsx +23 -0
  1974. package/packages/components/table-v2/src/components/expand-icon.tsx +39 -0
  1975. package/packages/components/table-v2/src/components/header-cell.tsx +16 -0
  1976. package/packages/components/table-v2/src/components/header-row.tsx +61 -0
  1977. package/packages/components/table-v2/src/components/header.tsx +148 -0
  1978. package/packages/components/table-v2/src/components/index.ts +18 -0
  1979. package/packages/components/table-v2/src/components/row.tsx +264 -0
  1980. package/packages/components/table-v2/src/components/sort-icon.tsx +25 -0
  1981. package/packages/components/table-v2/src/composables/index.ts +6 -0
  1982. package/packages/components/table-v2/src/composables/use-auto-resize.ts +46 -0
  1983. package/packages/components/table-v2/src/composables/use-columns.ts +133 -0
  1984. package/packages/components/table-v2/src/composables/use-data.ts +72 -0
  1985. package/packages/components/table-v2/src/composables/use-row.ts +194 -0
  1986. package/packages/components/table-v2/src/composables/use-scrollbar.ts +91 -0
  1987. package/packages/components/table-v2/src/composables/use-styles.ts +111 -0
  1988. package/packages/components/table-v2/src/composables/utils.ts +33 -0
  1989. package/packages/components/table-v2/src/constants.ts +22 -0
  1990. package/packages/components/table-v2/src/grid.ts +81 -0
  1991. package/packages/components/table-v2/src/header-cell.ts +15 -0
  1992. package/packages/components/table-v2/src/header-row.ts +27 -0
  1993. package/packages/components/table-v2/src/header.ts +37 -0
  1994. package/packages/components/table-v2/src/private.ts +1 -0
  1995. package/packages/components/table-v2/src/renderers/cell.tsx +137 -0
  1996. package/packages/components/table-v2/src/renderers/empty.tsx +22 -0
  1997. package/packages/components/table-v2/src/renderers/footer.tsx +18 -0
  1998. package/packages/components/table-v2/src/renderers/header-cell.tsx +111 -0
  1999. package/packages/components/table-v2/src/renderers/header.tsx +48 -0
  2000. package/packages/components/table-v2/src/renderers/left-table.tsx +23 -0
  2001. package/packages/components/table-v2/src/renderers/main-table.tsx +23 -0
  2002. package/packages/components/table-v2/src/renderers/overlay.tsx +13 -0
  2003. package/packages/components/table-v2/src/renderers/right-table.tsx +23 -0
  2004. package/packages/components/table-v2/src/renderers/row.tsx +136 -0
  2005. package/packages/components/table-v2/src/row.ts +96 -0
  2006. package/packages/components/table-v2/src/table-grid.tsx +354 -0
  2007. package/packages/components/table-v2/src/table-v2.tsx +383 -0
  2008. package/packages/components/table-v2/src/table.ts +208 -0
  2009. package/packages/components/table-v2/src/tokens.ts +13 -0
  2010. package/packages/components/table-v2/src/types.ts +137 -0
  2011. package/packages/components/table-v2/src/use-table.ts +234 -0
  2012. package/packages/components/table-v2/src/utils.ts +34 -0
  2013. package/packages/components/table-v2/style/css.ts +4 -0
  2014. package/packages/components/table-v2/style/index.ts +4 -0
  2015. package/packages/components/tabs/__tests__/tabs.test.tsx +1075 -0
  2016. package/packages/components/tabs/index.ts +20 -0
  2017. package/packages/components/tabs/src/constants.ts +36 -0
  2018. package/packages/components/tabs/src/tab-bar.ts +30 -0
  2019. package/packages/components/tabs/src/tab-bar.vue +123 -0
  2020. package/packages/components/tabs/src/tab-nav.tsx +513 -0
  2021. package/packages/components/tabs/src/tab-pane.ts +68 -0
  2022. package/packages/components/tabs/src/tab-pane.vue +93 -0
  2023. package/packages/components/tabs/src/tabs.tsx +324 -0
  2024. package/packages/components/tabs/style/css.ts +2 -0
  2025. package/packages/components/tabs/style/index.ts +2 -0
  2026. package/packages/components/tag/__tests__/tag.test.tsx +83 -0
  2027. package/packages/components/tag/index.ts +9 -0
  2028. package/packages/components/tag/src/tag.ts +103 -0
  2029. package/packages/components/tag/src/tag.vue +104 -0
  2030. package/packages/components/tag/style/css.ts +2 -0
  2031. package/packages/components/tag/style/index.ts +2 -0
  2032. package/packages/components/teleport/__tests__/teleport.test.tsx +40 -0
  2033. package/packages/components/teleport/index.ts +10 -0
  2034. package/packages/components/teleport/src/teleport.ts +16 -0
  2035. package/packages/components/teleport/src/teleport.vue +14 -0
  2036. package/packages/components/teleport/style/css.ts +1 -0
  2037. package/packages/components/teleport/style/index.ts +1 -0
  2038. package/packages/components/text/__tests__/text.test.tsx +55 -0
  2039. package/packages/components/text/index.ts +9 -0
  2040. package/packages/components/text/src/text.ts +72 -0
  2041. package/packages/components/text/src/text.vue +72 -0
  2042. package/packages/components/text/style/css.ts +2 -0
  2043. package/packages/components/text/style/index.ts +2 -0
  2044. package/packages/components/time-picker/__tests__/time-picker.test.tsx +1272 -0
  2045. package/packages/components/time-picker/index.ts +24 -0
  2046. package/packages/components/time-picker/src/common/picker-range-trigger.vue +135 -0
  2047. package/packages/components/time-picker/src/common/picker.vue +723 -0
  2048. package/packages/components/time-picker/src/common/props.ts +316 -0
  2049. package/packages/components/time-picker/src/composables/use-common-picker.ts +149 -0
  2050. package/packages/components/time-picker/src/composables/use-time-panel.ts +86 -0
  2051. package/packages/components/time-picker/src/composables/use-time-picker.ts +120 -0
  2052. package/packages/components/time-picker/src/constants.ts +32 -0
  2053. package/packages/components/time-picker/src/props/basic-time-spinner.ts +34 -0
  2054. package/packages/components/time-picker/src/props/panel-time-picker.ts +18 -0
  2055. package/packages/components/time-picker/src/props/panel-time-range.ts +17 -0
  2056. package/packages/components/time-picker/src/props/shared.ts +53 -0
  2057. package/packages/components/time-picker/src/time-picker-com/basic-time-spinner.vue +385 -0
  2058. package/packages/components/time-picker/src/time-picker-com/panel-time-pick.vue +202 -0
  2059. package/packages/components/time-picker/src/time-picker-com/panel-time-range.vue +320 -0
  2060. package/packages/components/time-picker/src/time-picker.tsx +80 -0
  2061. package/packages/components/time-picker/src/utils.ts +98 -0
  2062. package/packages/components/time-picker/style/css.ts +5 -0
  2063. package/packages/components/time-picker/style/index.ts +5 -0
  2064. package/packages/components/time-select/__tests__/time-select.test.tsx +348 -0
  2065. package/packages/components/time-select/index.ts +10 -0
  2066. package/packages/components/time-select/src/time-select.ts +224 -0
  2067. package/packages/components/time-select/src/time-select.vue +180 -0
  2068. package/packages/components/time-select/src/utils.ts +62 -0
  2069. package/packages/components/time-select/style/css.ts +6 -0
  2070. package/packages/components/time-select/style/index.ts +6 -0
  2071. package/packages/components/timeline/__tests__/timeline.test.tsx +309 -0
  2072. package/packages/components/timeline/index.ts +18 -0
  2073. package/packages/components/timeline/src/timeline-item.ts +115 -0
  2074. package/packages/components/timeline/src/timeline-item.vue +78 -0
  2075. package/packages/components/timeline/src/timeline.ts +53 -0
  2076. package/packages/components/timeline/src/tokens.ts +9 -0
  2077. package/packages/components/timeline/style/css.ts +2 -0
  2078. package/packages/components/timeline/style/index.ts +2 -0
  2079. package/packages/components/timeline-item/style/css.ts +2 -0
  2080. package/packages/components/timeline-item/style/index.ts +2 -0
  2081. package/packages/components/tooltip/__tests__/content.test.tsx +236 -0
  2082. package/packages/components/tooltip/__tests__/tooltip.test.tsx +266 -0
  2083. package/packages/components/tooltip/__tests__/trigger.test.tsx +187 -0
  2084. package/packages/components/tooltip/index.ts +11 -0
  2085. package/packages/components/tooltip/src/constants.ts +21 -0
  2086. package/packages/components/tooltip/src/content.ts +131 -0
  2087. package/packages/components/tooltip/src/content.vue +214 -0
  2088. package/packages/components/tooltip/src/tooltip.ts +75 -0
  2089. package/packages/components/tooltip/src/tooltip.vue +220 -0
  2090. package/packages/components/tooltip/src/trigger.ts +78 -0
  2091. package/packages/components/tooltip/src/trigger.vue +120 -0
  2092. package/packages/components/tooltip/src/utils.ts +26 -0
  2093. package/packages/components/tooltip/style/css.ts +3 -0
  2094. package/packages/components/tooltip/style/index.ts +3 -0
  2095. package/packages/components/tooltip/test-helper/provides.ts +30 -0
  2096. package/packages/components/tour/__tests__/tour.test.tsx +231 -0
  2097. package/packages/components/tour/index.ts +19 -0
  2098. package/packages/components/tour/src/content.ts +107 -0
  2099. package/packages/components/tour/src/content.vue +87 -0
  2100. package/packages/components/tour/src/helper.ts +304 -0
  2101. package/packages/components/tour/src/mask.ts +69 -0
  2102. package/packages/components/tour/src/mask.vue +85 -0
  2103. package/packages/components/tour/src/step.ts +156 -0
  2104. package/packages/components/tour/src/step.vue +188 -0
  2105. package/packages/components/tour/src/steps.ts +51 -0
  2106. package/packages/components/tour/src/tour.ts +200 -0
  2107. package/packages/components/tour/src/tour.vue +162 -0
  2108. package/packages/components/tour/src/types.ts +28 -0
  2109. package/packages/components/tour/style/css.ts +3 -0
  2110. package/packages/components/tour/style/index.ts +3 -0
  2111. package/packages/components/tour-step/style/css.ts +0 -0
  2112. package/packages/components/tour-step/style/index.ts +0 -0
  2113. package/packages/components/transfer/__tests__/transfer.test.tsx +384 -0
  2114. package/packages/components/transfer/index.ts +9 -0
  2115. package/packages/components/transfer/src/composables/index.ts +5 -0
  2116. package/packages/components/transfer/src/composables/use-check.ts +154 -0
  2117. package/packages/components/transfer/src/composables/use-checked-change.ts +36 -0
  2118. package/packages/components/transfer/src/composables/use-computed-data.ts +49 -0
  2119. package/packages/components/transfer/src/composables/use-move.ts +78 -0
  2120. package/packages/components/transfer/src/composables/use-props-alias.ts +16 -0
  2121. package/packages/components/transfer/src/transfer-panel.ts +69 -0
  2122. package/packages/components/transfer/src/transfer-panel.vue +125 -0
  2123. package/packages/components/transfer/src/transfer.ts +235 -0
  2124. package/packages/components/transfer/src/transfer.vue +198 -0
  2125. package/packages/components/transfer/style/css.ts +6 -0
  2126. package/packages/components/transfer/style/index.ts +6 -0
  2127. package/packages/components/tree/__tests__/tree.test.ts +2420 -0
  2128. package/packages/components/tree/index.ts +13 -0
  2129. package/packages/components/tree/src/instance.ts +3 -0
  2130. package/packages/components/tree/src/model/node.ts +621 -0
  2131. package/packages/components/tree/src/model/tree-store.ts +446 -0
  2132. package/packages/components/tree/src/model/useDragNode.ts +278 -0
  2133. package/packages/components/tree/src/model/useKeydown.ts +134 -0
  2134. package/packages/components/tree/src/model/useNodeExpandEventBroadcast.ts +51 -0
  2135. package/packages/components/tree/src/model/util.ts +34 -0
  2136. package/packages/components/tree/src/tokens.ts +5 -0
  2137. package/packages/components/tree/src/tree-node-content.vue +40 -0
  2138. package/packages/components/tree/src/tree-node.vue +364 -0
  2139. package/packages/components/tree/src/tree.ts +146 -0
  2140. package/packages/components/tree/src/tree.type.ts +139 -0
  2141. package/packages/components/tree/src/tree.vue +368 -0
  2142. package/packages/components/tree/style/css.ts +4 -0
  2143. package/packages/components/tree/style/index.ts +4 -0
  2144. package/packages/components/tree-select/__tests__/tree-select.test.tsx +1159 -0
  2145. package/packages/components/tree-select/index.ts +11 -0
  2146. package/packages/components/tree-select/src/cache-options.ts +54 -0
  2147. package/packages/components/tree-select/src/instance.ts +7 -0
  2148. package/packages/components/tree-select/src/select.ts +116 -0
  2149. package/packages/components/tree-select/src/tree-select-option.ts +51 -0
  2150. package/packages/components/tree-select/src/tree-select.vue +113 -0
  2151. package/packages/components/tree-select/src/tree.ts +305 -0
  2152. package/packages/components/tree-select/src/utils.ts +80 -0
  2153. package/packages/components/tree-select/style/css.ts +3 -0
  2154. package/packages/components/tree-select/style/index.ts +3 -0
  2155. package/packages/components/tree-v2/__tests__/tree.test.ts +1919 -0
  2156. package/packages/components/tree-v2/index.ts +9 -0
  2157. package/packages/components/tree-v2/src/composables/useCheck.ts +239 -0
  2158. package/packages/components/tree-v2/src/composables/useFilter.ts +83 -0
  2159. package/packages/components/tree-v2/src/composables/useTree.ts +367 -0
  2160. package/packages/components/tree-v2/src/instance.ts +3 -0
  2161. package/packages/components/tree-v2/src/tree-node-content.ts +24 -0
  2162. package/packages/components/tree-v2/src/tree-node.vue +127 -0
  2163. package/packages/components/tree-v2/src/tree.vue +157 -0
  2164. package/packages/components/tree-v2/src/types.ts +124 -0
  2165. package/packages/components/tree-v2/src/virtual-tree.ts +181 -0
  2166. package/packages/components/tree-v2/style/css.ts +5 -0
  2167. package/packages/components/tree-v2/style/index.ts +5 -0
  2168. package/packages/components/upload/__tests__/upload-dragger.test.tsx +110 -0
  2169. package/packages/components/upload/__tests__/upload-list.test.tsx +82 -0
  2170. package/packages/components/upload/__tests__/upload.test.tsx +413 -0
  2171. package/packages/components/upload/index.ts +13 -0
  2172. package/packages/components/upload/src/ajax.ts +120 -0
  2173. package/packages/components/upload/src/constants.ts +8 -0
  2174. package/packages/components/upload/src/upload-content.ts +85 -0
  2175. package/packages/components/upload/src/upload-content.vue +240 -0
  2176. package/packages/components/upload/src/upload-dragger.ts +34 -0
  2177. package/packages/components/upload/src/upload-dragger.vue +131 -0
  2178. package/packages/components/upload/src/upload-list.ts +64 -0
  2179. package/packages/components/upload/src/upload-list.vue +160 -0
  2180. package/packages/components/upload/src/upload.ts +424 -0
  2181. package/packages/components/upload/src/upload.vue +119 -0
  2182. package/packages/components/upload/src/use-handlers.ts +203 -0
  2183. package/packages/components/upload/style/css.ts +3 -0
  2184. package/packages/components/upload/style/index.ts +3 -0
  2185. package/packages/components/virtual-list/__tests__/dynamic-size-grid.test.ts +288 -0
  2186. package/packages/components/virtual-list/__tests__/dynamic-size-list.test.ts +249 -0
  2187. package/packages/components/virtual-list/__tests__/fixed-size-grid.test.ts +293 -0
  2188. package/packages/components/virtual-list/__tests__/fixed-size-list.test.ts +381 -0
  2189. package/packages/components/virtual-list/__tests__/scrollbar.test.ts +210 -0
  2190. package/packages/components/virtual-list/__tests__/setup-mock.ts +48 -0
  2191. package/packages/components/virtual-list/index.ts +15 -0
  2192. package/packages/components/virtual-list/src/builders/build-grid.ts +708 -0
  2193. package/packages/components/virtual-list/src/builders/build-list.ts +554 -0
  2194. package/packages/components/virtual-list/src/components/dynamic-size-grid.ts +436 -0
  2195. package/packages/components/virtual-list/src/components/dynamic-size-list.ts +257 -0
  2196. package/packages/components/virtual-list/src/components/fixed-size-grid.ts +232 -0
  2197. package/packages/components/virtual-list/src/components/fixed-size-list.ts +127 -0
  2198. package/packages/components/virtual-list/src/components/scrollbar.ts +282 -0
  2199. package/packages/components/virtual-list/src/defaults.ts +35 -0
  2200. package/packages/components/virtual-list/src/hooks/use-cache.ts +20 -0
  2201. package/packages/components/virtual-list/src/hooks/use-grid-touch.ts +76 -0
  2202. package/packages/components/virtual-list/src/hooks/use-grid-wheel.ts +74 -0
  2203. package/packages/components/virtual-list/src/hooks/use-wheel.ts +61 -0
  2204. package/packages/components/virtual-list/src/props.ts +206 -0
  2205. package/packages/components/virtual-list/src/types.ts +227 -0
  2206. package/packages/components/virtual-list/src/utils.ts +88 -0
  2207. package/packages/components/virtual-list/style/css.ts +3 -0
  2208. package/packages/components/virtual-list/style/index.ts +3 -0
  2209. package/packages/components/watermark/__tests__/__snapshots__/watermark.test.tsx.snap +3 -0
  2210. package/packages/components/watermark/__tests__/watermark.test.tsx +22 -0
  2211. package/packages/components/watermark/index.ts +10 -0
  2212. package/packages/components/watermark/src/useClips.ts +172 -0
  2213. package/packages/components/watermark/src/utils.ts +37 -0
  2214. package/packages/components/watermark/src/watermark.ts +124 -0
  2215. package/packages/components/watermark/src/watermark.vue +258 -0
  2216. package/packages/components/watermark/style/css.ts +0 -0
  2217. package/packages/components/watermark/style/index.ts +0 -0
  2218. package/packages/constants/aria.ts +17 -0
  2219. package/packages/constants/column-alignment.ts +3 -0
  2220. package/packages/constants/date.ts +26 -0
  2221. package/packages/constants/event.ts +3 -0
  2222. package/packages/constants/form.ts +2 -0
  2223. package/packages/constants/index.ts +7 -0
  2224. package/packages/constants/key.ts +1 -0
  2225. package/packages/constants/package.json +6 -0
  2226. package/packages/constants/size.ts +9 -0
  2227. package/packages/directives/__tests__/click-outside.test.tsx +131 -0
  2228. package/packages/directives/__tests__/mousewheel.test.ts +55 -0
  2229. package/packages/directives/__tests__/repeat-click.test.tsx +54 -0
  2230. package/packages/directives/__tests__/trap-focus.test.tsx +154 -0
  2231. package/packages/directives/click-outside/index.ts +120 -0
  2232. package/packages/directives/index.ts +4 -0
  2233. package/packages/directives/mousewheel/index.ts +57 -0
  2234. package/packages/directives/package.json +23 -0
  2235. package/packages/directives/repeat-click/index.ts +80 -0
  2236. package/packages/directives/trap-focus/index.ts +75 -0
  2237. package/packages/element-plus/README.md +11 -0
  2238. package/packages/element-plus/component.ts +227 -0
  2239. package/packages/element-plus/defaults.ts +5 -0
  2240. package/packages/element-plus/index.ts +13 -0
  2241. package/packages/element-plus/locales.ts +1 -0
  2242. package/packages/element-plus/make-installer.ts +22 -0
  2243. package/packages/element-plus/package.json +113 -0
  2244. package/packages/element-plus/plugin.ts +17 -0
  2245. package/packages/hooks/__tests__/use-attrs.test.tsx +102 -0
  2246. package/packages/hooks/__tests__/use-calc-input-width.test.tsx +45 -0
  2247. package/packages/hooks/__tests__/use-cursor.vitest.tsx +21 -0
  2248. package/packages/hooks/__tests__/use-delayed-toggle.test.ts +183 -0
  2249. package/packages/hooks/__tests__/use-deprecated.test.ts +55 -0
  2250. package/packages/hooks/__tests__/use-empty-values.test.tsx +81 -0
  2251. package/packages/hooks/__tests__/use-floating.test.tsx +90 -0
  2252. package/packages/hooks/__tests__/use-focus-controller.test.tsx +258 -0
  2253. package/packages/hooks/__tests__/use-focus.test.ts +17 -0
  2254. package/packages/hooks/__tests__/use-id.test.tsx +107 -0
  2255. package/packages/hooks/__tests__/use-intermediate-render.test.ts +99 -0
  2256. package/packages/hooks/__tests__/use-locale.test.tsx +93 -0
  2257. package/packages/hooks/__tests__/use-lockscreen.test.tsx +193 -0
  2258. package/packages/hooks/__tests__/use-modal.test.ts +33 -0
  2259. package/packages/hooks/__tests__/use-model-toggle.test.tsx +179 -0
  2260. package/packages/hooks/__tests__/use-namespace.test.tsx +106 -0
  2261. package/packages/hooks/__tests__/use-popper-container.test.tsx +114 -0
  2262. package/packages/hooks/__tests__/use-popper.test.tsx +120 -0
  2263. package/packages/hooks/__tests__/use-prevent-global.test.ts +41 -0
  2264. package/packages/hooks/__tests__/use-teleport.test.tsx +106 -0
  2265. package/packages/hooks/__tests__/use-throttle-render.test.tsx +96 -0
  2266. package/packages/hooks/__tests__/use-timeout.ssr.test.ts +28 -0
  2267. package/packages/hooks/__tests__/use-timeout.test.ts +81 -0
  2268. package/packages/hooks/__tests__/use-z-index.test.tsx +58 -0
  2269. package/packages/hooks/index.ts +33 -0
  2270. package/packages/hooks/package.json +24 -0
  2271. package/packages/hooks/use-aria/index.ts +44 -0
  2272. package/packages/hooks/use-attrs/index.ts +41 -0
  2273. package/packages/hooks/use-calc-input-width/index.ts +25 -0
  2274. package/packages/hooks/use-composition/index.ts +47 -0
  2275. package/packages/hooks/use-cursor/index.ts +65 -0
  2276. package/packages/hooks/use-delayed-toggle/index.ts +97 -0
  2277. package/packages/hooks/use-deprecated/index.ts +35 -0
  2278. package/packages/hooks/use-draggable/index.ts +127 -0
  2279. package/packages/hooks/use-empty-values/index.ts +110 -0
  2280. package/packages/hooks/use-escape-keydown/index.ts +32 -0
  2281. package/packages/hooks/use-floating/index.ts +122 -0
  2282. package/packages/hooks/use-focus/index.ts +13 -0
  2283. package/packages/hooks/use-focus-controller/index.ts +116 -0
  2284. package/packages/hooks/use-forward-ref/index.ts +38 -0
  2285. package/packages/hooks/use-id/index.ts +51 -0
  2286. package/packages/hooks/use-intermediate-render/index.ts +60 -0
  2287. package/packages/hooks/use-locale/index.ts +55 -0
  2288. package/packages/hooks/use-lockscreen/index.ts +84 -0
  2289. package/packages/hooks/use-modal/index.ts +34 -0
  2290. package/packages/hooks/use-model-toggle/index.ts +211 -0
  2291. package/packages/hooks/use-namespace/index.ts +124 -0
  2292. package/packages/hooks/use-ordered-children/index.ts +117 -0
  2293. package/packages/hooks/use-popper/index.ts +145 -0
  2294. package/packages/hooks/use-popper-container/index.ts +48 -0
  2295. package/packages/hooks/use-prevent-global/index.ts +26 -0
  2296. package/packages/hooks/use-prop/index.ts +8 -0
  2297. package/packages/hooks/use-same-target/index.ts +31 -0
  2298. package/packages/hooks/use-size/index.ts +30 -0
  2299. package/packages/hooks/use-teleport/index.ts +61 -0
  2300. package/packages/hooks/use-throttle-render/index.ts +58 -0
  2301. package/packages/hooks/use-timeout/index.ts +23 -0
  2302. package/packages/hooks/use-transition-fallthrough/index.ts +96 -0
  2303. package/packages/hooks/use-z-index/index.ts +64 -0
  2304. package/packages/locale/index.ts +76 -0
  2305. package/packages/locale/lang/af.ts +198 -0
  2306. package/packages/locale/lang/ar-eg.ts +197 -0
  2307. package/packages/locale/lang/ar.ts +197 -0
  2308. package/packages/locale/lang/az.ts +201 -0
  2309. package/packages/locale/lang/bg.ts +198 -0
  2310. package/packages/locale/lang/bn.ts +198 -0
  2311. package/packages/locale/lang/ca.ts +198 -0
  2312. package/packages/locale/lang/ckb.ts +198 -0
  2313. package/packages/locale/lang/cs.ts +200 -0
  2314. package/packages/locale/lang/da.ts +198 -0
  2315. package/packages/locale/lang/de.ts +200 -0
  2316. package/packages/locale/lang/el.ts +198 -0
  2317. package/packages/locale/lang/en.ts +198 -0
  2318. package/packages/locale/lang/eo.ts +198 -0
  2319. package/packages/locale/lang/es.ts +198 -0
  2320. package/packages/locale/lang/et.ts +198 -0
  2321. package/packages/locale/lang/eu.ts +198 -0
  2322. package/packages/locale/lang/fa.ts +200 -0
  2323. package/packages/locale/lang/fi.ts +198 -0
  2324. package/packages/locale/lang/fr.ts +200 -0
  2325. package/packages/locale/lang/he.ts +198 -0
  2326. package/packages/locale/lang/hi.ts +200 -0
  2327. package/packages/locale/lang/hr.ts +198 -0
  2328. package/packages/locale/lang/hu.ts +198 -0
  2329. package/packages/locale/lang/hy-am.ts +198 -0
  2330. package/packages/locale/lang/id.ts +198 -0
  2331. package/packages/locale/lang/it.ts +198 -0
  2332. package/packages/locale/lang/ja.ts +198 -0
  2333. package/packages/locale/lang/kk.ts +198 -0
  2334. package/packages/locale/lang/km.ts +200 -0
  2335. package/packages/locale/lang/ko.ts +198 -0
  2336. package/packages/locale/lang/ku.ts +198 -0
  2337. package/packages/locale/lang/ky.ts +198 -0
  2338. package/packages/locale/lang/lo.ts +196 -0
  2339. package/packages/locale/lang/lt.ts +198 -0
  2340. package/packages/locale/lang/lv.ts +198 -0
  2341. package/packages/locale/lang/mg.ts +198 -0
  2342. package/packages/locale/lang/mn.ts +198 -0
  2343. package/packages/locale/lang/ms.ts +202 -0
  2344. package/packages/locale/lang/my.ts +200 -0
  2345. package/packages/locale/lang/nb-no.ts +198 -0
  2346. package/packages/locale/lang/nl.ts +198 -0
  2347. package/packages/locale/lang/no.ts +196 -0
  2348. package/packages/locale/lang/pa.ts +198 -0
  2349. package/packages/locale/lang/pl.ts +198 -0
  2350. package/packages/locale/lang/pt-br.ts +198 -0
  2351. package/packages/locale/lang/pt.ts +198 -0
  2352. package/packages/locale/lang/ro.ts +198 -0
  2353. package/packages/locale/lang/ru.ts +198 -0
  2354. package/packages/locale/lang/sk.ts +200 -0
  2355. package/packages/locale/lang/sl.ts +198 -0
  2356. package/packages/locale/lang/sr.ts +198 -0
  2357. package/packages/locale/lang/sv.ts +198 -0
  2358. package/packages/locale/lang/sw.ts +199 -0
  2359. package/packages/locale/lang/ta.ts +198 -0
  2360. package/packages/locale/lang/te.ts +199 -0
  2361. package/packages/locale/lang/th.ts +198 -0
  2362. package/packages/locale/lang/tk.ts +198 -0
  2363. package/packages/locale/lang/tr.ts +198 -0
  2364. package/packages/locale/lang/ug-cn.ts +198 -0
  2365. package/packages/locale/lang/uk.ts +198 -0
  2366. package/packages/locale/lang/uz-uz.ts +198 -0
  2367. package/packages/locale/lang/vi.ts +196 -0
  2368. package/packages/locale/lang/zh-cn.ts +195 -0
  2369. package/packages/locale/lang/zh-hk.ts +196 -0
  2370. package/packages/locale/lang/zh-mo.ts +196 -0
  2371. package/packages/locale/lang/zh-tw.ts +196 -0
  2372. package/packages/locale/package.json +12 -0
  2373. package/packages/test-utils/composite-click.ts +25 -0
  2374. package/packages/test-utils/define-getter.ts +45 -0
  2375. package/packages/test-utils/dom.ts +3 -0
  2376. package/packages/test-utils/index.ts +14 -0
  2377. package/packages/test-utils/make-mount.ts +29 -0
  2378. package/packages/test-utils/make-scroll.ts +22 -0
  2379. package/packages/test-utils/mock.ts +24 -0
  2380. package/packages/test-utils/package.json +12 -0
  2381. package/packages/test-utils/sleep.ts +3 -0
  2382. package/packages/test-utils/stable-load.ts +23 -0
  2383. package/packages/test-utils/style-plugin.ts +12 -0
  2384. package/packages/test-utils/tick.ts +19 -0
  2385. package/packages/test-utils/trigger-event.ts +29 -0
  2386. package/packages/theme-chalk/README.md +41 -0
  2387. package/packages/theme-chalk/buildfile.ts +110 -0
  2388. package/packages/theme-chalk/package.json +37 -0
  2389. package/packages/theme-chalk/src/affix.scss +7 -0
  2390. package/packages/theme-chalk/src/alert.scss +115 -0
  2391. package/packages/theme-chalk/src/anchor-link.scss +45 -0
  2392. package/packages/theme-chalk/src/anchor.scss +93 -0
  2393. package/packages/theme-chalk/src/aside.scss +8 -0
  2394. package/packages/theme-chalk/src/autocomplete.scss +95 -0
  2395. package/packages/theme-chalk/src/avatar-group.scss +25 -0
  2396. package/packages/theme-chalk/src/avatar.scss +55 -0
  2397. package/packages/theme-chalk/src/backtop.scss +29 -0
  2398. package/packages/theme-chalk/src/badge.scss +58 -0
  2399. package/packages/theme-chalk/src/base.scss +3 -0
  2400. package/packages/theme-chalk/src/breadcrumb-item.scss +58 -0
  2401. package/packages/theme-chalk/src/breadcrumb.scss +9 -0
  2402. package/packages/theme-chalk/src/button-group.scss +133 -0
  2403. package/packages/theme-chalk/src/button.scss +324 -0
  2404. package/packages/theme-chalk/src/calendar.scss +94 -0
  2405. package/packages/theme-chalk/src/card.scss +49 -0
  2406. package/packages/theme-chalk/src/carousel-item.scss +58 -0
  2407. package/packages/theme-chalk/src/carousel.scss +195 -0
  2408. package/packages/theme-chalk/src/cascader-panel.scss +139 -0
  2409. package/packages/theme-chalk/src/cascader.scss +262 -0
  2410. package/packages/theme-chalk/src/check-tag.scss +60 -0
  2411. package/packages/theme-chalk/src/checkbox-button.scss +142 -0
  2412. package/packages/theme-chalk/src/checkbox-group.scss +7 -0
  2413. package/packages/theme-chalk/src/checkbox.scss +300 -0
  2414. package/packages/theme-chalk/src/col.scss +56 -0
  2415. package/packages/theme-chalk/src/collapse-item.scss +72 -0
  2416. package/packages/theme-chalk/src/collapse-transition.scss +1 -0
  2417. package/packages/theme-chalk/src/collapse.scss +29 -0
  2418. package/packages/theme-chalk/src/color/index.scss +20 -0
  2419. package/packages/theme-chalk/src/color-picker-panel.scss +294 -0
  2420. package/packages/theme-chalk/src/color-picker.scss +165 -0
  2421. package/packages/theme-chalk/src/common/popup.scss +47 -0
  2422. package/packages/theme-chalk/src/common/transition.scss +125 -0
  2423. package/packages/theme-chalk/src/common/var.scss +1696 -0
  2424. package/packages/theme-chalk/src/config-provider.scss +0 -0
  2425. package/packages/theme-chalk/src/container.scss +14 -0
  2426. package/packages/theme-chalk/src/dark/css-vars.scss +45 -0
  2427. package/packages/theme-chalk/src/dark/var.scss +224 -0
  2428. package/packages/theme-chalk/src/date-picker/date-picker.scss +121 -0
  2429. package/packages/theme-chalk/src/date-picker/date-range-picker.scss +165 -0
  2430. package/packages/theme-chalk/src/date-picker/date-table.scss +164 -0
  2431. package/packages/theme-chalk/src/date-picker/month-table.scss +112 -0
  2432. package/packages/theme-chalk/src/date-picker/picker-panel.scss +152 -0
  2433. package/packages/theme-chalk/src/date-picker/picker.scss +217 -0
  2434. package/packages/theme-chalk/src/date-picker/time-picker.scss +90 -0
  2435. package/packages/theme-chalk/src/date-picker/time-range-picker.scss +33 -0
  2436. package/packages/theme-chalk/src/date-picker/time-spinner.scss +115 -0
  2437. package/packages/theme-chalk/src/date-picker/utils.scss +14 -0
  2438. package/packages/theme-chalk/src/date-picker/year-table.scss +108 -0
  2439. package/packages/theme-chalk/src/date-picker-panel.scss +34 -0
  2440. package/packages/theme-chalk/src/date-picker.scss +0 -0
  2441. package/packages/theme-chalk/src/descriptions-item.scss +77 -0
  2442. package/packages/theme-chalk/src/descriptions.scss +151 -0
  2443. package/packages/theme-chalk/src/dialog.scss +207 -0
  2444. package/packages/theme-chalk/src/display.scss +12 -0
  2445. package/packages/theme-chalk/src/divider.scss +48 -0
  2446. package/packages/theme-chalk/src/drawer.scss +255 -0
  2447. package/packages/theme-chalk/src/dropdown-item.scss +0 -0
  2448. package/packages/theme-chalk/src/dropdown-menu.scss +0 -0
  2449. package/packages/theme-chalk/src/dropdown.scss +208 -0
  2450. package/packages/theme-chalk/src/empty.scss +49 -0
  2451. package/packages/theme-chalk/src/footer.scss +12 -0
  2452. package/packages/theme-chalk/src/form-item.scss +232 -0
  2453. package/packages/theme-chalk/src/form.scss +24 -0
  2454. package/packages/theme-chalk/src/header.scss +12 -0
  2455. package/packages/theme-chalk/src/icon.scss +41 -0
  2456. package/packages/theme-chalk/src/image-viewer.scss +161 -0
  2457. package/packages/theme-chalk/src/image.scss +49 -0
  2458. package/packages/theme-chalk/src/index.scss +115 -0
  2459. package/packages/theme-chalk/src/infinite-scroll.scss +0 -0
  2460. package/packages/theme-chalk/src/input-number.scss +192 -0
  2461. package/packages/theme-chalk/src/input-tag.scss +249 -0
  2462. package/packages/theme-chalk/src/input.scss +537 -0
  2463. package/packages/theme-chalk/src/link.scss +90 -0
  2464. package/packages/theme-chalk/src/loading.scss +104 -0
  2465. package/packages/theme-chalk/src/main.scss +14 -0
  2466. package/packages/theme-chalk/src/mention.scss +88 -0
  2467. package/packages/theme-chalk/src/menu-item-group.scss +0 -0
  2468. package/packages/theme-chalk/src/menu-item.scss +0 -0
  2469. package/packages/theme-chalk/src/menu.scss +376 -0
  2470. package/packages/theme-chalk/src/message-box.scss +220 -0
  2471. package/packages/theme-chalk/src/message.scss +123 -0
  2472. package/packages/theme-chalk/src/mixins/_button.scss +240 -0
  2473. package/packages/theme-chalk/src/mixins/_col.scss +41 -0
  2474. package/packages/theme-chalk/src/mixins/_var.scss +67 -0
  2475. package/packages/theme-chalk/src/mixins/config.scss +5 -0
  2476. package/packages/theme-chalk/src/mixins/function.scss +99 -0
  2477. package/packages/theme-chalk/src/mixins/mixins.scss +257 -0
  2478. package/packages/theme-chalk/src/mixins/utils.scss +39 -0
  2479. package/packages/theme-chalk/src/notification.scss +109 -0
  2480. package/packages/theme-chalk/src/option-group.scss +33 -0
  2481. package/packages/theme-chalk/src/option.scss +71 -0
  2482. package/packages/theme-chalk/src/overlay.scss +17 -0
  2483. package/packages/theme-chalk/src/page-header.scss +60 -0
  2484. package/packages/theme-chalk/src/pagination.scss +235 -0
  2485. package/packages/theme-chalk/src/popconfirm.scss +17 -0
  2486. package/packages/theme-chalk/src/popover.scss +61 -0
  2487. package/packages/theme-chalk/src/popper.scss +117 -0
  2488. package/packages/theme-chalk/src/progress.scss +179 -0
  2489. package/packages/theme-chalk/src/radio-button.scss +165 -0
  2490. package/packages/theme-chalk/src/radio-group.scss +9 -0
  2491. package/packages/theme-chalk/src/radio.scss +220 -0
  2492. package/packages/theme-chalk/src/rate.scss +121 -0
  2493. package/packages/theme-chalk/src/reset.scss +99 -0
  2494. package/packages/theme-chalk/src/result.scss +57 -0
  2495. package/packages/theme-chalk/src/row.scss +34 -0
  2496. package/packages/theme-chalk/src/scrollbar.scss +97 -0
  2497. package/packages/theme-chalk/src/segmented.scss +186 -0
  2498. package/packages/theme-chalk/src/select-dropdown-v2.scss +1 -0
  2499. package/packages/theme-chalk/src/select-dropdown.scss +57 -0
  2500. package/packages/theme-chalk/src/select-v2.scss +4 -0
  2501. package/packages/theme-chalk/src/select.scss +269 -0
  2502. package/packages/theme-chalk/src/skeleton-item.scss +83 -0
  2503. package/packages/theme-chalk/src/skeleton.scss +44 -0
  2504. package/packages/theme-chalk/src/slider.scss +212 -0
  2505. package/packages/theme-chalk/src/space.scss +20 -0
  2506. package/packages/theme-chalk/src/spinner.scss +43 -0
  2507. package/packages/theme-chalk/src/splitter-panel.scss +8 -0
  2508. package/packages/theme-chalk/src/splitter.scss +148 -0
  2509. package/packages/theme-chalk/src/statistic.scss +35 -0
  2510. package/packages/theme-chalk/src/step.scss +320 -0
  2511. package/packages/theme-chalk/src/steps.scss +22 -0
  2512. package/packages/theme-chalk/src/sub-menu.scss +0 -0
  2513. package/packages/theme-chalk/src/switch.scss +294 -0
  2514. package/packages/theme-chalk/src/tab-pane.scss +0 -0
  2515. package/packages/theme-chalk/src/table-column.scss +100 -0
  2516. package/packages/theme-chalk/src/table-v2.scss +239 -0
  2517. package/packages/theme-chalk/src/table.scss +698 -0
  2518. package/packages/theme-chalk/src/tabs.scss +691 -0
  2519. package/packages/theme-chalk/src/tag.scss +195 -0
  2520. package/packages/theme-chalk/src/text.scss +51 -0
  2521. package/packages/theme-chalk/src/time-picker.scss +5 -0
  2522. package/packages/theme-chalk/src/time-select.scss +37 -0
  2523. package/packages/theme-chalk/src/timeline-item.scss +135 -0
  2524. package/packages/theme-chalk/src/timeline.scss +101 -0
  2525. package/packages/theme-chalk/src/tooltip.scss +0 -0
  2526. package/packages/theme-chalk/src/tour.scss +187 -0
  2527. package/packages/theme-chalk/src/transfer.scss +201 -0
  2528. package/packages/theme-chalk/src/tree-select.scss +41 -0
  2529. package/packages/theme-chalk/src/tree.scss +134 -0
  2530. package/packages/theme-chalk/src/upload.scss +660 -0
  2531. package/packages/theme-chalk/src/var.scss +87 -0
  2532. package/packages/theme-chalk/src/virtual-list.scss +40 -0
  2533. package/packages/utils/__tests__/arrays.test.ts +30 -0
  2534. package/packages/utils/__tests__/browser.test.ts +28 -0
  2535. package/packages/utils/__tests__/dom/aria.test.ts +106 -0
  2536. package/packages/utils/__tests__/dom/style.test.ts +232 -0
  2537. package/packages/utils/__tests__/error.test.ts +26 -0
  2538. package/packages/utils/__tests__/i18n.test.ts +12 -0
  2539. package/packages/utils/__tests__/objects.test.ts +39 -0
  2540. package/packages/utils/__tests__/raf.test.ts +105 -0
  2541. package/packages/utils/__tests__/rand.test.ts +12 -0
  2542. package/packages/utils/__tests__/strings.test.ts +30 -0
  2543. package/packages/utils/__tests__/types.test.ts +78 -0
  2544. package/packages/utils/__tests__/typescript.test.ts +9 -0
  2545. package/packages/utils/__tests__/vue/global-node.test.ts +53 -0
  2546. package/packages/utils/__tests__/vue/icon.test.ts +42 -0
  2547. package/packages/utils/__tests__/vue/install.test.ts +174 -0
  2548. package/packages/utils/__tests__/vue/props.test.ts +581 -0
  2549. package/packages/utils/__tests__/vue/refs.test.ts +14 -0
  2550. package/packages/utils/__tests__/vue/size.test.ts +19 -0
  2551. package/packages/utils/__tests__/vue/validator.test.ts +26 -0
  2552. package/packages/utils/__tests__/vue/vnode.test.ts +94 -0
  2553. package/packages/utils/arrays.ts +19 -0
  2554. package/packages/utils/browser.ts +9 -0
  2555. package/packages/utils/dom/aria.ts +142 -0
  2556. package/packages/utils/dom/element.ts +20 -0
  2557. package/packages/utils/dom/event.ts +56 -0
  2558. package/packages/utils/dom/index.ts +6 -0
  2559. package/packages/utils/dom/position.ts +66 -0
  2560. package/packages/utils/dom/scroll.ts +165 -0
  2561. package/packages/utils/dom/style.ts +87 -0
  2562. package/packages/utils/easings.ts +8 -0
  2563. package/packages/utils/error.ts +24 -0
  2564. package/packages/utils/functions.ts +1 -0
  2565. package/packages/utils/i18n.ts +5 -0
  2566. package/packages/utils/index.ts +17 -0
  2567. package/packages/utils/numbers.ts +8 -0
  2568. package/packages/utils/objects.ts +24 -0
  2569. package/packages/utils/package.json +22 -0
  2570. package/packages/utils/raf.ts +9 -0
  2571. package/packages/utils/rand.ts +14 -0
  2572. package/packages/utils/strings.ts +14 -0
  2573. package/packages/utils/throttleByRaf.ts +22 -0
  2574. package/packages/utils/types.ts +39 -0
  2575. package/packages/utils/typescript.ts +122 -0
  2576. package/packages/utils/vue/global-node.ts +34 -0
  2577. package/packages/utils/vue/icon.ts +50 -0
  2578. package/packages/utils/vue/index.ts +9 -0
  2579. package/packages/utils/vue/install.ts +86 -0
  2580. package/packages/utils/vue/props/index.ts +3 -0
  2581. package/packages/utils/vue/props/runtime.ts +122 -0
  2582. package/packages/utils/vue/props/types.ts +165 -0
  2583. package/packages/utils/vue/props/util.ts +10 -0
  2584. package/packages/utils/vue/refs.ts +9 -0
  2585. package/packages/utils/vue/size.ts +7 -0
  2586. package/packages/utils/vue/typescript.ts +47 -0
  2587. package/packages/utils/vue/validator.ts +9 -0
  2588. package/packages/utils/vue/vnode.ts +160 -0
  2589. package/patches/async-validator@4.2.5.patch +28 -0
  2590. package/play/app.example.vue +41 -0
  2591. package/play/env.d.ts +2 -0
  2592. package/play/index.html +18 -0
  2593. package/play/main.ts +38 -0
  2594. package/play/package.json +22 -0
  2595. package/play/scripts/init.mjs +8 -0
  2596. package/play/src/.gitignore +2 -0
  2597. package/play/styles/custom.scss +3 -0
  2598. package/play/vite.config.mts +82 -0
  2599. package/pnpm-workspace.yaml +46 -0
  2600. package/scripts/build-table.ts +56 -0
  2601. package/scripts/file-check.sh +12 -0
  2602. package/scripts/gc.sh +115 -0
  2603. package/scripts/gen-version.ts +26 -0
  2604. package/scripts/nightly.sh +5 -0
  2605. package/scripts/publish.sh +23 -0
  2606. package/scripts/sync-locale.ts +243 -0
  2607. package/scripts/update-version.ts +51 -0
  2608. package/ssr-testing/assets/test-image.jpeg +0 -0
  2609. package/ssr-testing/cases/affix.vue +5 -0
  2610. package/ssr-testing/cases/alert.vue +6 -0
  2611. package/ssr-testing/cases/autocomplete.vue +61 -0
  2612. package/ssr-testing/cases/avatar.vue +33 -0
  2613. package/ssr-testing/cases/backtop.vue +4 -0
  2614. package/ssr-testing/cases/badge.vue +14 -0
  2615. package/ssr-testing/cases/basic.vue +16 -0
  2616. package/ssr-testing/cases/breadcrumb.vue +10 -0
  2617. package/ssr-testing/cases/button.vue +27 -0
  2618. package/ssr-testing/cases/calendar.vue +8 -0
  2619. package/ssr-testing/cases/card.vue +13 -0
  2620. package/ssr-testing/cases/carousel.vue +36 -0
  2621. package/ssr-testing/cases/cascader.vue +300 -0
  2622. package/ssr-testing/cases/checkbox.vue +29 -0
  2623. package/ssr-testing/cases/collapse.vue +56 -0
  2624. package/ssr-testing/cases/color-picker.vue +28 -0
  2625. package/ssr-testing/cases/container.vue +45 -0
  2626. package/ssr-testing/cases/date-picker.vue +123 -0
  2627. package/ssr-testing/cases/date-time-picker.vue +64 -0
  2628. package/ssr-testing/cases/descriptions.vue +13 -0
  2629. package/ssr-testing/cases/dialog.vue +25 -0
  2630. package/ssr-testing/cases/divider.vue +13 -0
  2631. package/ssr-testing/cases/drawer.vue +53 -0
  2632. package/ssr-testing/cases/dropdown.vue +31 -0
  2633. package/ssr-testing/cases/empty.vue +3 -0
  2634. package/ssr-testing/cases/form.vue +103 -0
  2635. package/ssr-testing/cases/image.vue +36 -0
  2636. package/ssr-testing/cases/infinite-scroll.vue +39 -0
  2637. package/ssr-testing/cases/input-number.vue +9 -0
  2638. package/ssr-testing/cases/input.vue +8 -0
  2639. package/ssr-testing/cases/layout.vue +92 -0
  2640. package/ssr-testing/cases/link.vue +18 -0
  2641. package/ssr-testing/cases/loading.vue +37 -0
  2642. package/ssr-testing/cases/menu.vue +17 -0
  2643. package/ssr-testing/cases/notification.vue +17 -0
  2644. package/ssr-testing/cases/page-header.vue +3 -0
  2645. package/ssr-testing/cases/pagination.vue +19 -0
  2646. package/ssr-testing/cases/popconfirm.vue +7 -0
  2647. package/ssr-testing/cases/popover.vue +14 -0
  2648. package/ssr-testing/cases/progress.vue +29 -0
  2649. package/ssr-testing/cases/radio.vue +30 -0
  2650. package/ssr-testing/cases/rate.vue +38 -0
  2651. package/ssr-testing/cases/result.vue +47 -0
  2652. package/ssr-testing/cases/scrollbar.vue +19 -0
  2653. package/ssr-testing/cases/select-v2.vue +54 -0
  2654. package/ssr-testing/cases/select.vue +55 -0
  2655. package/ssr-testing/cases/skeleton.vue +9 -0
  2656. package/ssr-testing/cases/slider.vue +59 -0
  2657. package/ssr-testing/cases/space.vue +15 -0
  2658. package/ssr-testing/cases/steps.vue +19 -0
  2659. package/ssr-testing/cases/table.vue +32 -0
  2660. package/ssr-testing/cases/tabs.vue +25 -0
  2661. package/ssr-testing/cases/tag.vue +7 -0
  2662. package/ssr-testing/cases/time-picker.vue +22 -0
  2663. package/ssr-testing/cases/time-select.vue +15 -0
  2664. package/ssr-testing/cases/timeline.vue +28 -0
  2665. package/ssr-testing/cases/tooltip.vue +32 -0
  2666. package/ssr-testing/cases/transfer.vue +108 -0
  2667. package/ssr-testing/cases/transition.vue +33 -0
  2668. package/ssr-testing/cases/tree-v2.vue +45 -0
  2669. package/ssr-testing/cases/tree.vue +35 -0
  2670. package/ssr-testing/cases/upload.vue +41 -0
  2671. package/ssr-testing/demo.spec.puppeteer.tsx +70 -0
  2672. package/ssr-testing/index.html +17 -0
  2673. package/ssr-testing/tsconfig.json +12 -0
  2674. package/ssr-testing/vitest.config.ts +16 -0
  2675. package/tsconfig.base.json +30 -0
  2676. package/tsconfig.json +10 -0
  2677. package/tsconfig.node.json +18 -0
  2678. package/tsconfig.play.json +18 -0
  2679. package/tsconfig.vite-config.json +9 -0
  2680. package/tsconfig.vitest.json +16 -0
  2681. package/tsconfig.web.json +21 -0
  2682. package/typings/env.d.ts +29 -0
  2683. package/typings/global.d.ts +129 -0
  2684. package/typings/style.d.ts +2 -0
  2685. package/typings/vue-test-utils.d.ts +13 -0
  2686. package/vitest.config.mts +27 -0
  2687. package/vitest.setup.ts +7 -0
@@ -0,0 +1,2420 @@
1
+ // @ts-nocheck
2
+ import { nextTick } from 'vue'
3
+ import { mount } from '@vue/test-utils'
4
+ import { describe, expect, test, vi } from 'vitest'
5
+ import defineGetter from '@element-plus/test-utils/define-getter'
6
+ import sleep from '@element-plus/test-utils/sleep'
7
+ import ElIcon from '@element-plus/components/icon'
8
+ import Tree from '../src/tree.vue'
9
+ import Button from '../../button/src/button.vue'
10
+
11
+ import type { TreeInstance } from '../index'
12
+ import type Node from '../src/model/node'
13
+
14
+ const ALL_NODE_COUNT = 9
15
+ const TREE_NODE_CHECKBOX_CLASS_NAME = '.el-checkbox__original'
16
+
17
+ const getTreeVm = (props = '', options = {}) => {
18
+ const wrapper = mount(
19
+ Object.assign(
20
+ {
21
+ components: {
22
+ 'el-tree': Tree,
23
+ },
24
+ template: `
25
+ <el-tree ref="tree" :data="data" ${props}></el-tree>
26
+ `,
27
+ data() {
28
+ return {
29
+ currentId: null,
30
+ currentNode: null,
31
+ nodeExpended: false,
32
+ defaultExpandedKeys: [],
33
+ defaultCheckedKeys: [],
34
+ clickedNode: null,
35
+ count: 1,
36
+ data: [
37
+ {
38
+ id: 1,
39
+ label: '一级 1',
40
+ children: [
41
+ {
42
+ id: 11,
43
+ label: '二级 1-1',
44
+ children: [
45
+ {
46
+ id: 111,
47
+ label: '三级 1-1',
48
+ },
49
+ ],
50
+ },
51
+ ],
52
+ },
53
+ {
54
+ id: 2,
55
+ label: '一级 2',
56
+ children: [
57
+ {
58
+ id: 21,
59
+ label: '二级 2-1',
60
+ },
61
+ {
62
+ id: 22,
63
+ label: '二级 2-2',
64
+ },
65
+ ],
66
+ },
67
+ {
68
+ id: 3,
69
+ label: '一级 3',
70
+ children: [
71
+ {
72
+ id: 31,
73
+ label: '二级 3-1',
74
+ },
75
+ {
76
+ id: 32,
77
+ label: '二级 3-2',
78
+ },
79
+ ],
80
+ },
81
+ ],
82
+ defaultProps: {
83
+ children: 'children',
84
+ label: 'label',
85
+ isLeaf: 'isLeaf',
86
+ },
87
+ }
88
+ },
89
+ },
90
+ options
91
+ )
92
+ )
93
+ return { wrapper, vm: wrapper.vm }
94
+ }
95
+
96
+ const getDisableTreeVm = (props = '', options = {}) => {
97
+ const wrapper = mount(
98
+ Object.assign(
99
+ {
100
+ components: {
101
+ 'el-tree': Tree,
102
+ },
103
+ template: `
104
+ <el-tree ref="tree" :data="data" ${props}></el-tree>
105
+ `,
106
+ data() {
107
+ return {
108
+ defaultExpandedKeys: [],
109
+ defaultCheckedKeys: [],
110
+ clickedNode: null,
111
+ count: 1,
112
+ data: [
113
+ {
114
+ id: 1,
115
+ label: '一级 1',
116
+ children: [
117
+ {
118
+ id: 11,
119
+ label: '二级 1-1',
120
+ children: [
121
+ {
122
+ id: 111,
123
+ label: '三级 1-1',
124
+ disabled: true,
125
+ },
126
+ ],
127
+ },
128
+ ],
129
+ },
130
+ {
131
+ id: 2,
132
+ label: '一级 2',
133
+ children: [
134
+ {
135
+ id: 21,
136
+ label: '二级 2-1',
137
+ },
138
+ {
139
+ id: 22,
140
+ label: '二级 2-2',
141
+ },
142
+ ],
143
+ },
144
+ {
145
+ id: 3,
146
+ label: '一级 3',
147
+ children: [
148
+ {
149
+ id: 31,
150
+ label: '二级 3-1',
151
+ },
152
+ {
153
+ id: 32,
154
+ label: '二级 3-2',
155
+ },
156
+ ],
157
+ },
158
+ ],
159
+ defaultProps: {
160
+ children: 'children',
161
+ label: 'label',
162
+ disabled: 'disabled',
163
+ },
164
+ }
165
+ },
166
+ },
167
+ options
168
+ )
169
+ )
170
+ return { wrapper, vm: wrapper.vm }
171
+ }
172
+
173
+ describe('Tree.vue', () => {
174
+ test('create', async () => {
175
+ const { wrapper, vm } = getTreeVm(
176
+ `:props="defaultProps" default-expand-all`
177
+ )
178
+
179
+ expect(wrapper.find('.el-tree').exists()).toBeTruthy()
180
+ expect(wrapper.findAll('.el-tree > .el-tree-node').length).toEqual(3)
181
+ expect(wrapper.findAll('.el-tree .el-tree-node').length).toEqual(
182
+ ALL_NODE_COUNT
183
+ )
184
+ vm.data[1].children = [{ label: '二级 2-1' }] as any
185
+ await nextTick()
186
+ expect(wrapper.findAll('.el-tree .el-tree-node').length).toEqual(
187
+ ALL_NODE_COUNT - 1
188
+ )
189
+ })
190
+
191
+ test('click node', async () => {
192
+ const { wrapper, vm } = getTreeVm(
193
+ `:props="defaultProps" @node-click="handleNodeClick"`,
194
+ {
195
+ methods: {
196
+ handleNodeClick(data) {
197
+ this.clickedNode = data
198
+ },
199
+ },
200
+ }
201
+ )
202
+
203
+ const firstNodeContentWrapper = wrapper.find('.el-tree-node__content')
204
+ const firstNodeWrapper = wrapper.find('.el-tree-node')
205
+
206
+ await firstNodeContentWrapper.trigger('click')
207
+ await nextTick() // because node click method to expaned is async
208
+
209
+ expect(vm.clickedNode.label).toEqual('一级 1')
210
+ expect(firstNodeWrapper.classes('is-expanded')).toBe(true)
211
+ expect(firstNodeWrapper.classes('is-current')).toBe(true)
212
+
213
+ await firstNodeContentWrapper.trigger('click')
214
+ await nextTick() // because node click method to expaned is async
215
+
216
+ expect(firstNodeWrapper.classes('is-expanded')).toBe(false)
217
+ expect(firstNodeWrapper.classes('is-current')).toBe(true)
218
+ })
219
+
220
+ test('emptyText', async () => {
221
+ const { wrapper, vm } = getTreeVm(`:props="defaultProps"`)
222
+ vm.data = []
223
+ await nextTick()
224
+ expect(wrapper.findAll('.el-tree__empty-block').length).toEqual(1)
225
+ })
226
+
227
+ test('expandOnNodeClick', async () => {
228
+ const { wrapper } = getTreeVm(
229
+ `:props="defaultProps" :expand-on-click-node="false"`
230
+ )
231
+
232
+ const firstNodeContentWrapper = wrapper.find('.el-tree-node__content')
233
+ const firstNodeWrapper = wrapper.find('.el-tree-node')
234
+
235
+ await firstNodeContentWrapper.trigger('click')
236
+ await nextTick() // because node click method to expaned is async
237
+
238
+ expect(firstNodeWrapper.classes('is-expanded')).toBe(false)
239
+ })
240
+
241
+ test('checkOnNodeClick', async () => {
242
+ const { wrapper } = getTreeVm(
243
+ `:props="defaultProps" node-key="id" show-checkbox check-on-click-node`
244
+ )
245
+
246
+ const treeWrapper = wrapper.findComponent(Tree)
247
+ const firstNodeContentWrapper = wrapper.find('.el-tree-node__content')
248
+
249
+ await firstNodeContentWrapper.trigger('click')
250
+ expect(
251
+ (treeWrapper.vm as InstanceType<typeof Tree>).getCheckedKeys()
252
+ ).toEqual([1, 11, 111])
253
+ })
254
+
255
+ test('current-node-key', async () => {
256
+ const { wrapper } = getTreeVm(
257
+ `:props="defaultProps" default-expand-all highlight-current node-key="id" :current-node-key="11"`
258
+ )
259
+
260
+ const currentNodeLabelWrapper = wrapper.find(
261
+ '.is-current .el-tree-node__label'
262
+ )
263
+
264
+ expect(currentNodeLabelWrapper.text()).toEqual('二级 1-1')
265
+ expect(wrapper.find('.el-tree--highlight-current').exists()).toBe(true)
266
+ })
267
+
268
+ test('update tree-data after current-node-key', async () => {
269
+ const { wrapper, vm } = getTreeVm(
270
+ `:props="defaultProps" :expand-on-click-node="false" default-expand-all highlight-current node-key="id" :current-node-key="currentId"`
271
+ )
272
+
273
+ vm.currentId = 22
274
+ await nextTick()
275
+ const currentNodeLabelWrapper = wrapper.find(
276
+ '.is-current .el-tree-node__label'
277
+ )
278
+ expect(wrapper.find('.el-tree--highlight-current').exists()).toBe(true)
279
+ expect(currentNodeLabelWrapper.text()).toEqual('二级 2-2')
280
+ const _data = [...vm.data]
281
+ await nextTick()
282
+ vm.data = [..._data]
283
+ await nextTick()
284
+ const currentNodeLabelWrapper2 = wrapper.find(
285
+ '.is-current .el-tree-node__label'
286
+ )
287
+ expect(currentNodeLabelWrapper2.exists()).toBe(true)
288
+ expect(currentNodeLabelWrapper2.text()).toEqual('二级 2-2')
289
+ expect(wrapper.find('.el-tree--highlight-current').exists()).toBe(true)
290
+ })
291
+
292
+ test('defaultExpandAll', async () => {
293
+ const { wrapper } = getTreeVm(`:props="defaultProps" default-expand-all`)
294
+ const expanedNodeWrappers = wrapper.findAll('.el-tree-node.is-expanded')
295
+ expect(expanedNodeWrappers.length).toEqual(ALL_NODE_COUNT)
296
+ })
297
+
298
+ test('defaultExpandedKeys', async () => {
299
+ const { wrapper } = getTreeVm(
300
+ `:props="defaultProps" :default-expanded-keys="defaultExpandedKeys" node-key="id"`,
301
+ {
302
+ created() {
303
+ this.defaultExpandedKeys = [1, 3]
304
+ },
305
+ }
306
+ )
307
+ const expanedNodeWrappers = wrapper.findAll('.el-tree-node.is-expanded')
308
+ expect(expanedNodeWrappers.length).toEqual(2)
309
+ })
310
+
311
+ test('defaultExpandedKeys set', async () => {
312
+ const { wrapper, vm } = getTreeVm(
313
+ `:props="defaultProps" :default-expanded-keys="defaultExpandedKeys" node-key="id"`,
314
+ {
315
+ created() {
316
+ this.defaultExpandedKeys = [1, 3]
317
+ },
318
+ }
319
+ )
320
+ await nextTick()
321
+ let expanedNodeWrappers = wrapper.findAll('.el-tree-node.is-expanded')
322
+ expect(expanedNodeWrappers.length).toEqual(2)
323
+ vm.defaultExpandedKeys = [2]
324
+ await nextTick()
325
+ await nextTick()
326
+ vm.data = [
327
+ {
328
+ id: 4,
329
+ label: 'L1 4',
330
+ children: [],
331
+ },
332
+ ...JSON.parse(JSON.stringify(vm.data)),
333
+ ]
334
+ await nextTick()
335
+ await nextTick()
336
+ await nextTick()
337
+ expanedNodeWrappers = wrapper.findAll('.el-tree-node.is-expanded')
338
+ expect(expanedNodeWrappers.length).toEqual(1)
339
+ })
340
+
341
+ test('filter-node-method', async () => {
342
+ const { wrapper } = getTreeVm(
343
+ `:props="defaultProps" :filter-node-method="filterNode"`,
344
+ {
345
+ methods: {
346
+ filterNode(value, data) {
347
+ if (!value) return true
348
+ return data.label.includes(value)
349
+ },
350
+ },
351
+ }
352
+ )
353
+
354
+ const treeWrapper = wrapper.findComponent(Tree)
355
+ ;(treeWrapper.vm as InstanceType<typeof Tree>).filter('2-1')
356
+
357
+ await sleep()
358
+ expect(treeWrapper.findAll('.el-tree-node.is-hidden').length).toEqual(3)
359
+ })
360
+ test('lazy load with filter expand loaded node', async () => {
361
+ const { wrapper } = getTreeVm(
362
+ `:props="defaultProps" lazy :load="loadNode" :filter-node-method="filterNode"`,
363
+ {
364
+ methods: {
365
+ loadNode(node, resolve) {
366
+ if (node.level === 0) {
367
+ return resolve([{ label: 'a', id: 'a', type: 'root' }])
368
+ }
369
+ if (node.data.type === 'root') {
370
+ return resolve([
371
+ {
372
+ label: 'node1',
373
+ id: 'node1',
374
+ type: 'node',
375
+ },
376
+ {
377
+ label: 'node2',
378
+ id: 'node2',
379
+ type: 'node',
380
+ },
381
+ ])
382
+ }
383
+ if (node.data.type === 'node') {
384
+ return resolve([
385
+ {
386
+ label: `${node.data.label}-child1`,
387
+ id: `${node.data.label}-child1`,
388
+ type: 'item',
389
+ leaf: true,
390
+ },
391
+ {
392
+ label: `${node.data.label}-child2`,
393
+ id: `${node.data.label}-child2`,
394
+ type: 'item',
395
+ leaf: true,
396
+ },
397
+ ])
398
+ }
399
+ resolve([])
400
+ },
401
+ filterNode(value, data) {
402
+ if (!value) return true
403
+ return data.label.includes(value)
404
+ },
405
+ },
406
+ }
407
+ )
408
+
409
+ let nodeWrappers = wrapper.findAll('.el-tree-node__content')
410
+
411
+ expect(nodeWrappers.length).toEqual(1)
412
+ nodeWrappers[0].trigger('click')
413
+ await sleep()
414
+ nodeWrappers = wrapper.findAll('.el-tree-node__content')
415
+ expect(nodeWrappers.length).toEqual(3)
416
+ nodeWrappers[1].trigger('click')
417
+ nodeWrappers[2].trigger('click')
418
+ await sleep()
419
+ nodeWrappers = wrapper.findAll('.el-tree-node__content')
420
+ expect(nodeWrappers.length).toEqual(7)
421
+ expect(wrapper.findAll('.is-expanded').length).toEqual(3)
422
+ // collapse node
423
+ const rootNode = nodeWrappers[0]
424
+ rootNode.trigger('click')
425
+ await sleep()
426
+ expect(rootNode.element.parentNode.getAttribute('aria-expanded')).toEqual(
427
+ 'false'
428
+ )
429
+ // filter
430
+ wrapper.findComponent(Tree).vm.filter('1')
431
+ await sleep()
432
+ expect(rootNode.element.parentNode.getAttribute('aria-expanded')).toEqual(
433
+ 'true'
434
+ )
435
+ })
436
+
437
+ test('autoExpandParent = true', async () => {
438
+ const { wrapper } = getTreeVm(
439
+ `:props="defaultProps" :default-expanded-keys="defaultExpandedKeys" node-key="id"`,
440
+ {
441
+ created() {
442
+ this.defaultExpandedKeys = [111]
443
+ },
444
+ }
445
+ )
446
+ expect(wrapper.findAll('.el-tree-node.is-expanded').length).toEqual(3)
447
+ })
448
+
449
+ test('autoExpandParent = false', async () => {
450
+ const { wrapper } = getTreeVm(
451
+ `:props="defaultProps" :default-expanded-keys="defaultExpandedKeys" node-key="id" :auto-expand-parent="false"`,
452
+ {
453
+ created() {
454
+ this.defaultExpandedKeys = [11]
455
+ },
456
+ }
457
+ )
458
+ expect(wrapper.findAll('.el-tree-node.is-expanded').length).toEqual(0)
459
+
460
+ const firstNodeContentWrapper = wrapper.find('.el-tree-node__content')
461
+ await firstNodeContentWrapper.trigger('click')
462
+ await nextTick()
463
+
464
+ expect(wrapper.findAll('.el-tree-node.is-expanded').length).toEqual(2)
465
+ })
466
+
467
+ test('defaultCheckedKeys & check-strictly = false', async () => {
468
+ const { wrapper } = getTreeVm(
469
+ `:props="defaultProps" default-expand-all show-checkbox :default-checked-keys="defaultCheckedKeys" node-key="id"`,
470
+ {
471
+ created() {
472
+ this.defaultCheckedKeys = [1]
473
+ },
474
+ }
475
+ )
476
+ expect(wrapper.findAll('.el-checkbox .is-checked').length).toEqual(3)
477
+ })
478
+
479
+ test('defaultCheckedKeys & check-strictly', async () => {
480
+ const { wrapper } = getTreeVm(
481
+ `:props="defaultProps" default-expand-all show-checkbox :default-checked-keys="defaultCheckedKeys" node-key="id" check-strictly`,
482
+ {
483
+ created() {
484
+ this.defaultCheckedKeys = [1]
485
+ },
486
+ }
487
+ )
488
+ expect(wrapper.findAll('.el-checkbox .is-checked').length).toEqual(1)
489
+ })
490
+
491
+ test('show checkbox', async () => {
492
+ const { wrapper } = getTreeVm(`:props="defaultProps" show-checkbox`)
493
+
494
+ const treeWrapper = wrapper.findComponent(Tree)
495
+ const treeVm = treeWrapper.vm as InstanceType<typeof Tree>
496
+ const secondNodeContentWrapper = treeWrapper.findAll(
497
+ '.el-tree-node__content'
498
+ )[1]
499
+ const secondNodeCheckboxWrapper =
500
+ secondNodeContentWrapper.find('.el-checkbox')
501
+ const secondNodeExpandIconWrapper = secondNodeContentWrapper.find(
502
+ '.el-tree-node__expand-icon'
503
+ )
504
+
505
+ expect(secondNodeCheckboxWrapper.exists()).toBe(true)
506
+ await secondNodeCheckboxWrapper.trigger('click')
507
+
508
+ expect(treeVm.getCheckedNodes().length).toEqual(3)
509
+ expect(treeVm.getCheckedNodes(true).length).toEqual(2)
510
+
511
+ await secondNodeExpandIconWrapper.trigger('click')
512
+ await nextTick()
513
+
514
+ const secondTreeNodeWrapper = treeWrapper.findAll('.el-tree-node')[1]
515
+ const secondNodefirstLeafCheckboxWrapper = secondTreeNodeWrapper.find(
516
+ '.el-tree-node__children .el-tree-node__content .el-checkbox'
517
+ )
518
+
519
+ await secondNodefirstLeafCheckboxWrapper.trigger('click')
520
+ expect(treeVm.getCheckedNodes().length).toEqual(1)
521
+ })
522
+
523
+ test('check', async () => {
524
+ const handleCheckMockFunction = vi.fn()
525
+ const { wrapper } = getTreeVm(
526
+ `:props="defaultProps" show-checkbox @check="handleCheck"`,
527
+ {
528
+ methods: {
529
+ handleCheck: handleCheckMockFunction,
530
+ },
531
+ }
532
+ )
533
+
534
+ const secondNodeContentWrapper = wrapper.findAll(
535
+ '.el-tree-node__content'
536
+ )[1]
537
+ const secondNodeCheckboxWrapper =
538
+ secondNodeContentWrapper.find('.el-checkbox')
539
+ expect(secondNodeCheckboxWrapper.exists()).toBe(true)
540
+
541
+ await secondNodeCheckboxWrapper.trigger('click')
542
+ await nextTick()
543
+
544
+ expect(handleCheckMockFunction.mock.calls.length).toBe(1)
545
+ const [data, args] = handleCheckMockFunction.mock.calls[0]
546
+ expect(data.id).toEqual(2)
547
+ expect(args.checkedNodes.length).toEqual(3)
548
+ })
549
+
550
+ test('check by clicking on leaf node', async () => {
551
+ const { wrapper } = getTreeVm(`:props="defaultProps" show-checkbox`)
552
+ const treeVm = wrapper.findComponent(Tree).vm
553
+
554
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
555
+
556
+ const secondTreeNodeWrapper = wrapper.findAll('.el-tree-node')[2]
557
+ await secondTreeNodeWrapper.trigger('click')
558
+
559
+ const secondNodeContentWrapper = secondTreeNodeWrapper.findAll(
560
+ '.el-tree-node__content'
561
+ )[1]
562
+ await secondNodeContentWrapper.trigger('click')
563
+
564
+ expect(treeVm.getCheckedNodes().length).toEqual(1)
565
+ })
566
+
567
+ test('show-checkbox :check-on-click-leaf="false"', async () => {
568
+ const { wrapper } = getTreeVm(
569
+ `:props="defaultProps" show-checkbox :check-on-click-leaf="false"`
570
+ )
571
+ const treeVm = wrapper.findComponent(Tree).vm
572
+
573
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
574
+
575
+ const secondTreeNodeWrapper = wrapper.findAll('.el-tree-node')[2]
576
+ await secondTreeNodeWrapper.trigger('click')
577
+
578
+ const secondNodeContentWrapper = secondTreeNodeWrapper.findAll(
579
+ '.el-tree-node__content'
580
+ )[1]
581
+ await secondNodeContentWrapper.trigger('click')
582
+
583
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
584
+ })
585
+
586
+ test('ensure no checked nodes in non show-checkbox mode', async () => {
587
+ const { wrapper } = getTreeVm(`:props="defaultProps"`)
588
+ const treeVm = wrapper.findComponent(Tree).vm
589
+
590
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
591
+
592
+ const secondTreeNodeWrapper = wrapper.findAll('.el-tree-node')[2]
593
+ await secondTreeNodeWrapper.trigger('click')
594
+
595
+ const secondNodeContentWrapper = secondTreeNodeWrapper.findAll(
596
+ '.el-tree-node__content'
597
+ )[1]
598
+
599
+ expect(
600
+ secondNodeContentWrapper
601
+ .findComponent(ElIcon)
602
+ .classes()
603
+ .includes('is-leaf')
604
+ ).toBe(true)
605
+
606
+ await secondNodeContentWrapper.trigger('click')
607
+
608
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
609
+ })
610
+
611
+ test('setCheckedNodes', async () => {
612
+ const { wrapper } = getTreeVm(
613
+ `:props="defaultProps" show-checkbox node-key="id"`
614
+ )
615
+ const treeWrapper = wrapper.findComponent(Tree)
616
+ const treeVm = treeWrapper.vm as InstanceType<typeof Tree>
617
+ const secondNodeContentWrapper = wrapper.findAll(
618
+ '.el-tree-node__content'
619
+ )[1]
620
+ const secondNodeCheckWrapper = secondNodeContentWrapper.find('.el-checkbox')
621
+ await secondNodeCheckWrapper.trigger('click')
622
+
623
+ expect(treeVm.getCheckedNodes().length).toEqual(3)
624
+ expect(treeVm.getCheckedNodes(true).length).toEqual(2)
625
+
626
+ treeVm.setCheckedNodes([])
627
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
628
+ })
629
+
630
+ test('setCheckedNodes with disabled node', async () => {
631
+ const nodes = [
632
+ {
633
+ id: 1,
634
+ label: 'Level one 1',
635
+ children: [
636
+ {
637
+ id: 4,
638
+ label: 'Level two 1-1',
639
+ children: [
640
+ {
641
+ id: 9,
642
+ label: 'Level three 1-1-1',
643
+ },
644
+ {
645
+ id: 10,
646
+ label: 'Level three 1-1-2',
647
+ },
648
+ ],
649
+ },
650
+ ],
651
+ },
652
+ {
653
+ id: 2,
654
+ label: 'Level one 2',
655
+ children: [
656
+ {
657
+ id: 5,
658
+ disabled: true,
659
+ label: 'Level two 2-1',
660
+ },
661
+ {
662
+ id: 6,
663
+ label: 'Level two 2-2',
664
+ },
665
+ ],
666
+ },
667
+ {
668
+ id: 3,
669
+ label: 'Level one 3',
670
+ children: [
671
+ {
672
+ id: 7,
673
+ label: 'Level two 3-1',
674
+ },
675
+ {
676
+ id: 8,
677
+ label: 'Level two 3-2',
678
+ },
679
+ ],
680
+ },
681
+ ]
682
+ const wrapper = mount(
683
+ Object.assign({
684
+ components: {
685
+ 'el-tree': Tree,
686
+ },
687
+ template: `
688
+ <el-tree ref="tree" :data="data" :props="defaultProps" default-expand-all show-checkbox node-key="id"></el-tree>
689
+ `,
690
+ data() {
691
+ return {
692
+ data: nodes,
693
+ defaultProps: {
694
+ children: 'children',
695
+ label: 'label',
696
+ },
697
+ }
698
+ },
699
+ })
700
+ )
701
+ const treeWrapper = wrapper.findComponent(Tree)
702
+ const treeVm = treeWrapper.vm as InstanceType<typeof Tree>
703
+ expect(treeVm.getCheckedNodes().length).toEqual(0)
704
+
705
+ function flattenTree(data) {
706
+ const result = []
707
+
708
+ function flatten(node) {
709
+ result.push(node)
710
+ if (node?.children?.length) {
711
+ node.children.forEach(flatten)
712
+ }
713
+ }
714
+
715
+ data.forEach(flatten)
716
+ return result
717
+ }
718
+ const list = flattenTree(nodes).filter((item) => !item.disabled)
719
+
720
+ treeVm.setCheckedNodes(list)
721
+ expect(treeVm.getCheckedNodes().length).toEqual(8)
722
+ })
723
+
724
+ test('setCheckedKeys', async () => {
725
+ const { wrapper } = getTreeVm(
726
+ `:props="defaultProps" show-checkbox node-key="id"`
727
+ )
728
+ const treeWrapper = wrapper.findComponent(Tree)
729
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
730
+
731
+ tree.setCheckedKeys([111])
732
+ expect(tree.getCheckedNodes().length).toEqual(3)
733
+ expect(tree.getCheckedKeys().length).toEqual(3)
734
+
735
+ tree.setCheckedKeys([1])
736
+ expect(tree.getCheckedNodes().length).toEqual(3)
737
+ expect(tree.getCheckedKeys().length).toEqual(3)
738
+
739
+ tree.setCheckedKeys([2])
740
+ expect(tree.getCheckedNodes().length).toEqual(3)
741
+ expect(tree.getCheckedKeys().length).toEqual(3)
742
+
743
+ tree.setCheckedKeys([21])
744
+ expect(tree.getCheckedNodes().length).toEqual(1)
745
+ expect(tree.getCheckedKeys().length).toEqual(1)
746
+ })
747
+
748
+ test('setCheckedKeys with checkStrictly', async () => {
749
+ const { wrapper } = getTreeVm(
750
+ `:props="defaultProps" checkStrictly show-checkbox node-key="id"`
751
+ )
752
+ const treeWrapper = wrapper.findComponent(Tree)
753
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
754
+
755
+ tree.setCheckedKeys([111])
756
+ expect(tree.getCheckedNodes().length).toEqual(1)
757
+ expect(tree.getCheckedKeys().length).toEqual(1)
758
+
759
+ tree.setCheckedKeys([1])
760
+ expect(tree.getCheckedNodes().length).toEqual(1)
761
+ expect(tree.getCheckedKeys().length).toEqual(1)
762
+
763
+ tree.setCheckedKeys([2])
764
+ expect(tree.getCheckedNodes().length).toEqual(1)
765
+ expect(tree.getCheckedKeys().length).toEqual(1)
766
+
767
+ tree.setCheckedKeys([21, 22])
768
+ expect(tree.getCheckedNodes().length).toEqual(2)
769
+ expect(tree.getCheckedKeys().length).toEqual(2)
770
+ })
771
+
772
+ test('method setChecked', async () => {
773
+ const { wrapper } = getTreeVm(
774
+ `:props="defaultProps" show-checkbox node-key="id"`
775
+ )
776
+ const treeWrapper = wrapper.findComponent(Tree)
777
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
778
+
779
+ tree.setChecked(111, true, true)
780
+ expect(tree.getCheckedNodes().length).toEqual(3)
781
+ expect(tree.getCheckedKeys().length).toEqual(3)
782
+
783
+ tree.setChecked(tree.data[0], false, true)
784
+ expect(tree.getCheckedNodes().length).toEqual(0)
785
+ expect(tree.getCheckedKeys().length).toEqual(0)
786
+ })
787
+
788
+ test('setCheckedKeys with leafOnly=false', async () => {
789
+ const { wrapper } = getTreeVm(
790
+ `:props="defaultProps" show-checkbox node-key="id"`
791
+ )
792
+ const treeWrapper = wrapper.findComponent(Tree)
793
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
794
+
795
+ tree.setCheckedKeys([1, 11, 111, 2], false)
796
+ expect(tree.getCheckedNodes().length).toEqual(6)
797
+ expect(tree.getCheckedKeys().length).toEqual(6)
798
+ })
799
+
800
+ test('setCheckedKeys with leafOnly=true', async () => {
801
+ const { wrapper } = getTreeVm(
802
+ `:props="defaultProps" show-checkbox node-key="id"`
803
+ )
804
+ const treeWrapper = wrapper.findComponent(Tree)
805
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
806
+
807
+ tree.setCheckedKeys([2], true)
808
+ expect(tree.getCheckedNodes().length).toEqual(3)
809
+ expect(tree.getCheckedKeys().length).toEqual(3)
810
+ })
811
+
812
+ test('setCheckedKeys with leafOnly=true produces consistent parent states', async () => {
813
+ const { wrapper } = getTreeVm(
814
+ `:props="defaultProps" show-checkbox node-key="id"`
815
+ )
816
+ const treeWrapper = wrapper.findComponent(Tree)
817
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
818
+
819
+ tree.setCheckedKeys([1], true)
820
+
821
+ expect(tree.getCheckedKeys().sort()).toEqual([1, 11, 111])
822
+ expect(tree.getHalfCheckedNodes()).toEqual([])
823
+ expect(tree.getHalfCheckedKeys()).toEqual([])
824
+ })
825
+
826
+ test('setCurrentKey', async () => {
827
+ const { wrapper } = getTreeVm(
828
+ `:props="defaultProps" show-checkbox node-key="id"`
829
+ )
830
+ const treeWrapper = wrapper.findComponent(Tree)
831
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
832
+
833
+ tree.setCurrentKey(111)
834
+ expect(tree.store.currentNode.data.id).toEqual(111)
835
+
836
+ tree.setCurrentKey(null)
837
+ expect(tree.store.currentNode).toEqual(null)
838
+ })
839
+
840
+ test('setCurrentKey should also auto expand parent', async () => {
841
+ const { wrapper } = getTreeVm(
842
+ `:props="defaultProps" show-checkbox node-key="id"`
843
+ )
844
+ const treeWrapper = wrapper.findComponent(Tree)
845
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
846
+
847
+ tree.setCurrentKey(111)
848
+ await nextTick()
849
+ expect(wrapper.find('.is-current').exists()).toBeTruthy()
850
+
851
+ tree.setCurrentKey(null)
852
+ await nextTick()
853
+ expect(wrapper.find('.is-current').exists()).toBeFalsy()
854
+ })
855
+
856
+ test('setCurrentKey should not expand self', async () => {
857
+ const { wrapper } = getTreeVm(
858
+ `:props="defaultProps" show-checkbox node-key="id"`
859
+ )
860
+ const treeWrapper = wrapper.findComponent(Tree)
861
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
862
+
863
+ tree.setCurrentKey(1)
864
+ await nextTick()
865
+ await nextTick()
866
+ await nextTick()
867
+ expect(wrapper.text()).toBe('一级 1一级 2一级 3')
868
+ expect(wrapper.findAll('.is-expanded')).toHaveLength(0)
869
+
870
+ tree.setCurrentKey(11)
871
+ await nextTick()
872
+ await nextTick()
873
+ await nextTick()
874
+ expect(wrapper.text()).toBe('一级 1二级 1-1一级 2一级 3')
875
+ expect(wrapper.findAll('.is-expanded')).toHaveLength(1)
876
+
877
+ tree.setCurrentKey(111)
878
+ await nextTick()
879
+ await nextTick()
880
+ await nextTick()
881
+ expect(wrapper.text()).toBe('一级 1二级 1-1三级 1-1一级 2一级 3')
882
+ expect(wrapper.findAll('.is-expanded')).toHaveLength(2)
883
+ })
884
+
885
+ test('setCurrentKey should not have multiple nodes with highlighted states at the same time', async () => {
886
+ const { wrapper, vm } = getTreeVm(`:props="defaultProps" node-key="id"`)
887
+
888
+ const treeWrapper = wrapper.findComponent(Tree)
889
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
890
+
891
+ tree.setCurrentKey(1)
892
+ await nextTick()
893
+ expect(treeWrapper.findAll('.is-current').length).toEqual(1)
894
+
895
+ const nodeData = { label: '一级 4', id: 4, children: [] }
896
+ vm.data.push(nodeData)
897
+
898
+ tree.setCurrentKey(4)
899
+ await nextTick()
900
+ expect(treeWrapper.findAll('.is-current').length).toEqual(1)
901
+ })
902
+
903
+ test('setCurrentNode', async () => {
904
+ const { wrapper } = getTreeVm(
905
+ `:props="defaultProps" show-checkbox node-key="id"`
906
+ )
907
+ const treeWrapper = wrapper.findComponent(Tree)
908
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
909
+
910
+ tree.setCurrentNode({
911
+ id: 111,
912
+ label: '三级 1-1',
913
+ } as Node)
914
+ expect(tree.store.currentNode.data.id).toEqual(111)
915
+
916
+ tree.setCurrentKey(null)
917
+ expect(tree.store.currentNode).toEqual(null)
918
+ })
919
+
920
+ test('setCurrentNode should also auto expand parent', async () => {
921
+ const { wrapper } = getTreeVm(
922
+ `:props="defaultProps" show-checkbox node-key="id"`
923
+ )
924
+ const treeWrapper = wrapper.findComponent(Tree)
925
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
926
+
927
+ tree.setCurrentNode({
928
+ id: 111,
929
+ label: '三级 1-1',
930
+ } as Node)
931
+ await nextTick()
932
+ expect(wrapper.find('.is-current').exists()).toBeTruthy()
933
+
934
+ tree.setCurrentKey(null)
935
+ await nextTick()
936
+ expect(wrapper.find('.is-current').exists()).toBeFalsy()
937
+ })
938
+
939
+ test('setCurrentNode should not expand self', async () => {
940
+ const { wrapper } = getTreeVm(
941
+ `:props="defaultProps" show-checkbox node-key="id"`
942
+ )
943
+ await nextTick()
944
+ const treeWrapper = wrapper.findComponent(Tree)
945
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
946
+
947
+ tree.setCurrentNode({
948
+ id: 1,
949
+ label: '一级 1-1',
950
+ } as Node)
951
+ await nextTick()
952
+ await nextTick()
953
+ await nextTick()
954
+ expect(wrapper.text()).toBe('一级 1一级 2一级 3')
955
+ expect(wrapper.findAll('.is-expanded')).toHaveLength(0)
956
+
957
+ tree.setCurrentNode({
958
+ id: 11,
959
+ label: '二级 1-1',
960
+ } as Node)
961
+ await nextTick()
962
+ await nextTick()
963
+ await nextTick()
964
+ expect(wrapper.text()).toBe('一级 1二级 1-1一级 2一级 3')
965
+ expect(wrapper.findAll('.is-expanded')).toHaveLength(1)
966
+
967
+ tree.setCurrentNode({
968
+ id: 111,
969
+ label: '三级 1-1',
970
+ } as Node)
971
+ await nextTick()
972
+ await nextTick()
973
+ await nextTick()
974
+ expect(wrapper.text()).toBe('一级 1二级 1-1三级 1-1一级 2一级 3')
975
+ expect(wrapper.findAll('.is-expanded')).toHaveLength(2)
976
+ })
977
+
978
+ test('getCurrentKey', async () => {
979
+ const { wrapper } = getTreeVm(
980
+ `:props="defaultProps" show-checkbox node-key="id"`
981
+ )
982
+ const treeWrapper = wrapper.findComponent(Tree)
983
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
984
+
985
+ tree.setCurrentKey(111)
986
+ expect(tree.getCurrentKey()).toEqual(111)
987
+
988
+ tree.setCurrentKey(null)
989
+ expect(tree.getCurrentKey()).toEqual(null)
990
+ })
991
+
992
+ test('getCurrentNode', async () => {
993
+ const { wrapper } = getTreeVm(
994
+ `:props="defaultProps" show-checkbox node-key="id"`
995
+ )
996
+ const treeWrapper = wrapper.findComponent(Tree)
997
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
998
+
999
+ tree.setCurrentKey(111)
1000
+ expect(tree.getCurrentNode().id).toEqual(111)
1001
+ })
1002
+
1003
+ test('getNode', async () => {
1004
+ const { wrapper } = getTreeVm(`:props="defaultProps" node-key="id"`)
1005
+ const treeWrapper = wrapper.findComponent(Tree)
1006
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1007
+
1008
+ const node = tree.getNode(111)
1009
+ expect(node.data.id).toEqual(111)
1010
+ })
1011
+
1012
+ test('remove', async () => {
1013
+ const { wrapper } = getTreeVm(`:props="defaultProps" node-key="id"`)
1014
+ const treeWrapper = wrapper.findComponent(Tree)
1015
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1016
+
1017
+ tree.setCurrentKey(1)
1018
+ expect(tree.getCurrentNode().id).toEqual(1)
1019
+ tree.remove(1)
1020
+
1021
+ expect(tree.data[0].id).toEqual(2)
1022
+ expect(tree.getNode(1)).toEqual(null)
1023
+ expect(tree.getCurrentNode()).toEqual(null)
1024
+ })
1025
+
1026
+ test('append', async () => {
1027
+ const { wrapper } = getTreeVm(`:props="defaultProps" node-key="id"`)
1028
+ const treeWrapper = wrapper.findComponent(Tree)
1029
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1030
+
1031
+ const nodeData = { id: 88, label: '88' }
1032
+ tree.append(nodeData, tree.getNode(1))
1033
+
1034
+ expect(tree.data[0].children.length).toEqual(2)
1035
+ expect(tree.getNode(88).data).toEqual(nodeData)
1036
+ })
1037
+
1038
+ test('insertBefore', async () => {
1039
+ const { wrapper } = getTreeVm(`:props="defaultProps" node-key="id"`)
1040
+ const treeWrapper = wrapper.findComponent(Tree)
1041
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1042
+
1043
+ const nodeData = { id: 88, label: '88' }
1044
+ tree.insertBefore(nodeData, tree.getNode(11))
1045
+ expect(tree.data[0].children.length).toEqual(2)
1046
+ expect(tree.data[0].children[0]).toEqual(nodeData)
1047
+ expect(tree.getNode(88).data).toEqual(nodeData)
1048
+ })
1049
+
1050
+ test('insertAfter', async () => {
1051
+ const { wrapper } = getTreeVm(`:props="defaultProps" node-key="id"`)
1052
+ const treeWrapper = wrapper.findComponent(Tree)
1053
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1054
+
1055
+ const nodeData = { id: 88, label: '88' }
1056
+ tree.insertAfter(nodeData, tree.getNode(11))
1057
+ expect(tree.data[0].children.length).toEqual(2)
1058
+ expect(tree.data[0].children[1]).toEqual(nodeData)
1059
+ expect(tree.getNode(88).data).toEqual(nodeData)
1060
+ })
1061
+
1062
+ test('set disabled checkbox', async () => {
1063
+ const { wrapper } = getDisableTreeVm(
1064
+ `:props="defaultProps" show-checkbox node-key="id" default-expand-all`
1065
+ )
1066
+ const nodeWrapper = wrapper.findAll('.el-tree-node__content')[2]
1067
+ const checkboxWrapper = nodeWrapper.find('.el-checkbox input')
1068
+
1069
+ expect((checkboxWrapper.element as HTMLInputElement).disabled).toEqual(true)
1070
+ })
1071
+
1072
+ test('check strictly', async () => {
1073
+ const { wrapper } = getTreeVm(
1074
+ `:props="defaultProps" show-checkbox check-strictly default-expand-all`
1075
+ )
1076
+ const treeWrapper = wrapper.findComponent(Tree)
1077
+ const secondNodeContentWrapper = wrapper.findAll(
1078
+ '.el-tree-node__content'
1079
+ )[3]
1080
+ const secondNodeCheckboxWrapper =
1081
+ secondNodeContentWrapper.find('.el-checkbox')
1082
+ await secondNodeCheckboxWrapper.trigger('click')
1083
+ expect(
1084
+ (treeWrapper.vm as InstanceType<typeof Tree>).getCheckedNodes().length
1085
+ ).toEqual(1)
1086
+ expect(
1087
+ (treeWrapper.vm as InstanceType<typeof Tree>).getCheckedNodes(true).length
1088
+ ).toEqual(0)
1089
+
1090
+ const secondTreeNodeWrapper = treeWrapper.findAll('.el-tree-node')[3]
1091
+ const secondNodefirstLeafCheckboxWrapper = secondTreeNodeWrapper.find(
1092
+ '.el-tree-node__children .el-tree-node__content .el-checkbox'
1093
+ )
1094
+ await secondNodefirstLeafCheckboxWrapper.trigger('click')
1095
+ expect(
1096
+ (treeWrapper.vm as InstanceType<typeof Tree>).getCheckedNodes().length
1097
+ ).toEqual(2)
1098
+ })
1099
+
1100
+ test('render content', async () => {
1101
+ const { wrapper } = getTreeVm(
1102
+ `:props="defaultProps" :render-content="renderContent"`,
1103
+ {
1104
+ methods: {
1105
+ renderContent(h, node) {
1106
+ return h('div', { class: 'custom-content' }, [
1107
+ h('button', { class: 'el-button' }, [node.node.label]),
1108
+ ])
1109
+ },
1110
+ },
1111
+ }
1112
+ )
1113
+ const firstNodeWrapper = wrapper.find('.el-tree-node__content')
1114
+ expect(firstNodeWrapper.find('.custom-content').exists()).toBe(true)
1115
+
1116
+ const buttonWrapper = firstNodeWrapper.find('.custom-content button')
1117
+ expect(buttonWrapper.exists()).toBe(true)
1118
+ expect(buttonWrapper.text()).toEqual('一级 1')
1119
+ })
1120
+
1121
+ test('custom-node-class', async () => {
1122
+ const { wrapper } = getTreeVm(
1123
+ `:props="{class:(data)=>{return data.id===11?'is-test':null}}" default-expand-all highlight-current node-key="id" :current-node-key="11"`
1124
+ )
1125
+
1126
+ const currentNodeLabelWrapper = wrapper.find(
1127
+ '.is-test .el-tree-node__label'
1128
+ )
1129
+
1130
+ expect(currentNodeLabelWrapper.text()).toEqual('二级 1-1')
1131
+ })
1132
+
1133
+ test('scoped slot', async () => {
1134
+ const { wrapper } = getTreeVm('', {
1135
+ template: `
1136
+ <el-tree ref="tree" :data="data">
1137
+ <template #default="scope">
1138
+ <div class="custom-tree-template">
1139
+ <span>{{ scope.node.label }}</span>
1140
+ <button></button>
1141
+ </div>
1142
+ </template>
1143
+ </el-tree>
1144
+ `,
1145
+ methods: {
1146
+ renderContent(h, node) {
1147
+ return h('div', { class: 'custom-content' }, [
1148
+ h('button', { class: 'el-button' }, [node.node.label]),
1149
+ ])
1150
+ },
1151
+ },
1152
+ })
1153
+ const firstNodeWrapper = wrapper.find('.custom-tree-template')
1154
+ expect(firstNodeWrapper.exists()).toBe(true)
1155
+ const spanWrapper = firstNodeWrapper.find('span')
1156
+ const buttonWrapper = firstNodeWrapper.find('button')
1157
+ expect(spanWrapper.exists()).toBe(true)
1158
+ expect(spanWrapper.text()).toEqual('一级 1')
1159
+ expect(buttonWrapper.exists()).toBe(true)
1160
+ })
1161
+
1162
+ test('load node', async () => {
1163
+ const { wrapper } = getTreeVm(
1164
+ `:props="defaultProps" lazy :load="loadNode" show-checkbox`,
1165
+ {
1166
+ methods: {
1167
+ loadNode(node, resolve) {
1168
+ if (node.level === 0) {
1169
+ return resolve([{ label: 'region1' }, { label: 'region2' }])
1170
+ }
1171
+ if (node.level > 4) return resolve([])
1172
+ setTimeout(() => {
1173
+ resolve([
1174
+ {
1175
+ label: `zone${this.count++}`,
1176
+ },
1177
+ {
1178
+ label: `zone${this.count++}`,
1179
+ },
1180
+ ])
1181
+ }, 50)
1182
+ },
1183
+ },
1184
+ }
1185
+ )
1186
+
1187
+ let nodeWrappers = wrapper.findAll('.el-tree-node__content')
1188
+
1189
+ expect(nodeWrappers.length).toEqual(2)
1190
+ vi.useFakeTimers()
1191
+ await nodeWrappers[0].trigger('click')
1192
+ vi.runAllTimers()
1193
+ vi.useRealTimers()
1194
+ await nextTick() // wait load finish
1195
+ nodeWrappers = wrapper.findAll('.el-tree-node__content')
1196
+ expect(nodeWrappers.length).toEqual(4)
1197
+ })
1198
+
1199
+ test('lazy defaultChecked', async () => {
1200
+ const { wrapper } = getTreeVm(
1201
+ `:props="defaultProps" node-key="id" lazy :load="loadNode" show-checkbox`,
1202
+ {
1203
+ methods: {
1204
+ loadNode(node, resolve) {
1205
+ if (node.level === 0) {
1206
+ return resolve([
1207
+ { label: 'region1', id: this.count++ },
1208
+ { label: 'region2', id: this.count++ },
1209
+ ])
1210
+ }
1211
+ if (node.level > 4) return resolve([])
1212
+ setTimeout(() => {
1213
+ resolve([
1214
+ {
1215
+ label: `zone${this.count}`,
1216
+ id: this.count++,
1217
+ },
1218
+ {
1219
+ label: `zone${this.count}`,
1220
+ id: this.count++,
1221
+ },
1222
+ ])
1223
+ }, 50)
1224
+ },
1225
+ },
1226
+ }
1227
+ )
1228
+
1229
+ const treeWrapper = wrapper.findComponent(Tree)
1230
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1231
+ const firstNodeWrapper = treeWrapper.find('.el-tree-node__content')
1232
+ expect(firstNodeWrapper.find('.is-indeterminate').exists()).toEqual(false)
1233
+
1234
+ tree.store.setCheckedKeys([3])
1235
+ vi.useFakeTimers()
1236
+ await firstNodeWrapper.find('.el-tree-node__expand-icon').trigger('click')
1237
+ vi.runAllTimers()
1238
+ vi.useRealTimers()
1239
+ await nextTick()
1240
+
1241
+ expect(firstNodeWrapper.find('.is-indeterminate').exists()).toEqual(true)
1242
+ const childWrapper = treeWrapper.findAll('.el-tree-node__content')[1]
1243
+ expect(childWrapper.find('input').element.checked).toEqual(true)
1244
+ })
1245
+
1246
+ test('lazy expandOnChecked', async () => {
1247
+ const { wrapper } = getTreeVm(
1248
+ `:props="defaultProps" node-key="id" lazy :load="loadNode" show-checkbox check-descendants`,
1249
+ {
1250
+ methods: {
1251
+ loadNode(node, resolve) {
1252
+ if (node.level === 0) {
1253
+ return resolve([
1254
+ { label: 'region1', id: this.count++ },
1255
+ { label: 'region2', id: this.count++ },
1256
+ ])
1257
+ }
1258
+ if (node.level > 2) return resolve([])
1259
+ setTimeout(() => {
1260
+ resolve([
1261
+ {
1262
+ label: `zone${this.count}`,
1263
+ id: this.count++,
1264
+ },
1265
+ {
1266
+ label: `zone${this.count}`,
1267
+ id: this.count++,
1268
+ },
1269
+ ])
1270
+ }, 10)
1271
+ },
1272
+ },
1273
+ }
1274
+ )
1275
+
1276
+ const treeWrapper = wrapper.findComponent(Tree)
1277
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1278
+
1279
+ vi.useFakeTimers()
1280
+ tree.store.setCheckedKeys([1])
1281
+ vi.runAllTimers()
1282
+ vi.useRealTimers()
1283
+ await nextTick()
1284
+ expect(tree.getCheckedKeys().length).toEqual(7)
1285
+ })
1286
+
1287
+ test('lazy without expandOnChecked', async () => {
1288
+ const { wrapper } = getTreeVm(
1289
+ `:props="defaultProps" node-key="id" lazy :load="loadNode" show-checkbox`,
1290
+ {
1291
+ methods: {
1292
+ loadNode(node, resolve) {
1293
+ if (node.level === 0) {
1294
+ return resolve([
1295
+ { label: 'region1', id: this.count++ },
1296
+ { label: 'region2', id: this.count++ },
1297
+ ])
1298
+ }
1299
+ if (node.level > 4) return resolve([])
1300
+ setTimeout(() => {
1301
+ resolve([
1302
+ {
1303
+ label: `zone${this.count}`,
1304
+ id: this.count++,
1305
+ },
1306
+ {
1307
+ label: `zone${this.count}`,
1308
+ id: this.count++,
1309
+ },
1310
+ ])
1311
+ }, 50)
1312
+ },
1313
+ },
1314
+ }
1315
+ )
1316
+
1317
+ const treeWrapper = wrapper.findComponent(Tree)
1318
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1319
+
1320
+ tree.store.setCheckedKeys([1])
1321
+ await nextTick()
1322
+
1323
+ const nodeWrappers = treeWrapper.findAll('.el-tree-node__content')
1324
+ expect(nodeWrappers[0].find('input').element.checked).toEqual(true)
1325
+ expect(nodeWrappers.length).toEqual(2)
1326
+ })
1327
+
1328
+ test('accordion', async () => {
1329
+ const { wrapper } = getTreeVm(`:props="defaultProps" accordion`)
1330
+
1331
+ const firstNodeContentWrapper = wrapper.find('.el-tree-node__content')
1332
+ const secondNodeContentWrapper = wrapper.find(
1333
+ '.el-tree-node:nth-child(2) .el-tree-node__content'
1334
+ )
1335
+ await firstNodeContentWrapper.trigger('click')
1336
+
1337
+ expect(wrapper.find('.el-tree-node').classes('is-expanded')).toBe(true)
1338
+ await secondNodeContentWrapper.trigger('click')
1339
+ expect(wrapper.find('.el-tree-node').classes('is-expanded')).toBe(false)
1340
+ })
1341
+
1342
+ test('handleNodeOpen & handleNodeClose', async () => {
1343
+ const { wrapper, vm } = getTreeVm(
1344
+ `:props="defaultProps" lazy :load="loadNode" @node-expand="handleNodeOpen" @node-collapse="handleNodeClose"`,
1345
+ {
1346
+ methods: {
1347
+ loadNode(node, resolve) {
1348
+ if (node.level === 0) {
1349
+ return resolve([{ label: 'region1' }, { label: 'region2' }])
1350
+ }
1351
+ if (node.level > 4) return resolve([])
1352
+ nextTick(() => {
1353
+ resolve([
1354
+ {
1355
+ label: `zone${this.count++}`,
1356
+ },
1357
+ {
1358
+ label: `zone${this.count++}`,
1359
+ },
1360
+ ])
1361
+ })
1362
+ },
1363
+ handleNodeOpen(data) {
1364
+ this.currentNode = data
1365
+ this.nodeExpended = true
1366
+ },
1367
+ handleNodeClose(data) {
1368
+ this.currentNode = data
1369
+ this.nodeExpended = false
1370
+ },
1371
+ },
1372
+ }
1373
+ )
1374
+
1375
+ const firstNodeContentWrapper = wrapper.find('.el-tree-node__content')
1376
+ const firstNodeWrapper = wrapper.find('.el-tree-node')
1377
+
1378
+ expect(firstNodeWrapper.find('.el-tree-node__children').exists()).toBe(
1379
+ false
1380
+ )
1381
+
1382
+ await firstNodeContentWrapper.trigger('click')
1383
+ await nextTick() // first next tick for UI update
1384
+ await nextTick() // second next tick for triggering loadNode
1385
+ await nextTick() // third next tick for updating props.node.expanded
1386
+
1387
+ expect(vm.nodeExpended).toEqual(true)
1388
+ expect(vm.currentNode.label).toEqual('region1')
1389
+
1390
+ await firstNodeContentWrapper.trigger('click')
1391
+ await nextTick()
1392
+ await nextTick()
1393
+ await nextTick()
1394
+
1395
+ expect(vm.nodeExpended).toEqual(false)
1396
+ expect(vm.currentNode.label).toEqual('region1')
1397
+ })
1398
+
1399
+ test('updateKeyChildren', async () => {
1400
+ const { wrapper } = getTreeVm(
1401
+ `:props="defaultProps" show-checkbox node-key="id" default-expand-all`
1402
+ )
1403
+
1404
+ const treeWrapper = wrapper.findComponent(Tree)
1405
+ const tree = treeWrapper.vm as InstanceType<typeof Tree>
1406
+
1407
+ tree.updateKeyChildren(1, [
1408
+ {
1409
+ id: 111,
1410
+ label: '三级 1-1',
1411
+ },
1412
+ ])
1413
+
1414
+ await nextTick()
1415
+
1416
+ const nodeContentWrapper = wrapper.findAll('.el-tree-node__content')[1]
1417
+ const nodeLabelWrapper = nodeContentWrapper.find('.el-tree-node__label')
1418
+
1419
+ expect(tree.store.nodesMap['11']).toEqual(undefined)
1420
+ expect(tree.store.nodesMap['1'].childNodes[0].data.id).toEqual(111)
1421
+ expect(nodeLabelWrapper.text()).toEqual('三级 1-1')
1422
+ })
1423
+
1424
+ test('update multi tree data', async () => {
1425
+ const { wrapper, vm } = getTreeVm(``, {
1426
+ template: `
1427
+ <div>
1428
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps"></el-tree>
1429
+ <el-tree ref="tree2" :data="data" node-key="id" :props="defaultProps"></el-tree>
1430
+ </div>
1431
+ `,
1432
+ })
1433
+
1434
+ const nodeData = { label: '新增 1', id: 4, children: [] }
1435
+ vm.data.push(nodeData)
1436
+ vm.data = [...vm.data]
1437
+
1438
+ await nextTick()
1439
+
1440
+ const treeWrappers: any = wrapper.findAllComponents(Tree)
1441
+ expect(treeWrappers[0].vm.getNode(4).data).toEqual(nodeData)
1442
+ expect(treeWrappers[1].vm.getNode(4).data).toEqual(nodeData)
1443
+ })
1444
+
1445
+ test('navigate with defaultExpandAll', () => {
1446
+ const { wrapper } = getTreeVm(``, {
1447
+ template: `
1448
+ <div>
1449
+ <el-tree default-expand-all ref="tree1" :data="data" node-key="id" :props="defaultProps"></el-tree>
1450
+ </div>
1451
+ `,
1452
+ })
1453
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1454
+ expect(
1455
+ Object.values(
1456
+ (tree.vm as InstanceType<typeof Tree>).store.nodesMap
1457
+ ).filter((item) => item.canFocus).length
1458
+ ).toBe(9)
1459
+ })
1460
+
1461
+ test('navigate up', async () => {
1462
+ const { wrapper } = getTreeVm(``, {
1463
+ template: `
1464
+ <div>
1465
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps"></el-tree>
1466
+ </div>
1467
+ `,
1468
+ })
1469
+ let flag = false
1470
+ function handleFocus() {
1471
+ return () => (flag = true)
1472
+ }
1473
+ await nextTick()
1474
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1475
+ const targetElement = wrapper.find('div[data-key="3"]').element
1476
+ const fromElement = wrapper.find('div[data-key="1"]').element
1477
+ defineGetter(targetElement, 'focus', handleFocus)
1478
+ ;(tree.vm as InstanceType<typeof Tree>).setCurrentKey(1)
1479
+ expect(fromElement.classList.contains('is-focusable')).toBeTruthy()
1480
+ fromElement.dispatchEvent(
1481
+ new KeyboardEvent('keydown', {
1482
+ code: 'ArrowUp',
1483
+ bubbles: true,
1484
+ cancelable: false,
1485
+ })
1486
+ )
1487
+ expect(flag).toBe(true)
1488
+ })
1489
+
1490
+ test('navigate down', async () => {
1491
+ const { wrapper } = getTreeVm(``, {
1492
+ template: `
1493
+ <div>
1494
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps"></el-tree>
1495
+ </div>
1496
+ `,
1497
+ })
1498
+ let flag = false
1499
+ function handleFocus() {
1500
+ return () => (flag = true)
1501
+ }
1502
+ await nextTick()
1503
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1504
+ const targetElement = wrapper.find('div[data-key="2"]').element
1505
+ const fromElement = wrapper.find('div[data-key="1"]').element
1506
+ defineGetter(targetElement, 'focus', handleFocus)
1507
+ ;(tree.vm as InstanceType<typeof Tree>).setCurrentKey(1)
1508
+ expect(fromElement.classList.contains('is-focusable')).toBeTruthy()
1509
+ fromElement.dispatchEvent(
1510
+ new KeyboardEvent('keydown', {
1511
+ code: 'ArrowDown',
1512
+ bubbles: true,
1513
+ cancelable: false,
1514
+ })
1515
+ )
1516
+ expect(flag).toBe(true)
1517
+ })
1518
+
1519
+ test('navigate down with multiple trees', async () => {
1520
+ const data = [{ label: 'one' }, { label: 'two' }]
1521
+ const wrapper = mount({
1522
+ template: `
1523
+ <div>
1524
+ <el-tree :data="data" default-expand-all />
1525
+ <el-tree :data="data" default-expand-all />
1526
+ </div>
1527
+ `,
1528
+ components: { 'el-tree': Tree },
1529
+ data: () => ({ data }),
1530
+ })
1531
+ await nextTick()
1532
+ let focused = false
1533
+ const secondTree = wrapper.findAllComponents({ name: 'ElTree' })[1]
1534
+ const treeNodes = secondTree.findAll('.is-focusable[role=treeitem]')
1535
+ defineGetter(treeNodes[1].element, 'focus', () => () => (focused = true))
1536
+ await treeNodes[0].trigger('keydown', { code: 'ArrowDown' })
1537
+ expect(focused).toBe(true)
1538
+ })
1539
+
1540
+ test('collapse and navigate down and up', async () => {
1541
+ const { wrapper } = getTreeVm(``, {
1542
+ template: `
1543
+ <div>
1544
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps" default-expand-all></el-tree>
1545
+ </div>
1546
+ `,
1547
+ })
1548
+ await nextTick()
1549
+ let flag = false
1550
+ function handleFocus() {
1551
+ return () => (flag = true)
1552
+ }
1553
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1554
+ const targetElement = wrapper.find('div[data-key="2"]').element
1555
+ const fromElement = wrapper.find('div[data-key="1"]')
1556
+ await fromElement.trigger('click')
1557
+
1558
+ expect(fromElement.classes('is-expanded')).toBe(false) // 判断是否已折叠
1559
+
1560
+ await nextTick()
1561
+ defineGetter(targetElement, 'focus', handleFocus)
1562
+ ;(tree.vm as InstanceType<typeof Tree>).setCurrentKey(1)
1563
+ // 模拟按下下箭头键
1564
+ fromElement.element.dispatchEvent(
1565
+ new KeyboardEvent('keydown', {
1566
+ code: 'ArrowDown',
1567
+ bubbles: true,
1568
+ cancelable: false,
1569
+ })
1570
+ )
1571
+ expect(flag).toBe(true)
1572
+
1573
+ await nextTick()
1574
+
1575
+ flag = false
1576
+ defineGetter(fromElement.element, 'focus', handleFocus)
1577
+ // 模拟按下上箭头键
1578
+ targetElement.dispatchEvent(
1579
+ new KeyboardEvent('keydown', {
1580
+ code: 'ArrowUp',
1581
+ bubbles: true,
1582
+ cancelable: false,
1583
+ })
1584
+ )
1585
+ expect(flag).toBe(true)
1586
+ })
1587
+
1588
+ test('filter-node-method and navigate down', async () => {
1589
+ const { wrapper } = getTreeVm(``, {
1590
+ template: `
1591
+ <div>
1592
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps" :filter-node-method="filterNode"></el-tree>
1593
+ </div>
1594
+ `,
1595
+ methods: {
1596
+ filterNode(value, data) {
1597
+ if (!value) return true
1598
+ return data.label.includes(value)
1599
+ },
1600
+ },
1601
+ })
1602
+ let flag = false
1603
+ function handleFocus() {
1604
+ return () => (flag = true)
1605
+ }
1606
+
1607
+ const treeWrapper = wrapper.findComponent(Tree)
1608
+ ;(treeWrapper.vm as InstanceType<typeof Tree>).filter('-1')
1609
+
1610
+ await sleep()
1611
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1612
+ ;(tree.vm as InstanceType<typeof Tree>).setCurrentKey(1)
1613
+
1614
+ const allNodes = treeWrapper.findAll('.el-tree-node')
1615
+ const visibleNodes = allNodes.filter(
1616
+ (node) => !node.classes().includes('is-hidden')
1617
+ )
1618
+ const len = visibleNodes.length
1619
+ for (let i = 0; i < len; i++) {
1620
+ if (visibleNodes[i + 1]) {
1621
+ defineGetter(visibleNodes[i + 1].element, 'focus', handleFocus)
1622
+ // 模拟按下下箭头键
1623
+ visibleNodes[i].element.dispatchEvent(
1624
+ new KeyboardEvent('keydown', {
1625
+ code: 'ArrowDown',
1626
+ bubbles: true,
1627
+ cancelable: false,
1628
+ })
1629
+ )
1630
+ expect(flag).toBe(true)
1631
+ flag = false
1632
+ }
1633
+ }
1634
+ })
1635
+
1636
+ test('expand and render-after-expand set to false', async () => {
1637
+ const { wrapper } = getTreeVm(``, {
1638
+ template: `
1639
+ <div>
1640
+ <el-tree ref="tree1" :data="data" node-key="id" :render-after-expand="false"></el-tree>
1641
+ </div>
1642
+ `,
1643
+ data() {
1644
+ return {
1645
+ data: [
1646
+ {
1647
+ id: 1,
1648
+ label: '一级 1',
1649
+ children: [
1650
+ {
1651
+ id: 11,
1652
+ label: '二级 1-1',
1653
+ children: [
1654
+ {
1655
+ id: 111,
1656
+ label: '三级 1-1',
1657
+ },
1658
+ ],
1659
+ },
1660
+ ],
1661
+ },
1662
+ {
1663
+ id: 2,
1664
+ label: '一级 2',
1665
+ children: [
1666
+ {
1667
+ id: 21,
1668
+ label: '二级 2-1',
1669
+ children: [
1670
+ {
1671
+ id: 211,
1672
+ label: '三级 2-1-1',
1673
+ },
1674
+ ],
1675
+ },
1676
+ {
1677
+ id: 22,
1678
+ label: '二级 2-2',
1679
+ },
1680
+ ],
1681
+ },
1682
+ {
1683
+ id: 3,
1684
+ label: '一级 3',
1685
+ children: [
1686
+ {
1687
+ id: 31,
1688
+ label: '二级 3-1',
1689
+ },
1690
+ {
1691
+ id: 32,
1692
+ label: '二级 3-2',
1693
+ },
1694
+ ],
1695
+ },
1696
+ ],
1697
+ }
1698
+ },
1699
+ })
1700
+ await nextTick()
1701
+ let flag = false
1702
+ function handleFocus() {
1703
+ return () => (flag = true)
1704
+ }
1705
+
1706
+ const fromElement = wrapper.find('div[data-key="2"]')
1707
+ await fromElement.trigger('click')
1708
+
1709
+ expect(fromElement.classes('is-expanded')).toBe(true) // 判断是否已展开
1710
+
1711
+ const treeWrapper = wrapper.findComponent(Tree)
1712
+
1713
+ await sleep()
1714
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1715
+ ;(tree.vm as InstanceType<typeof Tree>).setCurrentKey(2)
1716
+
1717
+ const allNodes = treeWrapper.findAll('.el-tree-node')
1718
+ const visibleNodes = allNodes.filter((val) => {
1719
+ const node = wrapper.vm.$refs.tree1.getNode(val.element.dataset.key)!
1720
+ return node.parent?.expanded || node.parent?.level === 0
1721
+ })
1722
+ const len = visibleNodes.length
1723
+ for (let i = 0; i < len; i++) {
1724
+ if (visibleNodes[i + 1]) {
1725
+ defineGetter(visibleNodes[i + 1].element, 'focus', handleFocus)
1726
+ // 模拟按下下箭头键
1727
+ visibleNodes[i].element.dispatchEvent(
1728
+ new KeyboardEvent('keydown', {
1729
+ code: 'ArrowDown',
1730
+ bubbles: true,
1731
+ cancelable: false,
1732
+ })
1733
+ )
1734
+
1735
+ expect(flag).toBe(true)
1736
+ flag = false
1737
+ }
1738
+ }
1739
+ })
1740
+
1741
+ test('navigate with disabled', async () => {
1742
+ const wrapper = mount({
1743
+ template: `
1744
+ <div>
1745
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps"></el-tree>
1746
+ </div>
1747
+ `,
1748
+ components: {
1749
+ 'el-tree': Tree,
1750
+ },
1751
+ data() {
1752
+ return {
1753
+ data: [
1754
+ {
1755
+ id: 1,
1756
+ label: '一级 1',
1757
+ children: [
1758
+ {
1759
+ id: 11,
1760
+ label: '二级 1-1',
1761
+ children: [
1762
+ {
1763
+ id: 111,
1764
+ label: '三级 1-1',
1765
+ disabled: true,
1766
+ },
1767
+ ],
1768
+ },
1769
+ ],
1770
+ },
1771
+ {
1772
+ id: 2,
1773
+ label: '一级 2',
1774
+ disabled: true,
1775
+ children: [
1776
+ {
1777
+ id: 21,
1778
+ label: '二级 2-1',
1779
+ },
1780
+ {
1781
+ id: 22,
1782
+ label: '二级 2-2',
1783
+ },
1784
+ ],
1785
+ },
1786
+ {
1787
+ id: 3,
1788
+ label: '一级 3',
1789
+ children: [
1790
+ {
1791
+ id: 31,
1792
+ label: '二级 3-1',
1793
+ },
1794
+ {
1795
+ id: 32,
1796
+ label: '二级 3-2',
1797
+ },
1798
+ ],
1799
+ },
1800
+ ],
1801
+ defaultProps: {
1802
+ children: 'children',
1803
+ label: 'label',
1804
+ disabled: 'disabled',
1805
+ },
1806
+ }
1807
+ },
1808
+ })
1809
+ let flag = false
1810
+ function handleFocus() {
1811
+ return () => (flag = true)
1812
+ }
1813
+ await nextTick()
1814
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1815
+ const targetElement = wrapper.find('div[data-key="3"]').element
1816
+ const fromElement = wrapper.find('div[data-key="1"]').element
1817
+ defineGetter(targetElement, 'focus', handleFocus)
1818
+ ;(tree.vm as InstanceType<typeof Tree>).setCurrentKey(1)
1819
+ expect(fromElement.classList.contains('is-focusable')).toBeTruthy()
1820
+ fromElement.dispatchEvent(
1821
+ new KeyboardEvent('keydown', {
1822
+ code: 'ArrowDown',
1823
+ bubbles: true,
1824
+ cancelable: false,
1825
+ })
1826
+ )
1827
+ expect(flag).toBe(true)
1828
+ })
1829
+
1830
+ test('custom children and label', async () => {
1831
+ const wrapper = mount({
1832
+ template: `
1833
+ <div>
1834
+ <el-tree ref="tree1" :data="data" node-key="id" :props="defaultProps"></el-tree>
1835
+ <el-button @click="addNewNode">add</el-button>
1836
+ </div>
1837
+ `,
1838
+ components: {
1839
+ 'el-tree': Tree,
1840
+ 'el-button': Button,
1841
+ },
1842
+ data() {
1843
+ return {
1844
+ data: [
1845
+ {
1846
+ id: 1,
1847
+ l: '一级 1',
1848
+ c: [
1849
+ {
1850
+ id: 11,
1851
+ l: '二级 1-1',
1852
+ c: [
1853
+ {
1854
+ id: 111,
1855
+ l: '三级 1-1',
1856
+ },
1857
+ ],
1858
+ },
1859
+ ],
1860
+ },
1861
+ {
1862
+ id: 2,
1863
+ l: '一级 2',
1864
+ c: [
1865
+ {
1866
+ id: 21,
1867
+ l: '二级 2-1',
1868
+ },
1869
+ {
1870
+ id: 22,
1871
+ l: '二级 2-2',
1872
+ },
1873
+ ],
1874
+ },
1875
+ {
1876
+ id: 3,
1877
+ l: '一级 3',
1878
+ c: [
1879
+ {
1880
+ id: 31,
1881
+ l: '二级 3-1',
1882
+ },
1883
+ {
1884
+ id: 32,
1885
+ l: '二级 3-2',
1886
+ },
1887
+ ],
1888
+ },
1889
+ ],
1890
+ defaultProps: {
1891
+ children: 'c',
1892
+ label: 'l',
1893
+ },
1894
+ }
1895
+ },
1896
+ methods: {
1897
+ addNewNode() {
1898
+ this.data[0].c.push({
1899
+ id: 12,
1900
+ l: 'new node',
1901
+ })
1902
+ },
1903
+ },
1904
+ })
1905
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1906
+ const button = wrapper.findComponent({ name: 'ElButton' })
1907
+ const firstNode = wrapper.find('.el-tree-node')
1908
+
1909
+ expect(tree.vm.getNode(1).data.l).toEqual('一级 1')
1910
+ expect(tree.vm.getNode(1).data.c[0].l).toEqual('二级 1-1')
1911
+
1912
+ firstNode.trigger('click')
1913
+ await nextTick()
1914
+
1915
+ const firstChildrenNode = firstNode.element.querySelector(
1916
+ '.el-tree-node__children'
1917
+ )
1918
+ expect(firstChildrenNode.children.length).toEqual(1)
1919
+
1920
+ button.trigger('click')
1921
+ await nextTick()
1922
+
1923
+ expect(tree.vm.getNode(1).data.c[1].l).toEqual('new node')
1924
+ expect(firstChildrenNode.children.length).toEqual(2)
1925
+ expect(firstChildrenNode.children[1].textContent).toEqual('new node')
1926
+ })
1927
+
1928
+ test('navigate with lazy and without node-key', async () => {
1929
+ const wrapper = mount({
1930
+ template: `
1931
+ <div>
1932
+ <el-tree
1933
+ :props="defaultProps"
1934
+ :load="loadNode"
1935
+ lazy
1936
+ show-checkbox>
1937
+ </el-tree>
1938
+ </div>
1939
+ `,
1940
+ components: {
1941
+ 'el-tree': Tree,
1942
+ },
1943
+ data() {
1944
+ return {
1945
+ defaultProps: {
1946
+ children: 'children',
1947
+ label: 'label',
1948
+ disabled: 'disabled',
1949
+ },
1950
+ count: 0,
1951
+ }
1952
+ },
1953
+ methods: {
1954
+ loadNode(node: Node, resolve: typeof Promise.resolve) {
1955
+ if (node.level === 0) {
1956
+ return resolve([{ name: 'region1' }, { name: 'region2' }])
1957
+ }
1958
+ if (node.level > 3) return resolve([])
1959
+
1960
+ let hasChild: boolean
1961
+ if (node.data.name === 'region1') {
1962
+ hasChild = true
1963
+ } else if (node.data.name === 'region2') {
1964
+ hasChild = false
1965
+ } else {
1966
+ hasChild = false
1967
+ }
1968
+
1969
+ let data: { name: string }[]
1970
+ if (hasChild) {
1971
+ data = [
1972
+ {
1973
+ name: `zone${++this.count}`,
1974
+ },
1975
+ {
1976
+ name: `zone${++this.count}`,
1977
+ },
1978
+ ]
1979
+ } else {
1980
+ data = []
1981
+ }
1982
+ resolve(data)
1983
+ },
1984
+ },
1985
+ })
1986
+ let flag = false
1987
+ function handleFocus() {
1988
+ return () => (flag = !flag)
1989
+ }
1990
+ await nextTick()
1991
+ const tree = wrapper.findComponent({ name: 'ElTree' })
1992
+ const originElements = wrapper.findAll('div[data-key]')
1993
+ const region1 = originElements[0].element
1994
+ const region2 = originElements[1].element
1995
+ defineGetter(region2, 'focus', handleFocus)
1996
+ // expand
1997
+ region1.dispatchEvent(new MouseEvent('click'))
1998
+ expect(region1.classList.contains('is-focusable')).toBeTruthy()
1999
+ await nextTick()
2000
+ await nextTick()
2001
+ expect(
2002
+ Object.values((tree.vm as InstanceType<typeof Tree>).store.nodesMap)
2003
+ ).toHaveLength(5) // The root node (void node) + 4 child nodes (region1, region2, zone1, zone2)
2004
+ expect(
2005
+ Object.values(
2006
+ Object.values(
2007
+ (tree.vm as InstanceType<typeof Tree>).store.nodesMap
2008
+ ).filter((item) => item.canFocus).length === 4
2009
+ )
2010
+ ).toBeTruthy()
2011
+ // collapse
2012
+ region1.dispatchEvent(new MouseEvent('click'))
2013
+ expect(
2014
+ Object.values(
2015
+ Object.values(
2016
+ (tree.vm as InstanceType<typeof Tree>).store.nodesMap
2017
+ ).filter((item) => item.canFocus).length === 2
2018
+ )
2019
+ ).toBeTruthy()
2020
+ // ArrowDown, region2 focus
2021
+ region1.dispatchEvent(
2022
+ new KeyboardEvent('keydown', {
2023
+ code: 'ArrowDown',
2024
+ bubbles: true,
2025
+ cancelable: false,
2026
+ })
2027
+ )
2028
+ expect(flag).toBe(true)
2029
+ defineGetter(region1, 'focus', handleFocus)
2030
+ // ArrowDown, region1 focus
2031
+ region2.dispatchEvent(
2032
+ new KeyboardEvent('keydown', {
2033
+ code: 'ArrowDown',
2034
+ bubbles: true,
2035
+ cancelable: false,
2036
+ })
2037
+ )
2038
+ expect(flag).toBe(false)
2039
+ })
2040
+
2041
+ test('customize some node contents', async () => {
2042
+ const wrapper = mount({
2043
+ template: `
2044
+ <el-tree :data="data">
2045
+ <template #default="{ data }">
2046
+ <div v-if="data.id === '1'">
2047
+ customize: {{ data.label }}
2048
+ </div>
2049
+ </template>
2050
+ </el-tree>
2051
+ `,
2052
+ components: {
2053
+ 'el-tree': Tree,
2054
+ },
2055
+ data() {
2056
+ return {
2057
+ data: [
2058
+ {
2059
+ id: '1',
2060
+ label: 'Level one 1',
2061
+ children: [
2062
+ {
2063
+ id: '1-1',
2064
+ label: 'Level two 1-1',
2065
+ children: [
2066
+ {
2067
+ label: 'Level three 1-1-1',
2068
+ },
2069
+ ],
2070
+ },
2071
+ ],
2072
+ },
2073
+ {
2074
+ id: '2',
2075
+ label: 'Level one 2',
2076
+ children: [
2077
+ {
2078
+ id: '2-1',
2079
+ label: 'Level two 2-1',
2080
+ children: [
2081
+ {
2082
+ label: 'Level three 2-1-1',
2083
+ },
2084
+ ],
2085
+ },
2086
+ ],
2087
+ },
2088
+ ],
2089
+ }
2090
+ },
2091
+ })
2092
+ const nodeContentWrapper1 = wrapper.findAll('.el-tree-node__content')[0]
2093
+ const nodeContentWrapper2 = wrapper.findAll('.el-tree-node__content')[1]
2094
+
2095
+ const nodeLabelWrapper1 = nodeContentWrapper1.find('div')
2096
+ const nodeLabelWrapper2 = nodeContentWrapper2.find(
2097
+ 'span.el-tree-node__label'
2098
+ )
2099
+ expect(nodeLabelWrapper1.text()).toEqual('customize: Level one 1')
2100
+ expect(nodeLabelWrapper2.text()).toEqual('Level one 2')
2101
+ })
2102
+
2103
+ test('render slot `empty`', async () => {
2104
+ const wrapper = mount({
2105
+ template: `
2106
+ <el-tree :data="[]">
2107
+ <template #empty>
2108
+ EmptySlot
2109
+ </template>
2110
+ </el-tree>
2111
+ `,
2112
+ components: {
2113
+ 'el-tree': Tree,
2114
+ },
2115
+ })
2116
+ await nextTick()
2117
+ expect(wrapper.find('.el-tree__empty-block').text()).toBe('EmptySlot')
2118
+ })
2119
+
2120
+ test('should correctly handle checkbox state when disabled nodes exist', async () => {
2121
+ const wrapper = mount({
2122
+ template: `
2123
+ <el-tree
2124
+ :data="data"
2125
+ node-key="id"
2126
+ show-checkbox
2127
+ default-expand-all
2128
+ />
2129
+ `,
2130
+ components: { 'el-tree': Tree },
2131
+ data() {
2132
+ return {
2133
+ data: [
2134
+ {
2135
+ id: '1',
2136
+ label: 'node-1',
2137
+ children: [
2138
+ {
2139
+ id: '1-1',
2140
+ label: 'node-1-1',
2141
+ children: [
2142
+ {
2143
+ id: '1-1-1',
2144
+ label: 'node-1-1-1',
2145
+ },
2146
+ {
2147
+ id: '1-1-2',
2148
+ label: 'node-1-1-2',
2149
+ disabled: true,
2150
+ },
2151
+ ],
2152
+ },
2153
+ {
2154
+ id: '1-2',
2155
+ label: 'node-1-2',
2156
+ children: [
2157
+ {
2158
+ id: '1-2-1',
2159
+ label: 'node-1-2-1',
2160
+ },
2161
+ ],
2162
+ },
2163
+ {
2164
+ id: '1-3',
2165
+ label: 'node-1-3',
2166
+ disabled: true,
2167
+ children: [
2168
+ {
2169
+ id: '1-3-1',
2170
+ label: 'node-1-3-1',
2171
+ },
2172
+ {
2173
+ id: '1-3-2',
2174
+ label: 'node-1-3-2',
2175
+ },
2176
+ ],
2177
+ },
2178
+ ],
2179
+ },
2180
+ ],
2181
+ }
2182
+ },
2183
+ })
2184
+
2185
+ await nextTick()
2186
+ const treeRef = wrapper.findComponent({ name: 'ElTree' }).vm as TreeInstance
2187
+
2188
+ expect(treeRef.getCheckedKeys()).toHaveLength(0)
2189
+
2190
+ let nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2191
+ await nodes[0].trigger('click')
2192
+ expect(treeRef.getCheckedKeys()).toEqual([
2193
+ '1-1-1',
2194
+ '1-2',
2195
+ '1-2-1',
2196
+ '1-3',
2197
+ '1-3-1',
2198
+ '1-3-2',
2199
+ ])
2200
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2201
+ await nodes[1].trigger('click')
2202
+ expect(treeRef.getCheckedKeys()).toEqual([
2203
+ '1-2',
2204
+ '1-2-1',
2205
+ '1-3',
2206
+ '1-3-1',
2207
+ '1-3-2',
2208
+ ])
2209
+
2210
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2211
+ await nodes[0].trigger('click')
2212
+ expect(treeRef.getCheckedKeys()).toEqual([
2213
+ '1-1-1',
2214
+ '1-2',
2215
+ '1-2-1',
2216
+ '1-3',
2217
+ '1-3-1',
2218
+ '1-3-2',
2219
+ ])
2220
+
2221
+ treeRef.setCheckedKeys([])
2222
+ expect(treeRef.getCheckedKeys()).toHaveLength(0)
2223
+ const allKeys = [
2224
+ '1',
2225
+ '1-1',
2226
+ '1-1-1',
2227
+ '1-1-2',
2228
+ '1-2',
2229
+ '1-2-1',
2230
+ '1-3',
2231
+ '1-3-1',
2232
+ '1-3-2',
2233
+ ]
2234
+ treeRef.setCheckedKeys(allKeys)
2235
+ expect(treeRef.getCheckedKeys()).toEqual(allKeys)
2236
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2237
+ await nodes[0].trigger('click')
2238
+ expect(treeRef.getCheckedKeys()).toEqual(['1-1-2'])
2239
+ })
2240
+
2241
+ test('should not block descendant updates when a disabled non-leaf node exists', async () => {
2242
+ const wrapper = mount({
2243
+ template: `
2244
+ <el-tree
2245
+ :data="data"
2246
+ node-key="id"
2247
+ show-checkbox
2248
+ default-expand-all
2249
+ />
2250
+ `,
2251
+ components: { 'el-tree': Tree },
2252
+ data() {
2253
+ return {
2254
+ data: [
2255
+ {
2256
+ id: '1',
2257
+ label: 'node-1',
2258
+ children: [
2259
+ {
2260
+ id: '1-1',
2261
+ label: 'node-1-1',
2262
+ },
2263
+ {
2264
+ id: '1-2',
2265
+ label: 'node-1-2',
2266
+ disabled: true,
2267
+ children: [
2268
+ {
2269
+ id: '1-2-1',
2270
+ label: 'node-1-2-1',
2271
+ },
2272
+ ],
2273
+ },
2274
+ ],
2275
+ },
2276
+ {
2277
+ id: '2',
2278
+ label: 'node-2',
2279
+ children: [
2280
+ {
2281
+ id: '2-1',
2282
+ label: 'node-2-1',
2283
+ disabled: true,
2284
+ children: [
2285
+ {
2286
+ id: '2-1-1',
2287
+ label: 'node-2-1-1',
2288
+ },
2289
+ {
2290
+ id: '2-1-2',
2291
+ label: 'node-2-1-2',
2292
+ disabled: true,
2293
+ },
2294
+ ],
2295
+ },
2296
+ ],
2297
+ },
2298
+ ],
2299
+ }
2300
+ },
2301
+ })
2302
+
2303
+ await nextTick()
2304
+ const treeRef = wrapper.findComponent({ name: 'ElTree' }).vm as TreeInstance
2305
+ const keys = ['1', '1-1', '1-2', '1-2-1']
2306
+
2307
+ expect(treeRef.getCheckedKeys()).toHaveLength(0)
2308
+
2309
+ treeRef.setCheckedKeys(keys)
2310
+ expect(treeRef.getCheckedKeys()).toEqual(keys)
2311
+
2312
+ let nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2313
+ await nodes[0].trigger('click')
2314
+ expect(treeRef.getCheckedKeys()).toHaveLength(0)
2315
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2316
+ await nodes[4].trigger('click')
2317
+ expect(treeRef.getCheckedKeys()).toEqual(['2-1-1'])
2318
+ })
2319
+
2320
+ test('should correctly handle checkbox state in lazy mode when disabled nodes exist', async () => {
2321
+ const { wrapper } = getTreeVm(
2322
+ `:props="defaultProps" :load="loadNode" node-key="id" show-checkbox lazy`,
2323
+ {
2324
+ methods: {
2325
+ loadNode(node, resolve) {
2326
+ if (node.level === 0) {
2327
+ return resolve([{ label: 'a', id: 'a' }])
2328
+ }
2329
+ if (node.level > 1) return resolve([])
2330
+
2331
+ const data = [
2332
+ {
2333
+ label: 'leaf',
2334
+ id: 'b',
2335
+ isLeaf: true,
2336
+ disabled: true,
2337
+ },
2338
+ {
2339
+ label: 'zone',
2340
+ id: 'c',
2341
+ },
2342
+ ]
2343
+ resolve(data)
2344
+ },
2345
+ },
2346
+ }
2347
+ )
2348
+
2349
+ await nextTick()
2350
+ const nodeWrappers = wrapper.findAll('.el-tree-node__content')
2351
+ const treeRef = wrapper.findComponent({ name: 'ElTree' }).vm as TreeInstance
2352
+
2353
+ expect(treeRef.getCheckedKeys()).toHaveLength(0)
2354
+
2355
+ let nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2356
+ await nodes[0].trigger('click')
2357
+ expect(treeRef.getCheckedKeys()).toEqual(['a'])
2358
+ await nodeWrappers[0].trigger('click')
2359
+ expect(treeRef.getCheckedKeys()).toEqual(['c'])
2360
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2361
+ await nodes[0].trigger('click')
2362
+ expect(treeRef.getCheckedKeys()).toEqual([])
2363
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2364
+ await nodes[0].trigger('click')
2365
+ expect(treeRef.getCheckedKeys()).toEqual(['c'])
2366
+ })
2367
+
2368
+ test('should correctly handle checkbox state under default-checked-keys when disabled nodes exist', async () => {
2369
+ const wrapper = mount({
2370
+ template: `
2371
+ <el-tree
2372
+ :data="data"
2373
+ node-key="id"
2374
+ show-checkbox
2375
+ default-expand-all
2376
+ :default-checked-keys="['1-1', '1-2']"
2377
+ />
2378
+ `,
2379
+ components: { 'el-tree': Tree },
2380
+ data() {
2381
+ return {
2382
+ data: [
2383
+ {
2384
+ id: '1',
2385
+ label: 'node-1',
2386
+ children: [
2387
+ {
2388
+ id: '1-1',
2389
+ label: 'node-1-1',
2390
+ },
2391
+ {
2392
+ id: '1-2',
2393
+ label: 'node-1-2',
2394
+ },
2395
+ {
2396
+ id: '1-3',
2397
+ label: 'node-1-3',
2398
+ disabled: true,
2399
+ },
2400
+ ],
2401
+ },
2402
+ ],
2403
+ }
2404
+ },
2405
+ })
2406
+
2407
+ await nextTick()
2408
+ const treeRef = wrapper.findComponent({ name: 'ElTree' }).vm as TreeInstance
2409
+ const keys = ['1-1', '1-2']
2410
+
2411
+ expect(treeRef.getCheckedKeys()).toEqual(keys)
2412
+
2413
+ let nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2414
+ await nodes[0].trigger('click')
2415
+ expect(treeRef.getCheckedKeys()).toEqual([])
2416
+ nodes = wrapper.findAll(TREE_NODE_CHECKBOX_CLASS_NAME)
2417
+ await nodes[0].trigger('click')
2418
+ expect(treeRef.getCheckedKeys()).toEqual(keys)
2419
+ })
2420
+ })