@element-plus/nightly 0.0.20260313 → 0.0.20260314

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 (914) hide show
  1. package/dist/index.full.js +2 -2
  2. package/dist/index.full.min.js +2 -2
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +2 -2
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +2 -2
  7. package/dist/locale/af.js +1 -1
  8. package/dist/locale/af.min.js +1 -1
  9. package/dist/locale/af.min.mjs +1 -1
  10. package/dist/locale/af.mjs +1 -1
  11. package/dist/locale/ar-eg.js +1 -1
  12. package/dist/locale/ar-eg.min.js +1 -1
  13. package/dist/locale/ar-eg.min.mjs +1 -1
  14. package/dist/locale/ar-eg.mjs +1 -1
  15. package/dist/locale/ar.js +1 -1
  16. package/dist/locale/ar.min.js +1 -1
  17. package/dist/locale/ar.min.mjs +1 -1
  18. package/dist/locale/ar.mjs +1 -1
  19. package/dist/locale/az.js +1 -1
  20. package/dist/locale/az.min.js +1 -1
  21. package/dist/locale/az.min.mjs +1 -1
  22. package/dist/locale/az.mjs +1 -1
  23. package/dist/locale/bg.js +1 -1
  24. package/dist/locale/bg.min.js +1 -1
  25. package/dist/locale/bg.min.mjs +1 -1
  26. package/dist/locale/bg.mjs +1 -1
  27. package/dist/locale/bn.js +1 -1
  28. package/dist/locale/bn.min.js +1 -1
  29. package/dist/locale/bn.min.mjs +1 -1
  30. package/dist/locale/bn.mjs +1 -1
  31. package/dist/locale/ca.js +1 -1
  32. package/dist/locale/ca.min.js +1 -1
  33. package/dist/locale/ca.min.mjs +1 -1
  34. package/dist/locale/ca.mjs +1 -1
  35. package/dist/locale/ckb.js +1 -1
  36. package/dist/locale/ckb.min.js +1 -1
  37. package/dist/locale/ckb.min.mjs +1 -1
  38. package/dist/locale/ckb.mjs +1 -1
  39. package/dist/locale/cs.js +1 -1
  40. package/dist/locale/cs.min.js +1 -1
  41. package/dist/locale/cs.min.mjs +1 -1
  42. package/dist/locale/cs.mjs +1 -1
  43. package/dist/locale/da.js +1 -1
  44. package/dist/locale/da.min.js +1 -1
  45. package/dist/locale/da.min.mjs +1 -1
  46. package/dist/locale/da.mjs +1 -1
  47. package/dist/locale/de.js +1 -1
  48. package/dist/locale/de.min.js +1 -1
  49. package/dist/locale/de.min.mjs +1 -1
  50. package/dist/locale/de.mjs +1 -1
  51. package/dist/locale/el.js +1 -1
  52. package/dist/locale/el.min.js +1 -1
  53. package/dist/locale/el.min.mjs +1 -1
  54. package/dist/locale/el.mjs +1 -1
  55. package/dist/locale/en.js +1 -1
  56. package/dist/locale/en.min.js +1 -1
  57. package/dist/locale/en.min.mjs +1 -1
  58. package/dist/locale/en.mjs +1 -1
  59. package/dist/locale/eo.js +1 -1
  60. package/dist/locale/eo.min.js +1 -1
  61. package/dist/locale/eo.min.mjs +1 -1
  62. package/dist/locale/eo.mjs +1 -1
  63. package/dist/locale/es.js +1 -1
  64. package/dist/locale/es.min.js +1 -1
  65. package/dist/locale/es.min.mjs +1 -1
  66. package/dist/locale/es.mjs +1 -1
  67. package/dist/locale/et.js +1 -1
  68. package/dist/locale/et.min.js +1 -1
  69. package/dist/locale/et.min.mjs +1 -1
  70. package/dist/locale/et.mjs +1 -1
  71. package/dist/locale/eu.js +1 -1
  72. package/dist/locale/eu.min.js +1 -1
  73. package/dist/locale/eu.min.mjs +1 -1
  74. package/dist/locale/eu.mjs +1 -1
  75. package/dist/locale/fa.js +1 -1
  76. package/dist/locale/fa.min.js +1 -1
  77. package/dist/locale/fa.min.mjs +1 -1
  78. package/dist/locale/fa.mjs +1 -1
  79. package/dist/locale/fi.js +1 -1
  80. package/dist/locale/fi.min.js +1 -1
  81. package/dist/locale/fi.min.mjs +1 -1
  82. package/dist/locale/fi.mjs +1 -1
  83. package/dist/locale/fr.js +1 -1
  84. package/dist/locale/fr.min.js +1 -1
  85. package/dist/locale/fr.min.mjs +1 -1
  86. package/dist/locale/fr.mjs +1 -1
  87. package/dist/locale/he.js +1 -1
  88. package/dist/locale/he.min.js +1 -1
  89. package/dist/locale/he.min.mjs +1 -1
  90. package/dist/locale/he.mjs +1 -1
  91. package/dist/locale/hi.js +1 -1
  92. package/dist/locale/hi.min.js +1 -1
  93. package/dist/locale/hi.min.mjs +1 -1
  94. package/dist/locale/hi.mjs +1 -1
  95. package/dist/locale/hr.js +1 -1
  96. package/dist/locale/hr.min.js +1 -1
  97. package/dist/locale/hr.min.mjs +1 -1
  98. package/dist/locale/hr.mjs +1 -1
  99. package/dist/locale/hu.js +1 -1
  100. package/dist/locale/hu.min.js +1 -1
  101. package/dist/locale/hu.min.mjs +1 -1
  102. package/dist/locale/hu.mjs +1 -1
  103. package/dist/locale/hy-am.js +1 -1
  104. package/dist/locale/hy-am.min.js +1 -1
  105. package/dist/locale/hy-am.min.mjs +1 -1
  106. package/dist/locale/hy-am.mjs +1 -1
  107. package/dist/locale/id.js +1 -1
  108. package/dist/locale/id.min.js +1 -1
  109. package/dist/locale/id.min.mjs +1 -1
  110. package/dist/locale/id.mjs +1 -1
  111. package/dist/locale/it.js +1 -1
  112. package/dist/locale/it.min.js +1 -1
  113. package/dist/locale/it.min.mjs +1 -1
  114. package/dist/locale/it.mjs +1 -1
  115. package/dist/locale/ja.js +1 -1
  116. package/dist/locale/ja.min.js +1 -1
  117. package/dist/locale/ja.min.mjs +1 -1
  118. package/dist/locale/ja.mjs +1 -1
  119. package/dist/locale/kk.js +1 -1
  120. package/dist/locale/kk.min.js +1 -1
  121. package/dist/locale/kk.min.mjs +1 -1
  122. package/dist/locale/kk.mjs +1 -1
  123. package/dist/locale/km.js +1 -1
  124. package/dist/locale/km.min.js +1 -1
  125. package/dist/locale/km.min.mjs +1 -1
  126. package/dist/locale/km.mjs +1 -1
  127. package/dist/locale/ko.js +1 -1
  128. package/dist/locale/ko.min.js +1 -1
  129. package/dist/locale/ko.min.mjs +1 -1
  130. package/dist/locale/ko.mjs +1 -1
  131. package/dist/locale/ku.js +1 -1
  132. package/dist/locale/ku.min.js +1 -1
  133. package/dist/locale/ku.min.mjs +1 -1
  134. package/dist/locale/ku.mjs +1 -1
  135. package/dist/locale/ky.js +1 -1
  136. package/dist/locale/ky.min.js +1 -1
  137. package/dist/locale/ky.min.mjs +1 -1
  138. package/dist/locale/ky.mjs +1 -1
  139. package/dist/locale/lo.js +1 -1
  140. package/dist/locale/lo.min.js +1 -1
  141. package/dist/locale/lo.min.mjs +1 -1
  142. package/dist/locale/lo.mjs +1 -1
  143. package/dist/locale/lt.js +1 -1
  144. package/dist/locale/lt.min.js +1 -1
  145. package/dist/locale/lt.min.mjs +1 -1
  146. package/dist/locale/lt.mjs +1 -1
  147. package/dist/locale/lv.js +1 -1
  148. package/dist/locale/lv.min.js +1 -1
  149. package/dist/locale/lv.min.mjs +1 -1
  150. package/dist/locale/lv.mjs +1 -1
  151. package/dist/locale/mg.js +1 -1
  152. package/dist/locale/mg.min.js +1 -1
  153. package/dist/locale/mg.min.mjs +1 -1
  154. package/dist/locale/mg.mjs +1 -1
  155. package/dist/locale/mn.js +1 -1
  156. package/dist/locale/mn.min.js +1 -1
  157. package/dist/locale/mn.min.mjs +1 -1
  158. package/dist/locale/mn.mjs +1 -1
  159. package/dist/locale/ms.js +1 -1
  160. package/dist/locale/ms.min.js +1 -1
  161. package/dist/locale/ms.min.mjs +1 -1
  162. package/dist/locale/ms.mjs +1 -1
  163. package/dist/locale/my.js +1 -1
  164. package/dist/locale/my.min.js +1 -1
  165. package/dist/locale/my.min.mjs +1 -1
  166. package/dist/locale/my.mjs +1 -1
  167. package/dist/locale/nb-no.js +1 -1
  168. package/dist/locale/nb-no.min.js +1 -1
  169. package/dist/locale/nb-no.min.mjs +1 -1
  170. package/dist/locale/nb-no.mjs +1 -1
  171. package/dist/locale/nl.js +1 -1
  172. package/dist/locale/nl.min.js +1 -1
  173. package/dist/locale/nl.min.mjs +1 -1
  174. package/dist/locale/nl.mjs +1 -1
  175. package/dist/locale/no.js +1 -1
  176. package/dist/locale/no.min.js +1 -1
  177. package/dist/locale/no.min.mjs +1 -1
  178. package/dist/locale/no.mjs +1 -1
  179. package/dist/locale/pa.js +1 -1
  180. package/dist/locale/pa.min.js +1 -1
  181. package/dist/locale/pa.min.mjs +1 -1
  182. package/dist/locale/pa.mjs +1 -1
  183. package/dist/locale/pl.js +1 -1
  184. package/dist/locale/pl.min.js +1 -1
  185. package/dist/locale/pl.min.mjs +1 -1
  186. package/dist/locale/pl.mjs +1 -1
  187. package/dist/locale/pt-br.js +1 -1
  188. package/dist/locale/pt-br.min.js +1 -1
  189. package/dist/locale/pt-br.min.mjs +1 -1
  190. package/dist/locale/pt-br.mjs +1 -1
  191. package/dist/locale/pt.js +1 -1
  192. package/dist/locale/pt.min.js +1 -1
  193. package/dist/locale/pt.min.mjs +1 -1
  194. package/dist/locale/pt.mjs +1 -1
  195. package/dist/locale/ro.js +1 -1
  196. package/dist/locale/ro.min.js +1 -1
  197. package/dist/locale/ro.min.mjs +1 -1
  198. package/dist/locale/ro.mjs +1 -1
  199. package/dist/locale/ru.js +1 -1
  200. package/dist/locale/ru.min.js +1 -1
  201. package/dist/locale/ru.min.mjs +1 -1
  202. package/dist/locale/ru.mjs +1 -1
  203. package/dist/locale/sk.js +1 -1
  204. package/dist/locale/sk.min.js +1 -1
  205. package/dist/locale/sk.min.mjs +1 -1
  206. package/dist/locale/sk.mjs +1 -1
  207. package/dist/locale/sl.js +1 -1
  208. package/dist/locale/sl.min.js +1 -1
  209. package/dist/locale/sl.min.mjs +1 -1
  210. package/dist/locale/sl.mjs +1 -1
  211. package/dist/locale/sr.js +1 -1
  212. package/dist/locale/sr.min.js +1 -1
  213. package/dist/locale/sr.min.mjs +1 -1
  214. package/dist/locale/sr.mjs +1 -1
  215. package/dist/locale/sv.js +1 -1
  216. package/dist/locale/sv.min.js +1 -1
  217. package/dist/locale/sv.min.mjs +1 -1
  218. package/dist/locale/sv.mjs +1 -1
  219. package/dist/locale/sw.js +1 -1
  220. package/dist/locale/sw.min.js +1 -1
  221. package/dist/locale/sw.min.mjs +1 -1
  222. package/dist/locale/sw.mjs +1 -1
  223. package/dist/locale/ta.js +1 -1
  224. package/dist/locale/ta.min.js +1 -1
  225. package/dist/locale/ta.min.mjs +1 -1
  226. package/dist/locale/ta.mjs +1 -1
  227. package/dist/locale/te.js +1 -1
  228. package/dist/locale/te.min.js +1 -1
  229. package/dist/locale/te.min.mjs +1 -1
  230. package/dist/locale/te.mjs +1 -1
  231. package/dist/locale/th.js +1 -1
  232. package/dist/locale/th.min.js +1 -1
  233. package/dist/locale/th.min.mjs +1 -1
  234. package/dist/locale/th.mjs +1 -1
  235. package/dist/locale/tk.js +1 -1
  236. package/dist/locale/tk.min.js +1 -1
  237. package/dist/locale/tk.min.mjs +1 -1
  238. package/dist/locale/tk.mjs +1 -1
  239. package/dist/locale/tr.js +1 -1
  240. package/dist/locale/tr.min.js +1 -1
  241. package/dist/locale/tr.min.mjs +1 -1
  242. package/dist/locale/tr.mjs +1 -1
  243. package/dist/locale/ug-cn.js +1 -1
  244. package/dist/locale/ug-cn.min.js +1 -1
  245. package/dist/locale/ug-cn.min.mjs +1 -1
  246. package/dist/locale/ug-cn.mjs +1 -1
  247. package/dist/locale/uk.js +1 -1
  248. package/dist/locale/uk.min.js +1 -1
  249. package/dist/locale/uk.min.mjs +1 -1
  250. package/dist/locale/uk.mjs +1 -1
  251. package/dist/locale/uz-uz.js +1 -1
  252. package/dist/locale/uz-uz.min.js +1 -1
  253. package/dist/locale/uz-uz.min.mjs +1 -1
  254. package/dist/locale/uz-uz.mjs +1 -1
  255. package/dist/locale/vi.js +1 -1
  256. package/dist/locale/vi.min.js +1 -1
  257. package/dist/locale/vi.min.mjs +1 -1
  258. package/dist/locale/vi.mjs +1 -1
  259. package/dist/locale/zh-cn.js +1 -1
  260. package/dist/locale/zh-cn.min.js +1 -1
  261. package/dist/locale/zh-cn.min.mjs +1 -1
  262. package/dist/locale/zh-cn.mjs +1 -1
  263. package/dist/locale/zh-hk.js +1 -1
  264. package/dist/locale/zh-hk.min.js +1 -1
  265. package/dist/locale/zh-hk.min.mjs +1 -1
  266. package/dist/locale/zh-hk.mjs +1 -1
  267. package/dist/locale/zh-mo.js +1 -1
  268. package/dist/locale/zh-mo.min.js +1 -1
  269. package/dist/locale/zh-mo.min.mjs +1 -1
  270. package/dist/locale/zh-mo.mjs +1 -1
  271. package/dist/locale/zh-tw.js +1 -1
  272. package/dist/locale/zh-tw.min.js +1 -1
  273. package/dist/locale/zh-tw.min.mjs +1 -1
  274. package/dist/locale/zh-tw.mjs +1 -1
  275. package/es/components/affix/src/affix.d.ts +5 -5
  276. package/es/components/affix/src/affix.mjs.map +1 -1
  277. package/es/components/affix/src/affix.vue.d.ts +10 -31
  278. package/es/components/alert/src/alert.vue.d.ts +6 -30
  279. package/es/components/anchor/src/anchor-link.vue.d.ts +2 -16
  280. package/es/components/anchor/src/anchor.d.ts +3 -3
  281. package/es/components/anchor/src/anchor.vue.d.ts +5 -29
  282. package/es/components/autocomplete/src/autocomplete.d.ts +16 -21
  283. package/es/components/autocomplete/src/autocomplete.vue.d.ts +25 -73
  284. package/es/components/avatar/src/avatar-group-props.d.ts +3 -3
  285. package/es/components/avatar/src/avatar-group.d.ts +10 -10
  286. package/es/components/avatar/src/avatar.d.ts +5 -5
  287. package/es/components/avatar/src/avatar.mjs.map +1 -1
  288. package/es/components/avatar/src/avatar.vue.d.ts +7 -22
  289. package/es/components/backtop/src/backtop.vue.d.ts +4 -24
  290. package/es/components/badge/src/badge.d.ts +2 -2
  291. package/es/components/badge/src/badge.vue.d.ts +4 -28
  292. package/es/components/breadcrumb/src/breadcrumb-item.d.ts +1 -1
  293. package/es/components/breadcrumb/src/breadcrumb-item.vue.d.ts +2 -16
  294. package/es/components/breadcrumb/src/breadcrumb.d.ts +1 -1
  295. package/es/components/breadcrumb/src/breadcrumb.vue.d.ts +2 -16
  296. package/es/components/button/src/button-group.vue.d.ts +2 -18
  297. package/es/components/button/src/button.d.ts +4 -4
  298. package/es/components/button/src/button.vue.d.ts +10 -42
  299. package/es/components/calendar/src/calendar.d.ts +1 -1
  300. package/es/components/calendar/src/calendar.vue.d.ts +6 -20
  301. package/es/components/calendar/src/date-table.d.ts +7 -1
  302. package/es/components/calendar/src/date-table.vue.d.ts +4 -4
  303. package/es/components/card/src/card.d.ts +1 -1
  304. package/es/components/card/src/card.vue.d.ts +2 -22
  305. package/es/components/carousel/src/carousel-item.vue.d.ts +3 -19
  306. package/es/components/carousel/src/carousel.d.ts +1 -1
  307. package/es/components/carousel/src/carousel.vue.d.ts +8 -44
  308. package/es/components/cascader/src/cascader.d.ts +16 -21
  309. package/es/components/cascader/src/cascader.vue.d.ts +21 -77
  310. package/es/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  311. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  312. package/es/components/cascader-panel/src/config.d.ts +6 -6
  313. package/es/components/cascader-panel/src/index.vue.d.ts +128 -26
  314. package/es/components/cascader-panel/src/menu.vue.d.ts +3 -3
  315. package/es/components/check-tag/src/check-tag.vue.d.ts +4 -18
  316. package/es/components/checkbox/src/checkbox-button.vue.d.ts +10 -44
  317. package/es/components/checkbox/src/checkbox-group.d.ts +2 -2
  318. package/es/components/checkbox/src/checkbox-group.vue.d.ts +9 -41
  319. package/es/components/checkbox/src/checkbox.d.ts +8 -8
  320. package/es/components/checkbox/src/checkbox.vue.d.ts +10 -44
  321. package/es/components/checkbox/src/composables/use-checkbox-model.d.ts +2 -2
  322. package/es/components/checkbox/src/composables/use-checkbox-status.d.ts +1 -1
  323. package/es/components/checkbox/src/composables/use-checkbox.d.ts +3 -3
  324. package/es/components/col/src/col.d.ts +5 -5
  325. package/es/components/col/src/col.vue.d.ts +2 -34
  326. package/es/components/collapse/src/collapse-item.d.ts +3 -8
  327. package/es/components/collapse/src/collapse-item.vue.d.ts +3 -19
  328. package/es/components/collapse/src/collapse.d.ts +2 -2
  329. package/es/components/collapse/src/collapse.vue.d.ts +6 -22
  330. package/es/components/collapse-transition/src/collapse-transition.vue.d.ts +1 -1
  331. package/es/components/collection/src/collection.d.ts +6 -6
  332. package/es/components/color-picker/src/color-picker.d.ts +7 -7
  333. package/es/components/color-picker/src/color-picker.vue.d.ts +12 -42
  334. package/es/components/color-picker-panel/src/color-picker-panel.d.ts +4 -4
  335. package/es/components/color-picker-panel/src/color-picker-panel.vue.d.ts +7 -27
  336. package/es/components/config-provider/src/config-provider-props.d.ts +1 -1
  337. package/es/components/config-provider/src/config-provider.d.ts +8 -8
  338. package/es/components/config-provider/src/hooks/use-global-config.d.ts +1 -1
  339. package/es/components/container/src/aside.vue.d.ts +2 -16
  340. package/es/components/container/src/container.vue.d.ts +7 -1
  341. package/es/components/container/src/footer.vue.d.ts +2 -16
  342. package/es/components/container/src/header.vue.d.ts +2 -16
  343. package/es/components/container/src/main.vue.d.ts +1 -1
  344. package/es/components/countdown/src/countdown.d.ts +2 -2
  345. package/es/components/countdown/src/countdown.vue.d.ts +6 -24
  346. package/es/components/date-picker/src/date-picker.d.ts +47 -56
  347. package/es/components/date-picker/src/props.d.ts +16 -21
  348. package/es/components/date-picker-panel/src/date-picker-panel.d.ts +17 -17
  349. package/es/components/date-picker-panel/src/props/date-picker-panel.d.ts +4 -4
  350. package/es/components/descriptions/src/description-item.d.ts +18 -18
  351. package/es/components/descriptions/src/description.vue.d.ts +2 -22
  352. package/es/components/dialog/src/dialog.d.ts +3 -3
  353. package/es/components/dialog/src/dialog.vue.d.ts +14 -56
  354. package/es/components/dialog/src/use-dialog.d.ts +7 -7
  355. package/es/components/divider/src/divider.d.ts +1 -1
  356. package/es/components/divider/src/divider.vue.d.ts +2 -20
  357. package/es/components/drawer/src/drawer.d.ts +3 -3
  358. package/es/components/drawer/src/drawer.vue.d.ts +14 -64
  359. package/es/components/dropdown/src/dropdown-item-impl.mjs.map +1 -1
  360. package/es/components/dropdown/src/dropdown-item.mjs.map +1 -1
  361. package/es/components/dropdown/src/dropdown-item.vue.d.ts +141 -9
  362. package/es/components/dropdown/src/dropdown-menu.mjs.map +1 -1
  363. package/es/components/dropdown/src/dropdown-menu.vue.d.ts +6 -6
  364. package/es/components/dropdown/src/dropdown.d.ts +14 -14
  365. package/es/components/dropdown/src/dropdown.vue.d.ts +576 -52
  366. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  367. package/es/components/empty/src/empty.vue.d.ts +2 -18
  368. package/es/components/focus-trap/src/focus-trap.vue.d.ts +6 -6
  369. package/es/components/focus-trap/src/utils.d.ts +3 -3
  370. package/es/components/form/src/form-item.d.ts +2 -2
  371. package/es/components/form/src/form-item.vue.d.ts +5 -25
  372. package/es/components/form/src/form.d.ts +1 -1
  373. package/es/components/form/src/form.vue.d.ts +6 -32
  374. package/es/components/form/src/hooks/use-form-item.d.ts +1 -1
  375. package/es/components/icon/src/icon.d.ts +1 -1
  376. package/es/components/icon/src/icon.vue.d.ts +2 -16
  377. package/es/components/image/src/image.d.ts +3 -3
  378. package/es/components/image/src/image.vue.d.ts +13 -45
  379. package/es/components/image-viewer/src/image-viewer.d.ts +2 -2
  380. package/es/components/image-viewer/src/image-viewer.vue.d.ts +10 -38
  381. package/es/components/index.d.ts +8 -8
  382. package/es/components/infinite-scroll/index.d.ts +1 -1
  383. package/es/components/input/src/input.d.ts +12 -17
  384. package/es/components/input/src/input.vue.d.ts +23 -57
  385. package/es/components/input-number/src/input-number.d.ts +4 -4
  386. package/es/components/input-number/src/input-number.vue.d.ts +15 -53
  387. package/es/components/input-tag/src/composables/use-drag-tag.d.ts +2 -2
  388. package/es/components/input-tag/src/composables/use-hovering.d.ts +1 -1
  389. package/es/components/input-tag/src/composables/use-input-tag-dom.d.ts +4 -3
  390. package/es/components/input-tag/src/composables/use-input-tag.d.ts +6 -6
  391. package/es/components/input-tag/src/input-tag.d.ts +4 -9
  392. package/es/components/input-tag/src/input-tag.vue.d.ts +15 -53
  393. package/es/components/link/src/link.d.ts +2 -2
  394. package/es/components/link/src/link.vue.d.ts +4 -24
  395. package/es/components/loading/src/loading.d.ts +19 -15
  396. package/es/components/mention/src/mention.d.ts +19 -24
  397. package/es/components/mention/src/mention.vue.d.ts +21 -71
  398. package/es/components/menu/index.d.ts +1 -1
  399. package/es/components/menu/src/menu-item-group.vue.d.ts +2 -1
  400. package/es/components/menu/src/menu-item.d.ts +2 -2
  401. package/es/components/menu/src/menu-item.vue.d.ts +5 -19
  402. package/es/components/menu/src/menu.d.ts +26 -26
  403. package/es/components/menu/src/sub-menu.d.ts +21 -21
  404. package/es/components/message/src/message.d.ts +5 -5
  405. package/es/components/message/src/message.vue.d.ts +11 -56
  406. package/es/components/message-box/src/index.mjs.map +1 -1
  407. package/es/components/notification/src/notification.d.ts +6 -11
  408. package/es/components/notification/src/notification.vue.d.ts +12 -46
  409. package/es/components/overlay/index.d.ts +11 -11
  410. package/es/components/overlay/src/overlay.d.ts +3 -3
  411. package/es/components/overlay/src/overlay.mjs.map +1 -1
  412. package/es/components/page-header/src/page-header.d.ts +1 -1
  413. package/es/components/page-header/src/page-header.vue.d.ts +4 -20
  414. package/es/components/pagination/src/pagination.d.ts +22 -22
  415. package/es/components/popconfirm/src/popconfirm.d.ts +2 -2
  416. package/es/components/popconfirm/src/popconfirm.vue.d.ts +7 -35
  417. package/es/components/popover/src/popover.d.ts +11 -11
  418. package/es/components/popover/src/popover.vue.d.ts +12 -60
  419. package/es/components/popper/src/arrow.vue.d.ts +2 -2
  420. package/es/components/popper/src/composables/use-content-dom.d.ts +1 -1
  421. package/es/components/popper/src/composables/use-content.d.ts +3 -3
  422. package/es/components/popper/src/composables/use-focus-trap.d.ts +2 -2
  423. package/es/components/popper/src/content.d.ts +18 -18
  424. package/es/components/popper/src/content.vue.d.ts +15 -63
  425. package/es/components/popper/src/popper.d.ts +2 -2
  426. package/es/components/popper/src/popper.vue.d.ts +2 -16
  427. package/es/components/popper/src/trigger.vue.d.ts +3 -13
  428. package/es/components/progress/src/progress.d.ts +4 -4
  429. package/es/components/progress/src/progress.vue.d.ts +4 -36
  430. package/es/components/radio/src/radio-button.d.ts +3 -3
  431. package/es/components/radio/src/radio-button.vue.d.ts +5 -27
  432. package/es/components/radio/src/radio-group.d.ts +1 -1
  433. package/es/components/radio/src/radio-group.vue.d.ts +9 -39
  434. package/es/components/radio/src/radio.d.ts +6 -6
  435. package/es/components/radio/src/radio.vue.d.ts +7 -31
  436. package/es/components/rate/src/rate.d.ts +5 -5
  437. package/es/components/rate/src/rate.vue.d.ts +7 -49
  438. package/es/components/result/src/result.vue.d.ts +2 -20
  439. package/es/components/roving-focus-group/src/roving-focus-group.d.ts +9 -9
  440. package/es/components/roving-focus-group/src/roving-focus-group.vue.d.ts +77 -1
  441. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  442. package/es/components/roving-focus-group/src/roving-focus-item.mjs.map +1 -1
  443. package/es/components/roving-focus-group/src/roving-focus-item.vue.d.ts +26 -7
  444. package/es/components/row/src/row.vue.d.ts +2 -20
  445. package/es/components/scrollbar/src/scrollbar.d.ts +1 -1
  446. package/es/components/scrollbar/src/scrollbar.vue.d.ts +7 -39
  447. package/es/components/scrollbar/src/thumb.vue.d.ts +2 -1
  448. package/es/components/segmented/index.d.ts +30 -243
  449. package/es/components/segmented/src/segmented.d.ts +4 -4
  450. package/es/components/segmented/src/segmented.vue.d.ts +7 -31
  451. package/es/components/select/src/option-group.mjs.map +1 -1
  452. package/es/components/select/src/option-group.vue.d.ts +6 -6
  453. package/es/components/select/src/option.d.ts +2 -2
  454. package/es/components/select/src/option.vue.d.ts +13 -13
  455. package/es/components/select/src/option2.mjs.map +1 -1
  456. package/es/components/select/src/select-dropdown.mjs.map +1 -1
  457. package/es/components/select/src/select.d.ts +13 -23
  458. package/es/components/select/src/select.vue.d.ts +572 -108
  459. package/es/components/select/src/select2.mjs.map +1 -1
  460. package/es/components/select-v2/src/defaults.d.ts +16 -26
  461. package/es/components/select-v2/src/group-item.mjs.map +1 -1
  462. package/es/components/select-v2/src/option-item.mjs.map +1 -1
  463. package/es/components/select-v2/src/select.mjs.map +1 -1
  464. package/es/components/select-v2/src/select.vue.d.ts +362 -107
  465. package/es/components/skeleton/src/skeleton-item.d.ts +1 -1
  466. package/es/components/skeleton/src/skeleton-item.vue.d.ts +2 -16
  467. package/es/components/skeleton/src/skeleton.d.ts +2 -2
  468. package/es/components/skeleton/src/skeleton.vue.d.ts +4 -22
  469. package/es/components/slider/src/button.vue.d.ts +9 -9
  470. package/es/components/slider/src/composables/use-lifecycle.d.ts +1 -1
  471. package/es/components/slider/src/composables/use-slide.d.ts +3 -3
  472. package/es/components/slider/src/composables/use-slider-button.d.ts +5 -5
  473. package/es/components/slider/src/marker.d.ts +2 -2
  474. package/es/components/slider/src/slider.d.ts +6 -6
  475. package/es/components/slider/src/slider.vue.d.ts +27 -27
  476. package/es/components/slot/src/only-child.d.ts +1 -1
  477. package/es/components/space/src/item.d.ts +4 -4
  478. package/es/components/space/src/space.d.ts +22 -23
  479. package/es/components/space/src/space.mjs.map +1 -1
  480. package/es/components/space/src/use-space.d.ts +1 -1
  481. package/es/components/splitter/src/hooks/useContainer.d.ts +2 -2
  482. package/es/components/splitter/src/hooks/useResize.d.ts +7 -1
  483. package/es/components/splitter/src/hooks/useSize.d.ts +1 -1
  484. package/es/components/splitter/src/split-panel.vue.d.ts +6 -20
  485. package/es/components/splitter/src/splitter.vue.d.ts +4 -18
  486. package/es/components/statistic/src/statistic.d.ts +2 -2
  487. package/es/components/statistic/src/statistic.vue.d.ts +3 -25
  488. package/es/components/steps/src/item.d.ts +2 -2
  489. package/es/components/steps/src/item.vue.d.ts +2 -22
  490. package/es/components/steps/src/steps.d.ts +2 -2
  491. package/es/components/steps/src/steps.vue.d.ts +4 -26
  492. package/es/components/switch/src/switch.d.ts +5 -5
  493. package/es/components/switch/src/switch.vue.d.ts +7 -37
  494. package/es/components/table/src/filter-panel.mjs.map +1 -1
  495. package/es/components/table/src/h-helper.d.ts +17 -0
  496. package/es/components/table/src/store/index.d.ts +880 -880
  497. package/es/components/table/src/table-body/index.d.ts +10 -8
  498. package/es/components/table/src/table-column/index.d.ts +109 -9
  499. package/es/components/table/src/table-footer/index.d.ts +6 -6
  500. package/es/components/table/src/table-header/index.d.ts +110 -8
  501. package/es/components/table/src/table.mjs.map +1 -1
  502. package/es/components/table/src/table.vue.d.ts +945 -474
  503. package/es/components/table-v2/src/cell.d.ts +1 -1
  504. package/es/components/table-v2/src/components/auto-resizer.d.ts +4 -4
  505. package/es/components/table-v2/src/components/header-row.d.ts +3 -3
  506. package/es/components/table-v2/src/components/header.d.ts +7 -7
  507. package/es/components/table-v2/src/components/row.d.ts +7 -7
  508. package/es/components/table-v2/src/composables/use-auto-resize.d.ts +3 -3
  509. package/es/components/table-v2/src/composables/use-data.d.ts +1 -1
  510. package/es/components/table-v2/src/composables/use-row.d.ts +4 -4
  511. package/es/components/table-v2/src/composables/use-scrollbar.d.ts +3 -0
  512. package/es/components/table-v2/src/header.d.ts +1 -1
  513. package/es/components/table-v2/src/row.d.ts +1 -1
  514. package/es/components/table-v2/src/table-grid.d.ts +10 -10
  515. package/es/components/table-v2/src/table-v2.d.ts +24 -24
  516. package/es/components/table-v2/src/table.d.ts +9 -9
  517. package/es/components/table-v2/src/use-table.d.ts +8 -8
  518. package/es/components/tabs/src/tab-bar.d.ts +4 -4
  519. package/es/components/tabs/src/tab-bar.vue.d.ts +4 -20
  520. package/es/components/tabs/src/tab-nav.d.ts +11 -11
  521. package/es/components/tabs/src/tab-pane.vue.d.ts +2 -18
  522. package/es/components/tabs/src/tabs.d.ts +13 -13
  523. package/es/components/tag/src/tag.vue.d.ts +6 -22
  524. package/es/components/teleport/src/teleport.d.ts +1 -1
  525. package/es/components/teleport/src/teleport.vue.d.ts +6 -6
  526. package/es/components/text/src/text.vue.d.ts +2 -20
  527. package/es/components/time-picker/src/common/picker.vue.d.ts +52 -61
  528. package/es/components/time-picker/src/common/props.d.ts +17 -22
  529. package/es/components/time-picker/src/composables/use-common-picker.d.ts +13 -3
  530. package/es/components/time-picker/src/time-picker-com/panel-time-pick.vue.d.ts +5 -5
  531. package/es/components/time-picker/src/time-picker.d.ts +44 -53
  532. package/es/components/time-select/src/time-select.d.ts +8 -8
  533. package/es/components/time-select/src/time-select.vue.d.ts +15 -53
  534. package/es/components/timeline/src/timeline-item.d.ts +1 -1
  535. package/es/components/timeline/src/timeline-item.vue.d.ts +3 -25
  536. package/es/components/timeline/src/timeline.d.ts +5 -5
  537. package/es/components/tooltip/src/content.d.ts +11 -11
  538. package/es/components/tooltip/src/content.vue.d.ts +13 -71
  539. package/es/components/tooltip/src/tooltip.d.ts +14 -14
  540. package/es/components/tooltip/src/tooltip.vue.d.ts +20 -86
  541. package/es/components/tooltip/src/trigger.d.ts +2 -2
  542. package/es/components/tour/src/content.d.ts +3 -3
  543. package/es/components/tour/src/step.d.ts +8 -8
  544. package/es/components/tour/src/step.vue.d.ts +6 -28
  545. package/es/components/tour/src/tour.d.ts +9 -9
  546. package/es/components/tour/src/tour.vue.d.ts +11 -53
  547. package/es/components/transfer/src/transfer-panel.vue.d.ts +6 -36
  548. package/es/components/transfer/src/transfer.d.ts +8 -8
  549. package/es/components/transfer/src/transfer.vue.d.ts +9 -49
  550. package/es/components/tree/src/model/useDragNode.d.ts +1 -1
  551. package/es/components/tree/src/tree-node.mjs.map +1 -1
  552. package/es/components/tree/src/tree.d.ts +4 -4
  553. package/es/components/tree/src/tree.vue.d.ts +594 -23
  554. package/es/components/tree/src/tree2.mjs.map +1 -1
  555. package/es/components/tree-select/src/tree-select.vue.d.ts +68 -86
  556. package/es/components/tree-v2/src/tree.vue.d.ts +7 -54
  557. package/es/components/tree-v2/src/virtual-tree.d.ts +1 -12
  558. package/es/components/upload/src/upload-content.d.ts +19 -19
  559. package/es/components/upload/src/upload-content.vue.d.ts +6 -54
  560. package/es/components/upload/src/upload-dragger.vue.d.ts +4 -18
  561. package/es/components/upload/src/upload-list.d.ts +4 -4
  562. package/es/components/upload/src/upload-list.vue.d.ts +4 -24
  563. package/es/components/upload/src/upload.d.ts +27 -27
  564. package/es/components/upload/src/upload.vue.d.ts +6 -56
  565. package/es/components/virtual-list/src/builders/build-grid.d.ts +24 -24
  566. package/es/components/virtual-list/src/components/dynamic-size-grid.d.ts +24 -24
  567. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +35 -21
  568. package/es/components/virtual-list/src/components/fixed-size-grid.d.ts +24 -24
  569. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +35 -21
  570. package/es/components/virtual-list/src/hooks/use-cache.d.ts +1 -3
  571. package/es/components/virtual-list/src/hooks/use-cache.mjs.map +1 -1
  572. package/es/components/virtual-list/src/props.d.ts +17 -17
  573. package/es/components/watermark/src/watermark.d.ts +2 -2
  574. package/es/components/watermark/src/watermark.vue.d.ts +4 -24
  575. package/es/directives/index.d.ts +1 -1
  576. package/es/hooks/use-calc-input-width/index.d.ts +2 -2
  577. package/es/hooks/use-composition/index.d.ts +1 -1
  578. package/es/hooks/use-draggable/index.d.ts +1 -1
  579. package/es/hooks/use-empty-values/index.d.ts +1 -1
  580. package/es/hooks/use-floating/index.d.ts +58 -6
  581. package/es/hooks/use-focus-controller/index.d.ts +2 -2
  582. package/es/hooks/use-model-toggle/index.d.ts +1 -1
  583. package/es/hooks/use-ordered-children/index.d.ts +2 -2
  584. package/es/hooks/use-popper/index.d.ts +1 -1
  585. package/es/hooks/use-teleport/index.d.ts +1 -1
  586. package/es/hooks/use-throttle-render/index.d.ts +1 -1
  587. package/es/index.d.ts +9 -9
  588. package/es/utils/index.d.ts +2 -2
  589. package/es/utils/typescript.d.ts +5 -1
  590. package/es/utils/typescript.mjs.map +1 -1
  591. package/es/utils/vue/icon.d.ts +14 -14
  592. package/es/version.mjs +1 -1
  593. package/es/version.mjs.map +1 -1
  594. package/lib/components/affix/src/affix.d.ts +5 -5
  595. package/lib/components/affix/src/affix.js.map +1 -1
  596. package/lib/components/affix/src/affix.vue.d.ts +10 -31
  597. package/lib/components/alert/src/alert.vue.d.ts +6 -30
  598. package/lib/components/anchor/src/anchor-link.vue.d.ts +2 -16
  599. package/lib/components/anchor/src/anchor.d.ts +3 -3
  600. package/lib/components/anchor/src/anchor.vue.d.ts +5 -29
  601. package/lib/components/autocomplete/src/autocomplete.d.ts +16 -21
  602. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +25 -73
  603. package/lib/components/avatar/src/avatar-group-props.d.ts +3 -3
  604. package/lib/components/avatar/src/avatar-group.d.ts +10 -10
  605. package/lib/components/avatar/src/avatar.d.ts +5 -5
  606. package/lib/components/avatar/src/avatar.js.map +1 -1
  607. package/lib/components/avatar/src/avatar.vue.d.ts +7 -22
  608. package/lib/components/backtop/src/backtop.vue.d.ts +4 -24
  609. package/lib/components/badge/src/badge.d.ts +2 -2
  610. package/lib/components/badge/src/badge.vue.d.ts +4 -28
  611. package/lib/components/breadcrumb/src/breadcrumb-item.d.ts +1 -1
  612. package/lib/components/breadcrumb/src/breadcrumb-item.vue.d.ts +2 -16
  613. package/lib/components/breadcrumb/src/breadcrumb.d.ts +1 -1
  614. package/lib/components/breadcrumb/src/breadcrumb.vue.d.ts +2 -16
  615. package/lib/components/button/src/button-group.vue.d.ts +2 -18
  616. package/lib/components/button/src/button.d.ts +4 -4
  617. package/lib/components/button/src/button.vue.d.ts +10 -42
  618. package/lib/components/calendar/src/calendar.d.ts +1 -1
  619. package/lib/components/calendar/src/calendar.vue.d.ts +6 -20
  620. package/lib/components/calendar/src/date-table.d.ts +7 -1
  621. package/lib/components/calendar/src/date-table.vue.d.ts +4 -4
  622. package/lib/components/card/src/card.d.ts +1 -1
  623. package/lib/components/card/src/card.vue.d.ts +2 -22
  624. package/lib/components/carousel/src/carousel-item.vue.d.ts +3 -19
  625. package/lib/components/carousel/src/carousel.d.ts +1 -1
  626. package/lib/components/carousel/src/carousel.vue.d.ts +8 -44
  627. package/lib/components/cascader/src/cascader.d.ts +16 -21
  628. package/lib/components/cascader/src/cascader.vue.d.ts +21 -77
  629. package/lib/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.js.map +1 -1
  630. package/lib/components/cascader/src/cascader2.js.map +1 -1
  631. package/lib/components/cascader-panel/src/config.d.ts +6 -6
  632. package/lib/components/cascader-panel/src/index.vue.d.ts +128 -26
  633. package/lib/components/cascader-panel/src/menu.vue.d.ts +3 -3
  634. package/lib/components/check-tag/src/check-tag.vue.d.ts +4 -18
  635. package/lib/components/checkbox/src/checkbox-button.vue.d.ts +10 -44
  636. package/lib/components/checkbox/src/checkbox-group.d.ts +2 -2
  637. package/lib/components/checkbox/src/checkbox-group.vue.d.ts +9 -41
  638. package/lib/components/checkbox/src/checkbox.d.ts +8 -8
  639. package/lib/components/checkbox/src/checkbox.vue.d.ts +10 -44
  640. package/lib/components/checkbox/src/composables/use-checkbox-model.d.ts +2 -2
  641. package/lib/components/checkbox/src/composables/use-checkbox-status.d.ts +1 -1
  642. package/lib/components/checkbox/src/composables/use-checkbox.d.ts +3 -3
  643. package/lib/components/col/src/col.d.ts +5 -5
  644. package/lib/components/col/src/col.vue.d.ts +2 -34
  645. package/lib/components/collapse/src/collapse-item.d.ts +3 -8
  646. package/lib/components/collapse/src/collapse-item.vue.d.ts +3 -19
  647. package/lib/components/collapse/src/collapse.d.ts +2 -2
  648. package/lib/components/collapse/src/collapse.vue.d.ts +6 -22
  649. package/lib/components/collapse-transition/src/collapse-transition.vue.d.ts +1 -1
  650. package/lib/components/collection/src/collection.d.ts +6 -6
  651. package/lib/components/color-picker/src/color-picker.d.ts +7 -7
  652. package/lib/components/color-picker/src/color-picker.vue.d.ts +12 -42
  653. package/lib/components/color-picker-panel/src/color-picker-panel.d.ts +4 -4
  654. package/lib/components/color-picker-panel/src/color-picker-panel.vue.d.ts +7 -27
  655. package/lib/components/config-provider/src/config-provider-props.d.ts +1 -1
  656. package/lib/components/config-provider/src/config-provider.d.ts +8 -8
  657. package/lib/components/config-provider/src/hooks/use-global-config.d.ts +1 -1
  658. package/lib/components/container/src/aside.vue.d.ts +2 -16
  659. package/lib/components/container/src/container.vue.d.ts +7 -1
  660. package/lib/components/container/src/footer.vue.d.ts +2 -16
  661. package/lib/components/container/src/header.vue.d.ts +2 -16
  662. package/lib/components/container/src/main.vue.d.ts +1 -1
  663. package/lib/components/countdown/src/countdown.d.ts +2 -2
  664. package/lib/components/countdown/src/countdown.vue.d.ts +6 -24
  665. package/lib/components/date-picker/src/date-picker.d.ts +47 -56
  666. package/lib/components/date-picker/src/props.d.ts +16 -21
  667. package/lib/components/date-picker-panel/src/date-picker-panel.d.ts +17 -17
  668. package/lib/components/date-picker-panel/src/props/date-picker-panel.d.ts +4 -4
  669. package/lib/components/descriptions/src/description-item.d.ts +18 -18
  670. package/lib/components/descriptions/src/description.vue.d.ts +2 -22
  671. package/lib/components/dialog/src/dialog.d.ts +3 -3
  672. package/lib/components/dialog/src/dialog.vue.d.ts +14 -56
  673. package/lib/components/dialog/src/use-dialog.d.ts +7 -7
  674. package/lib/components/divider/src/divider.d.ts +1 -1
  675. package/lib/components/divider/src/divider.vue.d.ts +2 -20
  676. package/lib/components/drawer/src/drawer.d.ts +3 -3
  677. package/lib/components/drawer/src/drawer.vue.d.ts +14 -64
  678. package/lib/components/dropdown/src/dropdown-item-impl.js.map +1 -1
  679. package/lib/components/dropdown/src/dropdown-item.js.map +1 -1
  680. package/lib/components/dropdown/src/dropdown-item.vue.d.ts +141 -9
  681. package/lib/components/dropdown/src/dropdown-menu.js.map +1 -1
  682. package/lib/components/dropdown/src/dropdown-menu.vue.d.ts +6 -6
  683. package/lib/components/dropdown/src/dropdown.d.ts +14 -14
  684. package/lib/components/dropdown/src/dropdown.vue.d.ts +576 -52
  685. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  686. package/lib/components/empty/src/empty.vue.d.ts +2 -18
  687. package/lib/components/focus-trap/src/focus-trap.vue.d.ts +6 -6
  688. package/lib/components/focus-trap/src/utils.d.ts +3 -3
  689. package/lib/components/form/src/form-item.d.ts +2 -2
  690. package/lib/components/form/src/form-item.vue.d.ts +5 -25
  691. package/lib/components/form/src/form.d.ts +1 -1
  692. package/lib/components/form/src/form.vue.d.ts +6 -32
  693. package/lib/components/form/src/hooks/use-form-item.d.ts +1 -1
  694. package/lib/components/icon/src/icon.d.ts +1 -1
  695. package/lib/components/icon/src/icon.vue.d.ts +2 -16
  696. package/lib/components/image/src/image.d.ts +3 -3
  697. package/lib/components/image/src/image.vue.d.ts +13 -45
  698. package/lib/components/image-viewer/src/image-viewer.d.ts +2 -2
  699. package/lib/components/image-viewer/src/image-viewer.vue.d.ts +10 -38
  700. package/lib/components/index.d.ts +8 -8
  701. package/lib/components/infinite-scroll/index.d.ts +1 -1
  702. package/lib/components/input/src/input.d.ts +12 -17
  703. package/lib/components/input/src/input.vue.d.ts +23 -57
  704. package/lib/components/input-number/src/input-number.d.ts +4 -4
  705. package/lib/components/input-number/src/input-number.vue.d.ts +15 -53
  706. package/lib/components/input-tag/src/composables/use-drag-tag.d.ts +2 -2
  707. package/lib/components/input-tag/src/composables/use-hovering.d.ts +1 -1
  708. package/lib/components/input-tag/src/composables/use-input-tag-dom.d.ts +4 -3
  709. package/lib/components/input-tag/src/composables/use-input-tag.d.ts +6 -6
  710. package/lib/components/input-tag/src/input-tag.d.ts +4 -9
  711. package/lib/components/input-tag/src/input-tag.vue.d.ts +15 -53
  712. package/lib/components/link/src/link.d.ts +2 -2
  713. package/lib/components/link/src/link.vue.d.ts +4 -24
  714. package/lib/components/loading/src/loading.d.ts +19 -15
  715. package/lib/components/mention/src/mention.d.ts +19 -24
  716. package/lib/components/mention/src/mention.vue.d.ts +21 -71
  717. package/lib/components/menu/index.d.ts +1 -1
  718. package/lib/components/menu/src/menu-item-group.vue.d.ts +2 -1
  719. package/lib/components/menu/src/menu-item.d.ts +2 -2
  720. package/lib/components/menu/src/menu-item.vue.d.ts +5 -19
  721. package/lib/components/menu/src/menu.d.ts +26 -26
  722. package/lib/components/menu/src/sub-menu.d.ts +21 -21
  723. package/lib/components/message/src/message.d.ts +5 -5
  724. package/lib/components/message/src/message.vue.d.ts +11 -56
  725. package/lib/components/message-box/src/index.js.map +1 -1
  726. package/lib/components/notification/src/notification.d.ts +6 -11
  727. package/lib/components/notification/src/notification.vue.d.ts +12 -46
  728. package/lib/components/overlay/index.d.ts +11 -11
  729. package/lib/components/overlay/src/overlay.d.ts +3 -3
  730. package/lib/components/overlay/src/overlay.js.map +1 -1
  731. package/lib/components/page-header/src/page-header.d.ts +1 -1
  732. package/lib/components/page-header/src/page-header.vue.d.ts +4 -20
  733. package/lib/components/pagination/src/pagination.d.ts +22 -22
  734. package/lib/components/popconfirm/src/popconfirm.d.ts +2 -2
  735. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +7 -35
  736. package/lib/components/popover/src/popover.d.ts +11 -11
  737. package/lib/components/popover/src/popover.vue.d.ts +12 -60
  738. package/lib/components/popper/src/arrow.vue.d.ts +2 -2
  739. package/lib/components/popper/src/composables/use-content-dom.d.ts +1 -1
  740. package/lib/components/popper/src/composables/use-content.d.ts +3 -3
  741. package/lib/components/popper/src/composables/use-focus-trap.d.ts +2 -2
  742. package/lib/components/popper/src/content.d.ts +18 -18
  743. package/lib/components/popper/src/content.vue.d.ts +15 -63
  744. package/lib/components/popper/src/popper.d.ts +2 -2
  745. package/lib/components/popper/src/popper.vue.d.ts +2 -16
  746. package/lib/components/popper/src/trigger.vue.d.ts +3 -13
  747. package/lib/components/progress/src/progress.d.ts +4 -4
  748. package/lib/components/progress/src/progress.vue.d.ts +4 -36
  749. package/lib/components/radio/src/radio-button.d.ts +3 -3
  750. package/lib/components/radio/src/radio-button.vue.d.ts +5 -27
  751. package/lib/components/radio/src/radio-group.d.ts +1 -1
  752. package/lib/components/radio/src/radio-group.vue.d.ts +9 -39
  753. package/lib/components/radio/src/radio.d.ts +6 -6
  754. package/lib/components/radio/src/radio.vue.d.ts +7 -31
  755. package/lib/components/rate/src/rate.d.ts +5 -5
  756. package/lib/components/rate/src/rate.vue.d.ts +7 -49
  757. package/lib/components/result/src/result.vue.d.ts +2 -20
  758. package/lib/components/roving-focus-group/src/roving-focus-group.d.ts +9 -9
  759. package/lib/components/roving-focus-group/src/roving-focus-group.vue.d.ts +77 -1
  760. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  761. package/lib/components/roving-focus-group/src/roving-focus-item.js.map +1 -1
  762. package/lib/components/roving-focus-group/src/roving-focus-item.vue.d.ts +26 -7
  763. package/lib/components/row/src/row.vue.d.ts +2 -20
  764. package/lib/components/scrollbar/src/scrollbar.d.ts +1 -1
  765. package/lib/components/scrollbar/src/scrollbar.vue.d.ts +7 -39
  766. package/lib/components/scrollbar/src/thumb.vue.d.ts +2 -1
  767. package/lib/components/segmented/index.d.ts +30 -243
  768. package/lib/components/segmented/src/segmented.d.ts +4 -4
  769. package/lib/components/segmented/src/segmented.vue.d.ts +7 -31
  770. package/lib/components/select/src/option-group.js.map +1 -1
  771. package/lib/components/select/src/option-group.vue.d.ts +6 -6
  772. package/lib/components/select/src/option.d.ts +2 -2
  773. package/lib/components/select/src/option.vue.d.ts +13 -13
  774. package/lib/components/select/src/option2.js.map +1 -1
  775. package/lib/components/select/src/select-dropdown.js.map +1 -1
  776. package/lib/components/select/src/select.d.ts +13 -23
  777. package/lib/components/select/src/select.vue.d.ts +572 -108
  778. package/lib/components/select/src/select2.js.map +1 -1
  779. package/lib/components/select-v2/src/defaults.d.ts +16 -26
  780. package/lib/components/select-v2/src/group-item.js.map +1 -1
  781. package/lib/components/select-v2/src/option-item.js.map +1 -1
  782. package/lib/components/select-v2/src/select.js.map +1 -1
  783. package/lib/components/select-v2/src/select.vue.d.ts +362 -107
  784. package/lib/components/skeleton/src/skeleton-item.d.ts +1 -1
  785. package/lib/components/skeleton/src/skeleton-item.vue.d.ts +2 -16
  786. package/lib/components/skeleton/src/skeleton.d.ts +2 -2
  787. package/lib/components/skeleton/src/skeleton.vue.d.ts +4 -22
  788. package/lib/components/slider/src/button.vue.d.ts +9 -9
  789. package/lib/components/slider/src/composables/use-lifecycle.d.ts +1 -1
  790. package/lib/components/slider/src/composables/use-slide.d.ts +3 -3
  791. package/lib/components/slider/src/composables/use-slider-button.d.ts +5 -5
  792. package/lib/components/slider/src/marker.d.ts +2 -2
  793. package/lib/components/slider/src/slider.d.ts +6 -6
  794. package/lib/components/slider/src/slider.vue.d.ts +27 -27
  795. package/lib/components/slot/src/only-child.d.ts +1 -1
  796. package/lib/components/space/src/item.d.ts +4 -4
  797. package/lib/components/space/src/space.d.ts +22 -23
  798. package/lib/components/space/src/space.js.map +1 -1
  799. package/lib/components/space/src/use-space.d.ts +1 -1
  800. package/lib/components/splitter/src/hooks/useContainer.d.ts +2 -2
  801. package/lib/components/splitter/src/hooks/useResize.d.ts +7 -1
  802. package/lib/components/splitter/src/hooks/useSize.d.ts +1 -1
  803. package/lib/components/splitter/src/split-panel.vue.d.ts +6 -20
  804. package/lib/components/splitter/src/splitter.vue.d.ts +4 -18
  805. package/lib/components/statistic/src/statistic.d.ts +2 -2
  806. package/lib/components/statistic/src/statistic.vue.d.ts +3 -25
  807. package/lib/components/steps/src/item.d.ts +2 -2
  808. package/lib/components/steps/src/item.vue.d.ts +2 -22
  809. package/lib/components/steps/src/steps.d.ts +2 -2
  810. package/lib/components/steps/src/steps.vue.d.ts +4 -26
  811. package/lib/components/switch/src/switch.d.ts +5 -5
  812. package/lib/components/switch/src/switch.vue.d.ts +7 -37
  813. package/lib/components/table/src/filter-panel.js.map +1 -1
  814. package/lib/components/table/src/h-helper.d.ts +17 -0
  815. package/lib/components/table/src/store/index.d.ts +880 -880
  816. package/lib/components/table/src/table-body/index.d.ts +10 -8
  817. package/lib/components/table/src/table-column/index.d.ts +109 -9
  818. package/lib/components/table/src/table-footer/index.d.ts +6 -6
  819. package/lib/components/table/src/table-header/index.d.ts +110 -8
  820. package/lib/components/table/src/table.js.map +1 -1
  821. package/lib/components/table/src/table.vue.d.ts +945 -474
  822. package/lib/components/table-v2/src/cell.d.ts +1 -1
  823. package/lib/components/table-v2/src/components/auto-resizer.d.ts +4 -4
  824. package/lib/components/table-v2/src/components/header-row.d.ts +3 -3
  825. package/lib/components/table-v2/src/components/header.d.ts +7 -7
  826. package/lib/components/table-v2/src/components/row.d.ts +7 -7
  827. package/lib/components/table-v2/src/composables/use-auto-resize.d.ts +3 -3
  828. package/lib/components/table-v2/src/composables/use-data.d.ts +1 -1
  829. package/lib/components/table-v2/src/composables/use-row.d.ts +4 -4
  830. package/lib/components/table-v2/src/composables/use-scrollbar.d.ts +3 -0
  831. package/lib/components/table-v2/src/header.d.ts +1 -1
  832. package/lib/components/table-v2/src/row.d.ts +1 -1
  833. package/lib/components/table-v2/src/table-grid.d.ts +10 -10
  834. package/lib/components/table-v2/src/table-v2.d.ts +24 -24
  835. package/lib/components/table-v2/src/table.d.ts +9 -9
  836. package/lib/components/table-v2/src/use-table.d.ts +8 -8
  837. package/lib/components/tabs/src/tab-bar.d.ts +4 -4
  838. package/lib/components/tabs/src/tab-bar.vue.d.ts +4 -20
  839. package/lib/components/tabs/src/tab-nav.d.ts +11 -11
  840. package/lib/components/tabs/src/tab-pane.vue.d.ts +2 -18
  841. package/lib/components/tabs/src/tabs.d.ts +13 -13
  842. package/lib/components/tag/src/tag.vue.d.ts +6 -22
  843. package/lib/components/teleport/src/teleport.d.ts +1 -1
  844. package/lib/components/teleport/src/teleport.vue.d.ts +6 -6
  845. package/lib/components/text/src/text.vue.d.ts +2 -20
  846. package/lib/components/time-picker/src/common/picker.vue.d.ts +52 -61
  847. package/lib/components/time-picker/src/common/props.d.ts +17 -22
  848. package/lib/components/time-picker/src/composables/use-common-picker.d.ts +13 -3
  849. package/lib/components/time-picker/src/time-picker-com/panel-time-pick.vue.d.ts +5 -5
  850. package/lib/components/time-picker/src/time-picker.d.ts +44 -53
  851. package/lib/components/time-select/src/time-select.d.ts +8 -8
  852. package/lib/components/time-select/src/time-select.vue.d.ts +15 -53
  853. package/lib/components/timeline/src/timeline-item.d.ts +1 -1
  854. package/lib/components/timeline/src/timeline-item.vue.d.ts +3 -25
  855. package/lib/components/timeline/src/timeline.d.ts +5 -5
  856. package/lib/components/tooltip/src/content.d.ts +11 -11
  857. package/lib/components/tooltip/src/content.vue.d.ts +13 -71
  858. package/lib/components/tooltip/src/tooltip.d.ts +14 -14
  859. package/lib/components/tooltip/src/tooltip.vue.d.ts +20 -86
  860. package/lib/components/tooltip/src/trigger.d.ts +2 -2
  861. package/lib/components/tour/src/content.d.ts +3 -3
  862. package/lib/components/tour/src/step.d.ts +8 -8
  863. package/lib/components/tour/src/step.vue.d.ts +6 -28
  864. package/lib/components/tour/src/tour.d.ts +9 -9
  865. package/lib/components/tour/src/tour.vue.d.ts +11 -53
  866. package/lib/components/transfer/src/transfer-panel.vue.d.ts +6 -36
  867. package/lib/components/transfer/src/transfer.d.ts +8 -8
  868. package/lib/components/transfer/src/transfer.vue.d.ts +9 -49
  869. package/lib/components/tree/src/model/useDragNode.d.ts +1 -1
  870. package/lib/components/tree/src/tree-node.js.map +1 -1
  871. package/lib/components/tree/src/tree.d.ts +4 -4
  872. package/lib/components/tree/src/tree.vue.d.ts +594 -23
  873. package/lib/components/tree/src/tree2.js.map +1 -1
  874. package/lib/components/tree-select/src/tree-select.vue.d.ts +68 -86
  875. package/lib/components/tree-v2/src/tree.vue.d.ts +7 -54
  876. package/lib/components/tree-v2/src/virtual-tree.d.ts +1 -12
  877. package/lib/components/upload/src/upload-content.d.ts +19 -19
  878. package/lib/components/upload/src/upload-content.vue.d.ts +6 -54
  879. package/lib/components/upload/src/upload-dragger.vue.d.ts +4 -18
  880. package/lib/components/upload/src/upload-list.d.ts +4 -4
  881. package/lib/components/upload/src/upload-list.vue.d.ts +4 -24
  882. package/lib/components/upload/src/upload.d.ts +27 -27
  883. package/lib/components/upload/src/upload.vue.d.ts +6 -56
  884. package/lib/components/virtual-list/src/builders/build-grid.d.ts +24 -24
  885. package/lib/components/virtual-list/src/components/dynamic-size-grid.d.ts +24 -24
  886. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +35 -21
  887. package/lib/components/virtual-list/src/components/fixed-size-grid.d.ts +24 -24
  888. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +35 -21
  889. package/lib/components/virtual-list/src/hooks/use-cache.d.ts +1 -3
  890. package/lib/components/virtual-list/src/hooks/use-cache.js.map +1 -1
  891. package/lib/components/virtual-list/src/props.d.ts +17 -17
  892. package/lib/components/watermark/src/watermark.d.ts +2 -2
  893. package/lib/components/watermark/src/watermark.vue.d.ts +4 -24
  894. package/lib/directives/index.d.ts +1 -1
  895. package/lib/hooks/use-calc-input-width/index.d.ts +2 -2
  896. package/lib/hooks/use-composition/index.d.ts +1 -1
  897. package/lib/hooks/use-draggable/index.d.ts +1 -1
  898. package/lib/hooks/use-empty-values/index.d.ts +1 -1
  899. package/lib/hooks/use-floating/index.d.ts +58 -6
  900. package/lib/hooks/use-focus-controller/index.d.ts +2 -2
  901. package/lib/hooks/use-model-toggle/index.d.ts +1 -1
  902. package/lib/hooks/use-ordered-children/index.d.ts +2 -2
  903. package/lib/hooks/use-popper/index.d.ts +1 -1
  904. package/lib/hooks/use-teleport/index.d.ts +1 -1
  905. package/lib/hooks/use-throttle-render/index.d.ts +1 -1
  906. package/lib/index.d.ts +9 -9
  907. package/lib/utils/index.d.ts +2 -2
  908. package/lib/utils/typescript.d.ts +5 -1
  909. package/lib/utils/typescript.js.map +1 -1
  910. package/lib/utils/vue/icon.d.ts +14 -14
  911. package/lib/version.js +1 -1
  912. package/lib/version.js.map +1 -1
  913. package/package.json +2 -2
  914. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"cascader.vue_vue_type_script_setup_true_lang.js","names":["$slots","$nextTick"],"sources":["../../../../../../packages/components/cascader/src/cascader.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"tooltipRef\"\n :visible=\"popperVisible\"\n :teleported=\"teleported\"\n :popper-class=\"[nsCascader.e('dropdown'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :popper-options=\"popperOptions\"\n :fallback-placements=\"fallbackPlacements\"\n :stop-popper-mouse-event=\"false\"\n :gpu-acceleration=\"false\"\n :placement=\"placement\"\n :transition=\"`${nsCascader.namespace.value}-zoom-in-top`\"\n :effect=\"effect\"\n pure\n :persistent=\"persistent\"\n @hide=\"hideSuggestionPanel\"\n >\n <template #default>\n <div\n ref=\"wrapperRef\"\n v-clickoutside:[contentRef]=\"handleClickOutside\"\n :class=\"cascaderKls\"\n :style=\"cascaderStyle\"\n @click=\"() => togglePopperVisible(readonly ? undefined : true)\"\n @keydown=\"handleKeyDown\"\n @mouseenter=\"inputHover = true\"\n @mouseleave=\"inputHover = false\"\n >\n <el-input\n ref=\"inputRef\"\n v-model=\"inputValue\"\n :placeholder=\"currentPlaceholder\"\n :readonly=\"readonly\"\n :disabled=\"isDisabled\"\n :validate-event=\"false\"\n :size=\"realSize\"\n :class=\"inputClass\"\n :tabindex=\"multiple && filterable && !isDisabled ? -1 : undefined\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n @input=\"handleInput\"\n >\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template #suffix>\n <el-icon\n v-if=\"clearBtnVisible\"\n key=\"clear\"\n :class=\"[nsInput.e('icon'), 'icon-circle-close']\"\n @click.stop=\"handleClear\"\n >\n <component :is=\"clearIcon\" />\n </el-icon>\n <el-icon\n v-else\n key=\"arrow-down\"\n :class=\"cascaderIconKls\"\n @click.stop=\"togglePopperVisible()\"\n >\n <arrow-down />\n </el-icon>\n </template>\n </el-input>\n\n <div\n v-if=\"multiple\"\n ref=\"tagWrapper\"\n :class=\"[\n nsCascader.e('tags'),\n nsCascader.is('validate', Boolean(validateState)),\n ]\"\n >\n <slot name=\"tag\" :data=\"tags\" :delete-tag=\"deleteTag\">\n <el-tag\n v-for=\"tag in showTagList\"\n :key=\"tag.key\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </slot>\n <el-tooltip\n v-if=\"collapseTags && tags.length > maxCollapseTags\"\n ref=\"tagTooltipRef\"\n :disabled=\"popperVisible || !collapseTagsTooltip\"\n :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n placement=\"bottom\"\n :popper-class=\"popperClass\"\n :popper-style=\"popperStyle\"\n :effect=\"effect\"\n :persistent=\"persistent\"\n >\n <template #default>\n <el-tag\n :closable=\"false\"\n :size=\"tagSize\"\n :type=\"tagType\"\n :effect=\"tagEffect\"\n disable-transitions\n >\n <span :class=\"nsCascader.e('tags-text')\">\n + {{ tags.length - maxCollapseTags }}\n </span>\n </el-tag>\n </template>\n <template #content>\n <el-scrollbar :max-height=\"maxCollapseTagsTooltipHeight\">\n <div :class=\"nsCascader.e('collapse-tags')\">\n <div\n v-for=\"(tag, idx) in collapseTagList\"\n :key=\"idx\"\n :class=\"nsCascader.e('collapse-tag')\"\n >\n <el-tag\n :key=\"tag.key\"\n class=\"in-tooltip\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </div>\n </div>\n </el-scrollbar>\n </template>\n </el-tooltip>\n <input\n v-if=\"filterable && !isDisabled\"\n v-model=\"searchInputValue\"\n type=\"text\"\n :class=\"nsCascader.e('search-input')\"\n :placeholder=\"presentText ? '' : inputPlaceholder\"\n @input=\"(e) => handleInput(searchInputValue, e as InputEvent)\"\n @click.stop=\"togglePopperVisible(true)\"\n @keydown.delete=\"handleDelete\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n />\n </div>\n </div>\n </template>\n\n <template #content>\n <div v-if=\"$slots.header\" :class=\"nsCascader.e('header')\" @click.stop>\n <slot name=\"header\" />\n </div>\n <el-cascader-panel\n v-show=\"!filtering\"\n ref=\"cascaderPanelRef\"\n v-model=\"checkedValue\"\n :options=\"options\"\n :props=\"props.props\"\n :border=\"false\"\n :render-label=\"$slots.default\"\n @expand-change=\"handleExpandChange\"\n @close=\"$nextTick(() => togglePopperVisible(false))\"\n >\n <template #empty>\n <slot name=\"empty\" />\n </template>\n </el-cascader-panel>\n <el-scrollbar\n v-if=\"filterable\"\n v-show=\"filtering\"\n ref=\"suggestionPanel\"\n tag=\"ul\"\n :class=\"nsCascader.e('suggestion-panel')\"\n :view-class=\"nsCascader.e('suggestion-list')\"\n @keydown=\"handleSuggestionKeyDown\"\n >\n <template v-if=\"suggestions.length\">\n <li\n v-for=\"item in suggestions\"\n :key=\"item.uid\"\n :class=\"[\n nsCascader.e('suggestion-item'),\n nsCascader.is('checked', item.checked),\n ]\"\n :tabindex=\"-1\"\n @click=\"handleSuggestionClick(item)\"\n >\n <slot name=\"suggestion-item\" :item=\"item\">\n <span>{{ item.text }}</span>\n <el-icon v-if=\"item.checked\">\n <check />\n </el-icon>\n </slot>\n </li>\n </template>\n <slot v-else name=\"empty\">\n <li :class=\"nsCascader.e('empty-text')\">\n {{ t('el.cascader.noMatch') }}\n </li>\n </slot>\n </el-scrollbar>\n <div v-if=\"$slots.footer\" :class=\"nsCascader.e('footer')\" @click.stop>\n <slot name=\"footer\" />\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n markRaw,\n nextTick,\n onMounted,\n ref,\n useAttrs,\n watch,\n} from 'vue'\nimport { cloneDeep } from 'lodash-unified'\nimport { useCssVar, useDebounceFn, useResizeObserver } from '@vueuse/core'\nimport {\n debugWarn,\n focusNode,\n getEventCode,\n getSibling,\n isClient,\n isPromise,\n} from '@element-plus/utils'\nimport ElCascaderPanel from '@element-plus/components/cascader-panel'\nimport ElInput from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport {\n useComposition,\n useEmptyValues,\n useFocusController,\n useLocale,\n useNamespace,\n} from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { ArrowDown, Check, CircleClose } from '@element-plus/icons-vue'\nimport { cascaderEmits } from './cascader'\n\nimport type { Options } from '@element-plus/components/popper'\nimport type { ComputedRef, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { ScrollbarInstance } from '@element-plus/components/scrollbar'\nimport type {\n CascaderNode,\n CascaderPanelInstance,\n CascaderValue,\n Tag,\n} from '@element-plus/components/cascader-panel'\nimport type { CascaderComponentProps } from './cascader'\n\nconst popperOptions: Partial<Options> = {\n modifiers: [\n {\n name: 'arrowPosition',\n enabled: true,\n phase: 'main',\n fn: ({ state }) => {\n const { modifiersData, placement } = state\n if (['right', 'left', 'bottom', 'top'].includes(placement)) return\n if (modifiersData.arrow) {\n modifiersData.arrow.x = 35\n }\n },\n requires: ['arrow'],\n },\n ],\n}\n\ndefineOptions({\n name: 'ElCascader',\n})\n\nconst props = withDefaults(defineProps<CascaderComponentProps>(), {\n options: () => [],\n props: () => ({}),\n disabled: undefined,\n clearIcon: markRaw(CircleClose),\n filterMethod: (node, keyword) => node.text.includes(keyword),\n separator: ' / ',\n showAllLevels: true,\n maxCollapseTags: 1,\n debounce: 300,\n beforeFilter: () => true,\n placement: 'bottom-start',\n fallbackPlacements: () => [\n 'bottom-start',\n 'bottom',\n 'top-start',\n 'top',\n 'right',\n 'left',\n ],\n teleported: true,\n effect: 'light',\n tagType: 'info',\n tagEffect: 'light',\n validateEvent: true,\n persistent: true,\n showCheckedStrategy: 'child',\n showPrefix: true,\n popperStyle: undefined,\n valueOnClear: undefined,\n})\nconst emit = defineEmits(cascaderEmits)\nconst attrs = useAttrs()\nconst slots = defineSlots()\n\nlet inputInitialHeight = 0\nlet pressDeleteCount = 0\n\nconst nsCascader = useNamespace('cascader')\nconst nsInput = useNamespace('input')\nconst sizeMapPadding = {\n small: 7,\n default: 11,\n large: 15,\n}\n\nconst { t } = useLocale()\nconst { formItem } = useFormItem()\nconst isDisabled = useFormDisabled()\nconst { valueOnClear } = useEmptyValues(props)\nconst { isComposing, handleComposition } = useComposition({\n afterComposition(event) {\n const text = (event.target as HTMLInputElement)?.value\n handleInput(text)\n },\n})\n\nconst tooltipRef = ref<TooltipInstance>()\nconst tagTooltipRef = ref<TooltipInstance>()\nconst inputRef = ref<InputInstance>()\nconst tagWrapper = ref<HTMLDivElement>()\nconst cascaderPanelRef = ref<CascaderPanelInstance>()\nconst suggestionPanel = ref<ScrollbarInstance>()\nconst popperVisible = ref(false)\nconst inputHover = ref(false)\nconst filtering = ref(false)\nconst inputValue = ref('')\nconst searchInputValue = ref('')\nconst tags = ref<Tag[]>([])\nconst suggestions = ref<CascaderNode[]>([])\n\nconst showTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags\n ? tags.value.slice(0, props.maxCollapseTags)\n : tags.value\n})\n\nconst collapseTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags ? tags.value.slice(props.maxCollapseTags) : []\n})\n\nconst cascaderStyle = computed(() => {\n return attrs.style as StyleValue\n})\n\nconst inputPlaceholder = computed(\n () => props.placeholder ?? t('el.cascader.placeholder')\n)\nconst currentPlaceholder = computed(() =>\n searchInputValue.value || tags.value.length > 0 || isComposing.value\n ? ''\n : inputPlaceholder.value\n)\nconst realSize = useFormSize()\nconst tagSize = computed(() =>\n realSize.value === 'small' ? 'small' : 'default'\n)\nconst multiple = computed(() => !!props.props.multiple)\nconst readonly = computed(() => !props.filterable || multiple.value)\nconst searchKeyword = computed(() =>\n multiple.value ? searchInputValue.value : inputValue.value\n)\nconst checkedNodes: ComputedRef<CascaderNode[]> = computed(\n () => cascaderPanelRef.value?.checkedNodes || []\n)\n\nconst { wrapperRef, isFocused, handleBlur } = useFocusController(inputRef, {\n disabled: isDisabled,\n beforeBlur(event) {\n return (\n tooltipRef.value?.isFocusInsideContent(event) ||\n tagTooltipRef.value?.isFocusInsideContent(event)\n )\n },\n afterBlur() {\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst clearBtnVisible = computed(() => {\n if (\n !props.clearable ||\n isDisabled.value ||\n filtering.value ||\n (!inputHover.value && !isFocused.value)\n )\n return false\n\n return !!checkedNodes.value.length\n})\nconst presentText = computed(() => {\n const { showAllLevels, separator } = props\n const nodes = checkedNodes.value\n return nodes.length\n ? multiple.value\n ? ''\n : nodes[0].calcText(showAllLevels, separator)\n : ''\n})\n\nconst validateState = computed(() => formItem?.validateState || '')\n\nconst checkedValue = computed<CascaderValue>({\n get() {\n return cloneDeep(props.modelValue) as CascaderValue\n },\n set(val) {\n // https://github.com/element-plus/element-plus/issues/17647\n const value = val ?? valueOnClear.value\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n if (props.validateEvent) {\n formItem?.validate('change').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst cascaderKls = computed(() => {\n return [\n nsCascader.b(),\n nsCascader.m(realSize.value),\n nsCascader.is('disabled', isDisabled.value),\n attrs.class,\n ]\n})\n\nconst cascaderIconKls = computed(() => {\n return [\n nsInput.e('icon'),\n 'icon-arrow-down',\n nsCascader.is('reverse', popperVisible.value),\n ]\n})\n\nconst inputClass = computed(() => nsCascader.is('focus', isFocused.value))\n\nconst contentRef = computed(() => {\n return tooltipRef.value?.popperRef?.contentRef\n})\n\nconst handleClickOutside = (event: Event) => {\n if (isFocused.value) {\n const _event = new FocusEvent('blur', event)\n handleBlur(_event)\n }\n togglePopperVisible(false)\n}\n\nconst togglePopperVisible = (visible?: boolean) => {\n if (isDisabled.value) return\n\n visible = visible ?? !popperVisible.value\n\n if (visible !== popperVisible.value) {\n popperVisible.value = visible\n inputRef.value?.input?.setAttribute('aria-expanded', `${visible}`)\n\n if (visible) {\n updatePopperPosition()\n cascaderPanelRef.value &&\n nextTick(cascaderPanelRef.value.scrollToExpandingNode)\n } else if (props.filterable) {\n syncPresentTextValue()\n }\n\n emit('visibleChange', visible)\n }\n}\n\nconst updatePopperPosition = () => {\n nextTick(() => {\n tooltipRef.value?.updatePopper()\n })\n}\nconst hideSuggestionPanel = () => {\n filtering.value = false\n}\n\nconst genTag = (node: CascaderNode): Tag => {\n const { showAllLevels, separator } = props\n return {\n node,\n key: node.uid,\n text: node.calcText(showAllLevels, separator),\n hitState: false,\n closable: !isDisabled.value && !node.isDisabled,\n }\n}\n\nconst deleteTag = (tag: Tag) => {\n const node = tag.node as CascaderNode\n node.doCheck(false)\n cascaderPanelRef.value?.calculateCheckedValue()\n emit('removeTag', node.valueByOption)\n}\n\nconst getStrategyCheckedNodes = (): CascaderNode[] => {\n switch (props.showCheckedStrategy) {\n case 'child':\n return checkedNodes.value\n case 'parent': {\n const clickedNodes = getCheckedNodes(false)\n const clickedNodesValue = clickedNodes!.map((o) => o.value)\n const parentNodes = clickedNodes!.filter(\n (o) => !o.parent || !clickedNodesValue.includes(o.parent.value)\n )\n return parentNodes\n }\n default:\n return []\n }\n}\n\nconst calculatePresentTags = () => {\n if (!multiple.value) return\n\n const nodes = getStrategyCheckedNodes()\n\n const allTags: Tag[] = []\n nodes.forEach((node) => allTags.push(genTag(node)))\n tags.value = allTags\n}\n\nconst calculateSuggestions = () => {\n const { filterMethod, showAllLevels, separator } = props\n const res = cascaderPanelRef.value\n ?.getFlattedNodes(!props.props.checkStrictly)\n ?.filter((node) => {\n if (node.isDisabled) return false\n node.calcText(showAllLevels, separator)\n return filterMethod(node, searchKeyword.value)\n })\n\n if (multiple.value) {\n tags.value.forEach((tag) => {\n tag.hitState = false\n })\n }\n\n filtering.value = true\n suggestions.value = res!\n updatePopperPosition()\n}\n\nconst focusFirstNode = () => {\n let firstNode!: HTMLElement\n\n if (filtering.value && suggestionPanel.value) {\n firstNode = suggestionPanel.value.$el.querySelector(\n `.${nsCascader.e('suggestion-item')}`\n )\n } else {\n firstNode = cascaderPanelRef.value?.$el.querySelector(\n `.${nsCascader.b('node')}[tabindex=\"-1\"]`\n )\n }\n\n if (firstNode) {\n firstNode.focus()\n !filtering.value && firstNode.click()\n }\n}\n\nconst updateStyle = () => {\n const inputInner = inputRef.value?.input\n const tagWrapperEl = tagWrapper.value\n const suggestionPanelEl = suggestionPanel.value?.$el\n\n if (!isClient || !inputInner) return\n\n if (suggestionPanelEl) {\n const suggestionList = suggestionPanelEl.querySelector(\n `.${nsCascader.e('suggestion-list')}`\n )\n suggestionList.style.minWidth = `${inputInner.offsetWidth}px`\n }\n\n if (tagWrapperEl) {\n const { offsetHeight } = tagWrapperEl\n // 2 is el-input__wrapper padding\n const height =\n tags.value.length > 0\n ? `${Math.max(offsetHeight, inputInitialHeight) - 2}px`\n : `${inputInitialHeight}px`\n inputInner.style.height = height\n // if prefix slot exists, update tagWrapperEl left position\n if (slots.prefix) {\n const prefix = inputRef.value?.$el.querySelector(\n `.${nsInput.e('prefix')}`\n ) as HTMLElement\n let left = 0\n if (prefix) {\n left = prefix.offsetWidth\n if (left > 0) {\n left += sizeMapPadding[realSize.value || 'default'] // this is the default padding of el-input__wrapper\n }\n }\n tagWrapperEl.style.left = `${left}px`\n } else {\n tagWrapperEl.style.left = `0`\n }\n updatePopperPosition()\n }\n}\n\nconst getCheckedNodes = (leafOnly: boolean) => {\n return cascaderPanelRef.value?.getCheckedNodes(leafOnly)\n}\n\nconst handleExpandChange = (value: CascaderValue) => {\n updatePopperPosition()\n emit('expandChange', value)\n}\n\nconst handleKeyDown = (e: KeyboardEvent) => {\n if (isComposing.value) return\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n togglePopperVisible()\n break\n case EVENT_CODE.down:\n togglePopperVisible(true)\n nextTick(focusFirstNode)\n e.preventDefault()\n break\n case EVENT_CODE.esc:\n if (popperVisible.value === true) {\n e.preventDefault()\n e.stopPropagation()\n togglePopperVisible(false)\n }\n break\n case EVENT_CODE.tab:\n togglePopperVisible(false)\n break\n }\n}\n\nconst handleClear = () => {\n cascaderPanelRef.value?.clearCheckedNodes()\n if (!popperVisible.value && props.filterable) {\n syncPresentTextValue()\n }\n togglePopperVisible(false)\n emit('clear')\n}\n\nconst syncPresentTextValue = () => {\n const { value } = presentText\n inputValue.value = value\n searchInputValue.value = value\n}\n\nconst handleSuggestionClick = (node: CascaderNode) => {\n const { checked } = node\n\n if (multiple.value) {\n cascaderPanelRef.value?.handleCheckChange(node, !checked, false)\n } else {\n !checked && cascaderPanelRef.value?.handleCheckChange(node, true, false)\n togglePopperVisible(false)\n }\n}\n\nconst handleSuggestionKeyDown = (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.up:\n case EVENT_CODE.down: {\n e.preventDefault()\n const distance = code === EVENT_CODE.up ? -1 : 1\n focusNode(\n getSibling(\n target,\n distance,\n `.${nsCascader.e('suggestion-item')}[tabindex=\"-1\"]`\n ) as HTMLElement\n )\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n target.click()\n break\n }\n}\n\nconst handleDelete = () => {\n const lastTag = tags.value[tags.value.length - 1]\n pressDeleteCount = searchInputValue.value ? 0 : pressDeleteCount + 1\n\n if (\n !lastTag ||\n !pressDeleteCount ||\n (props.collapseTags && tags.value.length > 1)\n )\n return\n\n if (lastTag.hitState) {\n deleteTag(lastTag)\n } else {\n lastTag.hitState = true\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst handleFilter = useDebounceFn(() => {\n const { value } = searchKeyword\n\n if (!value) return\n\n const passed = props.beforeFilter(value)\n\n if (isPromise(passed)) {\n passed.then(calculateSuggestions).catch(() => {\n /* prevent log error */\n })\n } else if (passed !== false) {\n calculateSuggestions()\n } else {\n hideSuggestionPanel()\n }\n}, debounce)\n\nconst handleInput = (val: string, e?: InputEvent) => {\n !popperVisible.value && togglePopperVisible(true)\n\n if (e?.isComposing) return\n\n val ? handleFilter() : hideSuggestionPanel()\n}\n\nconst getInputInnerHeight = (inputInner: HTMLElement): number =>\n Number.parseFloat(\n useCssVar(nsInput.cssVarName('input-height'), inputInner).value\n ) - 2\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nwatch(filtering, updatePopperPosition)\n\nwatch(\n [\n checkedNodes,\n isDisabled,\n () => props.collapseTags,\n () => props.maxCollapseTags,\n ],\n calculatePresentTags\n)\n\nwatch(tags, () => {\n nextTick(() => updateStyle())\n})\n\nwatch(realSize, async () => {\n await nextTick()\n const inputInner = inputRef.value!.input!\n inputInitialHeight = getInputInnerHeight(inputInner) || inputInitialHeight\n updateStyle()\n})\n\nwatch(presentText, syncPresentTextValue, { immediate: true })\n\nwatch(\n () => popperVisible.value,\n (val) => {\n if (val && props.props.lazy && props.props.lazyLoad) {\n cascaderPanelRef.value?.loadLazyRootNodes()\n }\n }\n)\n\nonMounted(() => {\n const inputInner = inputRef.value!.input!\n\n const inputInnerHeight = getInputInnerHeight(inputInner)\n\n inputInitialHeight = inputInner.offsetHeight || inputInnerHeight\n useResizeObserver(inputInner, updateStyle)\n})\n\ndefineExpose({\n /**\n * @description get an array of currently selected node,(leafOnly) whether only return the leaf checked nodes, default is `false`\n */\n getCheckedNodes,\n /**\n * @description cascader panel ref\n */\n cascaderPanelRef,\n /**\n * @description toggle the visible of popper\n */\n togglePopperVisible,\n /**\n * @description cascader content ref\n */\n contentRef,\n /**\n * @description selected content text\n */\n presentText,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n})\n</script>\n"],"mappings":"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"}
