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,4576 @@
1
+ // @ts-nocheck
2
+ /**
3
+ * @vitest-environment happy-dom
4
+ */
5
+ import { defineComponent, markRaw, nextTick, ref } from 'vue'
6
+ import { mount } from '@vue/test-utils'
7
+ import { afterEach, describe, expect, it, test, vi } from 'vitest'
8
+ import { BORDER_HORIZONTAL_WIDTH, EVENT_CODE } from '@element-plus/constants'
9
+ import { ArrowDown, CaretTop, CircleClose } from '@element-plus/icons-vue'
10
+ import { usePopperContainerId } from '@element-plus/hooks'
11
+ import { hasClass } from '@element-plus/utils'
12
+ import { ElForm, ElFormItem } from '@element-plus/components/form'
13
+ import Select from '../src/select.vue'
14
+ import Group from '../src/option-group.vue'
15
+ import Option from '../src/option.vue'
16
+
17
+ vi.mock('lodash-unified', async () => {
18
+ return {
19
+ ...((await vi.importActual('lodash-unified')) as Record<string, any>),
20
+ debounce: vi.fn((fn) => {
21
+ fn.cancel = vi.fn()
22
+ fn.flush = vi.fn()
23
+ return fn
24
+ }),
25
+ }
26
+ })
27
+
28
+ vi.mock('@vueuse/core', async () => {
29
+ return {
30
+ ...((await vi.importActual('@vueuse/core')) as Record<string, any>),
31
+ useDebounceFn: vi.fn((fn) => {
32
+ return fn
33
+ }),
34
+ }
35
+ })
36
+
37
+ interface SelectProps {
38
+ filterMethod?: any
39
+ remoteMethod?: any
40
+ multiple?: boolean
41
+ clearable?: boolean
42
+ filterable?: boolean
43
+ allowCreate?: boolean
44
+ remote?: boolean
45
+ collapseTags?: boolean
46
+ automaticDropdown?: boolean
47
+ multipleLimit?: number
48
+ popperClass?: string
49
+ popperStyle?: string
50
+ defaultFirstOption?: boolean
51
+ fitInputWidth?: boolean
52
+ size?: 'small' | 'default' | 'large'
53
+ debounce?: number
54
+ }
55
+
56
+ const _mount = (template: string, data: any = () => ({}), otherObj?) =>
57
+ mount(
58
+ {
59
+ components: {
60
+ 'el-select': Select,
61
+ 'el-option': Option,
62
+ 'el-group-option': Group,
63
+ 'el-form-item': ElFormItem,
64
+ 'el-form': ElForm,
65
+ },
66
+ template,
67
+ data,
68
+ setup() {
69
+ return usePopperContainerId()
70
+ },
71
+ ...otherObj,
72
+ },
73
+ {
74
+ attachTo: 'body',
75
+ global: {
76
+ provide: {
77
+ namespace: 'el',
78
+ },
79
+ },
80
+ }
81
+ )
82
+
83
+ function getOptions(): HTMLElement[] {
84
+ return Array.from(
85
+ document.querySelectorAll<HTMLElement>(
86
+ 'body > div:last-child .el-select-dropdown__item'
87
+ )
88
+ )
89
+ }
90
+
91
+ const getSelectVm = (configs: SelectProps = {}, options?) => {
92
+ ;[
93
+ 'multiple',
94
+ 'clearable',
95
+ 'defaultFirstOption',
96
+ 'filterable',
97
+ 'allowCreate',
98
+ 'remote',
99
+ 'collapseTags',
100
+ 'automaticDropdown',
101
+ 'fitInputWidth',
102
+ ].forEach((config) => {
103
+ configs[config] = configs[config] || false
104
+ })
105
+ configs.multipleLimit = configs.multipleLimit || 0
106
+ if (!options) {
107
+ options = [
108
+ {
109
+ value: '选项1',
110
+ label: '黄金糕',
111
+ disabled: false,
112
+ },
113
+ {
114
+ value: '选项2',
115
+ label: '双皮奶',
116
+ disabled: false,
117
+ },
118
+ {
119
+ value: '选项3',
120
+ label: '蚵仔煎',
121
+ disabled: false,
122
+ },
123
+ {
124
+ value: '选项4',
125
+ label: '龙须面',
126
+ disabled: false,
127
+ },
128
+ {
129
+ value: '选项5',
130
+ label: '北京烤鸭',
131
+ disabled: false,
132
+ },
133
+ ]
134
+ }
135
+
136
+ return _mount(
137
+ `
138
+ <el-select
139
+ ref="select"
140
+ v-model="value"
141
+ :multiple="multiple"
142
+ :multiple-limit="multipleLimit"
143
+ :popper-class="popperClass"
144
+ :popper-style="popperStyle"
145
+ :clearable="clearable"
146
+ :default-first-option="defaultFirstOption"
147
+ :filterable="filterable"
148
+ :collapse-tags="collapseTags"
149
+ :allow-create="allowCreate"
150
+ :filterMethod="filterMethod"
151
+ :remote="remote"
152
+ :loading="loading"
153
+ :remoteMethod="remoteMethod"
154
+ :automatic-dropdown="automaticDropdown"
155
+ :size="size"
156
+ :fit-input-width="fitInputWidth">
157
+ <el-option
158
+ v-for="item in options"
159
+ :label="item.label"
160
+ :key="item.value"
161
+ :disabled="item.disabled"
162
+ :value="item.value">
163
+ </el-option>
164
+ </el-select>
165
+ `,
166
+ () => ({
167
+ options,
168
+ multiple: configs.multiple,
169
+ multipleLimit: configs.multipleLimit,
170
+ clearable: configs.clearable,
171
+ defaultFirstOption: configs.defaultFirstOption,
172
+ filterable: configs.filterable,
173
+ collapseTags: configs.collapseTags,
174
+ allowCreate: configs.allowCreate,
175
+ popperClass: configs.popperClass,
176
+ popperStyle: configs.popperStyle,
177
+ automaticDropdown: configs.automaticDropdown,
178
+ fitInputWidth: configs.fitInputWidth,
179
+ loading: false,
180
+ filterMethod: configs.filterMethod,
181
+ remote: configs.remote,
182
+ remoteMethod: configs.remoteMethod,
183
+ value: configs.multiple ? [] : '',
184
+ size: configs.size || 'default',
185
+ })
186
+ )
187
+ }
188
+
189
+ const getGroupSelectVm = (configs: SelectProps = {}, options?) => {
190
+ ;[
191
+ 'multiple',
192
+ 'clearable',
193
+ 'filterable',
194
+ 'allowCreate',
195
+ 'remote',
196
+ 'collapseTags',
197
+ 'automaticDropdown',
198
+ 'fitInputWidth',
199
+ ].forEach((config) => {
200
+ configs[config] = configs[config] || false
201
+ })
202
+ configs.multipleLimit = configs.multipleLimit || 0
203
+ if (!options) {
204
+ options = [
205
+ {
206
+ label: 'Australia',
207
+ options: [
208
+ {
209
+ value: 'Sydney',
210
+ label: 'Sydney',
211
+ },
212
+ {
213
+ value: 'Melbourne',
214
+ label: 'Melbourne',
215
+ },
216
+ ],
217
+ },
218
+ {
219
+ label: 'China',
220
+ options: [
221
+ {
222
+ value: 'Shanghai',
223
+ label: 'Shanghai',
224
+ },
225
+ {
226
+ value: 'Shenzhen',
227
+ label: 'Shenzhen',
228
+ },
229
+ {
230
+ value: 'Guangzhou',
231
+ label: 'Guangzhou',
232
+ },
233
+ {
234
+ value: 'Dalian',
235
+ label: 'Dalian',
236
+ },
237
+ ],
238
+ },
239
+ {
240
+ label: 'India',
241
+ options: [
242
+ {
243
+ value: 'Mumbai',
244
+ label: 'Mumbai',
245
+ },
246
+ {
247
+ value: 'Delhi',
248
+ label: 'Delhi',
249
+ },
250
+ {
251
+ value: 'Bangalore',
252
+ label: 'Bangalore',
253
+ },
254
+ ],
255
+ },
256
+ {
257
+ label: 'Indonesia',
258
+ options: [
259
+ {
260
+ value: 'Bandung',
261
+ label: 'Bandung',
262
+ },
263
+ {
264
+ value: 'Jakarta',
265
+ label: 'Jakarta',
266
+ },
267
+ ],
268
+ },
269
+ ]
270
+ }
271
+ return _mount(
272
+ `
273
+ <el-select
274
+ ref="select"
275
+ v-model="value"
276
+ :multiple="multiple"
277
+ :multiple-limit="multipleLimit"
278
+ :popper-class="popperClass"
279
+ :clearable="clearable"
280
+ :filterable="filterable"
281
+ :collapse-tags="collapseTags"
282
+ :allow-create="allowCreate"
283
+ :filterMethod="filterMethod"
284
+ :remote="remote"
285
+ :loading="loading"
286
+ :remoteMethod="remoteMethod"
287
+ :automatic-dropdown="automaticDropdown"
288
+ :fit-input-width="fitInputWidth">
289
+ <el-group-option
290
+ v-for="group in options"
291
+ :key="group.label"
292
+ :disabled="group.disabled"
293
+ :label="group.label">
294
+ <el-option
295
+ v-for="item in group.options"
296
+ :key="item.value"
297
+ :label="item.label"
298
+ :value="item.value"/>
299
+ </el-group-option>
300
+ </el-select>
301
+ `,
302
+ () => ({
303
+ options,
304
+ multiple: configs.multiple,
305
+ multipleLimit: configs.multipleLimit,
306
+ clearable: configs.clearable,
307
+ filterable: configs.filterable,
308
+ collapseTags: configs.collapseTags,
309
+ allowCreate: configs.allowCreate,
310
+ popperClass: configs.popperClass,
311
+ automaticDropdown: configs.automaticDropdown,
312
+ fitInputWidth: configs.fitInputWidth,
313
+ loading: false,
314
+ filterMethod: configs.filterMethod,
315
+ remote: configs.remote,
316
+ remoteMethod: configs.remoteMethod,
317
+ value: configs.multiple ? [] : '',
318
+ })
319
+ )
320
+ }
321
+
322
+ const CLASS_NAME = 'el-select'
323
+ const WRAPPER_CLASS_NAME = 'el-select__wrapper'
324
+ const OPTION_ITEM_CLASS_NAME = 'el-select-dropdown__item'
325
+ const PLACEHOLDER_CLASS_NAME = 'el-select__placeholder'
326
+ const DEFAULT_PLACEHOLDER = 'Select'
327
+ const TAG_NAME = `${WRAPPER_CLASS_NAME} .el-tag`
328
+
329
+ describe('Select', () => {
330
+ let wrapper: ReturnType<typeof _mount>
331
+ afterEach(() => {
332
+ document.body.innerHTML = ''
333
+ })
334
+
335
+ test('create', async () => {
336
+ wrapper = _mount(`<el-select v-model="value"></el-select>`, () => ({
337
+ value: '',
338
+ }))
339
+ expect(wrapper.classes()).toContain(CLASS_NAME)
340
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(
341
+ DEFAULT_PLACEHOLDER
342
+ )
343
+ const select = wrapper.findComponent({ name: 'ElSelect' })
344
+ const trigger = wrapper.find(`.${WRAPPER_CLASS_NAME}`)
345
+ await trigger.trigger('mouseenter')
346
+ await trigger.trigger('click')
347
+ await nextTick()
348
+ expect((select.vm as any).expanded).toBe(true)
349
+ })
350
+
351
+ test('options rendered correctly', () => {
352
+ wrapper = getSelectVm()
353
+ const options = wrapper.element.querySelectorAll(
354
+ `.${OPTION_ITEM_CLASS_NAME}`
355
+ )
356
+ const result = Array.prototype.every.call(options, (option, index) => {
357
+ const text = option.querySelector('span').textContent
358
+ const vm = wrapper.vm as any
359
+ return text === vm.options[index].label
360
+ })
361
+ expect(result).toBe(true)
362
+ })
363
+
364
+ test('custom dropdown class', () => {
365
+ wrapper = getSelectVm({ popperClass: 'custom-dropdown' })
366
+ const dropdown = wrapper.findComponent({ name: 'ElSelectDropdown' })
367
+ expect(dropdown.classes()).toContain('custom-dropdown')
368
+ })
369
+
370
+ test('custom popper style', async () => {
371
+ wrapper = getSelectVm({ popperStyle: 'background: red;' })
372
+ const popper = document.querySelector('.el-popper') as HTMLElement
373
+ expect(popper.style.background).toBe('red')
374
+ })
375
+
376
+ test('default value', async () => {
377
+ wrapper = _mount(
378
+ `
379
+ <el-select v-model="value">
380
+ <el-option
381
+ v-for="item in options"
382
+ :label="item.label"
383
+ :key="item.value"
384
+ :value="item.value">
385
+ </el-option>
386
+ </el-select>
387
+ `,
388
+ () => ({
389
+ options: [
390
+ {
391
+ value: '选项1',
392
+ label: '黄金糕',
393
+ },
394
+ {
395
+ value: '选项2',
396
+ label: '双皮奶',
397
+ },
398
+ ],
399
+ value: '选项2',
400
+ })
401
+ )
402
+ await nextTick()
403
+
404
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('双皮奶')
405
+ })
406
+
407
+ test('the scenario of rendering label when there is a default value and persistent is false', async () => {
408
+ // This is convenient for testing the default value label rendering when persistent is false.
409
+ process.env.RUN_TEST_WITH_PERSISTENT = 'true'
410
+ wrapper = _mount(
411
+ `
412
+ <el-select v-model="value" :persistent="false">
413
+ <el-option
414
+ v-for="item in options"
415
+ :label="item.label"
416
+ :key="item.value"
417
+ :value="item.value">
418
+ </el-option>
419
+ </el-select>
420
+ `,
421
+ () => ({
422
+ options: [
423
+ {
424
+ value: '选项1',
425
+ label: '黄金糕',
426
+ },
427
+ {
428
+ value: '选项2',
429
+ label: '双皮奶',
430
+ },
431
+ ],
432
+ value: '选项2',
433
+ })
434
+ )
435
+ await nextTick()
436
+
437
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('双皮奶')
438
+ delete process.env.RUN_TEST_WITH_PERSISTENT
439
+ })
440
+
441
+ test('updates selected label after label change when closed and persistent=false', async () => {
442
+ process.env.RUN_TEST_WITH_PERSISTENT = 'true'
443
+ wrapper = _mount(
444
+ `
445
+ <el-select v-model="value" :persistent="false">
446
+ <el-option
447
+ v-for="item in options"
448
+ :label="item.label"
449
+ :key="item.value"
450
+ :value="item.value">
451
+ </el-option>
452
+ </el-select>
453
+ `,
454
+ () => ({
455
+ options: [
456
+ {
457
+ value: '1',
458
+ label: 'A',
459
+ },
460
+ {
461
+ value: '2',
462
+ label: 'B',
463
+ },
464
+ ],
465
+ value: '1',
466
+ })
467
+ )
468
+ await nextTick()
469
+ // initial label
470
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('A')
471
+ // update label while dropdown remains closed
472
+ ;(wrapper.vm as any).options = [
473
+ { value: '1', label: 'A2' },
474
+ { value: '2', label: 'B' },
475
+ ]
476
+ await nextTick()
477
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('A2')
478
+ delete process.env.RUN_TEST_WITH_PERSISTENT
479
+ })
480
+
481
+ test('keeps empty string label after label update when closed and persistent=false', async () => {
482
+ process.env.RUN_TEST_WITH_PERSISTENT = 'true'
483
+ wrapper = _mount(
484
+ `
485
+ <el-select v-model="value" :persistent="false">
486
+ <el-option
487
+ v-for="item in options"
488
+ :label="item.label"
489
+ :key="item.value"
490
+ :value="item.value">
491
+ </el-option>
492
+ </el-select>
493
+ `,
494
+ () => ({
495
+ options: [
496
+ {
497
+ value: 'value1',
498
+ label: '',
499
+ },
500
+ {
501
+ value: 'value2',
502
+ label: 'B',
503
+ },
504
+ ],
505
+ value: 'value1',
506
+ })
507
+ )
508
+ await nextTick()
509
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('')
510
+ delete process.env.RUN_TEST_WITH_PERSISTENT
511
+ })
512
+
513
+ test('when there is a default value and persistent is false, render the label and dynamically modify options and modelValue', async () => {
514
+ // This is convenient for testing the default value label rendering when persistent is false.
515
+ process.env.RUN_TEST_WITH_PERSISTENT = 'true'
516
+ wrapper = _mount(
517
+ `
518
+ <el-select v-model="value" :persistent="false">
519
+ <el-option
520
+ v-for="item in options"
521
+ :label="item.label"
522
+ :key="item.value"
523
+ :value="item.value">
524
+ </el-option>
525
+ </el-select>
526
+ `,
527
+ () => ({
528
+ options: [],
529
+ value: '选项2',
530
+ })
531
+ )
532
+ await nextTick()
533
+ const vm = wrapper.vm as any
534
+ vm.options = [
535
+ {
536
+ value: '选项1',
537
+ label: '黄金糕',
538
+ },
539
+ {
540
+ value: '选项2',
541
+ label: '双皮奶',
542
+ },
543
+ ]
544
+ await nextTick()
545
+
546
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('双皮奶')
547
+
548
+ vm.value = '选项1'
549
+ await nextTick()
550
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('黄金糕')
551
+
552
+ delete process.env.RUN_TEST_WITH_PERSISTENT
553
+ })
554
+
555
+ test('should not render the empty slot when multiple is true and persistent is false', async () => {
556
+ wrapper = _mount(
557
+ `
558
+ <el-select v-model="value" multiple :persistent="false">
559
+ <el-option
560
+ v-for="item in options"
561
+ :label="item.label"
562
+ :key="item.value"
563
+ :value="item.value">
564
+ </el-option>
565
+ <template #empty>
566
+ <div class="empty-slot">EmptySlot</div>
567
+ </template>
568
+ </el-select>
569
+ `,
570
+ () => ({
571
+ options: [
572
+ {
573
+ value: '选项1',
574
+ label: '黄金糕',
575
+ },
576
+ {
577
+ value: '选项2',
578
+ label: '双皮奶',
579
+ },
580
+ ],
581
+ value: [],
582
+ })
583
+ )
584
+ await nextTick()
585
+ const select = wrapper.findComponent({ name: 'ElSelect' })
586
+ const selectVm = select.vm as any
587
+ expect(selectVm.selectedLabel).toStrictEqual([])
588
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
589
+ const options = getOptions()
590
+ options[0].click()
591
+ await nextTick()
592
+ expect(selectVm.selectedLabel).toStrictEqual(['黄金糕'])
593
+
594
+ const emptySlot = document.querySelector('.empty-slot')
595
+ expect(emptySlot).toBeNull()
596
+ })
597
+
598
+ test('multiple is true and persistent is false', async () => {
599
+ // This is convenient for testing the default value label rendering when persistent is false.
600
+ process.env.RUN_TEST_WITH_PERSISTENT = 'true'
601
+ wrapper = _mount(
602
+ `
603
+ <el-select v-model="value" :persistent="false" multiple>
604
+ <el-option
605
+ v-for="item in options"
606
+ :label="item.label"
607
+ :key="item.value"
608
+ :value="item.value">
609
+ </el-option>
610
+ </el-select>
611
+ `,
612
+ () => ({
613
+ options: [
614
+ {
615
+ value: '选项1',
616
+ label: '黄金糕',
617
+ },
618
+ {
619
+ value: '选项2',
620
+ label: '双皮奶',
621
+ },
622
+ ],
623
+ value: ['选项2'],
624
+ })
625
+ )
626
+ await nextTick()
627
+
628
+ const tags = wrapper.findAll(`.${TAG_NAME}`)
629
+ expect(tags.length).toBe(1)
630
+ expect(tags[0].text()).toBe('双皮奶')
631
+ delete process.env.RUN_TEST_WITH_PERSISTENT
632
+ })
633
+
634
+ test('multiple is true and persistent is false, render the label and dynamically modify options', async () => {
635
+ wrapper = _mount(
636
+ `
637
+ <el-select v-model="value" :persistent="false" multiple>
638
+ <el-option
639
+ v-for="item in options"
640
+ :label="item.label"
641
+ :key="item.value"
642
+ :value="item.value">
643
+ </el-option>
644
+ </el-select>
645
+ `,
646
+ () => ({
647
+ options: [],
648
+ value: ['选项2'],
649
+ })
650
+ )
651
+ await nextTick()
652
+ const vm = wrapper.vm as any
653
+ vm.options = [
654
+ {
655
+ value: '选项1',
656
+ label: '黄金糕',
657
+ },
658
+ {
659
+ value: '选项2',
660
+ label: '双皮奶',
661
+ },
662
+ ]
663
+ await nextTick()
664
+
665
+ const tags = wrapper.findAll(`.${TAG_NAME}`)
666
+ expect(tags.length).toBe(1)
667
+ expect(tags[0].text()).toBe('双皮奶')
668
+ })
669
+
670
+ test('expose select label', async () => {
671
+ wrapper = _mount(
672
+ `
673
+ <el-select v-model="value" :multiple="multiple">
674
+ <el-option
675
+ v-for="item in options"
676
+ :label="item.label"
677
+ :key="item.value"
678
+ :value="item.value">
679
+ </el-option>
680
+ </el-select>
681
+ `,
682
+ () => ({
683
+ options: [
684
+ { value: '选项1', label: '黄金糕' },
685
+ { value: '选项2', label: '双皮奶' },
686
+ ],
687
+ value: '选项2',
688
+ multiple: false,
689
+ })
690
+ )
691
+ await nextTick()
692
+ const select = wrapper.findComponent({ name: 'ElSelect' })
693
+ const vm = wrapper.vm as any
694
+ const selectVm = select.vm as any
695
+
696
+ expect(selectVm.selectedLabel).toBe('双皮奶')
697
+
698
+ const options = getOptions()
699
+ options[0].click()
700
+ await nextTick()
701
+ expect(selectVm.selectedLabel).toBe('黄金糕')
702
+ vm.value = ''
703
+ await nextTick()
704
+ expect(selectVm.selectedLabel).toBe('')
705
+
706
+ vm.value = []
707
+ vm.multiple = true
708
+ await nextTick()
709
+ expect(selectVm.selectedLabel).toStrictEqual([])
710
+ vm.value = ['选项1', '选项2']
711
+ await nextTick()
712
+ expect(selectVm.selectedLabel).toStrictEqual(['黄金糕', '双皮奶'])
713
+ })
714
+
715
+ test('set default value to object', async () => {
716
+ wrapper = _mount(
717
+ `
718
+ <el-select v-model="value">
719
+ <el-option
720
+ v-for="item in options"
721
+ :label="item.label"
722
+ :key="item.value.value"
723
+ :value="item.value">
724
+ </el-option>
725
+ </el-select>
726
+ `,
727
+ () => ({
728
+ options: [
729
+ {
730
+ value: {
731
+ value: '选项1',
732
+ },
733
+ label: '黄金糕',
734
+ },
735
+ {
736
+ value: {
737
+ value: '选项2',
738
+ },
739
+ label: '双皮奶',
740
+ },
741
+ ],
742
+ value: {
743
+ value: '选项2',
744
+ },
745
+ })
746
+ )
747
+ await nextTick()
748
+
749
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('双皮奶')
750
+ })
751
+
752
+ test('custom label', async () => {
753
+ wrapper = _mount(
754
+ `
755
+ <el-select v-model="value">
756
+ <el-option
757
+ v-for="item in options"
758
+ :label="item.name"
759
+ :key="item.id"
760
+ :value="item.id">
761
+ </el-option>
762
+ </el-select>
763
+ `,
764
+ () => ({
765
+ options: [
766
+ {
767
+ id: 1,
768
+ name: '黄金糕',
769
+ },
770
+ {
771
+ id: 2,
772
+ name: '双皮奶',
773
+ },
774
+ ],
775
+ value: 2,
776
+ })
777
+ )
778
+ await nextTick()
779
+
780
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('双皮奶')
781
+ })
782
+
783
+ test('custom label with object', async () => {
784
+ wrapper = _mount(
785
+ `
786
+ <el-select v-model="value" value-key="id">
787
+ <el-option
788
+ v-for="item in options"
789
+ :label="item.name"
790
+ :key="item.id"
791
+ :value="item">
792
+ </el-option>
793
+ </el-select>
794
+ `,
795
+ () => ({
796
+ options: [
797
+ {
798
+ id: 1,
799
+ name: '黄金糕',
800
+ },
801
+ {
802
+ id: 2,
803
+ name: '双皮奶',
804
+ },
805
+ ],
806
+ value: {
807
+ id: 2,
808
+ },
809
+ })
810
+ )
811
+ await nextTick()
812
+
813
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('双皮奶')
814
+ })
815
+
816
+ test('value bind object with value-key', async () => {
817
+ wrapper = _mount(
818
+ `
819
+ <el-select v-model="value" value-key="id">
820
+ <el-option
821
+ v-for="item in options"
822
+ :key="item.id"
823
+ :label="item.label"
824
+ :value="item"
825
+ />
826
+ </el-select>
827
+ `,
828
+ () => ({
829
+ options: [
830
+ { id: 1, label: 'Option A', desc: 'Option A - 230506' },
831
+ { id: 2, label: 'Option B', desc: 'Option B - 230506' },
832
+ { id: 3, label: 'Option C', desc: 'Option C - 230506' },
833
+ { id: 4, label: 'Option D', desc: 'Option D - 230507' },
834
+ ],
835
+ value: {
836
+ value: '',
837
+ },
838
+ })
839
+ )
840
+ await nextTick()
841
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
842
+ const options = getOptions()
843
+ options[2].click()
844
+ await nextTick()
845
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('Option C')
846
+ options[3].click()
847
+ await nextTick()
848
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('Option D')
849
+ })
850
+
851
+ test('set default value to object with value-key', async () => {
852
+ wrapper = _mount(
853
+ `
854
+ <el-select v-model="value" value-key="id">
855
+ <el-option
856
+ v-for="item in options"
857
+ :key="item.id"
858
+ :label="item.label"
859
+ :value="item"
860
+ />
861
+ </el-select>
862
+ `,
863
+ () => ({
864
+ options: [
865
+ { id: 1, label: 'Option A', desc: 'Option A - 230506' },
866
+ { id: 2, label: 'Option B', desc: 'Option B - 230506' },
867
+ { id: 3, label: 'Option C', desc: 'Option C - 230506' },
868
+ { id: 4, label: 'Option A', desc: 'Option A - 230507' },
869
+ ],
870
+ value: { id: 3 },
871
+ })
872
+ )
873
+ await nextTick()
874
+ const options = getOptions()
875
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('Option C')
876
+ expect(Array.from(options[2].classList)).toContain('is-selected')
877
+ })
878
+
879
+ test('sync set value and options', async () => {
880
+ wrapper = _mount(
881
+ `
882
+ <el-select v-model="value">
883
+ <el-option
884
+ v-for="item in options"
885
+ :label="item.label"
886
+ :key="item.value"
887
+ :value="item.value">
888
+ </el-option>
889
+ </el-select>
890
+ `,
891
+ () => ({
892
+ options: [
893
+ {
894
+ value: '选项1',
895
+ label: '黄金糕',
896
+ },
897
+ {
898
+ value: '选项2',
899
+ label: '双皮奶',
900
+ },
901
+ ],
902
+ value: '选项2',
903
+ })
904
+ )
905
+ const vm = wrapper.vm as any
906
+ vm.options = [
907
+ {
908
+ value: '选项1',
909
+ label: '黄金糕',
910
+ },
911
+ ]
912
+ vm.value = '选项1'
913
+ await nextTick()
914
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('黄金糕')
915
+ })
916
+
917
+ test('single select', async () => {
918
+ wrapper = _mount(
919
+ `
920
+ <el-select v-model="value" @change="handleChange">
921
+ <el-option
922
+ v-for="item in options"
923
+ :label="item.label"
924
+ :key="item.value"
925
+ :value="item.value">
926
+ <p>{{item.label}} {{item.value}}</p>
927
+ </el-option>
928
+ </el-select>
929
+ `,
930
+ () => ({
931
+ options: [
932
+ {
933
+ value: '选项1',
934
+ label: '黄金糕',
935
+ },
936
+ {
937
+ value: '选项2',
938
+ label: '双皮奶',
939
+ },
940
+ {
941
+ value: '选项3',
942
+ label: '蚵仔煎',
943
+ },
944
+ {
945
+ value: '选项4',
946
+ label: '龙须面',
947
+ },
948
+ {
949
+ value: '选项5',
950
+ label: '北京烤鸭',
951
+ },
952
+ ],
953
+ value: '',
954
+ count: 0,
955
+ }),
956
+ {
957
+ methods: {
958
+ handleChange() {
959
+ this.count++
960
+ },
961
+ },
962
+ }
963
+ )
964
+
965
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
966
+ const options = getOptions()
967
+ const vm = wrapper.vm as any
968
+ expect(vm.value).toBe('')
969
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(
970
+ DEFAULT_PLACEHOLDER
971
+ )
972
+ options[2].click()
973
+ await nextTick()
974
+ expect(vm.value).toBe('选项3')
975
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('蚵仔煎')
976
+ expect(vm.count).toBe(1)
977
+ options[4].click()
978
+ await nextTick()
979
+ expect(vm.value).toBe('选项5')
980
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('北京烤鸭')
981
+ expect(vm.count).toBe(2)
982
+ })
983
+
984
+ test('disabled option', async () => {
985
+ wrapper = getSelectVm()
986
+ const vm = wrapper.vm as any
987
+ wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
988
+ vm.options[1].disabled = true
989
+ await nextTick()
990
+ const options = getOptions()
991
+ expect(options[1].className).toContain('is-disabled')
992
+ options[1].click()
993
+ await nextTick()
994
+ expect(vm.value).toBe('')
995
+ })
996
+
997
+ test('disabled select', () => {
998
+ wrapper = _mount(`<el-select disabled></el-select>`)
999
+ expect(wrapper.find(`.${WRAPPER_CLASS_NAME}`).classes()).toContain(
1000
+ 'is-disabled'
1001
+ )
1002
+ })
1003
+
1004
+ test('group disabled option', () => {
1005
+ const optionGroupData = [
1006
+ {
1007
+ label: 'Australia',
1008
+ disabled: true,
1009
+ options: [
1010
+ {
1011
+ value: 'Sydney',
1012
+ label: 'Sydney',
1013
+ },
1014
+ {
1015
+ value: 'Melbourne',
1016
+ label: 'Melbourne',
1017
+ },
1018
+ ],
1019
+ },
1020
+ ]
1021
+ wrapper = getGroupSelectVm({}, optionGroupData)
1022
+ const options = wrapper.findAllComponents(Option)
1023
+ expect(options[0].classes('is-disabled')).toBeTruthy()
1024
+ })
1025
+
1026
+ test('keyboard operations when option-group is disabled', async () => {
1027
+ const optionGroupData = [
1028
+ {
1029
+ label: 'Australia',
1030
+ disabled: true,
1031
+ options: [
1032
+ {
1033
+ value: 'Sydney',
1034
+ label: 'Sydney',
1035
+ },
1036
+ {
1037
+ value: 'Melbourne',
1038
+ label: 'Melbourne',
1039
+ },
1040
+ ],
1041
+ },
1042
+ {
1043
+ label: 'China',
1044
+ options: [
1045
+ {
1046
+ value: 'Shanghai',
1047
+ label: 'Shanghai',
1048
+ },
1049
+ {
1050
+ value: 'Shenzhen',
1051
+ label: 'Shenzhen',
1052
+ },
1053
+ {
1054
+ value: 'Guangzhou',
1055
+ label: 'Guangzhou',
1056
+ },
1057
+ {
1058
+ value: 'Dalian',
1059
+ label: 'Dalian',
1060
+ },
1061
+ ],
1062
+ },
1063
+ ]
1064
+ wrapper = getGroupSelectVm({}, optionGroupData)
1065
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1066
+ const vm = select.vm as any
1067
+ let i = 8
1068
+ while (i--) {
1069
+ vm.navigateOptions('next')
1070
+ }
1071
+ vm.navigateOptions('prev')
1072
+ vm.navigateOptions('prev')
1073
+ vm.navigateOptions('prev')
1074
+ await nextTick()
1075
+ vm.selectOption()
1076
+ await nextTick()
1077
+ expect((wrapper.vm as any).value).toBe('Dalian')
1078
+ })
1079
+
1080
+ test('visible event', async () => {
1081
+ wrapper = _mount(
1082
+ `
1083
+ <el-select v-model="value" @visible-change="handleVisibleChange">
1084
+ <el-option
1085
+ v-for="item in options"
1086
+ :label="item.label"
1087
+ :key="item.value"
1088
+ :value="item.value">
1089
+ </el-option>
1090
+ </el-select>`,
1091
+ () => ({
1092
+ options: [],
1093
+ value: '',
1094
+ visible: '',
1095
+ }),
1096
+ {
1097
+ methods: {
1098
+ handleVisibleChange(val) {
1099
+ this.visible = val
1100
+ },
1101
+ },
1102
+ }
1103
+ )
1104
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1105
+ const vm = wrapper.vm as any
1106
+ const selectVm = select.vm as any
1107
+ selectVm.expanded = true
1108
+ await selectVm.$nextTick()
1109
+ expect(vm.visible).toBe(true)
1110
+ })
1111
+
1112
+ test('keyboard operations', async () => {
1113
+ vi.useFakeTimers()
1114
+ wrapper = getSelectVm()
1115
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1116
+ const vm = select.vm as any
1117
+ let i = 8
1118
+ while (i--) {
1119
+ vm.navigateOptions('next')
1120
+ }
1121
+ vm.navigateOptions('prev')
1122
+ vm.navigateOptions('prev')
1123
+ vm.navigateOptions('prev')
1124
+ await nextTick()
1125
+ expect(vm.states.hoveringIndex).toBe(3)
1126
+ vm.selectOption()
1127
+ await nextTick()
1128
+ expect((wrapper.vm as any).value).toBe('选项4')
1129
+ vm.toggleMenu()
1130
+
1131
+ vi.runAllTimers()
1132
+ await nextTick()
1133
+
1134
+ vm.toggleMenu()
1135
+ await nextTick()
1136
+ expect(vm.states.hoveringIndex).toBe(3)
1137
+ vi.useRealTimers()
1138
+ })
1139
+
1140
+ test('keyboard operations when options have the same label', async () => {
1141
+ wrapper = _mount(
1142
+ `<el-select
1143
+ v-model="value"
1144
+ clearable
1145
+ filterable
1146
+ >
1147
+ <el-option
1148
+ v-for="item in options"
1149
+ :label="item.label"
1150
+ :key="item.value"
1151
+ :value="item.value"
1152
+ />
1153
+ </el-select>`,
1154
+ () => ({
1155
+ options: [
1156
+ {
1157
+ value: 'Option1',
1158
+ label: 'Option1',
1159
+ },
1160
+ {
1161
+ value: 'Option2',
1162
+ label: 'Option1',
1163
+ },
1164
+ {
1165
+ value: 'Option3',
1166
+ label: 'Option1',
1167
+ },
1168
+ {
1169
+ value: 'Option4',
1170
+ label: 'Option4',
1171
+ },
1172
+ {
1173
+ value: 'Option5',
1174
+ label: 'Option5',
1175
+ },
1176
+ ],
1177
+ value: 'Option1',
1178
+ })
1179
+ )
1180
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1181
+ const selectVm = select.vm as any
1182
+ const input = wrapper.find('input')
1183
+ await input.trigger('click')
1184
+ expect(selectVm.states.hoveringIndex).toBe(0)
1185
+ selectVm.navigateOptions('next')
1186
+ expect(selectVm.states.hoveringIndex).toBe(1)
1187
+ selectVm.navigateOptions('next')
1188
+ expect(selectVm.states.hoveringIndex).toBe(2)
1189
+ selectVm.navigateOptions('next')
1190
+ expect(selectVm.states.hoveringIndex).toBe(3)
1191
+ selectVm.navigateOptions('next')
1192
+ expect(selectVm.states.hoveringIndex).toBe(4)
1193
+ })
1194
+
1195
+ // #19136
1196
+ test('keyboard operations when options are disabled due to multiple-limit', async () => {
1197
+ wrapper = getSelectVm({ multiple: true, multipleLimit: 2 })
1198
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1199
+ await wrapper.setProps({
1200
+ modelValue: ['选项1', '选项2'],
1201
+ })
1202
+ const selectVm = select.vm as any
1203
+ const input = select.find('input')
1204
+ await input.trigger('click')
1205
+ expect(selectVm.states.hoveringIndex).toBe(1)
1206
+ selectVm.navigateOptions('next')
1207
+ expect(selectVm.states.hoveringIndex).toBe(0)
1208
+ selectVm.navigateOptions('next')
1209
+ expect(selectVm.states.hoveringIndex).toBe(1)
1210
+ })
1211
+
1212
+ test('clearable', async () => {
1213
+ wrapper = getSelectVm({ clearable: true })
1214
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1215
+ const vm = wrapper.vm as any
1216
+ const selectVm = select.vm as any
1217
+ vm.value = '选项1'
1218
+ await nextTick()
1219
+ selectVm.states.inputHovering = true
1220
+ await selectVm.$nextTick()
1221
+ const iconClear = wrapper.findComponent(CircleClose)
1222
+ expect(iconClear.exists()).toBe(true)
1223
+ await iconClear.trigger('click')
1224
+ expect(vm.value).toBe(undefined)
1225
+ })
1226
+
1227
+ test('suffix icon', async () => {
1228
+ wrapper = _mount(`<el-select></el-select>`)
1229
+ let suffixIcon = wrapper.findComponent(ArrowDown)
1230
+ expect(suffixIcon.exists()).toBe(true)
1231
+ await wrapper.setProps({ suffixIcon: markRaw(CaretTop) })
1232
+ suffixIcon = wrapper.findComponent(CaretTop)
1233
+ expect(suffixIcon.exists()).toBe(true)
1234
+ })
1235
+
1236
+ test('test remote show suffix', async () => {
1237
+ wrapper = _mount(`<el-select></el-select>`)
1238
+ await wrapper.setProps({
1239
+ remote: true,
1240
+ filters: true,
1241
+ remoteShowSuffix: true,
1242
+ })
1243
+
1244
+ const suffixIcon = wrapper.findComponent(ArrowDown)
1245
+ expect(suffixIcon.exists()).toBe(true)
1246
+ })
1247
+
1248
+ test('fitInputWidth', async () => {
1249
+ wrapper = getSelectVm({ fitInputWidth: true })
1250
+ const selectRef = wrapper.findComponent({ name: 'ElSelect' })
1251
+ const selectDom = selectRef.element
1252
+ const selectRect = {
1253
+ height: 40,
1254
+ width: 221,
1255
+ x: 44,
1256
+ y: 8,
1257
+ top: 8,
1258
+ }
1259
+ const mockSelectWidth = vi
1260
+ .spyOn(selectDom, 'getBoundingClientRect')
1261
+ .mockReturnValue(selectRect as DOMRect)
1262
+ const dropdown = wrapper.findComponent({ name: 'ElSelectDropdown' })
1263
+ dropdown.vm.minWidth = `${
1264
+ selectRef.element.getBoundingClientRect().width - BORDER_HORIZONTAL_WIDTH
1265
+ }px`
1266
+ await nextTick()
1267
+ expect(dropdown.element.style.width).toBe('219px')
1268
+ mockSelectWidth.mockRestore()
1269
+ })
1270
+
1271
+ test('check default first option', async () => {
1272
+ wrapper = getSelectVm({
1273
+ filterable: true,
1274
+ defaultFirstOption: true,
1275
+ })
1276
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1277
+ const selectVm = select.vm as any
1278
+ const input = wrapper.find('input')
1279
+ await input.trigger('click')
1280
+ expect(selectVm.states.hoveringIndex).toBe(0)
1281
+ selectVm.navigateOptions('next')
1282
+ expect(selectVm.states.hoveringIndex).toBe(1)
1283
+ })
1284
+
1285
+ test('check default first option when the very first option is disabled', async () => {
1286
+ const demoOptions = [
1287
+ {
1288
+ value: 'HTML',
1289
+ label: 'HTML',
1290
+ disabled: true,
1291
+ },
1292
+ {
1293
+ value: 'CSS',
1294
+ label: 'CSS',
1295
+ disabled: false,
1296
+ },
1297
+ {
1298
+ value: 'JavaScript',
1299
+ label: 'JavaScript',
1300
+ disabled: false,
1301
+ },
1302
+ ]
1303
+ wrapper = getSelectVm(
1304
+ {
1305
+ filterable: true,
1306
+ defaultFirstOption: true,
1307
+ },
1308
+ demoOptions
1309
+ )
1310
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1311
+ const selectVm = select.vm as any
1312
+ const input = wrapper.find('input')
1313
+ await input.trigger('click')
1314
+
1315
+ expect(selectVm.states.hoveringIndex).toBe(1) // index 0 was skipped
1316
+ selectVm.navigateOptions('next')
1317
+ expect(selectVm.states.hoveringIndex).toBe(2)
1318
+ selectVm.navigateOptions('next')
1319
+ expect(selectVm.states.hoveringIndex).toBe(1) // index 0 was skipped
1320
+ })
1321
+
1322
+ test('allow create', async () => {
1323
+ wrapper = getSelectVm({ filterable: true, allowCreate: true })
1324
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1325
+ const selectVm = select.vm as any
1326
+ const input = wrapper.find('input')
1327
+ await input.trigger('click')
1328
+ await input.setValue('new')
1329
+ selectVm.debouncedOnInputChange()
1330
+ await nextTick()
1331
+ const options = [...getOptions()]
1332
+ const target = options.find((option) => option.textContent === 'new')
1333
+ target.click()
1334
+ expect((wrapper.vm as any).value).toBe('new')
1335
+ })
1336
+
1337
+ test('allow create should clear input after creating a tag with reserveKeyword', async () => {
1338
+ wrapper = getSelectVm({
1339
+ filterable: true,
1340
+ allowCreate: true,
1341
+ multiple: true,
1342
+ })
1343
+ const selectVm = wrapper.findComponent({ name: 'ElSelect' }).vm as any
1344
+ const input = wrapper.find('input')
1345
+ await input.trigger('click')
1346
+ await input.setValue('new tag')
1347
+ selectVm.debouncedOnInputChange()
1348
+ await nextTick()
1349
+ getOptions()
1350
+ .find((o) => o.textContent === 'new tag')!
1351
+ .click()
1352
+ await nextTick()
1353
+ expect(selectVm.states.inputValue).toBe('')
1354
+ })
1355
+
1356
+ test('allow create with default first option', async () => {
1357
+ wrapper = getSelectVm(
1358
+ {
1359
+ filterable: true,
1360
+ allowCreate: true,
1361
+ defaultFirstOption: true,
1362
+ },
1363
+ [
1364
+ {
1365
+ value: 'HTML',
1366
+ label: 'HTML',
1367
+ },
1368
+ {
1369
+ value: 'CSS',
1370
+ label: 'CSS',
1371
+ },
1372
+ {
1373
+ value: 'JavaScript',
1374
+ label: 'JavaScript',
1375
+ },
1376
+ ]
1377
+ )
1378
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1379
+ const selectVm = select.vm as any
1380
+ const input = wrapper.find('input')
1381
+ await input.trigger('click')
1382
+ await input.setValue('Java')
1383
+ selectVm.debouncedOnInputChange()
1384
+ await nextTick()
1385
+ const options = [...getOptions()]
1386
+ expect(Array.from(options[0].classList)).toContain('is-hovering')
1387
+ options[0].click()
1388
+ expect((wrapper.vm as any).value).toBe('Java')
1389
+ })
1390
+
1391
+ test('allow create async option', async () => {
1392
+ const options = [
1393
+ {
1394
+ value: '选项1',
1395
+ label: '黄金糕',
1396
+ },
1397
+ {
1398
+ value: '选项2',
1399
+ label: '双皮奶',
1400
+ },
1401
+ ]
1402
+ wrapper = _mount(
1403
+ `
1404
+ <el-select
1405
+ v-model="value"
1406
+ filterable
1407
+ allowCreate
1408
+ >
1409
+ <el-option
1410
+ v-for="item in options"
1411
+ :label="item.label"
1412
+ :key="item.value"
1413
+ :value="item.value">
1414
+ </el-option>
1415
+ </el-select>
1416
+ `,
1417
+ () => ({
1418
+ options: [],
1419
+ value: '选项2',
1420
+ })
1421
+ )
1422
+
1423
+ await nextTick()
1424
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('选项2')
1425
+ await wrapper.setData({
1426
+ options,
1427
+ })
1428
+ expect(getOptions()).toHaveLength(options.length)
1429
+ })
1430
+
1431
+ test('multiple select', async () => {
1432
+ wrapper = getSelectVm({ multiple: true })
1433
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1434
+ const options = getOptions()
1435
+ const vm = wrapper.vm as any
1436
+ vm.value = ['选项1']
1437
+ nextTick()
1438
+ options[1].click()
1439
+ await nextTick()
1440
+ options[3].click()
1441
+ await nextTick()
1442
+ expect(vm.value.includes('选项2') && vm.value.includes('选项4')).toBe(true)
1443
+ const tagCloseIcons = wrapper.findAll('.el-tag__close')
1444
+ await tagCloseIcons[0].trigger('click')
1445
+ expect(vm.value.indexOf('选项1')).toBe(-1)
1446
+ })
1447
+
1448
+ test('should prevent option mousedown from blurring multiple select', async () => {
1449
+ wrapper = getSelectVm({ multiple: true })
1450
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1451
+ const option = getOptions()[0]
1452
+ const event = new MouseEvent('mousedown', {
1453
+ bubbles: true,
1454
+ cancelable: true,
1455
+ shiftKey: true,
1456
+ })
1457
+
1458
+ option.dispatchEvent(event)
1459
+
1460
+ expect(event.defaultPrevented).toBeTruthy()
1461
+ })
1462
+
1463
+ test('multiple select when content overflow', async () => {
1464
+ wrapper = _mount(
1465
+ `
1466
+ <el-select v-model="selectedList" multiple placeholder="请选择">
1467
+ <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
1468
+ </el-option>
1469
+ </el-select>
1470
+ `,
1471
+ () => ({
1472
+ options: [
1473
+ {
1474
+ value: '选项1',
1475
+ label:
1476
+ '黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕',
1477
+ },
1478
+ {
1479
+ value: '选项2',
1480
+ label:
1481
+ '双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶',
1482
+ },
1483
+ {
1484
+ value: '选项3',
1485
+ label: '蚵仔煎蚵仔煎蚵仔煎蚵仔煎蚵仔煎蚵仔煎',
1486
+ },
1487
+ {
1488
+ value: '选项4',
1489
+ label: '龙须面',
1490
+ },
1491
+ {
1492
+ value: '选项5',
1493
+ label: '北京烤鸭',
1494
+ },
1495
+ ],
1496
+ selectedList: [],
1497
+ })
1498
+ )
1499
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1500
+ const options = getOptions()
1501
+ const selectRef = wrapper.findComponent(Select)
1502
+ selectRef.vm.states.selectionWidth = 200
1503
+ options[0].click()
1504
+ await nextTick()
1505
+ options[1].click()
1506
+ await nextTick()
1507
+ options[2].click()
1508
+ await nextTick()
1509
+ const tagWrappers = wrapper.findAll('.el-tag')
1510
+ for (const tagWrapper of tagWrappers) {
1511
+ const tagWrapperDom = tagWrapper.element
1512
+ expect(tagWrapperDom.style.maxWidth).toBe('200px')
1513
+ }
1514
+ })
1515
+
1516
+ test('multiple select with collapseTags when content overflow', async () => {
1517
+ wrapper = _mount(
1518
+ `
1519
+ <el-select v-model="selectedList" multiple collapseTags placeholder="请选择">
1520
+ <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
1521
+ </el-option>
1522
+ </el-select>
1523
+ `,
1524
+ () => ({
1525
+ options: [
1526
+ {
1527
+ value: '选项1',
1528
+ label:
1529
+ '黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕黄金糕',
1530
+ },
1531
+ {
1532
+ value: '选项2',
1533
+ label:
1534
+ '双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶双皮奶',
1535
+ },
1536
+ {
1537
+ value: '选项3',
1538
+ label: '蚵仔煎蚵仔煎蚵仔煎蚵仔煎蚵仔煎蚵仔煎',
1539
+ },
1540
+ {
1541
+ value: '选项4',
1542
+ label: '龙须面',
1543
+ },
1544
+ {
1545
+ value: '选项5',
1546
+ label: '北京烤鸭',
1547
+ },
1548
+ ],
1549
+ selectedList: [],
1550
+ })
1551
+ )
1552
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1553
+ const options = getOptions()
1554
+ const selectRef = wrapper.findComponent(Select)
1555
+ selectRef.vm.states.selectionWidth = 200
1556
+ options[0].click()
1557
+ await nextTick()
1558
+ const tagWrappers = wrapper.findAll('.el-tag')
1559
+ const tagWrapperDom = tagWrappers[0].element
1560
+ expect(tagWrapperDom.style.maxWidth).toBe('200px')
1561
+ options[1].click()
1562
+ await nextTick()
1563
+ options[2].click()
1564
+ selectRef.vm.states.collapseItemWidth = 38
1565
+ await nextTick()
1566
+ expect(tagWrapperDom.style.maxWidth).toBe('156px')
1567
+ })
1568
+
1569
+ test('multiple select with collapseTagsTooltip', async () => {
1570
+ // This is convenient for testing the default value label rendering when persistent is false.
1571
+ process.env.RUN_TEST_WITH_PERSISTENT = 'true'
1572
+
1573
+ wrapper = _mount(
1574
+ `
1575
+ <div>
1576
+ <div class="append-target"></div>
1577
+ <el-select
1578
+ v-model="selectedList"
1579
+ multiple
1580
+ collapseTags
1581
+ collapse-tags-tooltip
1582
+ :tag-tooltip="{ appendTo: '.append-target' }"
1583
+ placeholder="请选择"
1584
+ >
1585
+ <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" />
1586
+ </el-select>
1587
+ </div>
1588
+ `,
1589
+ () => ({
1590
+ options: [
1591
+ {
1592
+ value: '选项1',
1593
+ label: '黄金糕',
1594
+ },
1595
+ {
1596
+ value: '选项2',
1597
+ label: '双皮奶',
1598
+ },
1599
+ {
1600
+ value: '选项3',
1601
+ label: '蚵仔煎',
1602
+ },
1603
+ {
1604
+ value: '选项4',
1605
+ label: '龙须面',
1606
+ },
1607
+ {
1608
+ value: '选项5',
1609
+ label: '北京烤鸭',
1610
+ },
1611
+ ],
1612
+ selectedList: [],
1613
+ })
1614
+ )
1615
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1616
+ const options = getOptions()
1617
+
1618
+ options[0].click()
1619
+ await nextTick()
1620
+ options[1].click()
1621
+ await nextTick()
1622
+ options[2].click()
1623
+ await nextTick()
1624
+
1625
+ const select = wrapper.findComponent(Select)
1626
+ const tagTooltip = select.findComponent({ ref: 'tagTooltipRef' })
1627
+ expect(tagTooltip.props('appendTo')).toBe('.append-target')
1628
+
1629
+ const triggerWrappers = wrapper.findAll('.el-tooltip__trigger')
1630
+ expect(triggerWrappers[0]).toBeDefined()
1631
+ const tags = document.querySelectorAll('.el-select__tags-text')
1632
+ expect(tags.length).toBe(2)
1633
+ expect(tags[1].textContent).toBe(' + 2')
1634
+
1635
+ delete process.env.RUN_TEST_WITH_PERSISTENT
1636
+ })
1637
+
1638
+ test('multiple select with maxCollapseTags', async () => {
1639
+ wrapper = _mount(
1640
+ `
1641
+ <el-select v-model="selectedList" multiple collapseTags :max-collapse-tags="3" placeholder="请选择">
1642
+ <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
1643
+ </el-option>
1644
+ </el-select>
1645
+ `,
1646
+ () => ({
1647
+ options: [
1648
+ {
1649
+ value: '选项1',
1650
+ label: '黄金糕',
1651
+ },
1652
+ {
1653
+ value: '选项2',
1654
+ label: '双皮奶',
1655
+ },
1656
+ {
1657
+ value: '选项3',
1658
+ label: '蚵仔煎',
1659
+ },
1660
+ {
1661
+ value: '选项4',
1662
+ label: '龙须面',
1663
+ },
1664
+ {
1665
+ value: '选项5',
1666
+ label: '北京烤鸭',
1667
+ },
1668
+ ],
1669
+ selectedList: [],
1670
+ })
1671
+ )
1672
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1673
+ const options = getOptions()
1674
+
1675
+ options[0].click()
1676
+ await nextTick()
1677
+ options[1].click()
1678
+ await nextTick()
1679
+ options[2].click()
1680
+ await nextTick()
1681
+ const triggerWrappers = wrapper.findAll('.el-tooltip__trigger')
1682
+ expect(triggerWrappers[0]).toBeDefined()
1683
+ const tags = document.querySelectorAll('.el-select__tags-text')
1684
+ expect(tags.length).toBe(3)
1685
+ })
1686
+
1687
+ test('multiple remove-tag', async () => {
1688
+ const handleRemoveTag = vi.fn()
1689
+
1690
+ wrapper = _mount(
1691
+ `
1692
+ <el-select v-model="value" multiple @remove-tag="handleRemoveTag">
1693
+ <el-option
1694
+ v-for="item in options"
1695
+ :label="item.label"
1696
+ :key="item.value"
1697
+ :value="item.value">
1698
+ <p>{{item.label}} {{item.value}}</p>
1699
+ </el-option>
1700
+ </el-select>
1701
+ `,
1702
+ () => ({
1703
+ options: [
1704
+ {
1705
+ value: '选项1',
1706
+ label: '黄金糕',
1707
+ },
1708
+ {
1709
+ value: '选项2',
1710
+ label: '双皮奶',
1711
+ },
1712
+ {
1713
+ value: '选项3',
1714
+ label: '蚵仔煎',
1715
+ },
1716
+ {
1717
+ value: '选项4',
1718
+ label: '龙须面',
1719
+ },
1720
+ {
1721
+ value: '选项5',
1722
+ label: '北京烤鸭',
1723
+ },
1724
+ ],
1725
+ value: ['选项1', '选项2'],
1726
+ handleRemoveTag,
1727
+ })
1728
+ )
1729
+
1730
+ const vm = wrapper.vm as any
1731
+ await nextTick()
1732
+ expect(vm.value.length).toBe(2)
1733
+ const tagCloseIcons = wrapper.findAll('.el-tag__close')
1734
+ await tagCloseIcons[1].trigger('click')
1735
+ expect(vm.value.length).toBe(1)
1736
+
1737
+ const input = wrapper.find('input')
1738
+ input.trigger('keydown', { code: EVENT_CODE.backspace })
1739
+ expect(vm.value.length).toBe(0)
1740
+ expect(handleRemoveTag).toHaveBeenLastCalledWith('选项1')
1741
+ })
1742
+
1743
+ test('allow remove non existant option', async () => {
1744
+ wrapper = _mount(
1745
+ `
1746
+ <el-select v-model="value" multiple filterable>
1747
+ <el-option
1748
+ v-for="item in options"
1749
+ :label="item.label"
1750
+ :key="item.value"
1751
+ :value="item.value">
1752
+ </el-option>
1753
+ </el-select>
1754
+ `,
1755
+ () => ({
1756
+ options: [],
1757
+ value: ['选项1'],
1758
+ })
1759
+ )
1760
+
1761
+ await nextTick()
1762
+ const vm = wrapper.vm as any
1763
+ expect(vm.value.length).toBe(1)
1764
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
1765
+
1766
+ const input = wrapper.find('input')
1767
+ await input.trigger('keydown', {
1768
+ code: EVENT_CODE.backspace,
1769
+ key: EVENT_CODE.backspace,
1770
+ })
1771
+
1772
+ expect(wrapper.findAll('.el-tag').length).toBe(0)
1773
+ expect(vm.value.length).toBe(0)
1774
+ })
1775
+
1776
+ test('multiple limit', async () => {
1777
+ wrapper = getSelectVm({ multiple: true, multipleLimit: 1 })
1778
+ const vm = wrapper.vm as any
1779
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
1780
+ const options = getOptions()
1781
+ options[1].click()
1782
+ await nextTick()
1783
+ expect(vm.value.includes('选项2')).toBe(true)
1784
+ options[3].click()
1785
+ await nextTick()
1786
+ expect(vm.value.indexOf('选项4')).toBe(-1)
1787
+ })
1788
+
1789
+ test('event:focus', async () => {
1790
+ const handleFocus = vi.fn()
1791
+ wrapper = _mount(`<el-select @focus="handleFocus" />`, () => ({
1792
+ handleFocus,
1793
+ }))
1794
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1795
+ const input = select.find('input')
1796
+
1797
+ expect(input.exists()).toBe(true)
1798
+ await input.trigger('focus')
1799
+ expect(handleFocus).toHaveBeenCalledTimes(1)
1800
+ })
1801
+
1802
+ test('should show clear btn on focus', async () => {
1803
+ const wrapper = _mount(
1804
+ `<el-select v-model="value" :options="options" clearable />`,
1805
+ () => ({
1806
+ options: [
1807
+ {
1808
+ value: 'value1',
1809
+ label: 'label1',
1810
+ },
1811
+ ],
1812
+ value: 'value1',
1813
+ })
1814
+ )
1815
+
1816
+ const input = wrapper.find('input')
1817
+ await input.trigger('blur')
1818
+ await input.trigger('focus')
1819
+ expect(wrapper.findComponent(CircleClose).exists()).toBe(true)
1820
+ })
1821
+
1822
+ test('event:blur', async () => {
1823
+ const handleBlur = vi.fn()
1824
+ wrapper = _mount(`<el-select @blur="handleBlur" />`, () => ({
1825
+ handleBlur,
1826
+ }))
1827
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1828
+ const input = select.find('input')
1829
+
1830
+ expect(input.exists()).toBe(true)
1831
+ await input.trigger('blur')
1832
+ expect(handleBlur).toHaveBeenCalledTimes(1)
1833
+ })
1834
+
1835
+ test('event:focus & blur for clearable & filterable', async () => {
1836
+ const handleFocus = vi.fn()
1837
+ const handleBlur = vi.fn()
1838
+ wrapper = _mount(
1839
+ `<el-select
1840
+ v-model="value"
1841
+ clearable
1842
+ filterable
1843
+ @focus="handleFocus"
1844
+ @blur="handleBlur"
1845
+ >
1846
+ <el-option
1847
+ v-for="item in options"
1848
+ :label="item.label"
1849
+ :key="item.value"
1850
+ :value="item.value"
1851
+ />
1852
+ </el-select>`,
1853
+ () => ({
1854
+ options: [
1855
+ {
1856
+ value: '选项1',
1857
+ label: '黄金糕',
1858
+ },
1859
+ ],
1860
+ value: '选项1',
1861
+ handleFocus,
1862
+ handleBlur,
1863
+ })
1864
+ )
1865
+
1866
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1867
+ const vm = wrapper.vm as any
1868
+ const selectVm = select.vm as any
1869
+ selectVm.states.inputHovering = true
1870
+ await selectVm.$nextTick()
1871
+
1872
+ const iconClear = wrapper.findComponent(CircleClose)
1873
+ expect(iconClear.exists()).toBe(true)
1874
+ await iconClear.trigger('click')
1875
+ expect(vm.value).toBe(undefined)
1876
+ expect(handleFocus).toHaveBeenCalledTimes(1)
1877
+ expect(handleBlur).not.toHaveBeenCalled()
1878
+
1879
+ const options = getOptions()
1880
+ options[0].click()
1881
+ await nextTick()
1882
+ expect(vm.value).toBe('选项1')
1883
+ selectVm.states.inputHovering = true
1884
+ await iconClear.trigger('click')
1885
+ expect(handleFocus).toHaveBeenCalledTimes(1)
1886
+ expect(handleBlur).not.toHaveBeenCalled()
1887
+
1888
+ const input = select.find('input')
1889
+ await input.trigger('blur')
1890
+ expect(handleBlur).toHaveBeenCalled()
1891
+ })
1892
+
1893
+ test('event:focus & blur for multiple & filterable select', async () => {
1894
+ const handleFocus = vi.fn()
1895
+ const handleBlur = vi.fn()
1896
+ wrapper = _mount(
1897
+ `
1898
+ <el-select
1899
+ @focus="handleFocus"
1900
+ @blur="handleBlur"
1901
+ multiple
1902
+ filterable
1903
+ />`,
1904
+ () => ({
1905
+ handleFocus,
1906
+ handleBlur,
1907
+ })
1908
+ )
1909
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1910
+ const input = select.find('input')
1911
+
1912
+ expect(input.exists()).toBe(true)
1913
+ await input.trigger('focus')
1914
+ expect(handleFocus).toHaveBeenCalled()
1915
+ await input.trigger('blur')
1916
+ expect(handleBlur).toHaveBeenCalled()
1917
+
1918
+ await input.trigger('focus')
1919
+ expect(handleFocus).toHaveBeenCalledTimes(2)
1920
+ await input.trigger('blur')
1921
+ expect(handleBlur).toHaveBeenCalled()
1922
+ })
1923
+
1924
+ test('event:focus & blur for multiple tag close', async () => {
1925
+ const handleFocus = vi.fn()
1926
+ const handleBlur = vi.fn()
1927
+ wrapper = _mount(
1928
+ `<el-select
1929
+ v-model="value"
1930
+ multiple
1931
+ @focus="handleFocus"
1932
+ @blur="handleBlur"
1933
+ >
1934
+ <el-option
1935
+ v-for="item in options"
1936
+ :label="item.label"
1937
+ :key="item.value"
1938
+ :value="item.value">
1939
+ <p>{{item.label}} {{item.value}}</p>
1940
+ </el-option>
1941
+ </el-select>`,
1942
+ () => ({
1943
+ options: [
1944
+ {
1945
+ value: '选项1',
1946
+ label: '黄金糕',
1947
+ },
1948
+ {
1949
+ value: '选项2',
1950
+ label: '双皮奶',
1951
+ },
1952
+ {
1953
+ value: '选项3',
1954
+ label: '蚵仔煎',
1955
+ },
1956
+ {
1957
+ value: '选项4',
1958
+ label: '龙须面',
1959
+ },
1960
+ {
1961
+ value: '选项5',
1962
+ label: '北京烤鸭',
1963
+ },
1964
+ ],
1965
+ value: ['选项1', '选项2'],
1966
+ handleFocus,
1967
+ handleBlur,
1968
+ })
1969
+ )
1970
+
1971
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1972
+ const input = select.find('input')
1973
+
1974
+ await input.trigger('focus')
1975
+ expect(handleFocus).toHaveBeenCalledTimes(1)
1976
+ const tagCloseIcons = wrapper.findAll('.el-tag__close')
1977
+ await tagCloseIcons[1].trigger('click')
1978
+ await tagCloseIcons[0].trigger('click')
1979
+ expect(handleFocus).toHaveBeenCalledTimes(1)
1980
+ expect(handleBlur).not.toHaveBeenCalled()
1981
+ await input.trigger('blur')
1982
+ expect(handleBlur).toHaveBeenCalled()
1983
+ })
1984
+
1985
+ it('should be target blur event when click outside', async () => {
1986
+ const handleBlur = vi.fn()
1987
+ wrapper = _mount(
1988
+ `
1989
+ <el-select @blur="handleBlur" />
1990
+ <button>button</button>
1991
+ `,
1992
+ () => ({ handleBlur })
1993
+ )
1994
+ const select = wrapper.findComponent({ name: 'ElSelect' })
1995
+ const input = select.find('input')
1996
+ await input.trigger('focus')
1997
+
1998
+ expect(wrapper.find(`.${WRAPPER_CLASS_NAME}`).classes()).toContain(
1999
+ 'is-focused'
2000
+ )
2001
+
2002
+ await wrapper.find('button').trigger('mousedown')
2003
+ await wrapper.find('button').trigger('mouseup')
2004
+
2005
+ expect(wrapper.find(`.${WRAPPER_CLASS_NAME}`).classes()).not.toContain(
2006
+ 'is-focused'
2007
+ )
2008
+ expect(handleBlur).toHaveBeenCalledTimes(1)
2009
+ expect(handleBlur.mock.calls[0]).toEqual([
2010
+ expect.objectContaining({ type: 'blur' }),
2011
+ ])
2012
+ })
2013
+
2014
+ test('should not open popper when automatic-dropdown not set', async () => {
2015
+ wrapper = getSelectVm()
2016
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2017
+ const input = select.find('input')
2018
+ await input.trigger('focus')
2019
+ expect((select.vm as any).expanded).toBe(false)
2020
+ })
2021
+
2022
+ test('should open popper when automatic-dropdown is set', async () => {
2023
+ wrapper = getSelectVm({ automaticDropdown: true })
2024
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2025
+ const input = select.find('input')
2026
+ await input.trigger('focus')
2027
+ expect((select.vm as any).expanded).toBe(true)
2028
+ })
2029
+
2030
+ test('automatic dropdown should cooperate with click to open the dropdown', async () => {
2031
+ wrapper = getSelectVm({ automaticDropdown: true })
2032
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2033
+ const input = select.find('input')
2034
+ await input.trigger('focus')
2035
+ expect((select.vm as any).expanded).toBe(true)
2036
+ await input.trigger('keydown', { key: EVENT_CODE.down })
2037
+ await input.trigger('keydown', { key: EVENT_CODE.enter })
2038
+ expect((select.vm as any).expanded).toBe(false)
2039
+ await input.trigger('click')
2040
+ expect((select.vm as any).expanded).toBe(true)
2041
+ })
2042
+
2043
+ test('only emit change on user input', async () => {
2044
+ let callCount = 0
2045
+ wrapper = _mount(
2046
+ `
2047
+ <el-select v-model="value" @change="change" ref="select">
2048
+ <el-option label="1" value="1" />
2049
+ <el-option label="2" value="2" />
2050
+ <el-option label="3" value="3" />
2051
+ </el-select>`,
2052
+ () => ({
2053
+ value: '1',
2054
+ change: () => ++callCount,
2055
+ })
2056
+ )
2057
+
2058
+ expect(callCount).toBe(0)
2059
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2060
+ const options = getOptions()
2061
+ options[2].click()
2062
+ expect(callCount).toBe(1)
2063
+ })
2064
+
2065
+ test('render slot `empty`', async () => {
2066
+ wrapper = _mount(
2067
+ `
2068
+ <el-select v-model="value">
2069
+ <template #empty>
2070
+ <div class="empty-slot">EmptySlot</div>
2071
+ </template>
2072
+ </el-select>`,
2073
+ () => ({
2074
+ value: '1',
2075
+ })
2076
+ )
2077
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2078
+ expect(
2079
+ document.querySelector<HTMLElement>('.empty-slot')?.textContent
2080
+ ).toBe('EmptySlot')
2081
+ })
2082
+
2083
+ test('should set placeholder to label of selected option when filterable is true and multiple is false', async () => {
2084
+ wrapper = _mount(
2085
+ `
2086
+ <el-select ref="select" v-model="value" filterable>
2087
+ <el-option label="test" value="test" />
2088
+ </el-select>`,
2089
+ () => ({ value: 'test' })
2090
+ )
2091
+ const vm = wrapper.vm as any
2092
+ const trigger = wrapper.find(`.${WRAPPER_CLASS_NAME}`)
2093
+ await trigger.trigger('mouseenter')
2094
+ await trigger.trigger('click')
2095
+ const selectVm = wrapper.findComponent({ name: 'ElSelect' }).vm as any
2096
+ expect(selectVm.expanded).toBe(true)
2097
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('test')
2098
+ expect(vm.value).toBe('test')
2099
+ })
2100
+
2101
+ test('default value is null or undefined', async () => {
2102
+ wrapper = _mount(
2103
+ `
2104
+ <el-select v-model="value">
2105
+ <el-option
2106
+ v-for="item in options"
2107
+ :label="item.label"
2108
+ :key="item.value"
2109
+ :value="item.value">
2110
+ </el-option>
2111
+ </el-select>`,
2112
+ () => ({
2113
+ options: [
2114
+ {
2115
+ value: '选项1',
2116
+ label: '黄金糕',
2117
+ },
2118
+ {
2119
+ value: '选项2',
2120
+ label: '双皮奶',
2121
+ },
2122
+ ],
2123
+ value: undefined,
2124
+ })
2125
+ )
2126
+ const vm = wrapper.vm as any
2127
+ vm.value = null
2128
+ await nextTick()
2129
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(
2130
+ DEFAULT_PLACEHOLDER
2131
+ )
2132
+ vm.value = '选项1'
2133
+ await nextTick()
2134
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('黄金糕')
2135
+ })
2136
+
2137
+ test('emptyText error show', async () => {
2138
+ wrapper = _mount(
2139
+ `
2140
+ <el-select :model-value="value" filterable placeholder="Select">
2141
+ <el-option
2142
+ v-for="item in options"
2143
+ :key="item.value"
2144
+ :label="item.label"
2145
+ :value="item.value">
2146
+ </el-option>
2147
+ </el-select>`,
2148
+ () => ({
2149
+ options: [
2150
+ {
2151
+ value: 'Option1',
2152
+ label: 'Option1',
2153
+ },
2154
+ {
2155
+ value: 'Option2',
2156
+ label: 'Option2',
2157
+ },
2158
+ {
2159
+ value: 'Option3',
2160
+ label: 'Option3',
2161
+ },
2162
+ {
2163
+ value: 'Option4',
2164
+ label: 'Option4',
2165
+ },
2166
+ {
2167
+ value: 'Option5',
2168
+ label: 'Option5',
2169
+ },
2170
+ ],
2171
+ value: 'test',
2172
+ })
2173
+ )
2174
+ const trigger = wrapper.find(`.${WRAPPER_CLASS_NAME}`)
2175
+ await trigger.trigger('mouseenter')
2176
+ await trigger.trigger('click')
2177
+ await nextTick()
2178
+ expect(
2179
+ !!(document.querySelector('.el-select__popper') as HTMLElement).style
2180
+ .display
2181
+ ).toBeFalsy()
2182
+ expect(wrapper.findAll('.el-select-dropdown__empty').length).toBe(0)
2183
+ })
2184
+
2185
+ test('multiple select with remote load', async () => {
2186
+ vi.useFakeTimers()
2187
+ wrapper = mount({
2188
+ template: `
2189
+ <el-select
2190
+ v-model="value"
2191
+ multiple
2192
+ filterable
2193
+ remote
2194
+ reserve-keyword
2195
+ placeholder="请输入关键词"
2196
+ :remote-method="remoteMethod"
2197
+ :loading="loading"
2198
+ >
2199
+ <el-option
2200
+ v-for="item in options"
2201
+ :key="item.value"
2202
+ :label="item.label"
2203
+ :value="item"
2204
+ />
2205
+ </el-select>`,
2206
+ components: { ElSelect: Select, ElOption: Option },
2207
+ data() {
2208
+ return {
2209
+ options: [],
2210
+ value: [],
2211
+ list: [],
2212
+ loading: false,
2213
+ states: [
2214
+ 'Alabama',
2215
+ 'Alaska',
2216
+ 'Arizona',
2217
+ 'Arkansas',
2218
+ 'California',
2219
+ 'Colorado',
2220
+ 'Connecticut',
2221
+ 'Delaware',
2222
+ 'Florida',
2223
+ 'Georgia',
2224
+ 'Hawaii',
2225
+ 'Idaho',
2226
+ 'Illinois',
2227
+ 'Indiana',
2228
+ 'Iowa',
2229
+ 'Kansas',
2230
+ 'Kentucky',
2231
+ 'Louisiana',
2232
+ 'Maine',
2233
+ 'Maryland',
2234
+ 'Massachusetts',
2235
+ 'Michigan',
2236
+ 'Minnesota',
2237
+ 'Mississippi',
2238
+ 'Missouri',
2239
+ 'Montana',
2240
+ 'Nebraska',
2241
+ 'Nevada',
2242
+ 'New Hampshire',
2243
+ 'New Jersey',
2244
+ 'New Mexico',
2245
+ 'New York',
2246
+ 'North Carolina',
2247
+ 'North Dakota',
2248
+ 'Ohio',
2249
+ 'Oklahoma',
2250
+ 'Oregon',
2251
+ 'Pennsylvania',
2252
+ 'Rhode Island',
2253
+ 'South Carolina',
2254
+ 'South Dakota',
2255
+ 'Tennessee',
2256
+ 'Texas',
2257
+ 'Utah',
2258
+ 'Vermont',
2259
+ 'Virginia',
2260
+ 'Washington',
2261
+ 'West Virginia',
2262
+ 'Wisconsin',
2263
+ 'Wyoming',
2264
+ ],
2265
+ }
2266
+ },
2267
+ mounted() {
2268
+ this.list = this.states.map((item) => {
2269
+ return { value: `value:${item}`, label: `label:${item}` }
2270
+ })
2271
+ },
2272
+ methods: {
2273
+ remoteMethod(query) {
2274
+ if (query !== '') {
2275
+ this.loading = true
2276
+ setTimeout(() => {
2277
+ this.loading = false
2278
+ this.options = this.list.filter((item) => {
2279
+ return item.label.toLowerCase().includes(query.toLowerCase())
2280
+ })
2281
+ }, 200)
2282
+ } else {
2283
+ this.options = []
2284
+ }
2285
+ },
2286
+ },
2287
+ })
2288
+
2289
+ const select = wrapper.findComponent({ name: 'ElSelect' }).vm
2290
+ select.onInput({
2291
+ target: {
2292
+ value: '',
2293
+ },
2294
+ })
2295
+
2296
+ select.onInput({
2297
+ target: {
2298
+ value: 'a',
2299
+ },
2300
+ })
2301
+ vi.runAllTimers()
2302
+ await nextTick()
2303
+ let options = getOptions()
2304
+ options[0].click()
2305
+ await nextTick()
2306
+ select.onInput({
2307
+ target: {
2308
+ value: 'n',
2309
+ },
2310
+ })
2311
+ vi.runAllTimers()
2312
+ await nextTick()
2313
+ options = getOptions()
2314
+ options[5].click()
2315
+ await nextTick()
2316
+ expect(select.states.selected.length === 2).toBeTruthy()
2317
+ expect(select.states.selected[0].currentLabel !== '').toBeTruthy()
2318
+ expect(select.states.selected[1].currentLabel !== '').toBeTruthy()
2319
+ vi.useRealTimers()
2320
+ })
2321
+
2322
+ test('disabled group', async () => {
2323
+ wrapper = _mount(
2324
+ `
2325
+ <el-select v-model="value">
2326
+ <el-group-option
2327
+ v-for="group in options"
2328
+ :key="group.label"
2329
+ :label="group.label"
2330
+ :disabled="group.disabled">
2331
+ <el-option
2332
+ v-for="item in group.options"
2333
+ :key="item.value"
2334
+ :label="item.label"
2335
+ :value="item.value">
2336
+ </el-option>
2337
+ </el-group-option>
2338
+ </el-select>`,
2339
+ () => ({
2340
+ options: [
2341
+ {
2342
+ label: 'Popular cities',
2343
+ options: [
2344
+ { value: 'Shanghai', label: 'Shanghai' },
2345
+ { value: 'Beijing', label: 'Beijing' },
2346
+ ],
2347
+ },
2348
+ {
2349
+ label: 'City name',
2350
+ options: [
2351
+ { value: 'Chengdu', label: 'Chengdu' },
2352
+ { value: 'Shenzhen', label: 'Shenzhen' },
2353
+ { value: 'Guangzhou', label: 'Guangzhou' },
2354
+ { value: 'Dalian', label: 'Dalian' },
2355
+ ],
2356
+ },
2357
+ ],
2358
+ value: '',
2359
+ })
2360
+ )
2361
+
2362
+ const vm = wrapper.vm as any
2363
+ wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2364
+ await nextTick()
2365
+ vm._.data.options[1].disabled = true
2366
+ await nextTick()
2367
+ const options = getOptions()
2368
+ expect(options[0].className).not.toContain('is-disabled')
2369
+ expect(options[2].className).toContain('is-disabled')
2370
+ options[0].click()
2371
+ await nextTick()
2372
+ expect(vm.value).toBe('Shanghai')
2373
+ options[2].click()
2374
+ await nextTick()
2375
+ expect(vm.value).toBe('Shanghai')
2376
+ })
2377
+
2378
+ test('el-option-group should visible when el-option in a component', async () => {
2379
+ const Options = defineComponent({
2380
+ components: {
2381
+ 'el-option': Option,
2382
+ },
2383
+ props: {
2384
+ options: {
2385
+ type: Array,
2386
+ default: () => [],
2387
+ },
2388
+ },
2389
+ template: `
2390
+ <el-option
2391
+ v-for="item in options"
2392
+ :key="item.value"
2393
+ :label="item.label"
2394
+ :value="item.value"
2395
+ />
2396
+ `,
2397
+ })
2398
+
2399
+ wrapper = mount({
2400
+ template: `
2401
+ <el-select v-model="value">
2402
+ <el-option-group
2403
+ v-for="group in options"
2404
+ :key="group.label"
2405
+ :label="group.label"
2406
+ >
2407
+ <Options :options="group.options" />
2408
+ </el-option-group>
2409
+ </el-select>
2410
+ `,
2411
+ components: {
2412
+ 'el-select': Select,
2413
+ 'el-option-group': Group,
2414
+ Options,
2415
+ },
2416
+ data() {
2417
+ return {
2418
+ value: '',
2419
+ options: [
2420
+ {
2421
+ label: 'Popular cities',
2422
+ options: [
2423
+ {
2424
+ value: 'Shanghai',
2425
+ label: 'Shanghai',
2426
+ },
2427
+ {
2428
+ value: 'Beijing',
2429
+ label: 'Beijing',
2430
+ },
2431
+ ],
2432
+ },
2433
+ ],
2434
+ }
2435
+ },
2436
+ })
2437
+
2438
+ expect(wrapper.findComponent(Group).vm.visible).toBe(true)
2439
+ })
2440
+
2441
+ test('el-option-group should visible when custom option component', async () => {
2442
+ const CustomOptions = defineComponent({
2443
+ components: {
2444
+ 'el-option': Option,
2445
+ },
2446
+ props: {
2447
+ label: {
2448
+ type: String,
2449
+ default: '',
2450
+ },
2451
+ value: {
2452
+ type: [String, Number],
2453
+ default: null,
2454
+ },
2455
+ },
2456
+ template: `
2457
+ <el-option
2458
+ :label="label"
2459
+ :value="value"
2460
+ >
2461
+ {{label}} - some extra text
2462
+ </el-option>
2463
+ `,
2464
+ })
2465
+
2466
+ wrapper = mount({
2467
+ template: `
2468
+ <el-select v-model="value">
2469
+ <el-option-group
2470
+ v-for="group in options"
2471
+ :key="group.label"
2472
+ :label="group.label"
2473
+ >
2474
+ <custom-options
2475
+ v-for="item in group.options"
2476
+ :key="item.value"
2477
+ :label="item.label"
2478
+ :value="item.value"
2479
+ />
2480
+ </el-option-group>
2481
+ </el-select>
2482
+ `,
2483
+ components: {
2484
+ 'el-select': Select,
2485
+ 'el-option-group': Group,
2486
+ CustomOptions,
2487
+ },
2488
+ data() {
2489
+ return {
2490
+ value: '',
2491
+ options: [
2492
+ {
2493
+ label: 'Popular cities',
2494
+ options: [
2495
+ {
2496
+ value: 'Shanghai',
2497
+ label: 'Shanghai',
2498
+ },
2499
+ {
2500
+ value: 'Beijing',
2501
+ label: 'Beijing',
2502
+ },
2503
+ ],
2504
+ },
2505
+ ],
2506
+ }
2507
+ },
2508
+ })
2509
+
2510
+ expect(wrapper.findComponent(Group).vm.visible).toBe(true)
2511
+ })
2512
+
2513
+ test('tag of disabled option is not closable', async () => {
2514
+ wrapper = _mount(
2515
+ `
2516
+ <el-select v-model="vendors" multiple :collapse-tags="isCollapsed" :clearable="isClearable" placeholder="Select Business Unit">
2517
+ <el-option
2518
+ v-for="(vendor, index) in options"
2519
+ :key="index"
2520
+ :value="index + 1"
2521
+ :label="vendor.name"
2522
+ :disabled="vendor.isDisabled"
2523
+ >
2524
+ </el-option>
2525
+ </el-select>`,
2526
+ () => ({
2527
+ vendors: [2, 3, 4],
2528
+ isCollapsed: false,
2529
+ isClearable: false,
2530
+ options: [
2531
+ { name: 'Test 1', isDisabled: false },
2532
+ { name: 'Test 2', isDisabled: true },
2533
+ { name: 'Test 3', isDisabled: false },
2534
+ { name: 'Test 4', isDisabled: true },
2535
+ ],
2536
+ })
2537
+ )
2538
+ const vm = wrapper.vm as any
2539
+ await nextTick()
2540
+ const selectVm = wrapper.findComponent({ name: 'ElSelect' }).vm as any
2541
+ expect(wrapper.findAll('.el-tag').length).toBe(3)
2542
+ const tagCloseIcons = wrapper.findAll('.el-tag__close')
2543
+ expect(tagCloseIcons.length).toBe(1)
2544
+ await tagCloseIcons[0].trigger('click')
2545
+ expect(wrapper.findAll('.el-tag__close').length).toBe(0)
2546
+ expect(wrapper.findAll('.el-tag').length).toBe(2)
2547
+
2548
+ //test if is clearable
2549
+ vm.isClearable = true
2550
+ vm.vendors = [2, 3, 4]
2551
+ await nextTick()
2552
+ selectVm.states.inputHovering = true
2553
+ await selectVm.$nextTick()
2554
+ const iconClear = wrapper.findComponent(CircleClose)
2555
+ expect(wrapper.findAll('.el-tag').length).toBe(3)
2556
+ await iconClear.trigger('click')
2557
+ expect(wrapper.findAll('.el-tag').length).toBe(2)
2558
+
2559
+ // test for collapse select
2560
+ vm.vendors = [1, 2, 4]
2561
+ vm.isCollapsed = true
2562
+ vm.isClearable = false
2563
+ await nextTick()
2564
+ expect(
2565
+ wrapper.findAll('.el-tag').filter((item) => {
2566
+ return !hasClass(item.element, 'in-tooltip')
2567
+ }).length
2568
+ ).toBe(2)
2569
+ await wrapper.find('.el-tag__close').trigger('click')
2570
+ expect(
2571
+ wrapper.findAll('.el-tag').filter((item) => {
2572
+ return !hasClass(item.element, 'in-tooltip')
2573
+ }).length
2574
+ ).toBe(2)
2575
+ expect(wrapper.findAll('.el-tag__close').length).toBe(0)
2576
+
2577
+ // test for collapse select if is clearable
2578
+ vm.vendors = [1, 2, 4]
2579
+ vm.isCollapsed = true
2580
+ vm.isClearable = true
2581
+ await nextTick()
2582
+ expect(
2583
+ wrapper.findAll('.el-tag__close').filter((item) => {
2584
+ return !hasClass(item.element.parentElement, 'in-tooltip')
2585
+ }).length
2586
+ ).toBe(1)
2587
+ await wrapper.find('.el-tag__close').trigger('click')
2588
+ expect(
2589
+ wrapper.findAll('.el-tag').filter((item) => {
2590
+ return !hasClass(item.element, 'in-tooltip')
2591
+ }).length
2592
+ ).toBe(2)
2593
+ expect(wrapper.findAll('.el-tag__close').length).toBe(0)
2594
+ })
2595
+
2596
+ test('tag type', async () => {
2597
+ wrapper = _mount(
2598
+ `
2599
+ <el-select v-model="value" multiple tag-type="success">
2600
+ <el-option
2601
+ v-for="item in options"
2602
+ :key="item.value"
2603
+ :label="item.label"
2604
+ :value="item.value"
2605
+ >
2606
+ </el-option>
2607
+ </el-select>
2608
+ `,
2609
+ () => ({
2610
+ options: [
2611
+ {
2612
+ value: '选项1',
2613
+ label: '黄金糕',
2614
+ },
2615
+ {
2616
+ value: '选项2',
2617
+ label: '双皮奶',
2618
+ },
2619
+ ],
2620
+ value: [],
2621
+ })
2622
+ )
2623
+
2624
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2625
+ const options = getOptions()
2626
+ options[1].click()
2627
+ await nextTick()
2628
+ expect(wrapper.find('.el-tag').classes()).toContain('el-tag--success')
2629
+ })
2630
+
2631
+ test('modelValue should be deep reactive in multiple mode', async () => {
2632
+ wrapper = _mount(
2633
+ `
2634
+ <el-select v-model="modelValue" multiple>
2635
+ <el-option
2636
+ v-for="option in options"
2637
+ :key="option.value"
2638
+ :value="option.value"
2639
+ :label="option.label"
2640
+ >
2641
+ </el-option>
2642
+ </el-select>`,
2643
+ () => ({
2644
+ modelValue: [1],
2645
+ options: [
2646
+ { label: 'Test 1', value: 1 },
2647
+ { label: 'Test 2', value: 2 },
2648
+ { label: 'Test 3', value: 3 },
2649
+ { label: 'Test 4', value: 4 },
2650
+ ],
2651
+ })
2652
+ )
2653
+ const vm = wrapper.vm as any
2654
+ await nextTick()
2655
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
2656
+
2657
+ vm._.data.modelValue.splice(0, 1)
2658
+
2659
+ await nextTick()
2660
+ expect(wrapper.findAll('.el-tag').length).toBe(0)
2661
+ })
2662
+
2663
+ test('should reset placeholder after clear when both multiple and filterable are true', async () => {
2664
+ const placeholder = 'placeholder'
2665
+ wrapper = _mount(
2666
+ `
2667
+ <el-select v-model="modelValue" multiple filterable placeholder=${placeholder}>
2668
+ <el-option label="1" value="1" />
2669
+ </el-select>`,
2670
+ () => ({
2671
+ modelValue: ['1'],
2672
+ })
2673
+ )
2674
+ await nextTick()
2675
+
2676
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).exists()).toBe(false)
2677
+
2678
+ const tagCloseIcon = wrapper.find('.el-tag__close')
2679
+ await tagCloseIcon.trigger('click')
2680
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(placeholder)
2681
+
2682
+ const input = wrapper.find('input')
2683
+ await input.setValue('a')
2684
+ await nextTick()
2685
+
2686
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).exists()).toBe(false)
2687
+ await input.setValue('')
2688
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(placeholder)
2689
+ })
2690
+
2691
+ test('should close popper when click icon twice', async () => {
2692
+ wrapper = getSelectVm({
2693
+ filterable: true,
2694
+ clearable: true,
2695
+ })
2696
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2697
+ const trigger = wrapper.find('.el-select__suffix')
2698
+ await trigger.trigger('click')
2699
+ expect((select.vm as any).expanded).toBe(true)
2700
+ await trigger.trigger('click')
2701
+ expect((select.vm as any).expanded).toBe(false)
2702
+ })
2703
+
2704
+ test('mouseenter click', async () => {
2705
+ wrapper = getSelectVm({
2706
+ filterable: false,
2707
+ clearable: true,
2708
+ })
2709
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2710
+ const trigger = wrapper.find(`.${WRAPPER_CLASS_NAME}`)
2711
+ await trigger.trigger('click')
2712
+ expect((select.vm as any).expanded).toBe(true)
2713
+
2714
+ await trigger.trigger('click')
2715
+ expect((select.vm as any).expanded).toBe(false)
2716
+ })
2717
+
2718
+ test('should keep the select dropdown open when using the filterable', async () => {
2719
+ wrapper = getSelectVm({
2720
+ filterable: true,
2721
+ clearable: true,
2722
+ })
2723
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2724
+ const trigger = wrapper.find(`.${WRAPPER_CLASS_NAME}`)
2725
+ await trigger.trigger('click')
2726
+ expect((select.vm as any).expanded).toBe(true)
2727
+
2728
+ await trigger.trigger('click')
2729
+ expect((select.vm as any).expanded).toBe(true)
2730
+ })
2731
+
2732
+ describe('should show all options when open select dropdown', () => {
2733
+ async function testShowOptions({ filterable, multiple }: SelectProps = {}) {
2734
+ wrapper = getSelectVm({ filterable, multiple })
2735
+ const options = wrapper.findAllComponents({ name: 'ElOption' })
2736
+
2737
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2738
+ expect(options.every((option) => option.vm.visible)).toBe(true)
2739
+
2740
+ await options[1].trigger('click')
2741
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2742
+ expect(options.every((option) => option.vm.visible)).toBe(true)
2743
+ }
2744
+
2745
+ test('both filterable and multiple are false', async () => {
2746
+ await testShowOptions()
2747
+ })
2748
+
2749
+ test('filterable is true and multiple is false', async () => {
2750
+ await testShowOptions({ filterable: true })
2751
+ })
2752
+
2753
+ test('filterable is false and multiple is true', async () => {
2754
+ await testShowOptions({ multiple: true })
2755
+ })
2756
+
2757
+ test('both filterable and multiple are true', async () => {
2758
+ await testShowOptions({ filterable: true, multiple: true })
2759
+ })
2760
+
2761
+ test('filterable is true with grouping', async () => {
2762
+ wrapper = getGroupSelectVm({ filterable: true })
2763
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
2764
+ const vm = wrapper.findComponent(Select).vm
2765
+ const event = { target: { value: 'sh' } }
2766
+ vm.onInput(event)
2767
+ await nextTick()
2768
+ const groups = wrapper.findAllComponents(Group)
2769
+ expect(
2770
+ groups.filter((group) => {
2771
+ const vm = group.vm as any
2772
+ return vm.visible
2773
+ }).length
2774
+ ).toBe(1)
2775
+ })
2776
+ })
2777
+
2778
+ describe('after search', () => {
2779
+ async function testAfterSearch({
2780
+ multiple,
2781
+ filterMethod,
2782
+ remote,
2783
+ remoteMethod,
2784
+ }: SelectProps) {
2785
+ wrapper = getSelectVm({
2786
+ filterable: true,
2787
+ multiple,
2788
+ filterMethod,
2789
+ remote,
2790
+ remoteMethod,
2791
+ })
2792
+ const method = remote ? remoteMethod : filterMethod
2793
+ const firstInputLetter = 'a'
2794
+ const secondInputLetter = 'aa'
2795
+
2796
+ await nextTick()
2797
+ await wrapper.trigger('mouseenter')
2798
+
2799
+ const input = wrapper.find('input')
2800
+ await input.setValue(firstInputLetter)
2801
+ expect(method).toBeCalled()
2802
+ expect(method.mock.calls[0][0]).toBe(firstInputLetter)
2803
+
2804
+ await input.setValue(secondInputLetter)
2805
+ expect(method).toBeCalledTimes(2)
2806
+ expect(method.mock.calls[1][0]).toBe(secondInputLetter)
2807
+ }
2808
+
2809
+ test('should call filter method', async () => {
2810
+ const filterMethod = vi.fn()
2811
+ await testAfterSearch({ filterMethod })
2812
+ })
2813
+
2814
+ test('should call filter method in multiple mode', async () => {
2815
+ const filterMethod = vi.fn()
2816
+ await testAfterSearch({ multiple: true, filterMethod })
2817
+ })
2818
+
2819
+ test('should call remote method', async () => {
2820
+ const remoteMethod = vi.fn()
2821
+ await testAfterSearch({ remote: true, remoteMethod })
2822
+ })
2823
+
2824
+ test('should call remote method in multiple mode', async () => {
2825
+ const remoteMethod = vi.fn()
2826
+ await testAfterSearch({ multiple: true, remote: true, remoteMethod })
2827
+ })
2828
+ })
2829
+
2830
+ describe('teleported API', () => {
2831
+ it('should mount on popper container', async () => {
2832
+ expect(document.body.innerHTML).toBe('')
2833
+ wrapper = _mount(
2834
+ `
2835
+ <el-select v-model="modelValue" multiple>
2836
+ <el-option
2837
+ v-for="option in options"
2838
+ :key="option.value"
2839
+ :value="option.value"
2840
+ :label="option.label"
2841
+ >
2842
+ </el-option>
2843
+ </el-select>`,
2844
+ () => ({
2845
+ modelValue: [1],
2846
+ options: [
2847
+ { label: 'Test 1', value: 1 },
2848
+ { label: 'Test 2', value: 2 },
2849
+ { label: 'Test 3', value: 3 },
2850
+ { label: 'Test 4', value: 4 },
2851
+ ],
2852
+ })
2853
+ )
2854
+
2855
+ await nextTick()
2856
+ const { selector } = wrapper.vm
2857
+ expect(document.body.querySelector(selector).innerHTML).not.toBe('')
2858
+ })
2859
+
2860
+ it('should not mount on the popper container', async () => {
2861
+ expect(document.body.innerHTML).toBe('')
2862
+ wrapper = _mount(
2863
+ `
2864
+ <el-select v-model="modelValue" multiple :teleported="false">
2865
+ <el-option
2866
+ v-for="option in options"
2867
+ :key="option.value"
2868
+ :value="option.value"
2869
+ :label="option.label"
2870
+ >
2871
+ </el-option>
2872
+ </el-select>`,
2873
+ () => ({
2874
+ modelValue: [1],
2875
+ options: [
2876
+ { label: 'Test 1', value: 1 },
2877
+ { label: 'Test 2', value: 2 },
2878
+ { label: 'Test 3', value: 3 },
2879
+ { label: 'Test 4', value: 4 },
2880
+ ],
2881
+ })
2882
+ )
2883
+
2884
+ await nextTick()
2885
+ const { selector } = wrapper.vm
2886
+ expect(document.body.querySelector(selector).innerHTML).toBe('')
2887
+ })
2888
+ })
2889
+
2890
+ it('multiple select has an initial value', async () => {
2891
+ const options = [{ value: `value:Alaska`, label: `label:Alaska` }]
2892
+ const modelValue = [{ value: `value:Alaska`, label: `label:Alaska` }]
2893
+ const wrapper = _mount(
2894
+ `
2895
+ <el-select v-model="modelValue"
2896
+ multiple
2897
+ value-key="value"
2898
+ filterable>
2899
+ <el-option
2900
+ v-for="option in options"
2901
+ :key="option.value"
2902
+ :value="option.value"
2903
+ :label="option.label"
2904
+ >
2905
+ </el-option>
2906
+ </el-select>`,
2907
+ () => ({
2908
+ modelValue,
2909
+ options,
2910
+ })
2911
+ )
2912
+ const select = wrapper.findComponent({ name: 'ElSelect' }).vm
2913
+ expect(select.states.selected[0].currentLabel).toBe(options[0].label)
2914
+ })
2915
+
2916
+ test('should reset selectedLabel when toggle multiple', async () => {
2917
+ wrapper = getSelectVm({ multiple: false })
2918
+ const select = wrapper.findComponent({ name: 'ElSelect' })
2919
+ const vm = wrapper.vm as any
2920
+ const selectVm = select.vm as any
2921
+ vm.value = '选项1'
2922
+ await nextTick()
2923
+ expect(selectVm.states.selectedLabel).toBe('黄金糕')
2924
+ vm.multiple = true
2925
+ vm.value = []
2926
+ await nextTick()
2927
+ expect(selectVm.states.selectedLabel).toBe('')
2928
+ })
2929
+
2930
+ test('should modify size height change', async () => {
2931
+ // no need to calculate input height
2932
+ })
2933
+
2934
+ describe('form item accessibility integration', () => {
2935
+ it('automatic id attachment', async () => {
2936
+ const wrapper = _mount(
2937
+ `<el-form-item label="Foobar" data-test-ref="item">
2938
+ <el-select v-model="modelValue">
2939
+ <el-option label="1" value="1" />
2940
+ </el-select>
2941
+ </el-form-item>`,
2942
+ () => ({
2943
+ modelValue: 1,
2944
+ })
2945
+ )
2946
+
2947
+ await nextTick()
2948
+ const formItem = wrapper.find('[data-test-ref="item"]')
2949
+ const formItemLabel = formItem.find('.el-form-item__label')
2950
+ const innerInput = wrapper.find('input')
2951
+ expect(formItem.attributes().role).toBeFalsy()
2952
+ expect(formItemLabel.attributes().for).toBe(innerInput.attributes().id)
2953
+ })
2954
+
2955
+ it('specified id attachment', async () => {
2956
+ const wrapper = _mount(
2957
+ `<el-form-item label="Foobar" data-test-ref="item">
2958
+ <el-select id="foobar" v-model="modelValue">
2959
+ <el-option label="1" value="1" />
2960
+ </el-select>
2961
+ </el-form-item>`,
2962
+ () => ({
2963
+ modelValue: 1,
2964
+ })
2965
+ )
2966
+
2967
+ await nextTick()
2968
+ const formItem = wrapper.find('[data-test-ref="item"]')
2969
+ const formItemLabel = formItem.find('.el-form-item__label')
2970
+ const innerInput = wrapper.find('input')
2971
+ expect(formItem.attributes().role).toBeFalsy()
2972
+ expect(innerInput.attributes().id).toBe('foobar')
2973
+ expect(formItemLabel.attributes().for).toBe(innerInput.attributes().id)
2974
+ })
2975
+
2976
+ it('form item role is group when multiple inputs', async () => {
2977
+ const wrapper = _mount(
2978
+ `<el-form-item label="Foobar" data-test-ref="item">
2979
+ <el-select v-model="modelValue">
2980
+ <el-option label="1" value="1" />
2981
+ </el-select>
2982
+ <el-select v-model="modelValue">
2983
+ <el-option label="1" value="1" />
2984
+ </el-select>
2985
+ </el-form-item>`,
2986
+ () => ({
2987
+ modelValue: 1,
2988
+ })
2989
+ )
2990
+
2991
+ await nextTick()
2992
+ const formItem = wrapper.find('[data-test-ref="item"]')
2993
+ expect(formItem.attributes().role).toBe('group')
2994
+ })
2995
+
2996
+ it('The disabled state of a component has higher priority than that of a form', async () => {
2997
+ const wrapper = _mount(
2998
+ `<el-form disabled>
2999
+ <el-select :disabled="false" v-model="modelValue">
3000
+ <el-option label="1" value="1" />
3001
+ </el-select>
3002
+ </el-form>`,
3003
+ () => ({
3004
+ modelValue: 1,
3005
+ })
3006
+ )
3007
+
3008
+ await nextTick()
3009
+ const innerInput = wrapper.find('.el-select__input')
3010
+ expect(innerInput.attributes('disabled')).toBeUndefined()
3011
+ })
3012
+ })
3013
+
3014
+ // fix: 8544
3015
+ it('When props are changed, label can be displayed correctly after selecting operation', async () => {
3016
+ wrapper = getGroupSelectVm({}, [
3017
+ {
3018
+ label: 'group1',
3019
+ options: [
3020
+ { value: 0, label: 'x' },
3021
+ { value: 1, label: 'y' },
3022
+ { value: 2, label: 'z' },
3023
+ ],
3024
+ },
3025
+ ])
3026
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
3027
+ let options = getOptions()
3028
+ const vm = wrapper.vm as any
3029
+ expect(vm.value).toBe('')
3030
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(
3031
+ DEFAULT_PLACEHOLDER
3032
+ )
3033
+ await nextTick()
3034
+ options[1].click()
3035
+ await nextTick()
3036
+ expect(vm.value).toBe(1)
3037
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('y')
3038
+ wrapper.vm.options = [
3039
+ {
3040
+ label: 'group2',
3041
+ options: [
3042
+ { value: 0, label: 'x' },
3043
+ { value: 1, label: 'y' },
3044
+ { value: 2, label: 'z' },
3045
+ ],
3046
+ },
3047
+ ]
3048
+
3049
+ await nextTick()
3050
+ options = getOptions()
3051
+ options[1].click()
3052
+ await nextTick()
3053
+ expect(vm.value).toBe(1)
3054
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('y')
3055
+ options[2].click()
3056
+ await nextTick()
3057
+ expect(vm.value).toBe(2)
3058
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('z')
3059
+ })
3060
+
3061
+ it('should update selected data when the options prop is changed and the select is focused', async () => {
3062
+ const options = [
3063
+ {
3064
+ value: '1',
3065
+ label: 'option 1',
3066
+ },
3067
+ {
3068
+ value: '2',
3069
+ label: 'option 2',
3070
+ },
3071
+ {
3072
+ value: '3',
3073
+ label: 'option 3',
3074
+ },
3075
+ ]
3076
+
3077
+ const wrapper = getSelectVm()
3078
+ const vm = wrapper.vm
3079
+ const input = wrapper.find('input')
3080
+ const nativeInput = input.element
3081
+
3082
+ await wrapper.setProps({ modelValue: '1' })
3083
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toEqual('1')
3084
+
3085
+ nativeInput.focus()
3086
+ vm.options = options
3087
+ await nextTick()
3088
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toEqual(
3089
+ 'option 1'
3090
+ )
3091
+
3092
+ vm.options = []
3093
+ await wrapper.setProps({ modelValue: ['1'] })
3094
+ await wrapper.setProps({ multiple: true })
3095
+
3096
+ nativeInput.focus()
3097
+ vm.options = options
3098
+ await nextTick()
3099
+ expect(wrapper.findAll('.el-tag')[0].text()).toBe('option 1')
3100
+ })
3101
+
3102
+ // fix: https://github.com/element-plus/element-plus/issues/11991
3103
+ it('backspace key should delete selected tag but should not delete disabled options', async () => {
3104
+ const options = [
3105
+ {
3106
+ value: 'Option1',
3107
+ label: 'Option1',
3108
+ disable: true,
3109
+ },
3110
+ {
3111
+ value: 'Option2',
3112
+ label: 'Option2',
3113
+ disable: false,
3114
+ },
3115
+ ]
3116
+ const value = ['Option2', 'Option1']
3117
+ const wrapper = _mount(
3118
+ `
3119
+ <el-select v-model="value"
3120
+ multiple
3121
+ filterable
3122
+ >
3123
+ <el-option
3124
+ v-for="option in options"
3125
+ :key="option.value"
3126
+ :value="option.value"
3127
+ :label="option.label"
3128
+ :disabled="option.disable"
3129
+ >
3130
+ </el-option>
3131
+ </el-select>
3132
+ `,
3133
+ () => ({
3134
+ value,
3135
+ options,
3136
+ })
3137
+ )
3138
+ await nextTick()
3139
+ const selectInput = wrapper.find('.el-select__input')
3140
+ expect(wrapper.findAll('.el-tag').length).toBe(2)
3141
+ // after deletion, an el-tag will be deleted
3142
+ await selectInput.trigger('keydown', {
3143
+ code: EVENT_CODE.backspace,
3144
+ key: EVENT_CODE.backspace,
3145
+ })
3146
+ await nextTick()
3147
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
3148
+ await selectInput.trigger('keydown', {
3149
+ code: EVENT_CODE.backspace,
3150
+ key: EVENT_CODE.backspace,
3151
+ })
3152
+ await nextTick()
3153
+ // after deletion, an el-tag still exist
3154
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
3155
+ })
3156
+
3157
+ it('should render label slot with index', async () => {
3158
+ const wrapper = _mount(
3159
+ `
3160
+ <el-select :model-value="'foo'">
3161
+ <el-option
3162
+ label="foo"
3163
+ value="foo"
3164
+ >
3165
+ </el-option>
3166
+ <template #label="{ label, index }">{{ label }} = {{ index }}</template>
3167
+ </el-select>
3168
+ `
3169
+ )
3170
+ await nextTick()
3171
+ const placeholder = wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()
3172
+ expect(placeholder).toBe('foo = 0')
3173
+ })
3174
+
3175
+ it('should label slot render dynamic index', async () => {
3176
+ const value = ref(['Option1'])
3177
+ const options = ref([
3178
+ {
3179
+ value: 'Option1',
3180
+ label: 'Label1',
3181
+ },
3182
+ {
3183
+ value: 'Option2',
3184
+ label: 'Label2',
3185
+ },
3186
+ ])
3187
+ const wrapper = _mount(
3188
+ `
3189
+ <el-select v-model="value" multiple>
3190
+ <el-option
3191
+ v-for="option in options"
3192
+ :key="option.value"
3193
+ :value="option.value"
3194
+ :label="option.label"
3195
+ />
3196
+ <template #label="{ label, index }">{{ label }} = {{ index }}</template>
3197
+ </el-select>
3198
+ `,
3199
+ () => ({
3200
+ value,
3201
+ options,
3202
+ })
3203
+ )
3204
+ await nextTick()
3205
+ const tag = wrapper.find('.el-tag')
3206
+ expect(tag.text()).toBe('Label1 = 0')
3207
+ options.value.shift()
3208
+ await nextTick()
3209
+ expect(tag.text()).toBe('Label1 = -1')
3210
+ options.value.push({ value: 'Option3', label: 'Label3' })
3211
+ await nextTick()
3212
+ value.value.push('Option2', 'Option3')
3213
+ await nextTick()
3214
+ const tags = wrapper.findAll('.el-tag')
3215
+ expect(tags[1].text()).toBe('Label2 = 0')
3216
+ expect(tags[2].text()).toBe('Label3 = 1')
3217
+ })
3218
+
3219
+ it('should ensure that isDisabled is fresh to prevent selected tag from being cleared', async () => {
3220
+ const disabled = ref(false)
3221
+ const wrapper = _mount(
3222
+ `
3223
+ <el-select v-model="value" multiple clearable>
3224
+ <el-option
3225
+ label="foo"
3226
+ value="foo"
3227
+ :disabled="disabled"
3228
+ >
3229
+ </el-option>
3230
+ </el-select>
3231
+ `,
3232
+ () => ({
3233
+ value: ['foo'],
3234
+ disabled,
3235
+ })
3236
+ )
3237
+ disabled.value = true
3238
+ const selectVm = wrapper.findComponent({ name: 'ElSelect' }).vm
3239
+ selectVm.states.inputHovering = true
3240
+ await nextTick()
3241
+ const iconClear = wrapper.findComponent(CircleClose)
3242
+ await iconClear.trigger('click')
3243
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
3244
+ const selectInput = wrapper.find('.el-select__input')
3245
+ await selectInput.trigger('keydown', {
3246
+ code: EVENT_CODE.backspace,
3247
+ key: EVENT_CODE.backspace,
3248
+ })
3249
+ await nextTick()
3250
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
3251
+ await selectInput.trigger('keydown', {
3252
+ code: EVENT_CODE.enter,
3253
+ key: EVENT_CODE.enter,
3254
+ })
3255
+ await nextTick()
3256
+ expect(wrapper.findAll('.el-tag').length).toBe(1)
3257
+ })
3258
+
3259
+ it('should return slot tag data correctly & dont have tag component', async () => {
3260
+ const value = [1, 3, 5]
3261
+ const wrapper = _mount(
3262
+ `
3263
+ <el-select v-model="value" multiple>
3264
+ <el-option v-for="option in options" :value="option.value" :label="option.label"></el-option>
3265
+ <template #tag="{ data }">
3266
+ <span v-for="option in data" class="no-tag" :key="option.value">
3267
+ {{ option.value }} - {{ option.currentLabel }}
3268
+ </span>
3269
+ </template>
3270
+ </el-select>
3271
+ `,
3272
+ () => ({
3273
+ value,
3274
+ multiple: true,
3275
+ options: [
3276
+ { label: 'Test 1', value: 1 },
3277
+ { label: 'Test 2', value: 2 },
3278
+ { label: 'Test 3', value: 3 },
3279
+ { label: 'Test 4', value: 4 },
3280
+ { label: 'Test 5', value: 5 },
3281
+ ],
3282
+ })
3283
+ )
3284
+ await nextTick()
3285
+ const slotTagEls = wrapper.findAll('.no-tag')
3286
+ expect(slotTagEls).toHaveLength(3)
3287
+ expect(wrapper.find('.el-tag').exists()).toBe(false)
3288
+ slotTagEls.forEach((el, idx) => {
3289
+ expect(el.text()).toBe(`${value[idx]} - Test ${value[idx]}`)
3290
+ })
3291
+ })
3292
+
3293
+ it('should expose delete-tag through slot & be able to delete a value', async () => {
3294
+ const wrapper = _mount(
3295
+ `
3296
+ <el-select v-model="value" multiple>
3297
+ <el-option v-for="option in options" :value="option.value" :label="option.label"></el-option>
3298
+ <template #tag="{ data, deleteTag }">
3299
+ <span v-for="option in data" class="no-tag" :key="option.value" @click="deleteTag($event, option)">
3300
+ {{ option.value }} - {{ option.currentLabel }}
3301
+ </span>
3302
+ </template>
3303
+ </el-select>
3304
+ `,
3305
+ () => ({
3306
+ value: [2, 3, 5],
3307
+ multiple: true,
3308
+ options: [
3309
+ { label: 'Test 1', value: 1 },
3310
+ { label: 'Test 2', value: 2 },
3311
+ { label: 'Test 3', value: 3 },
3312
+ { label: 'Test 4', value: 4 },
3313
+ { label: 'Test 5', value: 5 },
3314
+ ],
3315
+ })
3316
+ )
3317
+ await nextTick()
3318
+ const slotTagEls = wrapper.findAll('.no-tag')
3319
+ expect(slotTagEls).toHaveLength(3)
3320
+ expect(wrapper.vm.value).toEqual([2, 3, 5])
3321
+
3322
+ await slotTagEls[0].trigger('click')
3323
+ expect(wrapper.findAll('.no-tag')).toHaveLength(2)
3324
+ expect(wrapper.vm.value).toEqual([3, 5])
3325
+ })
3326
+
3327
+ it('It should generate accessible attributes', async () => {
3328
+ wrapper = _mount(
3329
+ `<el-select v-model="value">
3330
+ <el-option label="label" value="1" />
3331
+ <el-option label="disabled" value="2" disabled />
3332
+ </el-select>`,
3333
+ () => ({ value: '1' })
3334
+ )
3335
+
3336
+ const dropdown = wrapper.findComponent({ name: 'ElSelectDropdown' })
3337
+ const input = wrapper.find('input')
3338
+ const list = dropdown.find('.el-select-dropdown__list')
3339
+ const option = dropdown.find('.el-select-dropdown__item')
3340
+ const disabledOption = dropdown.find(
3341
+ '.el-select-dropdown__item:nth-child(2)'
3342
+ )
3343
+
3344
+ expect(input.attributes('role')).toBe('combobox')
3345
+ expect(input.attributes('tabindex')).toBe('0')
3346
+ expect(input.attributes('aria-autocomplete')).toBe('none')
3347
+ expect(input.attributes('aria-controls')).toBe(list.attributes('id'))
3348
+ expect(input.attributes('aria-expanded')).toBe('false')
3349
+ expect(input.attributes('aria-haspopup')).toBe('listbox')
3350
+ expect(input.attributes('aria-activedescendant')).toBe('')
3351
+
3352
+ expect(list.attributes('id')).toBeTruthy()
3353
+ expect(list.attributes('role')).toBe('listbox')
3354
+ expect(list.attributes('aria-orientation')).toBe('vertical')
3355
+
3356
+ expect(option.attributes('id')).toBeTruthy()
3357
+ expect(option.attributes('role')).toBe('option')
3358
+ expect(option.attributes('aria-disabled')).toBe(undefined)
3359
+ expect(option.attributes('aria-selected')).toBe('true')
3360
+ expect(disabledOption.attributes('aria-disabled')).toBe('true')
3361
+ })
3362
+
3363
+ it('tabindex', async () => {
3364
+ wrapper = _mount(
3365
+ `<el-select v-model="value" tabindex="1">
3366
+ <el-option label="label" value="1" />
3367
+ <el-option label="disabled" value="2" disabled />
3368
+ </el-select>`,
3369
+ () => ({ value: '1' })
3370
+ )
3371
+
3372
+ const input = wrapper.find('input')
3373
+ expect(input.attributes('tabindex')).toBe('1')
3374
+ })
3375
+
3376
+ it('should be trigger the click event', async () => {
3377
+ const handleClick = vi.fn()
3378
+ const wrapper = _mount(`<el-select @click="handleClick" />`, () => ({
3379
+ handleClick,
3380
+ }))
3381
+
3382
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
3383
+ expect(handleClick).toHaveBeenCalledOnce()
3384
+ })
3385
+
3386
+ test('should be run normally when switching multiple', async () => {
3387
+ wrapper = getSelectVm({ multiple: false })
3388
+ const vm = wrapper.vm as any
3389
+
3390
+ await (vm.value = undefined)
3391
+ await (vm.multiple = true)
3392
+ await (vm.multiple = false)
3393
+ expect(vm.value).toBe(undefined)
3394
+ })
3395
+
3396
+ // case #18022
3397
+ it('should be do not expend options when select is disabled', async () => {
3398
+ const value = null
3399
+ const wrapper = _mount(
3400
+ `
3401
+ <el-select v-model="value"
3402
+ filterable
3403
+ automatic-dropdown
3404
+ disabled
3405
+ >
3406
+ <el-option value="1">1</el-option>
3407
+ <el-option value="2">2</el-option>
3408
+ </el-select>
3409
+ `,
3410
+ () => ({
3411
+ value,
3412
+ })
3413
+ )
3414
+ await nextTick()
3415
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('focus')
3416
+ await nextTick()
3417
+ expect(
3418
+ (document.querySelector('.el-select__popper') as HTMLElement).style
3419
+ .display
3420
+ ).toBe('none')
3421
+ })
3422
+
3423
+ describe('check default first option after input', () => {
3424
+ it('defalut', async () => {
3425
+ vi.useFakeTimers()
3426
+ wrapper = getSelectVm({
3427
+ filterable: true,
3428
+ defaultFirstOption: true,
3429
+ })
3430
+
3431
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3432
+ const selectVm = select.vm as any
3433
+ const input = wrapper.find('input')
3434
+ input.element.focus()
3435
+
3436
+ selectVm.onInput({
3437
+ target: {
3438
+ value: '蚵仔煎',
3439
+ },
3440
+ })
3441
+
3442
+ vi.runAllTimers()
3443
+ await nextTick()
3444
+ expect(selectVm.states.hoveringIndex).toBe(2)
3445
+
3446
+ vi.useRealTimers()
3447
+ })
3448
+
3449
+ it('with multiple', async () => {
3450
+ vi.useFakeTimers()
3451
+ wrapper = getSelectVm({
3452
+ multiple: true,
3453
+ filterable: true,
3454
+ defaultFirstOption: true,
3455
+ })
3456
+
3457
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3458
+ const selectVm = select.vm as any
3459
+ const input = wrapper.find('input')
3460
+ input.element.focus()
3461
+
3462
+ selectVm.onInput({
3463
+ target: {
3464
+ value: '蚵仔煎',
3465
+ },
3466
+ })
3467
+
3468
+ vi.runAllTimers()
3469
+ await nextTick()
3470
+ expect(selectVm.states.hoveringIndex).toBe(2)
3471
+
3472
+ vi.useRealTimers()
3473
+ })
3474
+
3475
+ it('the value is string with value-key', async () => {
3476
+ vi.useFakeTimers()
3477
+ wrapper = getSelectVm({
3478
+ filterable: true,
3479
+ defaultFirstOption: true,
3480
+ valueKey: 'label',
3481
+ })
3482
+
3483
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3484
+ const selectVm = select.vm as any
3485
+ const input = wrapper.find('input')
3486
+ input.element.focus()
3487
+
3488
+ selectVm.onInput({
3489
+ target: {
3490
+ value: '蚵仔煎',
3491
+ },
3492
+ })
3493
+
3494
+ vi.runAllTimers()
3495
+ await nextTick()
3496
+ expect(selectVm.states.hoveringIndex).toBe(2)
3497
+
3498
+ vi.useRealTimers()
3499
+ })
3500
+
3501
+ it('the value is object with value-key', async () => {
3502
+ vi.useFakeTimers()
3503
+ wrapper = _mount(
3504
+ `
3505
+ <el-select v-model="value" value-key="id" filterable default-first-option>
3506
+ <el-option
3507
+ v-for="item in options"
3508
+ :label="item.name"
3509
+ :key="item.id"
3510
+ :value="item">
3511
+ </el-option>
3512
+ </el-select>
3513
+ `,
3514
+ () => ({
3515
+ options: [
3516
+ {
3517
+ id: 1,
3518
+ name: '黄金糕',
3519
+ },
3520
+ {
3521
+ id: 2,
3522
+ name: '双皮奶',
3523
+ },
3524
+ {
3525
+ id: 3,
3526
+ name: '蚵仔煎',
3527
+ },
3528
+ ],
3529
+ value: null,
3530
+ })
3531
+ )
3532
+
3533
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3534
+ const selectVm = select.vm as any
3535
+ const input = wrapper.find('input')
3536
+ input.element.focus()
3537
+
3538
+ selectVm.onInput({
3539
+ target: {
3540
+ value: '蚵仔煎',
3541
+ },
3542
+ })
3543
+
3544
+ vi.runAllTimers()
3545
+ await nextTick()
3546
+ expect(selectVm.states.hoveringIndex).toBe(2)
3547
+
3548
+ vi.useRealTimers()
3549
+ })
3550
+
3551
+ // fix: 11930
3552
+ it('should work when options changed', async () => {
3553
+ vi.useFakeTimers()
3554
+
3555
+ const wrapper = _mount(
3556
+ `
3557
+ <el-select v-model="value" filterable remote default-first-option :remoteMethod="remoteMethod">
3558
+ <el-option
3559
+ v-for="option in options"
3560
+ :key="option.value"
3561
+ :value="option.value"
3562
+ :label="option.label"
3563
+ />
3564
+ </el-select>
3565
+ `,
3566
+ () => ({
3567
+ value: '',
3568
+ options: [
3569
+ {
3570
+ value: 'a',
3571
+ label: 'a',
3572
+ },
3573
+ ],
3574
+ }),
3575
+ {
3576
+ methods: {
3577
+ remoteMethod() {
3578
+ setTimeout(() => {
3579
+ this.options = [
3580
+ {
3581
+ value: 0,
3582
+ label: 0,
3583
+ },
3584
+ ]
3585
+ }, 200)
3586
+ },
3587
+ },
3588
+ }
3589
+ )
3590
+
3591
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3592
+ const selectVm = select.vm as any
3593
+ const input = wrapper.find('input')
3594
+ input.element.focus()
3595
+
3596
+ vi.runAllTimers()
3597
+ await nextTick()
3598
+ let options = getOptions()
3599
+ expect(hasClass(options[0], 'is-hovering')).toBeTruthy()
3600
+
3601
+ selectVm.onInput({
3602
+ target: {
3603
+ value: '0',
3604
+ },
3605
+ })
3606
+
3607
+ vi.runAllTimers()
3608
+ await nextTick()
3609
+ options = getOptions()
3610
+ expect(hasClass(options[0], 'is-hovering')).toBeTruthy()
3611
+
3612
+ vi.useRealTimers()
3613
+ })
3614
+ })
3615
+
3616
+ it('should keep the selected label after filtering options', async () => {
3617
+ const initials = [
3618
+ {
3619
+ value: 'aa',
3620
+ label: 'label aa',
3621
+ },
3622
+ {
3623
+ value: 'bb',
3624
+ label: 'label bb',
3625
+ },
3626
+ ]
3627
+
3628
+ const wrapper = _mount(
3629
+ `
3630
+ <el-select v-model="value">
3631
+ <el-option
3632
+ v-for="option in options"
3633
+ :key="option.value"
3634
+ :value="option.value"
3635
+ :label="option.label"
3636
+ />
3637
+ </el-select>
3638
+ `,
3639
+ () => ({
3640
+ value: 'aa',
3641
+ options: initials,
3642
+ }),
3643
+ {
3644
+ methods: {
3645
+ handleSearch(val) {
3646
+ this.options = initials.filter((item) => item.label.includes(val))
3647
+ },
3648
+ },
3649
+ }
3650
+ )
3651
+
3652
+ await nextTick()
3653
+ const select = wrapper.findComponent(Select)
3654
+ const selectVm = select.vm as any
3655
+ const vm = wrapper.vm as any
3656
+
3657
+ expect(selectVm.selectedLabel).toBe('label aa')
3658
+
3659
+ const trigger = wrapper.find(`.${WRAPPER_CLASS_NAME}`)
3660
+ await trigger.trigger('mouseenter')
3661
+ await trigger.trigger('click')
3662
+ vm.handleSearch('bb')
3663
+
3664
+ await nextTick()
3665
+ expect(wrapper.vm.options.length).toBe(1)
3666
+ expect(selectVm.selectedLabel).toBe('label aa')
3667
+ vm.handleSearch('bbb')
3668
+
3669
+ await nextTick()
3670
+ expect(wrapper.vm.options.length).toBe(0)
3671
+ expect(selectVm.selectedLabel).toBe('label aa')
3672
+
3673
+ vm.value = 'bb'
3674
+ await nextTick()
3675
+ expect(selectVm.selectedLabel).toBe('bb')
3676
+
3677
+ vm.value = ''
3678
+ await nextTick()
3679
+ expect(selectVm.selectedLabel).toBe('')
3680
+ })
3681
+
3682
+ // #20905
3683
+ test('display correct when label is 0 or ""', async () => {
3684
+ wrapper = _mount(
3685
+ `
3686
+ <el-select>
3687
+ <el-option
3688
+ v-for="item in options"
3689
+ :label="item.label"
3690
+ :key="item.value"
3691
+ :value="item.value">
3692
+ </el-option>
3693
+ </el-select>
3694
+ `,
3695
+ () => ({
3696
+ options: [
3697
+ { value: '黄金糕', label: '' },
3698
+ { value: '双皮奶', label: 0 },
3699
+ { value: '蚵仔煎', label: '蚵仔煎' },
3700
+ { value: '北京烤鸭', label: undefined },
3701
+ ],
3702
+ })
3703
+ )
3704
+ await nextTick()
3705
+ const options = getOptions()
3706
+ expect(options[0].textContent).toBe('')
3707
+ expect(options[1].textContent).toBe('0')
3708
+ expect(options[2].textContent).toBe('蚵仔煎')
3709
+ expect(options[3].textContent).toBe('北京烤鸭')
3710
+ })
3711
+
3712
+ test('passes disabled prop to custom #tag slot', async () => {
3713
+ const wrapper = _mount(
3714
+ `
3715
+ <el-select
3716
+ v-model="value"
3717
+ multiple
3718
+ :disabled="isDisabled"
3719
+ >
3720
+ <el-option
3721
+ v-for="item in options"
3722
+ :key="item.value"
3723
+ :label="item.label"
3724
+ :value="item.value"
3725
+ />
3726
+ <template #tag="{ selectDisabled }">
3727
+ <span class="custom-tag">
3728
+ {{ selectDisabled ? 'selectDisabled' : 'enabled' }}
3729
+ </span>
3730
+ </template>
3731
+ </el-select>
3732
+ `,
3733
+ () => ({
3734
+ value: ['a', 'b'],
3735
+ isDisabled: true,
3736
+ options: [
3737
+ { value: 'a', label: 'A' },
3738
+ { value: 'b', label: 'B' },
3739
+ { value: 'c', label: 'C' },
3740
+ ],
3741
+ })
3742
+ )
3743
+
3744
+ await nextTick()
3745
+ expect(wrapper.find('.custom-tag').text()).toBe('selectDisabled')
3746
+
3747
+ await wrapper.setData({ isDisabled: false })
3748
+ expect(wrapper.find('.custom-tag').text()).toBe('enabled')
3749
+ })
3750
+
3751
+ test('disabled prop from el-form is passed to el-select and tag slot', async () => {
3752
+ const wrapper = _mount(
3753
+ `
3754
+ <el-form :disabled="formDisabled">
3755
+ <el-form-item label="Test Select">
3756
+ <el-select v-model="value" multiple>
3757
+ <el-option
3758
+ v-for="item in options"
3759
+ :key="item.value"
3760
+ :label="item.label"
3761
+ :value="item.value"
3762
+ />
3763
+ <template #tag="{ selectDisabled }">
3764
+ <span class="custom-tag">{{ selectDisabled ? 'selectDisabled' : 'enabled' }}</span>
3765
+ </template>
3766
+ </el-select>
3767
+ </el-form-item>
3768
+ </el-form>
3769
+ `,
3770
+ () => ({
3771
+ value: ['a'],
3772
+ formDisabled: true,
3773
+ options: [
3774
+ { value: 'a', label: 'Option A' },
3775
+ { value: 'b', label: 'Option B' },
3776
+ ],
3777
+ })
3778
+ )
3779
+
3780
+ await nextTick()
3781
+ expect(wrapper.find('.custom-tag').text()).toBe('selectDisabled')
3782
+
3783
+ await wrapper.setData({ formDisabled: false })
3784
+ expect(wrapper.find('.custom-tag').text()).toBe('enabled')
3785
+ })
3786
+
3787
+ test('renders options via props', async () => {
3788
+ wrapper = _mount(
3789
+ `<el-select v-model="value" @change="handleChange" :options="options"/>`,
3790
+ () => ({
3791
+ options: [
3792
+ {
3793
+ value: '选项1',
3794
+ label: '黄金糕',
3795
+ },
3796
+ {
3797
+ value: '选项2',
3798
+ label: '双皮奶',
3799
+ },
3800
+ {
3801
+ value: '选项3',
3802
+ label: '蚵仔煎',
3803
+ },
3804
+ {
3805
+ value: '选项4',
3806
+ label: '龙须面',
3807
+ },
3808
+ {
3809
+ value: '选项5',
3810
+ label: '北京烤鸭',
3811
+ },
3812
+ ],
3813
+ value: '',
3814
+ count: 0,
3815
+ }),
3816
+ {
3817
+ methods: {
3818
+ handleChange() {
3819
+ this.count++
3820
+ },
3821
+ },
3822
+ }
3823
+ )
3824
+
3825
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
3826
+ const options = getOptions()
3827
+ const vm = wrapper.vm as any
3828
+ expect(vm.value).toBe('')
3829
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(
3830
+ DEFAULT_PLACEHOLDER
3831
+ )
3832
+ options[2].click()
3833
+ await nextTick()
3834
+ expect(vm.value).toBe('选项3')
3835
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('蚵仔煎')
3836
+ expect(vm.count).toBe(1)
3837
+ options[4].click()
3838
+ await nextTick()
3839
+ expect(vm.value).toBe('选项5')
3840
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('北京烤鸭')
3841
+ expect(vm.count).toBe(2)
3842
+ })
3843
+
3844
+ test('renders options with custom field names', async () => {
3845
+ wrapper = _mount(
3846
+ `<el-select v-model="value" @change="handleChange" :options="options" :props="{
3847
+ value:'id'
3848
+ }"/>`,
3849
+ () => ({
3850
+ options: [
3851
+ {
3852
+ id: 1,
3853
+ label: '黄金糕',
3854
+ },
3855
+ {
3856
+ id: 2,
3857
+ label: '双皮奶',
3858
+ },
3859
+ {
3860
+ id: 3,
3861
+ label: '蚵仔煎',
3862
+ },
3863
+ {
3864
+ id: 4,
3865
+ label: '龙须面',
3866
+ },
3867
+ {
3868
+ id: 5,
3869
+ label: '北京烤鸭',
3870
+ },
3871
+ ],
3872
+ value: '',
3873
+ count: 0,
3874
+ }),
3875
+ {
3876
+ methods: {
3877
+ handleChange() {
3878
+ this.count++
3879
+ },
3880
+ },
3881
+ }
3882
+ )
3883
+
3884
+ await wrapper.find(`.${WRAPPER_CLASS_NAME}`).trigger('click')
3885
+ const options = getOptions()
3886
+ const vm = wrapper.vm as any
3887
+ expect(vm.value).toBe('')
3888
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe(
3889
+ DEFAULT_PLACEHOLDER
3890
+ )
3891
+ options[2].click()
3892
+ await nextTick()
3893
+ expect(vm.value).toBe(3)
3894
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('蚵仔煎')
3895
+ expect(vm.count).toBe(1)
3896
+ options[4].click()
3897
+ await nextTick()
3898
+ expect(vm.value).toBe(5)
3899
+ expect(wrapper.find(`.${PLACEHOLDER_CLASS_NAME}`).text()).toBe('北京烤鸭')
3900
+ expect(vm.count).toBe(2)
3901
+ })
3902
+
3903
+ test('loading appears on first click when remote', async () => {
3904
+ wrapper = _mount(
3905
+ `
3906
+ <el-select
3907
+ v-model="value"
3908
+ filterable
3909
+ remote
3910
+ :remote-method="remoteMethod"
3911
+ :loading="loading"
3912
+ >
3913
+ <el-option
3914
+ v-for="item in options"
3915
+ :key="item.value"
3916
+ :label="item.label"
3917
+ :value="item"
3918
+ />
3919
+ </el-select>`,
3920
+ () => ({
3921
+ options: [],
3922
+ value: '',
3923
+ loading: false,
3924
+ }),
3925
+ {
3926
+ methods: {
3927
+ remoteMethod() {
3928
+ this.loading = true
3929
+ setTimeout(() => {
3930
+ this.loading = false
3931
+ }, 1000)
3932
+ },
3933
+ },
3934
+ }
3935
+ )
3936
+
3937
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3938
+ const selectVm = select.vm as any
3939
+ const input = wrapper.find('input')
3940
+ await input.trigger('click')
3941
+ expect(selectVm.dropdownMenuVisible).toBeTruthy()
3942
+ })
3943
+
3944
+ test('should trigger scroll when option value is 0', async () => {
3945
+ wrapper = _mount(
3946
+ `
3947
+ <el-select v-model="value" :teleported="false">
3948
+ <el-option
3949
+ v-for="{ label, value } in options"
3950
+ :key="value"
3951
+ :label="label"
3952
+ :value="value"
3953
+ />
3954
+ </el-select>`,
3955
+ () => ({
3956
+ options: Array.from({ length: 10 }).map((_, i) => ({
3957
+ label: `label-${i}`,
3958
+ value: i,
3959
+ })),
3960
+ value: '',
3961
+ })
3962
+ )
3963
+
3964
+ const select = wrapper.findComponent({ name: 'ElSelect' })
3965
+ const selectVm = select.vm as any
3966
+ const wrapEl = wrapper.find('.el-select-dropdown__wrap').element
3967
+ const optionEls = wrapper.findAll('.el-select-dropdown__item')
3968
+ const cleanup = optionEls.map((item, i) =>
3969
+ vi.spyOn(item.element, 'offsetTop', 'get').mockReturnValue(i * 30)
3970
+ )
3971
+ cleanup.push(
3972
+ vi.spyOn(wrapEl, 'clientHeight', 'get').mockReturnValue(5 * 30)
3973
+ )
3974
+
3975
+ const input = wrapper.find('input')
3976
+ await input.trigger('click')
3977
+ await input.trigger('keydown', { key: EVENT_CODE.up })
3978
+ expect(selectVm.states.hoveringIndex).toBe(9)
3979
+ expect(wrapEl.scrollTop).toBe(4 * 30)
3980
+ await input.trigger('keydown', { key: EVENT_CODE.down })
3981
+ expect(selectVm.states.hoveringIndex).toBe(0)
3982
+ expect(wrapEl.scrollTop).toBe(0)
3983
+ cleanup.forEach((fn) => fn())
3984
+ })
3985
+
3986
+ test('keyboard navigation with Home, End, PageUp, PageDown', async () => {
3987
+ const options = Array.from({ length: 21 }).map((_, i) => ({
3988
+ value: `value-${i}`,
3989
+ label: `Option ${i}`,
3990
+ disabled: i === 0 || i === 10, // disable 10th options
3991
+ }))
3992
+
3993
+ const wrapper = _mount(
3994
+ `
3995
+ <el-select
3996
+ ref="select"
3997
+ v-model="value"
3998
+ filterable
3999
+ >
4000
+ <el-option
4001
+ v-for="item in options"
4002
+ :key="item.value"
4003
+ :label="item.label"
4004
+ :value="item.value"
4005
+ :disabled="item.disabled"
4006
+ />
4007
+ </el-select>
4008
+ `,
4009
+ () => ({
4010
+ value: '',
4011
+ options,
4012
+ })
4013
+ )
4014
+
4015
+ await nextTick()
4016
+ const vm = wrapper.vm as any
4017
+ const target = vm.$refs.select
4018
+ const input = wrapper.find('input')
4019
+ await input.trigger('focus')
4020
+ await input.trigger('keydown', { code: EVENT_CODE.down })
4021
+ await nextTick()
4022
+ await input.trigger('keydown', { code: EVENT_CODE.home })
4023
+ expect(target.states.hoveringIndex).toBe(1)
4024
+ await input.trigger('keydown', { code: EVENT_CODE.home })
4025
+ expect(target.states.hoveringIndex).toBe(1)
4026
+ await input.trigger('keydown', { code: EVENT_CODE.end })
4027
+ expect(target.states.hoveringIndex).toBe(20)
4028
+ await input.trigger('keydown', { code: EVENT_CODE.home })
4029
+ expect(target.states.hoveringIndex).toBe(1)
4030
+ await input.trigger('keydown', { code: EVENT_CODE.pageDown })
4031
+ expect(target.states.hoveringIndex).toBe(11)
4032
+ await input.trigger('keydown', { code: EVENT_CODE.pageDown })
4033
+ expect(target.states.hoveringIndex).toBe(20)
4034
+ await input.trigger('keydown', { code: EVENT_CODE.pageDown })
4035
+ expect(target.states.hoveringIndex).toBe(20)
4036
+ await input.trigger('keydown', { code: EVENT_CODE.pageUp })
4037
+ expect(target.states.hoveringIndex).toBe(9)
4038
+ await input.trigger('keydown', { code: EVENT_CODE.pageUp })
4039
+ expect(target.states.hoveringIndex).toBe(1)
4040
+ await input.trigger('keydown', { code: EVENT_CODE.pageUp })
4041
+ expect(target.states.hoveringIndex).toBe(1)
4042
+ })
4043
+
4044
+ test('should support selecting options with both Enter and Numpad Enter', async () => {
4045
+ const wrapper = _mount(
4046
+ `
4047
+ <el-select
4048
+ ref="select"
4049
+ v-model="value"
4050
+ filterable
4051
+ >
4052
+ <el-option
4053
+ v-for="item in options"
4054
+ :key="item.value"
4055
+ :label="item.label"
4056
+ :value="item.value"
4057
+ :disabled="item.disabled"
4058
+ />
4059
+ </el-select>
4060
+ `,
4061
+ () => ({
4062
+ options: Array.from({ length: 2 }).map((_, i) => ({
4063
+ label: `label-${i}`,
4064
+ value: i,
4065
+ })),
4066
+ value: '',
4067
+ })
4068
+ )
4069
+
4070
+ await nextTick()
4071
+ const vm = wrapper.vm as any
4072
+ const input = wrapper.find('input')
4073
+ await input.trigger('click')
4074
+ await input.trigger('keydown', { code: EVENT_CODE.down })
4075
+ await input.trigger('keydown', { code: EVENT_CODE.enter })
4076
+ expect(vm.value).toBe(0)
4077
+ await input.trigger('click')
4078
+ await input.trigger('keydown', { code: EVENT_CODE.down })
4079
+ await input.trigger('keydown', { code: EVENT_CODE.numpadEnter })
4080
+ expect(vm.value).toBe(1)
4081
+ })
4082
+
4083
+ test('hoveringIndex should stay on the most recently selected option when using multiple', async () => {
4084
+ wrapper = _mount(
4085
+ `<el-select
4086
+ v-model="value"
4087
+ clearable
4088
+ multiple
4089
+ >
4090
+ <el-option
4091
+ v-for="item in options"
4092
+ :label="item.label"
4093
+ :key="item.value"
4094
+ :value="item.value"
4095
+ />
4096
+ </el-select>`,
4097
+ () => ({
4098
+ options: [
4099
+ {
4100
+ value: 1,
4101
+ label: 'Option 1',
4102
+ },
4103
+ {
4104
+ value: 2,
4105
+ label: 'Option 2',
4106
+ },
4107
+ {
4108
+ value: 3,
4109
+ label: 'Option 3',
4110
+ },
4111
+ {
4112
+ value: 4,
4113
+ label: 'Option 4',
4114
+ },
4115
+ {
4116
+ value: 5,
4117
+ label: 'Option 5',
4118
+ },
4119
+ ],
4120
+ value: [1, 2],
4121
+ })
4122
+ )
4123
+
4124
+ const select = wrapper.findComponent({ name: 'ElSelect' })
4125
+ const selectVm = select.vm as any
4126
+ const input = wrapper.find('input')
4127
+
4128
+ await input.trigger('click')
4129
+ expect(selectVm.states.hoveringIndex).toBe(1)
4130
+ })
4131
+
4132
+ test('should locate the most recently selected option when using multiple', async () => {
4133
+ wrapper = _mount(
4134
+ `
4135
+ <el-select v-model="value" :teleported="false" multiple>
4136
+ <el-option
4137
+ v-for="{ label, value } in options"
4138
+ :key="value"
4139
+ :label="label"
4140
+ :value="value"
4141
+ />
4142
+ </el-select>`,
4143
+ () => ({
4144
+ options: Array.from({ length: 10 }).map((_, i) => ({
4145
+ label: `label-${i}`,
4146
+ value: i,
4147
+ })),
4148
+ value: [1, 9],
4149
+ })
4150
+ )
4151
+
4152
+ const wrapEl = wrapper.find('.el-select-dropdown__wrap').element
4153
+ const optionEls = wrapper.findAll('.el-select-dropdown__item')
4154
+ const cleanup = optionEls.map((item, i) =>
4155
+ vi.spyOn(item.element, 'offsetTop', 'get').mockReturnValue(i * 30)
4156
+ )
4157
+ cleanup.push(
4158
+ vi.spyOn(wrapEl, 'clientHeight', 'get').mockReturnValue(5 * 30)
4159
+ )
4160
+
4161
+ const input = wrapper.find('input')
4162
+ await input.trigger('click')
4163
+ expect(wrapEl.scrollTop).toBe(4 * 30)
4164
+ cleanup.forEach((fn) => fn())
4165
+ })
4166
+
4167
+ test('should restore warn handler after the last select unmounts', async () => {
4168
+ const warnHandler = vi.fn()
4169
+ const Parent = defineComponent({
4170
+ components: {
4171
+ 'el-select': Select,
4172
+ 'el-option': Option,
4173
+ },
4174
+ setup() {
4175
+ const showFirst = ref(true)
4176
+ const showSecond = ref(true)
4177
+ const value = ref('')
4178
+ const options = [
4179
+ { label: 'label-1', value: 1 },
4180
+ { label: 'label-2', value: 2 },
4181
+ ]
4182
+ const hideFirst = () => {
4183
+ showFirst.value = false
4184
+ }
4185
+ const hideSecond = () => {
4186
+ showSecond.value = false
4187
+ }
4188
+ return {
4189
+ showFirst,
4190
+ showSecond,
4191
+ value,
4192
+ options,
4193
+ hideFirst,
4194
+ hideSecond,
4195
+ }
4196
+ },
4197
+ template: `
4198
+ <div>
4199
+ <el-select v-if="showFirst" v-model="value">
4200
+ <el-option
4201
+ v-for="item in options"
4202
+ :key="item.value"
4203
+ :label="item.label"
4204
+ :value="item.value"
4205
+ />
4206
+ </el-select>
4207
+ <el-select v-if="showSecond" v-model="value">
4208
+ <el-option
4209
+ v-for="item in options"
4210
+ :key="item.value"
4211
+ :label="item.label"
4212
+ :value="item.value"
4213
+ />
4214
+ </el-select>
4215
+ </div>
4216
+ `,
4217
+ })
4218
+
4219
+ const wrapper = mount(Parent, {
4220
+ attachTo: 'body',
4221
+ global: {
4222
+ config: {
4223
+ warnHandler,
4224
+ },
4225
+ provide: {
4226
+ namespace: 'el',
4227
+ },
4228
+ },
4229
+ })
4230
+
4231
+ const appContext = (wrapper.vm.$ as any).appContext
4232
+
4233
+ expect(appContext.config.warnHandler).not.toBe(warnHandler)
4234
+
4235
+ wrapper.vm.hideFirst()
4236
+ await nextTick()
4237
+ expect(appContext.config.warnHandler).not.toBe(warnHandler)
4238
+
4239
+ wrapper.vm.hideSecond()
4240
+ await nextTick()
4241
+ expect(appContext.config.warnHandler).toBe(warnHandler)
4242
+
4243
+ wrapper.unmount()
4244
+ })
4245
+
4246
+ test('limitReached: hovering via DOM event should not update index nor add class', async () => {
4247
+ wrapper = _mount(
4248
+ `
4249
+ <el-select v-model="value" multiple :multiple-limit="1">
4250
+ <el-option v-for="o in options" :key="o.value" :label="o.label" :value="o.value" />
4251
+ </el-select>
4252
+ `,
4253
+ () => ({
4254
+ value: [],
4255
+ options: [
4256
+ { value: '选项1', label: '黄金糕' },
4257
+ { value: '选项2', label: '双皮奶' },
4258
+ { value: '选项3', label: '蚵仔煎' },
4259
+ ],
4260
+ })
4261
+ )
4262
+
4263
+ const selectVm = wrapper.findComponent({ name: 'ElSelect' }).vm as any
4264
+ await wrapper.find('.el-select__wrapper').trigger('click')
4265
+ await nextTick()
4266
+ const optionCmps = wrapper.findAllComponents({ name: 'ElOption' })
4267
+ await optionCmps[0].trigger('click')
4268
+ await nextTick()
4269
+ selectVm.states.hoveringIndex = 0
4270
+ const optionEls = getOptions()
4271
+ await optionCmps[1].trigger('mousemove')
4272
+ await nextTick()
4273
+ expect(selectVm.states.hoveringIndex).toBe(0)
4274
+ expect(Array.from(optionEls[1].classList)).not.toContain('is-hovering')
4275
+ })
4276
+
4277
+ test('should trigger visible-change when dropdownMenuVisible changes', async () => {
4278
+ const handleVisibleChange = vi.fn()
4279
+ wrapper = mount({
4280
+ template: `
4281
+ <el-select
4282
+ v-model="value"
4283
+ remote
4284
+ :remote-method="remoteMethod"
4285
+ :loading="loading"
4286
+ @visible-change="handleVisibleChange"
4287
+ >
4288
+ <el-option
4289
+ v-for="item in options"
4290
+ :key="item.value"
4291
+ :label="item.label"
4292
+ :value="item"
4293
+ />
4294
+ </el-select>`,
4295
+ components: { ElSelect: Select, ElOption: Option },
4296
+ data() {
4297
+ return {
4298
+ options: [],
4299
+ value: [],
4300
+ list: [],
4301
+ loading: false,
4302
+ states: ['Alabama', 'Alaska'],
4303
+ handleVisibleChange,
4304
+ }
4305
+ },
4306
+ mounted() {
4307
+ this.list = this.states.map((item) => {
4308
+ return { value: `value:${item}`, label: `label:${item}` }
4309
+ })
4310
+ },
4311
+ methods: {
4312
+ remoteMethod(query) {
4313
+ if (query !== '') {
4314
+ this.loading = true
4315
+ setTimeout(() => {
4316
+ this.loading = false
4317
+ this.options = this.list.filter((item) => {
4318
+ return item.label.toLowerCase().includes(query.toLowerCase())
4319
+ })
4320
+ }, 200)
4321
+ } else {
4322
+ this.options = []
4323
+ }
4324
+ },
4325
+ },
4326
+ })
4327
+
4328
+ const input = wrapper.find('input')
4329
+ await input.trigger('click')
4330
+ expect(handleVisibleChange).not.toHaveBeenCalled()
4331
+ await input.setValue('label:Alabama')
4332
+ expect(handleVisibleChange).toHaveBeenCalledTimes(1)
4333
+ await input.trigger('blur')
4334
+ expect(handleVisibleChange).toHaveBeenCalledTimes(2)
4335
+ })
4336
+
4337
+ test('should show empty slot correctly in remote search scenarios', async () => {
4338
+ vi.useFakeTimers()
4339
+ const wrapper = mount({
4340
+ components: {
4341
+ 'el-select': Select,
4342
+ 'el-option': Option,
4343
+ },
4344
+ template: `
4345
+ <el-select
4346
+ v-model="value"
4347
+ filterable
4348
+ remote
4349
+ :remote-method="remoteMethod"
4350
+ >
4351
+ <el-option
4352
+ v-for="item in options"
4353
+ :key="item.value"
4354
+ :label="item.label"
4355
+ :value="item.value"
4356
+ />
4357
+ <template #empty>
4358
+ <div class="custom-empty">NO DATA</div>
4359
+ </template>
4360
+ </el-select>
4361
+ `,
4362
+ setup() {
4363
+ const value = ref('')
4364
+ const options = ref<any[]>([])
4365
+
4366
+ const remoteMethod = (query: string) => {
4367
+ if (!query || query === 'empty') {
4368
+ options.value = []
4369
+ } else {
4370
+ options.value = [{ value: '1', label: 'Option 1' }]
4371
+ }
4372
+ }
4373
+ return { value, options, remoteMethod }
4374
+ },
4375
+ })
4376
+
4377
+ const select = wrapper.findComponent(Select)
4378
+ const input = wrapper.find('input')
4379
+ const vm = select.vm as any
4380
+
4381
+ await input.trigger('click')
4382
+ expect(vm.states.options.size).toBe(0)
4383
+ expect(vm.dropdownMenuVisible).toBe(true)
4384
+ expect(document.querySelector('.custom-empty')).not.toBeNull()
4385
+
4386
+ await input.setValue('a')
4387
+ vi.runAllTimers()
4388
+ await nextTick()
4389
+ expect(vm.states.options.size).toBe(1)
4390
+ expect(vm.dropdownMenuVisible).toBe(true)
4391
+ expect(document.querySelector('.custom-empty')).toBeNull()
4392
+
4393
+ await input.setValue('empty')
4394
+ vi.runAllTimers()
4395
+ await nextTick()
4396
+ expect(vm.states.options.size).toBe(0)
4397
+ expect(vm.dropdownMenuVisible).toBe(true)
4398
+ expect(document.querySelector('.custom-empty')).not.toBeNull()
4399
+
4400
+ vi.useRealTimers()
4401
+ })
4402
+
4403
+ describe('input-wrapper in multiple mode', () => {
4404
+ test('should hide input-wrapper when empty and not focused', async () => {
4405
+ wrapper = getSelectVm({
4406
+ multiple: true,
4407
+ filterable: true,
4408
+ })
4409
+ const inputWrapper = wrapper.find('.el-select__input-wrapper')
4410
+ const input = wrapper.find('input')
4411
+
4412
+ // When input is empty and not focused, input-wrapper should have hidden class
4413
+ expect(inputWrapper.classes()).toContain('is-hidden')
4414
+
4415
+ // Focus the input
4416
+ await input.trigger('focus')
4417
+
4418
+ // When focused, input-wrapper should not have hidden class
4419
+ expect(inputWrapper.classes()).not.toContain('is-hidden')
4420
+
4421
+ // Blur the input
4422
+ await input.trigger('blur')
4423
+
4424
+ // When blurred and empty, input-wrapper should have hidden class again
4425
+ expect(inputWrapper.classes()).toContain('is-hidden')
4426
+ })
4427
+
4428
+ test('should show input-wrapper when input has value', async () => {
4429
+ wrapper = getSelectVm({
4430
+ multiple: true,
4431
+ filterable: true,
4432
+ })
4433
+ const inputWrapper = wrapper.find('.el-select__input-wrapper')
4434
+ const input = wrapper.find('input')
4435
+
4436
+ // Initially empty, should be hidden
4437
+ expect(inputWrapper.classes()).toContain('is-hidden')
4438
+
4439
+ // Set input value
4440
+ await input.setValue('test')
4441
+
4442
+ // When input has value, input-wrapper should not have hidden class
4443
+ expect(inputWrapper.classes()).not.toContain('is-hidden')
4444
+
4445
+ // Clear input
4446
+ await input.setValue('')
4447
+
4448
+ // When empty again, should be hidden
4449
+ expect(inputWrapper.classes()).toContain('is-hidden')
4450
+ })
4451
+ })
4452
+
4453
+ it('should not bubble native change event from filter input', async () => {
4454
+ const wrapper = mount({
4455
+ template: `
4456
+ <div>
4457
+ <el-select filterable v-model="value">
4458
+ <el-option label="a" value="a" />
4459
+ </el-select>
4460
+ </div>
4461
+ `,
4462
+ components: { 'el-select': Select, 'el-option': Option },
4463
+ setup() {
4464
+ return {
4465
+ value: ref(''),
4466
+ }
4467
+ },
4468
+ })
4469
+
4470
+ const nativeChangeHandler = vi.fn()
4471
+ const parent = wrapper.element as HTMLElement
4472
+ parent.addEventListener('change', nativeChangeHandler)
4473
+
4474
+ await wrapper.find('input').trigger('change')
4475
+ expect(nativeChangeHandler).not.toHaveBeenCalled()
4476
+ })
4477
+ // #23838
4478
+ test('should keep dropdown visible during debouncing when options exist (remote)', async () => {
4479
+ vi.useFakeTimers()
4480
+
4481
+ const options = ref([{ value: 'test', label: 'test' }])
4482
+ const handleVisibleChange = vi.fn()
4483
+ const remoteMethod = vi.fn((query: string) => {
4484
+ if (query) {
4485
+ options.value = [
4486
+ { value: 'Alabama', label: 'Alabama' },
4487
+ { value: 'Alaska', label: 'Alaska' },
4488
+ ]
4489
+ }
4490
+ })
4491
+
4492
+ // Temporarily restore useDebounceFn to use real debounce with fake timers
4493
+ const { useDebounceFn } = await vi.importActual('@vueuse/core')
4494
+ const mockedUseDebounceFn = vi.mocked(
4495
+ (await import('@vueuse/core')).useDebounceFn
4496
+ )
4497
+ const originalUseDebounceFnImpl =
4498
+ mockedUseDebounceFn.getMockImplementation()
4499
+ mockedUseDebounceFn.mockImplementation(useDebounceFn)
4500
+
4501
+ try {
4502
+ wrapper = mount(
4503
+ {
4504
+ components: {
4505
+ 'el-select': Select,
4506
+ 'el-option': Option,
4507
+ },
4508
+ template: `
4509
+ <el-select
4510
+ v-model="value"
4511
+ filterable
4512
+ remote
4513
+ :debounce="300"
4514
+ :remote-method="remoteMethod"
4515
+ @visible-change="handleVisibleChange"
4516
+ >
4517
+ <el-option
4518
+ v-for="item in options"
4519
+ :key="item.value"
4520
+ :label="item.label"
4521
+ :value="item.value"
4522
+ />
4523
+ </el-select>
4524
+ `,
4525
+ setup() {
4526
+ return {
4527
+ value: ref(''),
4528
+ options,
4529
+ remoteMethod,
4530
+ handleVisibleChange,
4531
+ }
4532
+ },
4533
+ },
4534
+ {
4535
+ attachTo: 'body',
4536
+ }
4537
+ )
4538
+
4539
+ const select = wrapper.findComponent(Select)
4540
+ const vm = select.vm as any
4541
+ const input = wrapper.find('input')
4542
+
4543
+ // Open dropdown first
4544
+ await input.trigger('click')
4545
+ await nextTick()
4546
+ expect(vm.dropdownMenuVisible).toBe(true)
4547
+ expect(vm.states.options.size).toBe(1) // initial option exists
4548
+ expect(handleVisibleChange).toHaveBeenCalledTimes(1)
4549
+ expect(handleVisibleChange).toHaveBeenLastCalledWith(true)
4550
+
4551
+ // Start typing to trigger remote search and debouncing
4552
+ await input.setValue('a')
4553
+ await nextTick()
4554
+ vi.advanceTimersByTime(50) // Advance time but don't complete debounce
4555
+ await nextTick()
4556
+
4557
+ // During debouncing (before debounce completes), check dropdown and event count
4558
+ expect(vm.dropdownMenuVisible).toBe(true)
4559
+ expect(handleVisibleChange).toHaveBeenCalledTimes(1)
4560
+
4561
+ // Complete the debounce
4562
+ vi.advanceTimersByTime(300)
4563
+ await nextTick()
4564
+
4565
+ expect(remoteMethod).toHaveBeenCalledWith('a')
4566
+ expect(vm.dropdownMenuVisible).toBe(true)
4567
+ // Should still only have been called once - dropdown never closed
4568
+ expect(handleVisibleChange).toHaveBeenCalledTimes(1)
4569
+ } finally {
4570
+ mockedUseDebounceFn.mockImplementation(
4571
+ originalUseDebounceFnImpl ?? ((fn: any) => fn)
4572
+ )
4573
+ vi.useRealTimers()
4574
+ }
4575
+ })
4576
+ })