1
+ {"version":3,"file":"cascader.vue_vue_type_script_setup_true_lang.js","names":["$slots","$nextTick"],"sources":["../../../../../../packages/components/cascader/src/cascader.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"tooltipRef\"\n :visible=\"popperVisible\"\n :teleported=\"teleported\"\n :popper-class=\"[nsCascader.e('dropdown'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :popper-options=\"popperOptions\"\n :fallback-placements=\"fallbackPlacements\"\n :stop-popper-mouse-event=\"false\"\n :gpu-acceleration=\"false\"\n :placement=\"placement\"\n :transition=\"`${nsCascader.namespace.value}-zoom-in-top`\"\n :effect=\"effect\"\n pure\n :persistent=\"persistent\"\n @hide=\"hideSuggestionPanel\"\n >\n <template #default>\n <div\n ref=\"wrapperRef\"\n v-clickoutside:[contentRef]=\"handleClickOutside\"\n :class=\"cascaderKls\"\n :style=\"cascaderStyle\"\n @click=\"() => togglePopperVisible(readonly ? undefined : true)\"\n @keydown=\"handleKeyDown\"\n @mouseenter=\"inputHover = true\"\n @mouseleave=\"inputHover = false\"\n >\n <el-input\n ref=\"inputRef\"\n v-model=\"inputValue\"\n :placeholder=\"currentPlaceholder\"\n :readonly=\"readonly\"\n :disabled=\"isDisabled\"\n :validate-event=\"false\"\n :size=\"realSize\"\n :class=\"inputClass\"\n :tabindex=\"multiple && filterable && !isDisabled ? -1 : undefined\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n @input=\"handleInput\"\n >\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template #suffix>\n <el-icon\n v-if=\"clearBtnVisible\"\n key=\"clear\"\n :class=\"[nsInput.e('icon'), 'icon-circle-close']\"\n @click.stop=\"handleClear\"\n >\n <component :is=\"clearIcon\" />\n </el-icon>\n <el-icon\n v-else\n key=\"arrow-down\"\n :class=\"cascaderIconKls\"\n @click.stop=\"togglePopperVisible()\"\n >\n <arrow-down />\n </el-icon>\n </template>\n </el-input>\n\n <div\n v-if=\"multiple\"\n ref=\"tagWrapper\"\n :class=\"[\n nsCascader.e('tags'),\n nsCascader.is('validate', Boolean(validateState)),\n ]\"\n >\n <slot name=\"tag\" :data=\"tags\" :delete-tag=\"deleteTag\">\n <el-tag\n v-for=\"tag in showTagList\"\n :key=\"tag.key\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </slot>\n <el-tooltip\n v-if=\"collapseTags && tags.length > maxCollapseTags\"\n ref=\"tagTooltipRef\"\n :disabled=\"popperVisible || !collapseTagsTooltip\"\n :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n placement=\"bottom\"\n :popper-class=\"popperClass\"\n :popper-style=\"popperStyle\"\n :effect=\"effect\"\n :persistent=\"persistent\"\n >\n <template #default>\n <el-tag\n :closable=\"false\"\n :size=\"tagSize\"\n :type=\"tagType\"\n :effect=\"tagEffect\"\n disable-transitions\n >\n <span :class=\"nsCascader.e('tags-text')\">\n + {{ tags.length - maxCollapseTags }}\n </span>\n </el-tag>\n </template>\n <template #content>\n <el-scrollbar :max-height=\"maxCollapseTagsTooltipHeight\">\n <div :class=\"nsCascader.e('collapse-tags')\">\n <div\n v-for=\"(tag, idx) in collapseTagList\"\n :key=\"idx\"\n :class=\"nsCascader.e('collapse-tag')\"\n >\n <el-tag\n :key=\"tag.key\"\n class=\"in-tooltip\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </div>\n </div>\n </el-scrollbar>\n </template>\n </el-tooltip>\n <input\n v-if=\"filterable && !isDisabled\"\n v-model=\"searchInputValue\"\n type=\"text\"\n :class=\"nsCascader.e('search-input')\"\n :placeholder=\"presentText ? '' : inputPlaceholder\"\n @input=\"(e) => handleInput(searchInputValue, e as InputEvent)\"\n @click.stop=\"togglePopperVisible(true)\"\n @keydown.delete=\"handleDelete\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n />\n </div>\n </div>\n </template>\n\n <template #content>\n <div v-if=\"$slots.header\" :class=\"nsCascader.e('header')\" @click.stop>\n <slot name=\"header\" />\n </div>\n <el-cascader-panel\n v-show=\"!filtering\"\n ref=\"cascaderPanelRef\"\n v-model=\"checkedValue\"\n :options=\"options\"\n :props=\"props.props\"\n :border=\"false\"\n :render-label=\"$slots.default\"\n @expand-change=\"handleExpandChange\"\n @close=\"$nextTick(() => togglePopperVisible(false))\"\n >\n <template #empty>\n <slot name=\"empty\" />\n </template>\n </el-cascader-panel>\n <el-scrollbar\n v-if=\"filterable\"\n v-show=\"filtering\"\n ref=\"suggestionPanel\"\n tag=\"ul\"\n :class=\"nsCascader.e('suggestion-panel')\"\n :view-class=\"nsCascader.e('suggestion-list')\"\n @keydown=\"handleSuggestionKeyDown\"\n >\n <template v-if=\"suggestions.length\">\n <li\n v-for=\"item in suggestions\"\n :key=\"item.uid\"\n :class=\"[\n nsCascader.e('suggestion-item'),\n nsCascader.is('checked', item.checked),\n ]\"\n :tabindex=\"-1\"\n @click=\"handleSuggestionClick(item)\"\n >\n <slot name=\"suggestion-item\" :item=\"item\">\n <span>{{ item.text }}</span>\n <el-icon v-if=\"item.checked\">\n <check />\n </el-icon>\n </slot>\n </li>\n </template>\n <slot v-else name=\"empty\">\n <li :class=\"nsCascader.e('empty-text')\">\n {{ t('el.cascader.noMatch') }}\n </li>\n </slot>\n </el-scrollbar>\n <div v-if=\"$slots.footer\" :class=\"nsCascader.e('footer')\" @click.stop>\n <slot name=\"footer\" />\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n markRaw,\n nextTick,\n onMounted,\n ref,\n useAttrs,\n watch,\n} from 'vue'\nimport { cloneDeep } from 'lodash-unified'\nimport { useCssVar, useDebounceFn, useResizeObserver } from '@vueuse/core'\nimport {\n debugWarn,\n focusNode,\n getEventCode,\n getSibling,\n isClient,\n isPromise,\n} from '@element-plus/utils'\nimport ElCascaderPanel from '@element-plus/components/cascader-panel'\nimport ElInput from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport {\n useComposition,\n useEmptyValues,\n useFocusController,\n useLocale,\n useNamespace,\n} from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { ArrowDown, Check, CircleClose } from '@element-plus/icons-vue'\nimport { cascaderEmits } from './cascader'\n\nimport type { Options } from '@element-plus/components/popper'\nimport type { ComputedRef, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { ScrollbarInstance } from '@element-plus/components/scrollbar'\nimport type {\n CascaderNode,\n CascaderPanelInstance,\n CascaderValue,\n Tag,\n} from '@element-plus/components/cascader-panel'\nimport type { CascaderComponentProps } from './cascader'\n\nconst popperOptions: Partial<Options> = {\n modifiers: [\n {\n name: 'arrowPosition',\n enabled: true,\n phase: 'main',\n fn: ({ state }) => {\n const { modifiersData, placement } = state\n if (['right', 'left', 'bottom', 'top'].includes(placement)) return\n if (modifiersData.arrow) {\n modifiersData.arrow.x = 35\n }\n },\n requires: ['arrow'],\n },\n ],\n}\n\ndefineOptions({\n name: 'ElCascader',\n})\n\nconst props = withDefaults(defineProps<CascaderComponentProps>(), {\n options: () => [],\n props: () => ({}),\n disabled: undefined,\n clearIcon: markRaw(CircleClose),\n filterMethod: (node, keyword) => node.text.includes(keyword),\n separator: ' / ',\n showAllLevels: true,\n maxCollapseTags: 1,\n debounce: 300,\n beforeFilter: () => true,\n placement: 'bottom-start',\n fallbackPlacements: () => [\n 'bottom-start',\n 'bottom',\n 'top-start',\n 'top',\n 'right',\n 'left',\n ],\n teleported: true,\n effect: 'light',\n tagType: 'info',\n tagEffect: 'light',\n validateEvent: true,\n persistent: true,\n showCheckedStrategy: 'child',\n showPrefix: true,\n popperStyle: undefined,\n valueOnClear: undefined,\n})\nconst emit = defineEmits(cascaderEmits)\nconst attrs = useAttrs()\nconst slots = defineSlots()\n\nlet inputInitialHeight = 0\nlet pressDeleteCount = 0\n\nconst nsCascader = useNamespace('cascader')\nconst nsInput = useNamespace('input')\nconst sizeMapPadding = {\n small: 7,\n default: 11,\n large: 15,\n}\n\nconst { t } = useLocale()\nconst { formItem } = useFormItem()\nconst isDisabled = useFormDisabled()\nconst { valueOnClear } = useEmptyValues(props)\nconst { isComposing, handleComposition } = useComposition({\n afterComposition(event) {\n const text = (event.target as HTMLInputElement)?.value\n handleInput(text)\n },\n})\n\nconst tooltipRef = ref<TooltipInstance>()\nconst tagTooltipRef = ref<TooltipInstance>()\nconst inputRef = ref<InputInstance>()\nconst tagWrapper = ref<HTMLDivElement>()\nconst cascaderPanelRef = ref<CascaderPanelInstance>()\nconst suggestionPanel = ref<ScrollbarInstance>()\nconst popperVisible = ref(false)\nconst inputHover = ref(false)\nconst filtering = ref(false)\nconst inputValue = ref('')\nconst searchInputValue = ref('')\nconst tags = ref<Tag[]>([])\nconst suggestions = ref<CascaderNode[]>([])\n\nconst showTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags\n ? tags.value.slice(0, props.maxCollapseTags)\n : tags.value\n})\n\nconst collapseTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags ? tags.value.slice(props.maxCollapseTags) : []\n})\n\nconst cascaderStyle = computed(() => {\n return attrs.style as StyleValue\n})\n\nconst inputPlaceholder = computed(\n () => props.placeholder ?? t('el.cascader.placeholder')\n)\nconst currentPlaceholder = computed(() =>\n searchInputValue.value || tags.value.length > 0 || isComposing.value\n ? ''\n : inputPlaceholder.value\n)\nconst realSize = useFormSize()\nconst tagSize = computed(() =>\n realSize.value === 'small' ? 'small' : 'default'\n)\nconst multiple = computed(() => !!props.props.multiple)\nconst readonly = computed(() => !props.filterable || multiple.value)\nconst searchKeyword = computed(() =>\n multiple.value ? searchInputValue.value : inputValue.value\n)\nconst checkedNodes: ComputedRef<CascaderNode[]> = computed(\n () => cascaderPanelRef.value?.checkedNodes || []\n)\n\nconst { wrapperRef, isFocused, handleBlur } = useFocusController(inputRef, {\n disabled: isDisabled,\n beforeBlur(event) {\n return (\n tooltipRef.value?.isFocusInsideContent(event) ||\n tagTooltipRef.value?.isFocusInsideContent(event)\n )\n },\n afterBlur() {\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst clearBtnVisible = computed(() => {\n if (\n !props.clearable ||\n isDisabled.value ||\n filtering.value ||\n (!inputHover.value && !isFocused.value)\n )\n return false\n\n return !!checkedNodes.value.length\n})\nconst presentText = computed(() => {\n const { showAllLevels, separator } = props\n const nodes = checkedNodes.value\n return nodes.length\n ? multiple.value\n ? ''\n : nodes[0].calcText(showAllLevels, separator)\n : ''\n})\n\nconst validateState = computed(() => formItem?.validateState || '')\n\nconst checkedValue = computed<CascaderValue>({\n get() {\n return cloneDeep(props.modelValue) as CascaderValue\n },\n set(val) {\n // https://github.com/element-plus/element-plus/issues/17647\n const value = val ?? valueOnClear.value\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n if (props.validateEvent) {\n formItem?.validate('change').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst cascaderKls = computed(() => {\n return [\n nsCascader.b(),\n nsCascader.m(realSize.value),\n nsCascader.is('disabled', isDisabled.value),\n attrs.class,\n ]\n})\n\nconst cascaderIconKls = computed(() => {\n return [\n nsInput.e('icon'),\n 'icon-arrow-down',\n nsCascader.is('reverse', popperVisible.value),\n ]\n})\n\nconst inputClass = computed(() => nsCascader.is('focus', isFocused.value))\n\nconst contentRef = computed(() => {\n return tooltipRef.value?.popperRef?.contentRef\n})\n\nconst handleClickOutside = (event: Event) => {\n if (isFocused.value) {\n const _event = new FocusEvent('blur', event)\n handleBlur(_event)\n }\n togglePopperVisible(false)\n}\n\nconst togglePopperVisible = (visible?: boolean) => {\n if (isDisabled.value) return\n\n visible = visible ?? !popperVisible.value\n\n if (visible !== popperVisible.value) {\n popperVisible.value = visible\n inputRef.value?.input?.setAttribute('aria-expanded', `${visible}`)\n\n if (visible) {\n updatePopperPosition()\n cascaderPanelRef.value &&\n nextTick(cascaderPanelRef.value.scrollToExpandingNode)\n } else if (props.filterable) {\n syncPresentTextValue()\n }\n\n emit('visibleChange', visible)\n }\n}\n\nconst updatePopperPosition = () => {\n nextTick(() => {\n tooltipRef.value?.updatePopper()\n })\n}\nconst hideSuggestionPanel = () => {\n filtering.value = false\n}\n\nconst genTag = (node: CascaderNode): Tag => {\n const { showAllLevels, separator } = props\n return {\n node,\n key: node.uid,\n text: node.calcText(showAllLevels, separator),\n hitState: false,\n closable: !isDisabled.value && !node.isDisabled,\n }\n}\n\nconst deleteTag = (tag: Tag) => {\n const node = tag.node as CascaderNode\n node.doCheck(false)\n cascaderPanelRef.value?.calculateCheckedValue()\n emit('removeTag', node.valueByOption)\n}\n\nconst getStrategyCheckedNodes = (): CascaderNode[] => {\n switch (props.showCheckedStrategy) {\n case 'child':\n return checkedNodes.value\n case 'parent': {\n const clickedNodes = getCheckedNodes(false)\n const clickedNodesValue = clickedNodes!.map((o) => o.value)\n const parentNodes = clickedNodes!.filter(\n (o) => !o.parent || !clickedNodesValue.includes(o.parent.value)\n )\n return parentNodes\n }\n default:\n return []\n }\n}\n\nconst calculatePresentTags = () => {\n if (!multiple.value) return\n\n const nodes = getStrategyCheckedNodes()\n\n const allTags: Tag[] = []\n nodes.forEach((node) => allTags.push(genTag(node)))\n tags.value = allTags\n}\n\nconst calculateSuggestions = () => {\n const { filterMethod, showAllLevels, separator } = props\n const res = cascaderPanelRef.value\n ?.getFlattedNodes(!props.props.checkStrictly)\n ?.filter((node) => {\n if (node.isDisabled) return false\n node.calcText(showAllLevels, separator)\n return filterMethod(node, searchKeyword.value)\n })\n\n if (multiple.value) {\n tags.value.forEach((tag) => {\n tag.hitState = false\n })\n }\n\n filtering.value = true\n suggestions.value = res!\n updatePopperPosition()\n}\n\nconst focusFirstNode = () => {\n let firstNode!: HTMLElement\n\n if (filtering.value && suggestionPanel.value) {\n firstNode = suggestionPanel.value.$el.querySelector(\n `.${nsCascader.e('suggestion-item')}`\n )\n } else {\n firstNode = cascaderPanelRef.value?.$el.querySelector(\n `.${nsCascader.b('node')}[tabindex=\"-1\"]`\n )\n }\n\n if (firstNode) {\n firstNode.focus()\n !filtering.value && firstNode.click()\n }\n}\n\nconst updateStyle = () => {\n const inputInner = inputRef.value?.input\n const tagWrapperEl = tagWrapper.value\n const suggestionPanelEl = suggestionPanel.value?.$el\n\n if (!isClient || !inputInner) return\n\n if (suggestionPanelEl) {\n const suggestionList = suggestionPanelEl.querySelector(\n `.${nsCascader.e('suggestion-list')}`\n )\n suggestionList.style.minWidth = `${inputInner.offsetWidth}px`\n }\n\n if (tagWrapperEl) {\n const { offsetHeight } = tagWrapperEl\n // 2 is el-input__wrapper padding\n const height =\n tags.value.length > 0\n ? `${Math.max(offsetHeight, inputInitialHeight) - 2}px`\n : `${inputInitialHeight}px`\n inputInner.style.height = height\n // if prefix slot exists, update tagWrapperEl left position\n if (slots.prefix) {\n const prefix = inputRef.value?.$el.querySelector(\n `.${nsInput.e('prefix')}`\n ) as HTMLElement\n let left = 0\n if (prefix) {\n left = prefix.offsetWidth\n if (left > 0) {\n left += sizeMapPadding[realSize.value || 'default'] // this is the default padding of el-input__wrapper\n }\n }\n tagWrapperEl.style.left = `${left}px`\n } else {\n tagWrapperEl.style.left = `0`\n }\n updatePopperPosition()\n }\n}\n\nconst getCheckedNodes = (leafOnly: boolean) => {\n return cascaderPanelRef.value?.getCheckedNodes(leafOnly)\n}\n\nconst handleExpandChange = (value: CascaderValue) => {\n updatePopperPosition()\n emit('expandChange', value)\n}\n\nconst handleKeyDown = (e: KeyboardEvent) => {\n if (isComposing.value) return\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n togglePopperVisible()\n break\n case EVENT_CODE.down:\n togglePopperVisible(true)\n nextTick(focusFirstNode)\n e.preventDefault()\n break\n case EVENT_CODE.esc:\n if (popperVisible.value === true) {\n e.preventDefault()\n e.stopPropagation()\n togglePopperVisible(false)\n }\n break\n case EVENT_CODE.tab:\n togglePopperVisible(false)\n break\n }\n}\n\nconst handleClear = () => {\n cascaderPanelRef.value?.clearCheckedNodes()\n if (!popperVisible.value && props.filterable) {\n syncPresentTextValue()\n }\n togglePopperVisible(false)\n emit('clear')\n}\n\nconst syncPresentTextValue = () => {\n const { value } = presentText\n inputValue.value = value\n searchInputValue.value = value\n}\n\nconst handleSuggestionClick = (node: CascaderNode) => {\n const { checked } = node\n\n if (multiple.value) {\n cascaderPanelRef.value?.handleCheckChange(node, !checked, false)\n } else {\n !checked && cascaderPanelRef.value?.handleCheckChange(node, true, false)\n togglePopperVisible(false)\n }\n}\n\nconst handleSuggestionKeyDown = (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.up:\n case EVENT_CODE.down: {\n e.preventDefault()\n const distance = code === EVENT_CODE.up ? -1 : 1\n focusNode(\n getSibling(\n target,\n distance,\n `.${nsCascader.e('suggestion-item')}[tabindex=\"-1\"]`\n ) as HTMLElement\n )\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n target.click()\n break\n }\n}\n\nconst handleDelete = () => {\n const lastTag = tags.value[tags.value.length - 1]\n pressDeleteCount = searchInputValue.value ? 0 : pressDeleteCount + 1\n\n if (\n !lastTag ||\n !pressDeleteCount ||\n (props.collapseTags && tags.value.length > 1)\n )\n return\n\n if (lastTag.hitState) {\n deleteTag(lastTag)\n } else {\n lastTag.hitState = true\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst handleFilter = useDebounceFn(() => {\n const { value } = searchKeyword\n\n if (!value) return\n\n const passed = props.beforeFilter(value)\n\n if (isPromise(passed)) {\n passed.then(calculateSuggestions).catch(() => {\n /* prevent log error */\n })\n } else if (passed !== false) {\n calculateSuggestions()\n } else {\n hideSuggestionPanel()\n }\n}, debounce)\n\nconst handleInput = (val: string, e?: InputEvent) => {\n !popperVisible.value && togglePopperVisible(true)\n\n if (e?.isComposing) return\n\n val ? handleFilter() : hideSuggestionPanel()\n}\n\nconst getInputInnerHeight = (inputInner: HTMLElement): number =>\n Number.parseFloat(\n useCssVar(nsInput.cssVarName('input-height'), inputInner).value!\n ) - 2\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nwatch(filtering, updatePopperPosition)\n\nwatch(\n [\n checkedNodes,\n isDisabled,\n () => props.collapseTags,\n () => props.maxCollapseTags,\n ],\n calculatePresentTags\n)\n\nwatch(tags, () => {\n nextTick(() => updateStyle())\n})\n\nwatch(realSize, async () => {\n await nextTick()\n const inputInner = inputRef.value!.input!\n inputInitialHeight = getInputInnerHeight(inputInner) || inputInitialHeight\n updateStyle()\n})\n\nwatch(presentText, syncPresentTextValue, { immediate: true })\n\nwatch(\n () => popperVisible.value,\n (val) => {\n if (val && props.props.lazy && props.props.lazyLoad) {\n cascaderPanelRef.value?.loadLazyRootNodes()\n }\n }\n)\n\nonMounted(() => {\n const inputInner = inputRef.value!.input!\n\n const inputInnerHeight = getInputInnerHeight(inputInner)\n\n inputInitialHeight = inputInner.offsetHeight || inputInnerHeight\n useResizeObserver(inputInner, updateStyle)\n})\n\ndefineExpose({\n /**\n * @description get an array of currently selected node,(leafOnly) whether only return the leaf checked nodes, default is `false`\n */\n getCheckedNodes,\n /**\n * @description cascader panel ref\n */\n cascaderPanelRef,\n /**\n * @description toggle the visible of popper\n */\n togglePopperVisible,\n /**\n * @description cascader content ref\n */\n contentRef,\n /**\n * @description selected content text\n */\n presentText,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n})\n</script>\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"cascader2.js","names":[],"sources":["../../../../../../packages/components/cascader/src/cascader.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"tooltipRef\"\n :visible=\"popperVisible\"\n :teleported=\"teleported\"\n :popper-class=\"[nsCascader.e('dropdown'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :popper-options=\"popperOptions\"\n :fallback-placements=\"fallbackPlacements\"\n :stop-popper-mouse-event=\"false\"\n :gpu-acceleration=\"false\"\n :placement=\"placement\"\n :transition=\"`${nsCascader.namespace.value}-zoom-in-top`\"\n :effect=\"effect\"\n pure\n :persistent=\"persistent\"\n @hide=\"hideSuggestionPanel\"\n >\n <template #default>\n <div\n ref=\"wrapperRef\"\n v-clickoutside:[contentRef]=\"handleClickOutside\"\n :class=\"cascaderKls\"\n :style=\"cascaderStyle\"\n @click=\"() => togglePopperVisible(readonly ? undefined : true)\"\n @keydown=\"handleKeyDown\"\n @mouseenter=\"inputHover = true\"\n @mouseleave=\"inputHover = false\"\n >\n <el-input\n ref=\"inputRef\"\n v-model=\"inputValue\"\n :placeholder=\"currentPlaceholder\"\n :readonly=\"readonly\"\n :disabled=\"isDisabled\"\n :validate-event=\"false\"\n :size=\"realSize\"\n :class=\"inputClass\"\n :tabindex=\"multiple && filterable && !isDisabled ? -1 : undefined\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n @input=\"handleInput\"\n >\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template #suffix>\n <el-icon\n v-if=\"clearBtnVisible\"\n key=\"clear\"\n :class=\"[nsInput.e('icon'), 'icon-circle-close']\"\n @click.stop=\"handleClear\"\n >\n <component :is=\"clearIcon\" />\n </el-icon>\n <el-icon\n v-else\n key=\"arrow-down\"\n :class=\"cascaderIconKls\"\n @click.stop=\"togglePopperVisible()\"\n >\n <arrow-down />\n </el-icon>\n </template>\n </el-input>\n\n <div\n v-if=\"multiple\"\n ref=\"tagWrapper\"\n :class=\"[\n nsCascader.e('tags'),\n nsCascader.is('validate', Boolean(validateState)),\n ]\"\n >\n <slot name=\"tag\" :data=\"tags\" :delete-tag=\"deleteTag\">\n <el-tag\n v-for=\"tag in showTagList\"\n :key=\"tag.key\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </slot>\n <el-tooltip\n v-if=\"collapseTags && tags.length > maxCollapseTags\"\n ref=\"tagTooltipRef\"\n :disabled=\"popperVisible || !collapseTagsTooltip\"\n :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n placement=\"bottom\"\n :popper-class=\"popperClass\"\n :popper-style=\"popperStyle\"\n :effect=\"effect\"\n :persistent=\"persistent\"\n >\n <template #default>\n <el-tag\n :closable=\"false\"\n :size=\"tagSize\"\n :type=\"tagType\"\n :effect=\"tagEffect\"\n disable-transitions\n >\n <span :class=\"nsCascader.e('tags-text')\">\n + {{ tags.length - maxCollapseTags }}\n </span>\n </el-tag>\n </template>\n <template #content>\n <el-scrollbar :max-height=\"maxCollapseTagsTooltipHeight\">\n <div :class=\"nsCascader.e('collapse-tags')\">\n <div\n v-for=\"(tag, idx) in collapseTagList\"\n :key=\"idx\"\n :class=\"nsCascader.e('collapse-tag')\"\n >\n <el-tag\n :key=\"tag.key\"\n class=\"in-tooltip\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </div>\n </div>\n </el-scrollbar>\n </template>\n </el-tooltip>\n <input\n v-if=\"filterable && !isDisabled\"\n v-model=\"searchInputValue\"\n type=\"text\"\n :class=\"nsCascader.e('search-input')\"\n :placeholder=\"presentText ? '' : inputPlaceholder\"\n @input=\"(e) => handleInput(searchInputValue, e as InputEvent)\"\n @click.stop=\"togglePopperVisible(true)\"\n @keydown.delete=\"handleDelete\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n />\n </div>\n </div>\n </template>\n\n <template #content>\n <div v-if=\"$slots.header\" :class=\"nsCascader.e('header')\" @click.stop>\n <slot name=\"header\" />\n </div>\n <el-cascader-panel\n v-show=\"!filtering\"\n ref=\"cascaderPanelRef\"\n v-model=\"checkedValue\"\n :options=\"options\"\n :props=\"props.props\"\n :border=\"false\"\n :render-label=\"$slots.default\"\n @expand-change=\"handleExpandChange\"\n @close=\"$nextTick(() => togglePopperVisible(false))\"\n >\n <template #empty>\n <slot name=\"empty\" />\n </template>\n </el-cascader-panel>\n <el-scrollbar\n v-if=\"filterable\"\n v-show=\"filtering\"\n ref=\"suggestionPanel\"\n tag=\"ul\"\n :class=\"nsCascader.e('suggestion-panel')\"\n :view-class=\"nsCascader.e('suggestion-list')\"\n @keydown=\"handleSuggestionKeyDown\"\n >\n <template v-if=\"suggestions.length\">\n <li\n v-for=\"item in suggestions\"\n :key=\"item.uid\"\n :class=\"[\n nsCascader.e('suggestion-item'),\n nsCascader.is('checked', item.checked),\n ]\"\n :tabindex=\"-1\"\n @click=\"handleSuggestionClick(item)\"\n >\n <slot name=\"suggestion-item\" :item=\"item\">\n <span>{{ item.text }}</span>\n <el-icon v-if=\"item.checked\">\n <check />\n </el-icon>\n </slot>\n </li>\n </template>\n <slot v-else name=\"empty\">\n <li :class=\"nsCascader.e('empty-text')\">\n {{ t('el.cascader.noMatch') }}\n </li>\n </slot>\n </el-scrollbar>\n <div v-if=\"$slots.footer\" :class=\"nsCascader.e('footer')\" @click.stop>\n <slot name=\"footer\" />\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n markRaw,\n nextTick,\n onMounted,\n ref,\n useAttrs,\n watch,\n} from 'vue'\nimport { cloneDeep } from 'lodash-unified'\nimport { useCssVar, useDebounceFn, useResizeObserver } from '@vueuse/core'\nimport {\n debugWarn,\n focusNode,\n getEventCode,\n getSibling,\n isClient,\n isPromise,\n} from '@element-plus/utils'\nimport ElCascaderPanel from '@element-plus/components/cascader-panel'\nimport ElInput from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport {\n useComposition,\n useEmptyValues,\n useFocusController,\n useLocale,\n useNamespace,\n} from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { ArrowDown, Check, CircleClose } from '@element-plus/icons-vue'\nimport { cascaderEmits } from './cascader'\n\nimport type { Options } from '@element-plus/components/popper'\nimport type { ComputedRef, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { ScrollbarInstance } from '@element-plus/components/scrollbar'\nimport type {\n CascaderNode,\n CascaderPanelInstance,\n CascaderValue,\n Tag,\n} from '@element-plus/components/cascader-panel'\nimport type { CascaderComponentProps } from './cascader'\n\nconst popperOptions: Partial<Options> = {\n modifiers: [\n {\n name: 'arrowPosition',\n enabled: true,\n phase: 'main',\n fn: ({ state }) => {\n const { modifiersData, placement } = state\n if (['right', 'left', 'bottom', 'top'].includes(placement)) return\n if (modifiersData.arrow) {\n modifiersData.arrow.x = 35\n }\n },\n requires: ['arrow'],\n },\n ],\n}\n\ndefineOptions({\n name: 'ElCascader',\n})\n\nconst props = withDefaults(defineProps<CascaderComponentProps>(), {\n options: () => [],\n props: () => ({}),\n disabled: undefined,\n clearIcon: markRaw(CircleClose),\n filterMethod: (node, keyword) => node.text.includes(keyword),\n separator: ' / ',\n showAllLevels: true,\n maxCollapseTags: 1,\n debounce: 300,\n beforeFilter: () => true,\n placement: 'bottom-start',\n fallbackPlacements: () => [\n 'bottom-start',\n 'bottom',\n 'top-start',\n 'top',\n 'right',\n 'left',\n ],\n teleported: true,\n effect: 'light',\n tagType: 'info',\n tagEffect: 'light',\n validateEvent: true,\n persistent: true,\n showCheckedStrategy: 'child',\n showPrefix: true,\n popperStyle: undefined,\n valueOnClear: undefined,\n})\nconst emit = defineEmits(cascaderEmits)\nconst attrs = useAttrs()\nconst slots = defineSlots()\n\nlet inputInitialHeight = 0\nlet pressDeleteCount = 0\n\nconst nsCascader = useNamespace('cascader')\nconst nsInput = useNamespace('input')\nconst sizeMapPadding = {\n small: 7,\n default: 11,\n large: 15,\n}\n\nconst { t } = useLocale()\nconst { formItem } = useFormItem()\nconst isDisabled = useFormDisabled()\nconst { valueOnClear } = useEmptyValues(props)\nconst { isComposing, handleComposition } = useComposition({\n afterComposition(event) {\n const text = (event.target as HTMLInputElement)?.value\n handleInput(text)\n },\n})\n\nconst tooltipRef = ref<TooltipInstance>()\nconst tagTooltipRef = ref<TooltipInstance>()\nconst inputRef = ref<InputInstance>()\nconst tagWrapper = ref<HTMLDivElement>()\nconst cascaderPanelRef = ref<CascaderPanelInstance>()\nconst suggestionPanel = ref<ScrollbarInstance>()\nconst popperVisible = ref(false)\nconst inputHover = ref(false)\nconst filtering = ref(false)\nconst inputValue = ref('')\nconst searchInputValue = ref('')\nconst tags = ref<Tag[]>([])\nconst suggestions = ref<CascaderNode[]>([])\n\nconst showTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags\n ? tags.value.slice(0, props.maxCollapseTags)\n : tags.value\n})\n\nconst collapseTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags ? tags.value.slice(props.maxCollapseTags) : []\n})\n\nconst cascaderStyle = computed(() => {\n return attrs.style as StyleValue\n})\n\nconst inputPlaceholder = computed(\n () => props.placeholder ?? t('el.cascader.placeholder')\n)\nconst currentPlaceholder = computed(() =>\n searchInputValue.value || tags.value.length > 0 || isComposing.value\n ? ''\n : inputPlaceholder.value\n)\nconst realSize = useFormSize()\nconst tagSize = computed(() =>\n realSize.value === 'small' ? 'small' : 'default'\n)\nconst multiple = computed(() => !!props.props.multiple)\nconst readonly = computed(() => !props.filterable || multiple.value)\nconst searchKeyword = computed(() =>\n multiple.value ? searchInputValue.value : inputValue.value\n)\nconst checkedNodes: ComputedRef<CascaderNode[]> = computed(\n () => cascaderPanelRef.value?.checkedNodes || []\n)\n\nconst { wrapperRef, isFocused, handleBlur } = useFocusController(inputRef, {\n disabled: isDisabled,\n beforeBlur(event) {\n return (\n tooltipRef.value?.isFocusInsideContent(event) ||\n tagTooltipRef.value?.isFocusInsideContent(event)\n )\n },\n afterBlur() {\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst clearBtnVisible = computed(() => {\n if (\n !props.clearable ||\n isDisabled.value ||\n filtering.value ||\n (!inputHover.value && !isFocused.value)\n )\n return false\n\n return !!checkedNodes.value.length\n})\nconst presentText = computed(() => {\n const { showAllLevels, separator } = props\n const nodes = checkedNodes.value\n return nodes.length\n ? multiple.value\n ? ''\n : nodes[0].calcText(showAllLevels, separator)\n : ''\n})\n\nconst validateState = computed(() => formItem?.validateState || '')\n\nconst checkedValue = computed<CascaderValue>({\n get() {\n return cloneDeep(props.modelValue) as CascaderValue\n },\n set(val) {\n // https://github.com/element-plus/element-plus/issues/17647\n const value = val ?? valueOnClear.value\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n if (props.validateEvent) {\n formItem?.validate('change').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst cascaderKls = computed(() => {\n return [\n nsCascader.b(),\n nsCascader.m(realSize.value),\n nsCascader.is('disabled', isDisabled.value),\n attrs.class,\n ]\n})\n\nconst cascaderIconKls = computed(() => {\n return [\n nsInput.e('icon'),\n 'icon-arrow-down',\n nsCascader.is('reverse', popperVisible.value),\n ]\n})\n\nconst inputClass = computed(() => nsCascader.is('focus', isFocused.value))\n\nconst contentRef = computed(() => {\n return tooltipRef.value?.popperRef?.contentRef\n})\n\nconst handleClickOutside = (event: Event) => {\n if (isFocused.value) {\n const _event = new FocusEvent('blur', event)\n handleBlur(_event)\n }\n togglePopperVisible(false)\n}\n\nconst togglePopperVisible = (visible?: boolean) => {\n if (isDisabled.value) return\n\n visible = visible ?? !popperVisible.value\n\n if (visible !== popperVisible.value) {\n popperVisible.value = visible\n inputRef.value?.input?.setAttribute('aria-expanded', `${visible}`)\n\n if (visible) {\n updatePopperPosition()\n cascaderPanelRef.value &&\n nextTick(cascaderPanelRef.value.scrollToExpandingNode)\n } else if (props.filterable) {\n syncPresentTextValue()\n }\n\n emit('visibleChange', visible)\n }\n}\n\nconst updatePopperPosition = () => {\n nextTick(() => {\n tooltipRef.value?.updatePopper()\n })\n}\nconst hideSuggestionPanel = () => {\n filtering.value = false\n}\n\nconst genTag = (node: CascaderNode): Tag => {\n const { showAllLevels, separator } = props\n return {\n node,\n key: node.uid,\n text: node.calcText(showAllLevels, separator),\n hitState: false,\n closable: !isDisabled.value && !node.isDisabled,\n }\n}\n\nconst deleteTag = (tag: Tag) => {\n const node = tag.node as CascaderNode\n node.doCheck(false)\n cascaderPanelRef.value?.calculateCheckedValue()\n emit('removeTag', node.valueByOption)\n}\n\nconst getStrategyCheckedNodes = (): CascaderNode[] => {\n switch (props.showCheckedStrategy) {\n case 'child':\n return checkedNodes.value\n case 'parent': {\n const clickedNodes = getCheckedNodes(false)\n const clickedNodesValue = clickedNodes!.map((o) => o.value)\n const parentNodes = clickedNodes!.filter(\n (o) => !o.parent || !clickedNodesValue.includes(o.parent.value)\n )\n return parentNodes\n }\n default:\n return []\n }\n}\n\nconst calculatePresentTags = () => {\n if (!multiple.value) return\n\n const nodes = getStrategyCheckedNodes()\n\n const allTags: Tag[] = []\n nodes.forEach((node) => allTags.push(genTag(node)))\n tags.value = allTags\n}\n\nconst calculateSuggestions = () => {\n const { filterMethod, showAllLevels, separator } = props\n const res = cascaderPanelRef.value\n ?.getFlattedNodes(!props.props.checkStrictly)\n ?.filter((node) => {\n if (node.isDisabled) return false\n node.calcText(showAllLevels, separator)\n return filterMethod(node, searchKeyword.value)\n })\n\n if (multiple.value) {\n tags.value.forEach((tag) => {\n tag.hitState = false\n })\n }\n\n filtering.value = true\n suggestions.value = res!\n updatePopperPosition()\n}\n\nconst focusFirstNode = () => {\n let firstNode!: HTMLElement\n\n if (filtering.value && suggestionPanel.value) {\n firstNode = suggestionPanel.value.$el.querySelector(\n `.${nsCascader.e('suggestion-item')}`\n )\n } else {\n firstNode = cascaderPanelRef.value?.$el.querySelector(\n `.${nsCascader.b('node')}[tabindex=\"-1\"]`\n )\n }\n\n if (firstNode) {\n firstNode.focus()\n !filtering.value && firstNode.click()\n }\n}\n\nconst updateStyle = () => {\n const inputInner = inputRef.value?.input\n const tagWrapperEl = tagWrapper.value\n const suggestionPanelEl = suggestionPanel.value?.$el\n\n if (!isClient || !inputInner) return\n\n if (suggestionPanelEl) {\n const suggestionList = suggestionPanelEl.querySelector(\n `.${nsCascader.e('suggestion-list')}`\n )\n suggestionList.style.minWidth = `${inputInner.offsetWidth}px`\n }\n\n if (tagWrapperEl) {\n const { offsetHeight } = tagWrapperEl\n // 2 is el-input__wrapper padding\n const height =\n tags.value.length > 0\n ? `${Math.max(offsetHeight, inputInitialHeight) - 2}px`\n : `${inputInitialHeight}px`\n inputInner.style.height = height\n // if prefix slot exists, update tagWrapperEl left position\n if (slots.prefix) {\n const prefix = inputRef.value?.$el.querySelector(\n `.${nsInput.e('prefix')}`\n ) as HTMLElement\n let left = 0\n if (prefix) {\n left = prefix.offsetWidth\n if (left > 0) {\n left += sizeMapPadding[realSize.value || 'default'] // this is the default padding of el-input__wrapper\n }\n }\n tagWrapperEl.style.left = `${left}px`\n } else {\n tagWrapperEl.style.left = `0`\n }\n updatePopperPosition()\n }\n}\n\nconst getCheckedNodes = (leafOnly: boolean) => {\n return cascaderPanelRef.value?.getCheckedNodes(leafOnly)\n}\n\nconst handleExpandChange = (value: CascaderValue) => {\n updatePopperPosition()\n emit('expandChange', value)\n}\n\nconst handleKeyDown = (e: KeyboardEvent) => {\n if (isComposing.value) return\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n togglePopperVisible()\n break\n case EVENT_CODE.down:\n togglePopperVisible(true)\n nextTick(focusFirstNode)\n e.preventDefault()\n break\n case EVENT_CODE.esc:\n if (popperVisible.value === true) {\n e.preventDefault()\n e.stopPropagation()\n togglePopperVisible(false)\n }\n break\n case EVENT_CODE.tab:\n togglePopperVisible(false)\n break\n }\n}\n\nconst handleClear = () => {\n cascaderPanelRef.value?.clearCheckedNodes()\n if (!popperVisible.value && props.filterable) {\n syncPresentTextValue()\n }\n togglePopperVisible(false)\n emit('clear')\n}\n\nconst syncPresentTextValue = () => {\n const { value } = presentText\n inputValue.value = value\n searchInputValue.value = value\n}\n\nconst handleSuggestionClick = (node: CascaderNode) => {\n const { checked } = node\n\n if (multiple.value) {\n cascaderPanelRef.value?.handleCheckChange(node, !checked, false)\n } else {\n !checked && cascaderPanelRef.value?.handleCheckChange(node, true, false)\n togglePopperVisible(false)\n }\n}\n\nconst handleSuggestionKeyDown = (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.up:\n case EVENT_CODE.down: {\n e.preventDefault()\n const distance = code === EVENT_CODE.up ? -1 : 1\n focusNode(\n getSibling(\n target,\n distance,\n `.${nsCascader.e('suggestion-item')}[tabindex=\"-1\"]`\n ) as HTMLElement\n )\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n target.click()\n break\n }\n}\n\nconst handleDelete = () => {\n const lastTag = tags.value[tags.value.length - 1]\n pressDeleteCount = searchInputValue.value ? 0 : pressDeleteCount + 1\n\n if (\n !lastTag ||\n !pressDeleteCount ||\n (props.collapseTags && tags.value.length > 1)\n )\n return\n\n if (lastTag.hitState) {\n deleteTag(lastTag)\n } else {\n lastTag.hitState = true\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst handleFilter = useDebounceFn(() => {\n const { value } = searchKeyword\n\n if (!value) return\n\n const passed = props.beforeFilter(value)\n\n if (isPromise(passed)) {\n passed.then(calculateSuggestions).catch(() => {\n /* prevent log error */\n })\n } else if (passed !== false) {\n calculateSuggestions()\n } else {\n hideSuggestionPanel()\n }\n}, debounce)\n\nconst handleInput = (val: string, e?: InputEvent) => {\n !popperVisible.value && togglePopperVisible(true)\n\n if (e?.isComposing) return\n\n val ? handleFilter() : hideSuggestionPanel()\n}\n\nconst getInputInnerHeight = (inputInner: HTMLElement): number =>\n Number.parseFloat(\n useCssVar(nsInput.cssVarName('input-height'), inputInner).value\n ) - 2\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nwatch(filtering, updatePopperPosition)\n\nwatch(\n [\n checkedNodes,\n isDisabled,\n () => props.collapseTags,\n () => props.maxCollapseTags,\n ],\n calculatePresentTags\n)\n\nwatch(tags, () => {\n nextTick(() => updateStyle())\n})\n\nwatch(realSize, async () => {\n await nextTick()\n const inputInner = inputRef.value!.input!\n inputInitialHeight = getInputInnerHeight(inputInner) || inputInitialHeight\n updateStyle()\n})\n\nwatch(presentText, syncPresentTextValue, { immediate: true })\n\nwatch(\n () => popperVisible.value,\n (val) => {\n if (val && props.props.lazy && props.props.lazyLoad) {\n cascaderPanelRef.value?.loadLazyRootNodes()\n }\n }\n)\n\nonMounted(() => {\n const inputInner = inputRef.value!.input!\n\n const inputInnerHeight = getInputInnerHeight(inputInner)\n\n inputInitialHeight = inputInner.offsetHeight || inputInnerHeight\n useResizeObserver(inputInner, updateStyle)\n})\n\ndefineExpose({\n /**\n * @description get an array of currently selected node,(leafOnly) whether only return the leaf checked nodes, default is `false`\n */\n getCheckedNodes,\n /**\n * @description cascader panel ref\n */\n cascaderPanelRef,\n /**\n * @description toggle the visible of popper\n */\n togglePopperVisible,\n /**\n * @description cascader content ref\n */\n contentRef,\n /**\n * @description selected content text\n */\n presentText,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n})\n</script>\n"],"mappings":""}
1
+ {"version":3,"file":"cascader2.js","names":[],"sources":["../../../../../../packages/components/cascader/src/cascader.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"tooltipRef\"\n :visible=\"popperVisible\"\n :teleported=\"teleported\"\n :popper-class=\"[nsCascader.e('dropdown'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :popper-options=\"popperOptions\"\n :fallback-placements=\"fallbackPlacements\"\n :stop-popper-mouse-event=\"false\"\n :gpu-acceleration=\"false\"\n :placement=\"placement\"\n :transition=\"`${nsCascader.namespace.value}-zoom-in-top`\"\n :effect=\"effect\"\n pure\n :persistent=\"persistent\"\n @hide=\"hideSuggestionPanel\"\n >\n <template #default>\n <div\n ref=\"wrapperRef\"\n v-clickoutside:[contentRef]=\"handleClickOutside\"\n :class=\"cascaderKls\"\n :style=\"cascaderStyle\"\n @click=\"() => togglePopperVisible(readonly ? undefined : true)\"\n @keydown=\"handleKeyDown\"\n @mouseenter=\"inputHover = true\"\n @mouseleave=\"inputHover = false\"\n >\n <el-input\n ref=\"inputRef\"\n v-model=\"inputValue\"\n :placeholder=\"currentPlaceholder\"\n :readonly=\"readonly\"\n :disabled=\"isDisabled\"\n :validate-event=\"false\"\n :size=\"realSize\"\n :class=\"inputClass\"\n :tabindex=\"multiple && filterable && !isDisabled ? -1 : undefined\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n @input=\"handleInput\"\n >\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template #suffix>\n <el-icon\n v-if=\"clearBtnVisible\"\n key=\"clear\"\n :class=\"[nsInput.e('icon'), 'icon-circle-close']\"\n @click.stop=\"handleClear\"\n >\n <component :is=\"clearIcon\" />\n </el-icon>\n <el-icon\n v-else\n key=\"arrow-down\"\n :class=\"cascaderIconKls\"\n @click.stop=\"togglePopperVisible()\"\n >\n <arrow-down />\n </el-icon>\n </template>\n </el-input>\n\n <div\n v-if=\"multiple\"\n ref=\"tagWrapper\"\n :class=\"[\n nsCascader.e('tags'),\n nsCascader.is('validate', Boolean(validateState)),\n ]\"\n >\n <slot name=\"tag\" :data=\"tags\" :delete-tag=\"deleteTag\">\n <el-tag\n v-for=\"tag in showTagList\"\n :key=\"tag.key\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </slot>\n <el-tooltip\n v-if=\"collapseTags && tags.length > maxCollapseTags\"\n ref=\"tagTooltipRef\"\n :disabled=\"popperVisible || !collapseTagsTooltip\"\n :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n placement=\"bottom\"\n :popper-class=\"popperClass\"\n :popper-style=\"popperStyle\"\n :effect=\"effect\"\n :persistent=\"persistent\"\n >\n <template #default>\n <el-tag\n :closable=\"false\"\n :size=\"tagSize\"\n :type=\"tagType\"\n :effect=\"tagEffect\"\n disable-transitions\n >\n <span :class=\"nsCascader.e('tags-text')\">\n + {{ tags.length - maxCollapseTags }}\n </span>\n </el-tag>\n </template>\n <template #content>\n <el-scrollbar :max-height=\"maxCollapseTagsTooltipHeight\">\n <div :class=\"nsCascader.e('collapse-tags')\">\n <div\n v-for=\"(tag, idx) in collapseTagList\"\n :key=\"idx\"\n :class=\"nsCascader.e('collapse-tag')\"\n >\n <el-tag\n :key=\"tag.key\"\n class=\"in-tooltip\"\n :type=\"tagType\"\n :size=\"tagSize\"\n :effect=\"tagEffect\"\n :hit=\"tag.hitState\"\n :closable=\"tag.closable\"\n disable-transitions\n @close=\"deleteTag(tag)\"\n >\n <span>{{ tag.text }}</span>\n </el-tag>\n </div>\n </div>\n </el-scrollbar>\n </template>\n </el-tooltip>\n <input\n v-if=\"filterable && !isDisabled\"\n v-model=\"searchInputValue\"\n type=\"text\"\n :class=\"nsCascader.e('search-input')\"\n :placeholder=\"presentText ? '' : inputPlaceholder\"\n @input=\"(e) => handleInput(searchInputValue, e as InputEvent)\"\n @click.stop=\"togglePopperVisible(true)\"\n @keydown.delete=\"handleDelete\"\n @compositionstart=\"handleComposition\"\n @compositionupdate=\"handleComposition\"\n @compositionend=\"handleComposition\"\n />\n </div>\n </div>\n </template>\n\n <template #content>\n <div v-if=\"$slots.header\" :class=\"nsCascader.e('header')\" @click.stop>\n <slot name=\"header\" />\n </div>\n <el-cascader-panel\n v-show=\"!filtering\"\n ref=\"cascaderPanelRef\"\n v-model=\"checkedValue\"\n :options=\"options\"\n :props=\"props.props\"\n :border=\"false\"\n :render-label=\"$slots.default\"\n @expand-change=\"handleExpandChange\"\n @close=\"$nextTick(() => togglePopperVisible(false))\"\n >\n <template #empty>\n <slot name=\"empty\" />\n </template>\n </el-cascader-panel>\n <el-scrollbar\n v-if=\"filterable\"\n v-show=\"filtering\"\n ref=\"suggestionPanel\"\n tag=\"ul\"\n :class=\"nsCascader.e('suggestion-panel')\"\n :view-class=\"nsCascader.e('suggestion-list')\"\n @keydown=\"handleSuggestionKeyDown\"\n >\n <template v-if=\"suggestions.length\">\n <li\n v-for=\"item in suggestions\"\n :key=\"item.uid\"\n :class=\"[\n nsCascader.e('suggestion-item'),\n nsCascader.is('checked', item.checked),\n ]\"\n :tabindex=\"-1\"\n @click=\"handleSuggestionClick(item)\"\n >\n <slot name=\"suggestion-item\" :item=\"item\">\n <span>{{ item.text }}</span>\n <el-icon v-if=\"item.checked\">\n <check />\n </el-icon>\n </slot>\n </li>\n </template>\n <slot v-else name=\"empty\">\n <li :class=\"nsCascader.e('empty-text')\">\n {{ t('el.cascader.noMatch') }}\n </li>\n </slot>\n </el-scrollbar>\n <div v-if=\"$slots.footer\" :class=\"nsCascader.e('footer')\" @click.stop>\n <slot name=\"footer\" />\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n markRaw,\n nextTick,\n onMounted,\n ref,\n useAttrs,\n watch,\n} from 'vue'\nimport { cloneDeep } from 'lodash-unified'\nimport { useCssVar, useDebounceFn, useResizeObserver } from '@vueuse/core'\nimport {\n debugWarn,\n focusNode,\n getEventCode,\n getSibling,\n isClient,\n isPromise,\n} from '@element-plus/utils'\nimport ElCascaderPanel from '@element-plus/components/cascader-panel'\nimport ElInput from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport {\n useComposition,\n useEmptyValues,\n useFocusController,\n useLocale,\n useNamespace,\n} from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { ArrowDown, Check, CircleClose } from '@element-plus/icons-vue'\nimport { cascaderEmits } from './cascader'\n\nimport type { Options } from '@element-plus/components/popper'\nimport type { ComputedRef, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { ScrollbarInstance } from '@element-plus/components/scrollbar'\nimport type {\n CascaderNode,\n CascaderPanelInstance,\n CascaderValue,\n Tag,\n} from '@element-plus/components/cascader-panel'\nimport type { CascaderComponentProps } from './cascader'\n\nconst popperOptions: Partial<Options> = {\n modifiers: [\n {\n name: 'arrowPosition',\n enabled: true,\n phase: 'main',\n fn: ({ state }) => {\n const { modifiersData, placement } = state\n if (['right', 'left', 'bottom', 'top'].includes(placement)) return\n if (modifiersData.arrow) {\n modifiersData.arrow.x = 35\n }\n },\n requires: ['arrow'],\n },\n ],\n}\n\ndefineOptions({\n name: 'ElCascader',\n})\n\nconst props = withDefaults(defineProps<CascaderComponentProps>(), {\n options: () => [],\n props: () => ({}),\n disabled: undefined,\n clearIcon: markRaw(CircleClose),\n filterMethod: (node, keyword) => node.text.includes(keyword),\n separator: ' / ',\n showAllLevels: true,\n maxCollapseTags: 1,\n debounce: 300,\n beforeFilter: () => true,\n placement: 'bottom-start',\n fallbackPlacements: () => [\n 'bottom-start',\n 'bottom',\n 'top-start',\n 'top',\n 'right',\n 'left',\n ],\n teleported: true,\n effect: 'light',\n tagType: 'info',\n tagEffect: 'light',\n validateEvent: true,\n persistent: true,\n showCheckedStrategy: 'child',\n showPrefix: true,\n popperStyle: undefined,\n valueOnClear: undefined,\n})\nconst emit = defineEmits(cascaderEmits)\nconst attrs = useAttrs()\nconst slots = defineSlots()\n\nlet inputInitialHeight = 0\nlet pressDeleteCount = 0\n\nconst nsCascader = useNamespace('cascader')\nconst nsInput = useNamespace('input')\nconst sizeMapPadding = {\n small: 7,\n default: 11,\n large: 15,\n}\n\nconst { t } = useLocale()\nconst { formItem } = useFormItem()\nconst isDisabled = useFormDisabled()\nconst { valueOnClear } = useEmptyValues(props)\nconst { isComposing, handleComposition } = useComposition({\n afterComposition(event) {\n const text = (event.target as HTMLInputElement)?.value\n handleInput(text)\n },\n})\n\nconst tooltipRef = ref<TooltipInstance>()\nconst tagTooltipRef = ref<TooltipInstance>()\nconst inputRef = ref<InputInstance>()\nconst tagWrapper = ref<HTMLDivElement>()\nconst cascaderPanelRef = ref<CascaderPanelInstance>()\nconst suggestionPanel = ref<ScrollbarInstance>()\nconst popperVisible = ref(false)\nconst inputHover = ref(false)\nconst filtering = ref(false)\nconst inputValue = ref('')\nconst searchInputValue = ref('')\nconst tags = ref<Tag[]>([])\nconst suggestions = ref<CascaderNode[]>([])\n\nconst showTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags\n ? tags.value.slice(0, props.maxCollapseTags)\n : tags.value\n})\n\nconst collapseTagList = computed(() => {\n if (!props.props.multiple) {\n return []\n }\n return props.collapseTags ? tags.value.slice(props.maxCollapseTags) : []\n})\n\nconst cascaderStyle = computed(() => {\n return attrs.style as StyleValue\n})\n\nconst inputPlaceholder = computed(\n () => props.placeholder ?? t('el.cascader.placeholder')\n)\nconst currentPlaceholder = computed(() =>\n searchInputValue.value || tags.value.length > 0 || isComposing.value\n ? ''\n : inputPlaceholder.value\n)\nconst realSize = useFormSize()\nconst tagSize = computed(() =>\n realSize.value === 'small' ? 'small' : 'default'\n)\nconst multiple = computed(() => !!props.props.multiple)\nconst readonly = computed(() => !props.filterable || multiple.value)\nconst searchKeyword = computed(() =>\n multiple.value ? searchInputValue.value : inputValue.value\n)\nconst checkedNodes: ComputedRef<CascaderNode[]> = computed(\n () => cascaderPanelRef.value?.checkedNodes || []\n)\n\nconst { wrapperRef, isFocused, handleBlur } = useFocusController(inputRef, {\n disabled: isDisabled,\n beforeBlur(event) {\n return (\n tooltipRef.value?.isFocusInsideContent(event) ||\n tagTooltipRef.value?.isFocusInsideContent(event)\n )\n },\n afterBlur() {\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst clearBtnVisible = computed(() => {\n if (\n !props.clearable ||\n isDisabled.value ||\n filtering.value ||\n (!inputHover.value && !isFocused.value)\n )\n return false\n\n return !!checkedNodes.value.length\n})\nconst presentText = computed(() => {\n const { showAllLevels, separator } = props\n const nodes = checkedNodes.value\n return nodes.length\n ? multiple.value\n ? ''\n : nodes[0].calcText(showAllLevels, separator)\n : ''\n})\n\nconst validateState = computed(() => formItem?.validateState || '')\n\nconst checkedValue = computed<CascaderValue>({\n get() {\n return cloneDeep(props.modelValue) as CascaderValue\n },\n set(val) {\n // https://github.com/element-plus/element-plus/issues/17647\n const value = val ?? valueOnClear.value\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n if (props.validateEvent) {\n formItem?.validate('change').catch((err) => debugWarn(err))\n }\n },\n})\n\nconst cascaderKls = computed(() => {\n return [\n nsCascader.b(),\n nsCascader.m(realSize.value),\n nsCascader.is('disabled', isDisabled.value),\n attrs.class,\n ]\n})\n\nconst cascaderIconKls = computed(() => {\n return [\n nsInput.e('icon'),\n 'icon-arrow-down',\n nsCascader.is('reverse', popperVisible.value),\n ]\n})\n\nconst inputClass = computed(() => nsCascader.is('focus', isFocused.value))\n\nconst contentRef = computed(() => {\n return tooltipRef.value?.popperRef?.contentRef\n})\n\nconst handleClickOutside = (event: Event) => {\n if (isFocused.value) {\n const _event = new FocusEvent('blur', event)\n handleBlur(_event)\n }\n togglePopperVisible(false)\n}\n\nconst togglePopperVisible = (visible?: boolean) => {\n if (isDisabled.value) return\n\n visible = visible ?? !popperVisible.value\n\n if (visible !== popperVisible.value) {\n popperVisible.value = visible\n inputRef.value?.input?.setAttribute('aria-expanded', `${visible}`)\n\n if (visible) {\n updatePopperPosition()\n cascaderPanelRef.value &&\n nextTick(cascaderPanelRef.value.scrollToExpandingNode)\n } else if (props.filterable) {\n syncPresentTextValue()\n }\n\n emit('visibleChange', visible)\n }\n}\n\nconst updatePopperPosition = () => {\n nextTick(() => {\n tooltipRef.value?.updatePopper()\n })\n}\nconst hideSuggestionPanel = () => {\n filtering.value = false\n}\n\nconst genTag = (node: CascaderNode): Tag => {\n const { showAllLevels, separator } = props\n return {\n node,\n key: node.uid,\n text: node.calcText(showAllLevels, separator),\n hitState: false,\n closable: !isDisabled.value && !node.isDisabled,\n }\n}\n\nconst deleteTag = (tag: Tag) => {\n const node = tag.node as CascaderNode\n node.doCheck(false)\n cascaderPanelRef.value?.calculateCheckedValue()\n emit('removeTag', node.valueByOption)\n}\n\nconst getStrategyCheckedNodes = (): CascaderNode[] => {\n switch (props.showCheckedStrategy) {\n case 'child':\n return checkedNodes.value\n case 'parent': {\n const clickedNodes = getCheckedNodes(false)\n const clickedNodesValue = clickedNodes!.map((o) => o.value)\n const parentNodes = clickedNodes!.filter(\n (o) => !o.parent || !clickedNodesValue.includes(o.parent.value)\n )\n return parentNodes\n }\n default:\n return []\n }\n}\n\nconst calculatePresentTags = () => {\n if (!multiple.value) return\n\n const nodes = getStrategyCheckedNodes()\n\n const allTags: Tag[] = []\n nodes.forEach((node) => allTags.push(genTag(node)))\n tags.value = allTags\n}\n\nconst calculateSuggestions = () => {\n const { filterMethod, showAllLevels, separator } = props\n const res = cascaderPanelRef.value\n ?.getFlattedNodes(!props.props.checkStrictly)\n ?.filter((node) => {\n if (node.isDisabled) return false\n node.calcText(showAllLevels, separator)\n return filterMethod(node, searchKeyword.value)\n })\n\n if (multiple.value) {\n tags.value.forEach((tag) => {\n tag.hitState = false\n })\n }\n\n filtering.value = true\n suggestions.value = res!\n updatePopperPosition()\n}\n\nconst focusFirstNode = () => {\n let firstNode!: HTMLElement\n\n if (filtering.value && suggestionPanel.value) {\n firstNode = suggestionPanel.value.$el.querySelector(\n `.${nsCascader.e('suggestion-item')}`\n )\n } else {\n firstNode = cascaderPanelRef.value?.$el.querySelector(\n `.${nsCascader.b('node')}[tabindex=\"-1\"]`\n )\n }\n\n if (firstNode) {\n firstNode.focus()\n !filtering.value && firstNode.click()\n }\n}\n\nconst updateStyle = () => {\n const inputInner = inputRef.value?.input\n const tagWrapperEl = tagWrapper.value\n const suggestionPanelEl = suggestionPanel.value?.$el\n\n if (!isClient || !inputInner) return\n\n if (suggestionPanelEl) {\n const suggestionList = suggestionPanelEl.querySelector(\n `.${nsCascader.e('suggestion-list')}`\n )\n suggestionList.style.minWidth = `${inputInner.offsetWidth}px`\n }\n\n if (tagWrapperEl) {\n const { offsetHeight } = tagWrapperEl\n // 2 is el-input__wrapper padding\n const height =\n tags.value.length > 0\n ? `${Math.max(offsetHeight, inputInitialHeight) - 2}px`\n : `${inputInitialHeight}px`\n inputInner.style.height = height\n // if prefix slot exists, update tagWrapperEl left position\n if (slots.prefix) {\n const prefix = inputRef.value?.$el.querySelector(\n `.${nsInput.e('prefix')}`\n ) as HTMLElement\n let left = 0\n if (prefix) {\n left = prefix.offsetWidth\n if (left > 0) {\n left += sizeMapPadding[realSize.value || 'default'] // this is the default padding of el-input__wrapper\n }\n }\n tagWrapperEl.style.left = `${left}px`\n } else {\n tagWrapperEl.style.left = `0`\n }\n updatePopperPosition()\n }\n}\n\nconst getCheckedNodes = (leafOnly: boolean) => {\n return cascaderPanelRef.value?.getCheckedNodes(leafOnly)\n}\n\nconst handleExpandChange = (value: CascaderValue) => {\n updatePopperPosition()\n emit('expandChange', value)\n}\n\nconst handleKeyDown = (e: KeyboardEvent) => {\n if (isComposing.value) return\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n togglePopperVisible()\n break\n case EVENT_CODE.down:\n togglePopperVisible(true)\n nextTick(focusFirstNode)\n e.preventDefault()\n break\n case EVENT_CODE.esc:\n if (popperVisible.value === true) {\n e.preventDefault()\n e.stopPropagation()\n togglePopperVisible(false)\n }\n break\n case EVENT_CODE.tab:\n togglePopperVisible(false)\n break\n }\n}\n\nconst handleClear = () => {\n cascaderPanelRef.value?.clearCheckedNodes()\n if (!popperVisible.value && props.filterable) {\n syncPresentTextValue()\n }\n togglePopperVisible(false)\n emit('clear')\n}\n\nconst syncPresentTextValue = () => {\n const { value } = presentText\n inputValue.value = value\n searchInputValue.value = value\n}\n\nconst handleSuggestionClick = (node: CascaderNode) => {\n const { checked } = node\n\n if (multiple.value) {\n cascaderPanelRef.value?.handleCheckChange(node, !checked, false)\n } else {\n !checked && cascaderPanelRef.value?.handleCheckChange(node, true, false)\n togglePopperVisible(false)\n }\n}\n\nconst handleSuggestionKeyDown = (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n const code = getEventCode(e)\n\n switch (code) {\n case EVENT_CODE.up:\n case EVENT_CODE.down: {\n e.preventDefault()\n const distance = code === EVENT_CODE.up ? -1 : 1\n focusNode(\n getSibling(\n target,\n distance,\n `.${nsCascader.e('suggestion-item')}[tabindex=\"-1\"]`\n ) as HTMLElement\n )\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n target.click()\n break\n }\n}\n\nconst handleDelete = () => {\n const lastTag = tags.value[tags.value.length - 1]\n pressDeleteCount = searchInputValue.value ? 0 : pressDeleteCount + 1\n\n if (\n !lastTag ||\n !pressDeleteCount ||\n (props.collapseTags && tags.value.length > 1)\n )\n return\n\n if (lastTag.hitState) {\n deleteTag(lastTag)\n } else {\n lastTag.hitState = true\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst handleFilter = useDebounceFn(() => {\n const { value } = searchKeyword\n\n if (!value) return\n\n const passed = props.beforeFilter(value)\n\n if (isPromise(passed)) {\n passed.then(calculateSuggestions).catch(() => {\n /* prevent log error */\n })\n } else if (passed !== false) {\n calculateSuggestions()\n } else {\n hideSuggestionPanel()\n }\n}, debounce)\n\nconst handleInput = (val: string, e?: InputEvent) => {\n !popperVisible.value && togglePopperVisible(true)\n\n if (e?.isComposing) return\n\n val ? handleFilter() : hideSuggestionPanel()\n}\n\nconst getInputInnerHeight = (inputInner: HTMLElement): number =>\n Number.parseFloat(\n useCssVar(nsInput.cssVarName('input-height'), inputInner).value!\n ) - 2\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nwatch(filtering, updatePopperPosition)\n\nwatch(\n [\n checkedNodes,\n isDisabled,\n () => props.collapseTags,\n () => props.maxCollapseTags,\n ],\n calculatePresentTags\n)\n\nwatch(tags, () => {\n nextTick(() => updateStyle())\n})\n\nwatch(realSize, async () => {\n await nextTick()\n const inputInner = inputRef.value!.input!\n inputInitialHeight = getInputInnerHeight(inputInner) || inputInitialHeight\n updateStyle()\n})\n\nwatch(presentText, syncPresentTextValue, { immediate: true })\n\nwatch(\n () => popperVisible.value,\n (val) => {\n if (val && props.props.lazy && props.props.lazyLoad) {\n cascaderPanelRef.value?.loadLazyRootNodes()\n }\n }\n)\n\nonMounted(() => {\n const inputInner = inputRef.value!.input!\n\n const inputInnerHeight = getInputInnerHeight(inputInner)\n\n inputInitialHeight = inputInner.offsetHeight || inputInnerHeight\n useResizeObserver(inputInner, updateStyle)\n})\n\ndefineExpose({\n /**\n * @description get an array of currently selected node,(leafOnly) whether only return the leaf checked nodes, default is `false`\n */\n getCheckedNodes,\n /**\n * @description cascader panel ref\n */\n cascaderPanelRef,\n /**\n * @description toggle the visible of popper\n */\n togglePopperVisible,\n /**\n * @description cascader content ref\n */\n contentRef,\n /**\n * @description selected content text\n */\n presentText,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n})\n</script>\n"],"mappings":""}
@@ -21,13 +21,13 @@ interface CascaderCommonProps {
21
21
  }
22
22
  declare const CommonProps: {
23
23
  readonly modelValue: {
24
- readonly type: PropType<EpPropMergeType<(new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null) | ((new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null))[], unknown, unknown>>;
24
+ readonly type: PropType<EpPropMergeType<(new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null) | (((new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null)) | null)[], unknown, unknown>>;
25
25
  readonly required: false;
26
26
  readonly validator: ((val: unknown) => boolean) | undefined;
27
27
  __epPropKey: true;
28
28
  };
29
- readonly options: EpPropFinalized<(new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[]) | ((new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[]))[], unknown, unknown, () => CascaderOption[], boolean>;
30
- readonly props: EpPropFinalized<(new (...args: any[]) => CascaderProps) | (() => CascaderProps) | ((new (...args: any[]) => CascaderProps) | (() => CascaderProps))[], unknown, unknown, () => CascaderProps, boolean>;
29
+ readonly options: EpPropFinalized<(new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[]) | (((new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[])) | null)[], unknown, unknown, () => CascaderOption[], boolean>;
30
+ readonly props: EpPropFinalized<(new (...args: any[]) => CascaderProps) | (() => CascaderProps) | (((new (...args: any[]) => CascaderProps) | (() => CascaderProps)) | null)[], unknown, unknown, () => CascaderProps, boolean>;
31
31
  };
32
32
  interface CascaderPanelProps extends CascaderCommonProps {
33
33
  border?: boolean;
@@ -46,13 +46,13 @@ declare const cascaderPanelProps: {
46
46
  __epPropKey: true;
47
47
  };
48
48
  modelValue: {
49
- readonly type: PropType<EpPropMergeType<(new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null) | ((new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null))[], unknown, unknown>>;
49
+ readonly type: PropType<EpPropMergeType<(new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null) | (((new (...args: any[]) => string | number | Record<string, any> | CascaderNodePathValue | (CascaderNodeValue | CascaderNodePathValue)[]) | (() => CascaderValue | null)) | null)[], unknown, unknown>>;
50
50
  readonly required: false;
51
51
  readonly validator: ((val: unknown) => boolean) | undefined;
52
52
  __epPropKey: true;
53
53
  };
54
- options: EpPropFinalized<(new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[]) | ((new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[]))[], unknown, unknown, () => CascaderOption[], boolean>;
55
- props: EpPropFinalized<(new (...args: any[]) => CascaderProps) | (() => CascaderProps) | ((new (...args: any[]) => CascaderProps) | (() => CascaderProps))[], unknown, unknown, () => CascaderProps, boolean>;
54
+ options: EpPropFinalized<(new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[]) | (((new (...args: any[]) => CascaderOption[]) | (() => CascaderOption[])) | null)[], unknown, unknown, () => CascaderOption[], boolean>;
55
+ props: EpPropFinalized<(new (...args: any[]) => CascaderProps) | (() => CascaderProps) | (((new (...args: any[]) => CascaderProps) | (() => CascaderProps)) | null)[], unknown, unknown, () => CascaderProps, boolean>;
56
56
  };
57
57
  declare const cascaderPanelEmits: {
58
58
  "update:modelValue": (value: CascaderValue | undefined | null) => boolean;
@@ -9,12 +9,8 @@ declare var __VLS_8: {};
9
9
  type __VLS_Slots = {} & {
10
10
  empty?: (props: typeof __VLS_8) => any;
11
11
  };
12
- declare const __VLS_base: vue.DefineComponent<__VLS_WithDefaults<__VLS_TypePropsToOption<CascaderPanelProps>, {
13
- options: () => CascaderOption[];
14
- props: () => CascaderProps;
15
- border: boolean;
16
- }>, {
17
- menuList: vue.Ref<CascaderMenuInstance[]>;
12
+ declare const __VLS_base: vue.DefineComponent<CascaderPanelProps, {
13
+ menuList: vue.Ref<CascaderMenuInstance[], CascaderMenuInstance[]>;
18
14
  menus: vue.Ref<{
19
15
  readonly uid: number;
20
16
  readonly level: number;
@@ -75,6 +71,66 @@ declare const __VLS_base: vue.DefineComponent<__VLS_WithDefaults<__VLS_TypeProps
75
71
  onChildCheck: () => void;
76
72
  setCheckState: (checked: boolean) => void;
77
73
  doCheck: (checked: boolean) => void;
74
+ }[][], Node[][] | {
75
+ readonly uid: number;
76
+ readonly level: number;
77
+ readonly value: CascaderNodeValue;
78
+ readonly label: string;
79
+ readonly pathNodes: any[];
80
+ readonly pathValues: CascaderNodeValue[];
81
+ readonly pathLabels: string[];
82
+ childrenData: {
83
+ [x: string]: unknown;
84
+ label?: string | undefined;
85
+ value?: CascaderNodeValue | undefined;
86
+ children?: any[] | undefined;
87
+ disabled?: boolean | undefined;
88
+ leaf?: boolean | undefined;
89
+ }[] | undefined;
90
+ children: any[];
91
+ text: string;
92
+ loaded: boolean;
93
+ checked: boolean;
94
+ indeterminate: boolean;
95
+ loading: boolean;
96
+ readonly data: {
97
+ [x: string]: unknown;
98
+ label?: string | undefined;
99
+ value?: CascaderNodeValue | undefined;
100
+ children?: any[] | undefined;
101
+ disabled?: boolean | undefined;
102
+ leaf?: boolean | undefined;
103
+ };
104
+ readonly config: {
105
+ expandTrigger: ExpandTrigger;
106
+ multiple: boolean;
107
+ checkStrictly: boolean;
108
+ emitPath: boolean;
109
+ lazy: boolean;
110
+ lazyLoad: LazyLoad;
111
+ value: string;
112
+ label: string;
113
+ children: string;
114
+ disabled: string | isDisabled;
115
+ leaf: string | isLeaf;
116
+ hoverThreshold: number;
117
+ checkOnClickNode: boolean;
118
+ checkOnClickLeaf: boolean;
119
+ showPrefix: boolean;
120
+ };
121
+ readonly parent?: any | undefined;
122
+ readonly root: boolean;
123
+ readonly isDisabled: boolean;
124
+ readonly isLeaf: boolean;
125
+ readonly valueByOption: CascaderNodeValue | CascaderNodeValue[];
126
+ appendChild: (childData: CascaderOption) => Node;
127
+ calcText: (allLevels: boolean, separator: string) => string;
128
+ broadcast: (checked: boolean) => void;
129
+ emit: () => void;
130
+ onParentCheck: (checked: boolean) => void;
131
+ onChildCheck: () => void;
132
+ setCheckState: (checked: boolean) => void;
133
+ doCheck: (checked: boolean) => void;
78
134
  }[][]>;
79
135
  checkedNodes: vue.Ref<{
80
136
  readonly uid: number;
@@ -136,6 +192,66 @@ declare const __VLS_base: vue.DefineComponent<__VLS_WithDefaults<__VLS_TypeProps
136
192
  onChildCheck: () => void;
137
193
  setCheckState: (checked: boolean) => void;
138
194
  doCheck: (checked: boolean) => void;
195
+ }[], Node[] | {
196
+ readonly uid: number;
197
+ readonly level: number;
198
+ readonly value: CascaderNodeValue;
199
+ readonly label: string;
200
+ readonly pathNodes: any[];
201
+ readonly pathValues: CascaderNodeValue[];
202
+ readonly pathLabels: string[];
203
+ childrenData: {
204
+ [x: string]: unknown;
205
+ label?: string | undefined;
206
+ value?: CascaderNodeValue | undefined;
207
+ children?: any[] | undefined;
208
+ disabled?: boolean | undefined;
209
+ leaf?: boolean | undefined;
210
+ }[] | undefined;
211
+ children: any[];
212
+ text: string;
213
+ loaded: boolean;
214
+ checked: boolean;
215
+ indeterminate: boolean;
216
+ loading: boolean;
217
+ readonly data: {
218
+ [x: string]: unknown;
219
+ label?: string | undefined;
220
+ value?: CascaderNodeValue | undefined;
221
+ children?: any[] | undefined;
222
+ disabled?: boolean | undefined;
223
+ leaf?: boolean | undefined;
224
+ };
225
+ readonly config: {
226
+ expandTrigger: ExpandTrigger;
227
+ multiple: boolean;
228
+ checkStrictly: boolean;
229
+ emitPath: boolean;
230
+ lazy: boolean;
231
+ lazyLoad: LazyLoad;
232
+ value: string;
233
+ label: string;
234
+ children: string;
235
+ disabled: string | isDisabled;
236
+ leaf: string | isLeaf;
237
+ hoverThreshold: number;
238
+ checkOnClickNode: boolean;
239
+ checkOnClickLeaf: boolean;
240
+ showPrefix: boolean;
241
+ };
242
+ readonly parent?: any | undefined;
243
+ readonly root: boolean;
244
+ readonly isDisabled: boolean;
245
+ readonly isLeaf: boolean;
246
+ readonly valueByOption: CascaderNodeValue | CascaderNodeValue[];
247
+ appendChild: (childData: CascaderOption) => Node;
248
+ calcText: (allLevels: boolean, separator: string) => string;
249
+ broadcast: (checked: boolean) => void;
250
+ emit: () => void;
251
+ onParentCheck: (checked: boolean) => void;
252
+ onChildCheck: () => void;
253
+ setCheckState: (checked: boolean) => void;
254
+ doCheck: (checked: boolean) => void;
139
255
  }[]>;
140
256
  handleKeyDown: (e: KeyboardEvent) => void;
141
257
  handleCheckChange: (node: Node, checked: boolean, emitClose?: boolean) => void;
@@ -151,41 +267,27 @@ declare const __VLS_base: vue.DefineComponent<__VLS_WithDefaults<__VLS_TypeProps
151
267
  calculateCheckedValue: () => void;
152
268
  scrollToExpandingNode: () => void;
153
269
  loadLazyRootNodes: () => void;
154
- }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
270
+ }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
155
271
  close: () => void;
156
272
  "update:modelValue": (value: CascaderValue | null | undefined) => void;
157
273
  change: (value: CascaderValue | null | undefined) => void;
158
274
  "expand-change": (value: CascaderNodePathValue) => void;
159
- }, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToOption<CascaderPanelProps>, {
160
- options: () => CascaderOption[];
161
- props: () => CascaderProps;
162
- border: boolean;
163
- }>>> & {
164
- onClose?: (() => any) | undefined;
275
+ }, string, vue.PublicProps, Readonly<CascaderPanelProps> & Readonly<{
165
276
  onChange?: ((value: CascaderValue | null | undefined) => any) | undefined;
277
+ onClose?: (() => any) | undefined;
166
278
  "onUpdate:modelValue"?: ((value: CascaderValue | null | undefined) => any) | undefined;
167
279
  "onExpand-change"?: ((value: CascaderNodePathValue) => any) | undefined;
168
- }, {
169
- props: CascaderProps;
280
+ }>, {
170
281
  border: boolean;
282
+ props: CascaderProps;
171
283
  options: CascaderOption[];
172
- }, {}>;
284
+ }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;
173
285
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
174
286
  declare const _default: typeof __VLS_export;
175
- type __VLS_TypePropsToOption<T> = { [K in keyof T]-?: {} extends Pick<T, K> ? {
176
- type: vue.PropType<Required<T>[K]>;
177
- } : {
178
- type: vue.PropType<T[K]>;
179
- required: true;
180
- } };
181
- type __VLS_WithDefaults<P, D> = { [K in keyof Pick<P, keyof P>]: K extends keyof D ? __VLS_PrettifyLocal<P[K] & {
182
- default: D[K];
183
- }> : P[K] };
184
287
  type __VLS_WithSlots<T, S> = T & {
185
288
  new (): {
186
289
  $slots: S;
187
290
  };
188
291
  };
189
- type __VLS_PrettifyLocal<T> = (T extends any ? { [K in keyof T]: T[K] } : { [K in keyof T as K]: T[K] }) & {};
190
292
  //#endregion
191
293
  export { _default };
@@ -8,7 +8,7 @@ declare var __VLS_29: {};
8
8
  type __VLS_Slots = {} & {
9
9
  empty?: (props: typeof __VLS_29) => any;
10
10
  };
11
- declare const __VLS_base: vue.DefineComponent<{
11
+ declare const __VLS_base: vue.DefineComponent<vue.ExtractPropTypes<{
12
12
  nodes: {
13
13
  type: PropType<Node[]>;
14
14
  required: true;
@@ -17,7 +17,7 @@ declare const __VLS_base: vue.DefineComponent<{
17
17
  type: NumberConstructor;
18
18
  required: true;
19
19
  };
20
- }, unknown, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
20
+ }>, {}, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
21
21
  nodes: {
22
22
  type: PropType<Node[]>;
23
23
  required: true;
@@ -26,7 +26,7 @@ declare const __VLS_base: vue.DefineComponent<{
26
26
  type: NumberConstructor;
27
27
  required: true;
28
28
  };
29
- }>>, {}, {}>;
29
+ }>> & Readonly<{}>, {}, {}, {}, {}, string, vue.ComponentProvideOptions, true, {}, any>;
30
30
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
31
31
  declare const _default: typeof __VLS_export;
32
32
  type __VLS_WithSlots<T, S> = T & {
@@ -6,35 +6,21 @@ declare var __VLS_1: {};
6
6
  type __VLS_Slots = {} & {
7
7
  default?: (props: typeof __VLS_1) => any;
8
8
  };
9
- declare const __VLS_base: vue.DefineComponent<__VLS_WithDefaults<__VLS_TypePropsToOption<CheckTagProps>, {
10
- type: string;
11
- }>, unknown, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
9
+ declare const __VLS_base: vue.DefineComponent<CheckTagProps, {}, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
12
10
  change: (value: boolean) => void;
13
11
  "update:checked": (value: boolean) => void;
14
- }, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToOption<CheckTagProps>, {
15
- type: string;
16
- }>>> & {
12
+ }, string, vue.PublicProps, Readonly<CheckTagProps> & Readonly<{
17
13
  onChange?: ((value: boolean) => any) | undefined;
18
14
  "onUpdate:checked"?: ((value: boolean) => any) | undefined;
19
- }, {
15
+ }>, {
20
16
  type: "primary" | "success" | "info" | "warning" | "danger";
21
- }, {}>;
17
+ }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;
22
18
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
23
19
  declare const _default: typeof __VLS_export;
24
- type __VLS_TypePropsToOption<T> = { [K in keyof T]-?: {} extends Pick<T, K> ? {
25
- type: vue.PropType<Required<T>[K]>;
26
- } : {
27
- type: vue.PropType<T[K]>;
28
- required: true;
29
- } };
30
- type __VLS_WithDefaults<P, D> = { [K in keyof Pick<P, keyof P>]: K extends keyof D ? __VLS_PrettifyLocal<P[K] & {
31
- default: D[K];
32
- }> : P[K] };
33
20
  type __VLS_WithSlots<T, S> = T & {
34
21
  new (): {
35
22
  $slots: S;
36
23
  };
37
24
  };
38
- type __VLS_PrettifyLocal<T> = (T extends any ? { [K in keyof T]: T[K] } : { [K in keyof T as K]: T[K] }) & {};
39
25
  //#endregion
40
26
  export { _default };