@element-plus/nightly 0.0.20241202 → 0.0.20241203

Sign up to get free protection for your applications and to get access to all the features.
Files changed (364) hide show
  1. package/dist/index.full.js +4 -2
  2. package/dist/index.full.min.js +3 -3
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +3 -3
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +4 -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/hr.js +1 -1
  92. package/dist/locale/hr.min.js +1 -1
  93. package/dist/locale/hr.min.mjs +1 -1
  94. package/dist/locale/hr.mjs +1 -1
  95. package/dist/locale/hu.js +1 -1
  96. package/dist/locale/hu.min.js +1 -1
  97. package/dist/locale/hu.min.mjs +1 -1
  98. package/dist/locale/hu.mjs +1 -1
  99. package/dist/locale/hy-am.js +1 -1
  100. package/dist/locale/hy-am.min.js +1 -1
  101. package/dist/locale/hy-am.min.mjs +1 -1
  102. package/dist/locale/hy-am.mjs +1 -1
  103. package/dist/locale/id.js +1 -1
  104. package/dist/locale/id.min.js +1 -1
  105. package/dist/locale/id.min.mjs +1 -1
  106. package/dist/locale/id.mjs +1 -1
  107. package/dist/locale/it.js +1 -1
  108. package/dist/locale/it.min.js +1 -1
  109. package/dist/locale/it.min.mjs +1 -1
  110. package/dist/locale/it.mjs +1 -1
  111. package/dist/locale/ja.js +1 -1
  112. package/dist/locale/ja.min.js +1 -1
  113. package/dist/locale/ja.min.mjs +1 -1
  114. package/dist/locale/ja.mjs +1 -1
  115. package/dist/locale/kk.js +1 -1
  116. package/dist/locale/kk.min.js +1 -1
  117. package/dist/locale/kk.min.mjs +1 -1
  118. package/dist/locale/kk.mjs +1 -1
  119. package/dist/locale/km.js +1 -1
  120. package/dist/locale/km.min.js +1 -1
  121. package/dist/locale/km.min.mjs +1 -1
  122. package/dist/locale/km.mjs +1 -1
  123. package/dist/locale/ko.js +1 -1
  124. package/dist/locale/ko.min.js +1 -1
  125. package/dist/locale/ko.min.mjs +1 -1
  126. package/dist/locale/ko.mjs +1 -1
  127. package/dist/locale/ku.js +1 -1
  128. package/dist/locale/ku.min.js +1 -1
  129. package/dist/locale/ku.min.mjs +1 -1
  130. package/dist/locale/ku.mjs +1 -1
  131. package/dist/locale/ky.js +1 -1
  132. package/dist/locale/ky.min.js +1 -1
  133. package/dist/locale/ky.min.mjs +1 -1
  134. package/dist/locale/ky.mjs +1 -1
  135. package/dist/locale/lt.js +1 -1
  136. package/dist/locale/lt.min.js +1 -1
  137. package/dist/locale/lt.min.mjs +1 -1
  138. package/dist/locale/lt.mjs +1 -1
  139. package/dist/locale/lv.js +1 -1
  140. package/dist/locale/lv.min.js +1 -1
  141. package/dist/locale/lv.min.mjs +1 -1
  142. package/dist/locale/lv.mjs +1 -1
  143. package/dist/locale/mg.js +1 -1
  144. package/dist/locale/mg.min.js +1 -1
  145. package/dist/locale/mg.min.mjs +1 -1
  146. package/dist/locale/mg.mjs +1 -1
  147. package/dist/locale/mn.js +1 -1
  148. package/dist/locale/mn.min.js +1 -1
  149. package/dist/locale/mn.min.mjs +1 -1
  150. package/dist/locale/mn.mjs +1 -1
  151. package/dist/locale/ms.js +1 -1
  152. package/dist/locale/ms.min.js +1 -1
  153. package/dist/locale/ms.min.mjs +1 -1
  154. package/dist/locale/ms.mjs +1 -1
  155. package/dist/locale/my.js +1 -1
  156. package/dist/locale/my.min.js +1 -1
  157. package/dist/locale/my.min.mjs +1 -1
  158. package/dist/locale/my.mjs +1 -1
  159. package/dist/locale/nb-no.js +1 -1
  160. package/dist/locale/nb-no.min.js +1 -1
  161. package/dist/locale/nb-no.min.mjs +1 -1
  162. package/dist/locale/nb-no.mjs +1 -1
  163. package/dist/locale/nl.js +1 -1
  164. package/dist/locale/nl.min.js +1 -1
  165. package/dist/locale/nl.min.mjs +1 -1
  166. package/dist/locale/nl.mjs +1 -1
  167. package/dist/locale/pa.js +1 -1
  168. package/dist/locale/pa.min.js +1 -1
  169. package/dist/locale/pa.min.mjs +1 -1
  170. package/dist/locale/pa.mjs +1 -1
  171. package/dist/locale/pl.js +1 -1
  172. package/dist/locale/pl.min.js +1 -1
  173. package/dist/locale/pl.min.mjs +1 -1
  174. package/dist/locale/pl.mjs +1 -1
  175. package/dist/locale/pt-br.js +1 -1
  176. package/dist/locale/pt-br.min.js +1 -1
  177. package/dist/locale/pt-br.min.mjs +1 -1
  178. package/dist/locale/pt-br.mjs +1 -1
  179. package/dist/locale/pt.js +1 -1
  180. package/dist/locale/pt.min.js +1 -1
  181. package/dist/locale/pt.min.mjs +1 -1
  182. package/dist/locale/pt.mjs +1 -1
  183. package/dist/locale/ro.js +1 -1
  184. package/dist/locale/ro.min.js +1 -1
  185. package/dist/locale/ro.min.mjs +1 -1
  186. package/dist/locale/ro.mjs +1 -1
  187. package/dist/locale/ru.js +1 -1
  188. package/dist/locale/ru.min.js +1 -1
  189. package/dist/locale/ru.min.mjs +1 -1
  190. package/dist/locale/ru.mjs +1 -1
  191. package/dist/locale/sk.js +1 -1
  192. package/dist/locale/sk.min.js +1 -1
  193. package/dist/locale/sk.min.mjs +1 -1
  194. package/dist/locale/sk.mjs +1 -1
  195. package/dist/locale/sl.js +1 -1
  196. package/dist/locale/sl.min.js +1 -1
  197. package/dist/locale/sl.min.mjs +1 -1
  198. package/dist/locale/sl.mjs +1 -1
  199. package/dist/locale/sr.js +1 -1
  200. package/dist/locale/sr.min.js +1 -1
  201. package/dist/locale/sr.min.mjs +1 -1
  202. package/dist/locale/sr.mjs +1 -1
  203. package/dist/locale/sv.js +1 -1
  204. package/dist/locale/sv.min.js +1 -1
  205. package/dist/locale/sv.min.mjs +1 -1
  206. package/dist/locale/sv.mjs +1 -1
  207. package/dist/locale/sw.js +1 -1
  208. package/dist/locale/sw.min.js +1 -1
  209. package/dist/locale/sw.min.mjs +1 -1
  210. package/dist/locale/sw.mjs +1 -1
  211. package/dist/locale/ta.js +1 -1
  212. package/dist/locale/ta.min.js +1 -1
  213. package/dist/locale/ta.min.mjs +1 -1
  214. package/dist/locale/ta.mjs +1 -1
  215. package/dist/locale/th.js +1 -1
  216. package/dist/locale/th.min.js +1 -1
  217. package/dist/locale/th.min.mjs +1 -1
  218. package/dist/locale/th.mjs +1 -1
  219. package/dist/locale/tk.js +1 -1
  220. package/dist/locale/tk.min.js +1 -1
  221. package/dist/locale/tk.min.mjs +1 -1
  222. package/dist/locale/tk.mjs +1 -1
  223. package/dist/locale/tr.js +1 -1
  224. package/dist/locale/tr.min.js +1 -1
  225. package/dist/locale/tr.min.mjs +1 -1
  226. package/dist/locale/tr.mjs +1 -1
  227. package/dist/locale/ug-cn.js +1 -1
  228. package/dist/locale/ug-cn.min.js +1 -1
  229. package/dist/locale/ug-cn.min.mjs +1 -1
  230. package/dist/locale/ug-cn.mjs +1 -1
  231. package/dist/locale/uk.js +1 -1
  232. package/dist/locale/uk.min.js +1 -1
  233. package/dist/locale/uk.min.mjs +1 -1
  234. package/dist/locale/uk.mjs +1 -1
  235. package/dist/locale/uz-uz.js +1 -1
  236. package/dist/locale/uz-uz.min.js +1 -1
  237. package/dist/locale/uz-uz.min.mjs +1 -1
  238. package/dist/locale/uz-uz.mjs +1 -1
  239. package/dist/locale/vi.js +1 -1
  240. package/dist/locale/vi.min.js +1 -1
  241. package/dist/locale/vi.min.mjs +1 -1
  242. package/dist/locale/vi.mjs +1 -1
  243. package/dist/locale/zh-cn.js +1 -1
  244. package/dist/locale/zh-cn.min.js +1 -1
  245. package/dist/locale/zh-cn.min.mjs +1 -1
  246. package/dist/locale/zh-cn.mjs +1 -1
  247. package/dist/locale/zh-tw.js +1 -1
  248. package/dist/locale/zh-tw.min.js +1 -1
  249. package/dist/locale/zh-tw.min.mjs +1 -1
  250. package/dist/locale/zh-tw.mjs +1 -1
  251. package/es/components/badge/index.mjs +2 -2
  252. package/es/components/badge/src/badge.mjs +32 -68
  253. package/es/components/badge/src/badge.mjs.map +1 -1
  254. package/es/components/badge/src/badge2.mjs +68 -32
  255. package/es/components/badge/src/badge2.mjs.map +1 -1
  256. package/es/components/check-tag/index.mjs +2 -2
  257. package/es/components/check-tag/src/check-tag.mjs +14 -38
  258. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  259. package/es/components/check-tag/src/check-tag2.mjs +38 -14
  260. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  261. package/es/components/col/index.mjs +2 -2
  262. package/es/components/col/src/col.mjs +64 -43
  263. package/es/components/col/src/col.mjs.map +1 -1
  264. package/es/components/col/src/col2.mjs +43 -64
  265. package/es/components/col/src/col2.mjs.map +1 -1
  266. package/es/components/countdown/index.mjs +2 -2
  267. package/es/components/countdown/src/countdown.mjs +79 -22
  268. package/es/components/countdown/src/countdown.mjs.map +1 -1
  269. package/es/components/countdown/src/countdown2.mjs +22 -79
  270. package/es/components/countdown/src/countdown2.mjs.map +1 -1
  271. package/es/components/dropdown/index.mjs +2 -2
  272. package/es/components/dropdown/src/dropdown-item-impl.mjs +1 -1
  273. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  274. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  275. package/es/components/dropdown/src/dropdown.mjs +305 -92
  276. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  277. package/es/components/dropdown/src/dropdown2.mjs +92 -305
  278. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  279. package/es/components/index.mjs +7 -7
  280. package/es/components/input-tag/src/composables/use-input-tag.mjs +2 -0
  281. package/es/components/input-tag/src/composables/use-input-tag.mjs.map +1 -1
  282. package/es/components/message/index.mjs +1 -1
  283. package/es/components/message/src/message.mjs +145 -91
  284. package/es/components/message/src/message.mjs.map +1 -1
  285. package/es/components/message/src/message2.mjs +91 -145
  286. package/es/components/message/src/message2.mjs.map +1 -1
  287. package/es/components/message/src/method.mjs +2 -2
  288. package/es/components/notification/index.mjs +1 -1
  289. package/es/components/notification/src/notification.mjs +142 -68
  290. package/es/components/notification/src/notification.mjs.map +1 -1
  291. package/es/components/notification/src/notification2.mjs +68 -142
  292. package/es/components/notification/src/notification2.mjs.map +1 -1
  293. package/es/components/notification/src/notify.mjs +2 -2
  294. package/es/components/pagination/src/components/pager.mjs +16 -209
  295. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  296. package/es/components/pagination/src/components/pager2.mjs +209 -16
  297. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  298. package/es/components/pagination/src/pagination.mjs +1 -1
  299. package/es/components/popover/src/popover.mjs +1 -1
  300. package/es/directives/click-outside/index.mjs +1 -1
  301. package/es/hooks/use-focus-controller/index.mjs +1 -1
  302. package/es/hooks/use-lockscreen/index.mjs +1 -1
  303. package/es/index.mjs +7 -7
  304. package/es/version.d.ts +1 -1
  305. package/es/version.mjs +1 -1
  306. package/es/version.mjs.map +1 -1
  307. package/lib/components/badge/index.js +2 -2
  308. package/lib/components/badge/src/badge.js +32 -68
  309. package/lib/components/badge/src/badge.js.map +1 -1
  310. package/lib/components/badge/src/badge2.js +68 -32
  311. package/lib/components/badge/src/badge2.js.map +1 -1
  312. package/lib/components/check-tag/index.js +2 -2
  313. package/lib/components/check-tag/src/check-tag.js +15 -38
  314. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  315. package/lib/components/check-tag/src/check-tag2.js +38 -15
  316. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  317. package/lib/components/col/index.js +2 -2
  318. package/lib/components/col/src/col.js +64 -43
  319. package/lib/components/col/src/col.js.map +1 -1
  320. package/lib/components/col/src/col2.js +43 -64
  321. package/lib/components/col/src/col2.js.map +1 -1
  322. package/lib/components/countdown/index.js +2 -2
  323. package/lib/components/countdown/src/countdown.js +79 -23
  324. package/lib/components/countdown/src/countdown.js.map +1 -1
  325. package/lib/components/countdown/src/countdown2.js +23 -79
  326. package/lib/components/countdown/src/countdown2.js.map +1 -1
  327. package/lib/components/dropdown/index.js +2 -2
  328. package/lib/components/dropdown/src/dropdown-item-impl.js +1 -1
  329. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  330. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  331. package/lib/components/dropdown/src/dropdown.js +305 -101
  332. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  333. package/lib/components/dropdown/src/dropdown2.js +101 -305
  334. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  335. package/lib/components/index.js +7 -7
  336. package/lib/components/input-tag/src/composables/use-input-tag.js +2 -0
  337. package/lib/components/input-tag/src/composables/use-input-tag.js.map +1 -1
  338. package/lib/components/message/index.js +1 -1
  339. package/lib/components/message/src/message.js +144 -93
  340. package/lib/components/message/src/message.js.map +1 -1
  341. package/lib/components/message/src/message2.js +93 -144
  342. package/lib/components/message/src/message2.js.map +1 -1
  343. package/lib/components/message/src/method.js +2 -2
  344. package/lib/components/notification/index.js +1 -1
  345. package/lib/components/notification/src/notification.js +141 -69
  346. package/lib/components/notification/src/notification.js.map +1 -1
  347. package/lib/components/notification/src/notification2.js +69 -141
  348. package/lib/components/notification/src/notification2.js.map +1 -1
  349. package/lib/components/notification/src/notify.js +2 -2
  350. package/lib/components/pagination/src/components/pager.js +16 -209
  351. package/lib/components/pagination/src/components/pager.js.map +1 -1
  352. package/lib/components/pagination/src/components/pager2.js +209 -16
  353. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  354. package/lib/components/pagination/src/pagination.js +1 -1
  355. package/lib/components/popover/src/popover.js +1 -1
  356. package/lib/directives/click-outside/index.js +1 -1
  357. package/lib/hooks/use-focus-controller/index.js +1 -1
  358. package/lib/hooks/use-lockscreen/index.js +1 -1
  359. package/lib/index.js +7 -7
  360. package/lib/version.d.ts +1 -1
  361. package/lib/version.js +1 -1
  362. package/lib/version.js.map +1 -1
  363. package/package.json +2 -2
  364. package/web-types.json +1 -1
@@ -1,84 +1,27 @@
1
- import { defineComponent, ref, computed, onMounted, watch, onBeforeUnmount, openBlock, createBlock, unref, createSlots, renderList, withCtx, renderSlot } from 'vue';
2
- import { ElStatistic } from '../../statistic/index.mjs';
3
- import { countdownProps, countdownEmits } from './countdown.mjs';
4
- import { formatTime, getTime } from './utils.mjs';
5
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
- import { rAF, cAF } from '../../../utils/raf.mjs';
1
+ import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
2
+ import { CHANGE_EVENT } from '../../../constants/event.mjs';
3
+ import { isNumber } from '../../../utils/types.mjs';
7
4
 
8
- const __default__ = defineComponent({
9
- name: "ElCountdown"
10
- });
11
- const _sfc_main = /* @__PURE__ */ defineComponent({
12
- ...__default__,
13
- props: countdownProps,
14
- emits: countdownEmits,
15
- setup(__props, { expose, emit }) {
16
- const props = __props;
17
- let timer;
18
- const rawValue = ref(0);
19
- const displayValue = computed(() => formatTime(rawValue.value, props.format));
20
- const formatter = (val) => formatTime(val, props.format);
21
- const stopTimer = () => {
22
- if (timer) {
23
- cAF(timer);
24
- timer = void 0;
25
- }
26
- };
27
- const startTimer = () => {
28
- const timestamp = getTime(props.value);
29
- const frameFunc = () => {
30
- let diff = timestamp - Date.now();
31
- emit("change", diff);
32
- if (diff <= 0) {
33
- diff = 0;
34
- stopTimer();
35
- emit("finish");
36
- } else {
37
- timer = rAF(frameFunc);
38
- }
39
- rawValue.value = diff;
40
- };
41
- timer = rAF(frameFunc);
42
- };
43
- onMounted(() => {
44
- rawValue.value = getTime(props.value) - Date.now();
45
- watch(() => [props.value, props.format], () => {
46
- stopTimer();
47
- startTimer();
48
- }, {
49
- immediate: true
50
- });
51
- });
52
- onBeforeUnmount(() => {
53
- stopTimer();
54
- });
55
- expose({
56
- displayValue
57
- });
58
- return (_ctx, _cache) => {
59
- return openBlock(), createBlock(unref(ElStatistic), {
60
- value: rawValue.value,
61
- title: _ctx.title,
62
- prefix: _ctx.prefix,
63
- suffix: _ctx.suffix,
64
- "value-style": _ctx.valueStyle,
65
- formatter
66
- }, createSlots({
67
- _: 2
68
- }, [
69
- renderList(_ctx.$slots, (_, name) => {
70
- return {
71
- name,
72
- fn: withCtx(() => [
73
- renderSlot(_ctx.$slots, name)
74
- ])
75
- };
76
- })
77
- ]), 1032, ["value", "title", "prefix", "suffix", "value-style"]);
78
- };
5
+ const countdownProps = buildProps({
6
+ format: {
7
+ type: String,
8
+ default: "HH:mm:ss"
9
+ },
10
+ prefix: String,
11
+ suffix: String,
12
+ title: String,
13
+ value: {
14
+ type: definePropType([Number, Object]),
15
+ default: 0
16
+ },
17
+ valueStyle: {
18
+ type: definePropType([String, Object, Array])
79
19
  }
80
20
  });
81
- var Countdown = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "countdown.vue"]]);
21
+ const countdownEmits = {
22
+ finish: () => true,
23
+ [CHANGE_EVENT]: (value) => isNumber(value)
24
+ };
82
25
 
83
- export { Countdown as default };
26
+ export { countdownEmits, countdownProps };
84
27
  //# sourceMappingURL=countdown2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"countdown2.mjs","sources":["../../../../../../packages/components/countdown/src/countdown.vue"],"sourcesContent":["<template>\n <el-statistic\n :value=\"rawValue\"\n :title=\"title\"\n :prefix=\"prefix\"\n :suffix=\"suffix\"\n :value-style=\"valueStyle\"\n :formatter=\"formatter\"\n >\n <template v-for=\"(_, name) in $slots\" #[name]>\n <slot :name=\"name\" />\n </template>\n </el-statistic>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, onBeforeUnmount, onMounted, ref, watch } from 'vue'\nimport { ElStatistic } from '@element-plus/components/statistic'\nimport { cAF, rAF } from '@element-plus/utils'\nimport { countdownEmits, countdownProps } from './countdown'\nimport { formatTime, getTime } from './utils'\n\ndefineOptions({\n name: 'ElCountdown',\n})\n\nconst props = defineProps(countdownProps)\nconst emit = defineEmits(countdownEmits)\n\nlet timer: ReturnType<typeof rAF> | undefined\nconst rawValue = ref<number>(0)\nconst displayValue = computed(() => formatTime(rawValue.value, props.format))\n\nconst formatter = (val: number) => formatTime(val, props.format)\n\nconst stopTimer = () => {\n if (timer) {\n cAF(timer)\n timer = undefined\n }\n}\n\nconst startTimer = () => {\n const timestamp = getTime(props.value)\n const frameFunc = () => {\n let diff = timestamp - Date.now()\n emit('change', diff)\n if (diff <= 0) {\n diff = 0\n stopTimer()\n emit('finish')\n } else {\n timer = rAF(frameFunc)\n }\n rawValue.value = diff\n }\n timer = rAF(frameFunc)\n}\n\nonMounted(() => {\n rawValue.value = getTime(props.value) - Date.now()\n\n watch(\n () => [props.value, props.format],\n () => {\n stopTimer()\n startTimer()\n },\n {\n immediate: true,\n }\n )\n})\n\nonBeforeUnmount(() => {\n stopTimer()\n})\n\ndefineExpose({\n /**\n * @description current display value\n */\n displayValue,\n})\n</script>\n"],"names":["_openBlock","_createBlock","_unref"],"mappings":";;;;;;;mCAqBc,CAAA;AAAA,EACZ,IAAM,EAAA,aAAA;AACR,CAAA,CAAA,CAAA;;;;;;;AAKA,IAAI,IAAA,KAAA,CAAA;AACJ,IAAM,MAAA,QAAA,GAAW,IAAY,CAAC,CAAA,CAAA;AAC9B,IAAM,MAAA,YAAA,GAAe,SAAS,MAAM,UAAA,CAAW,SAAS,KAAO,EAAA,KAAA,CAAM,MAAM,CAAC,CAAA,CAAA;AAE5E,IAAA,MAAM,YAAY,CAAC,GAAA,KAAgB,UAAW,CAAA,GAAA,EAAK,MAAM,MAAM,CAAA,CAAA;AAE/D,IAAA,MAAM,YAAY,MAAM;AACtB,MAAA,IAAI,KAAO,EAAA;AACT,QAAA,GAAA,CAAI,KAAK,CAAA,CAAA;AACT,QAAQ,KAAA,GAAA,KAAA,CAAA,CAAA;AAAA,OACV;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,aAAa,MAAM;AACvB,MAAM,MAAA,SAAA,GAAY,OAAQ,CAAA,KAAA,CAAM,KAAK,CAAA,CAAA;AACrC,MAAA,MAAM,YAAY,MAAM;AACtB,QAAI,IAAA,IAAA,GAAO,SAAY,GAAA,IAAA,CAAK,GAAI,EAAA,CAAA;AAChC,QAAA,IAAA,CAAK,UAAU,IAAI,CAAA,CAAA;AACnB,QAAA,IAAI,QAAQ,CAAG,EAAA;AACb,UAAO,IAAA,GAAA,CAAA,CAAA;AACP,UAAU,SAAA,EAAA,CAAA;AACV,UAAA,IAAA,CAAK,QAAQ,CAAA,CAAA;AAAA,SACR,MAAA;AACL,UAAA,KAAA,GAAQ,IAAI,SAAS,CAAA,CAAA;AAAA,SACvB;AACA,QAAA,QAAA,CAAS,KAAQ,GAAA,IAAA,CAAA;AAAA,OACnB,CAAA;AACA,MAAA,KAAA,GAAQ,IAAI,SAAS,CAAA,CAAA;AAAA,KACvB,CAAA;AAEA,IAAA,SAAA,CAAU,MAAM;AACd,MAAA,QAAA,CAAS,QAAQ,OAAQ,CAAA,KAAA,CAAM,KAAK,CAAA,GAAI,KAAK,GAAI,EAAA,CAAA;AAEjD,MAAA,KAAA,CAAA,MAAA,CAAA,KAAA,CAAA,KAAA,EAAA,KAAA,CAAA,MAAA,CAAA,EAAA,MAAA;AAAA,QACE,SAAa,EAAA,CAAA;AAAmB,QAChC,UAAM,EAAA,CAAA;AACJ,OAAU,EAAA;AACV,QAAW,SAAA,EAAA,IAAA;AAAA,OACb,CAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAAA,IAAA,eACa,CAAA,MAAA;AAAA,MACb,SAAA,EAAA,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,IACF,MAAC,CAAA;AAED,MAAA,YAAA;AACE,KAAU,CAAA,CAAA;AAAA,IACZ,OAAC,CAAA,IAAA,EAAA,MAAA,KAAA;AAED,MAAa,OAAAA,SAAA,EAAA,EAAAC,WAAA,CAAAC,KAAA,CAAA,WAAA,CAAA,EAAA;AAAA,QAAA,KAAA,EAAA,QAAA,CAAA,KAAA;AAAA,QAAA,KAAA,EAAA,IAAA,CAAA,KAAA;AAAA,QAAA,MAAA,EAAA,IAAA,CAAA,MAAA;AAAA,QAIX,MAAA,EAAA,IAAA,CAAA,MAAA;AAAA,QACD,aAAA,EAAA,IAAA,CAAA,UAAA;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"countdown2.mjs","sources":["../../../../../../packages/components/countdown/src/countdown.ts"],"sourcesContent":["import { buildProps, definePropType, isNumber } from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, StyleValue } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type Countdown from './countdown.vue'\n\nexport const countdownProps = buildProps({\n /**\n * @description Formatting the countdown display\n */\n format: {\n type: String,\n default: 'HH:mm:ss',\n },\n /**\n * @description Sets the prefix of a countdown\n */\n prefix: String,\n /**\n * @description Sets the suffix of a countdown\n */\n suffix: String,\n /**\n * @description countdown titles\n */\n title: String,\n /**\n * @description target time\n */\n value: {\n type: definePropType<number | Dayjs>([Number, Object]),\n default: 0,\n },\n /**\n * @description Styles countdown values\n */\n valueStyle: {\n type: definePropType<StyleValue>([String, Object, Array]),\n },\n} as const)\nexport type CountdownProps = ExtractPropTypes<typeof countdownProps>\n\nexport const countdownEmits = {\n finish: () => true,\n [CHANGE_EVENT]: (value: number) => isNumber(value),\n}\nexport type CountdownEmits = typeof countdownEmits\n\nexport type CountdownInstance = InstanceType<typeof Countdown>\n"],"names":[],"mappings":";;;;AAEY,MAAC,cAAc,GAAG,UAAU,CAAC;AACzC,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,UAAU;AACvB,GAAG;AACH,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC1C,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AACjD,GAAG;AACH,CAAC,EAAE;AACS,MAAC,cAAc,GAAG;AAC9B,EAAE,MAAM,EAAE,MAAM,IAAI;AACpB,EAAE,CAAC,YAAY,GAAG,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAC5C;;;;"}
@@ -1,7 +1,7 @@
1
- import Dropdown from './src/dropdown2.mjs';
1
+ import Dropdown from './src/dropdown.mjs';
2
2
  import DropdownItem from './src/dropdown-item.mjs';
3
3
  import DropdownMenu from './src/dropdown-menu.mjs';
4
- export { DROPDOWN_COLLECTION_INJECTION_KEY, DROPDOWN_COLLECTION_ITEM_INJECTION_KEY, ElCollection, ElCollectionItem, FIRST_KEYS, FIRST_LAST_KEYS, LAST_KEYS, dropdownItemProps, dropdownMenuProps, dropdownProps } from './src/dropdown.mjs';
4
+ export { DROPDOWN_COLLECTION_INJECTION_KEY, DROPDOWN_COLLECTION_ITEM_INJECTION_KEY, ElCollection, ElCollectionItem, FIRST_KEYS, FIRST_LAST_KEYS, LAST_KEYS, dropdownItemProps, dropdownMenuProps, dropdownProps } from './src/dropdown2.mjs';
5
5
  export { DROPDOWN_INJECTION_KEY } from './src/tokens.mjs';
6
6
  import { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';
7
7
 
@@ -1,6 +1,6 @@
1
1
  import { defineComponent, inject, computed, resolveComponent, openBlock, createElementBlock, Fragment, normalizeClass, createCommentVNode, createElementVNode, mergeProps, withModifiers, createBlock, withCtx, resolveDynamicComponent, renderSlot } from 'vue';
2
2
  import { ElIcon } from '../../icon/index.mjs';
3
- import { dropdownItemProps, DROPDOWN_COLLECTION_ITEM_INJECTION_KEY as COLLECTION_ITEM_INJECTION_KEY } from './dropdown.mjs';
3
+ import { dropdownItemProps, DROPDOWN_COLLECTION_ITEM_INJECTION_KEY as COLLECTION_ITEM_INJECTION_KEY } from './dropdown2.mjs';
4
4
  import { DROPDOWN_INJECTION_KEY } from './tokens.mjs';
5
5
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
6
  import { ROVING_FOCUS_ITEM_COLLECTION_INJECTION_KEY as COLLECTION_ITEM_INJECTION_KEY$1 } from '../../roving-focus-group/src/roving-focus-group.mjs';
@@ -2,7 +2,7 @@ import { defineComponent, getCurrentInstance, ref, computed, unref, inject, reso
2
2
  import ElRovingFocusItem from '../../roving-focus-group/src/roving-focus-item.mjs';
3
3
  import ElDropdownItemImpl from './dropdown-item-impl.mjs';
4
4
  import { useDropdown } from './useDropdown.mjs';
5
- import { ElCollectionItem, dropdownItemProps } from './dropdown.mjs';
5
+ import { ElCollectionItem, dropdownItemProps } from './dropdown2.mjs';
6
6
  import { DROPDOWN_INJECTION_KEY } from './tokens.mjs';
7
7
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
8
8
  import { composeEventHandlers, whenMouse } from '../../../utils/dom/event.mjs';
@@ -1,6 +1,6 @@
1
1
  import { defineComponent, inject, computed, openBlock, createElementBlock, normalizeClass, normalizeStyle, withModifiers, renderSlot, unref } from 'vue';
2
2
  import { DROPDOWN_INJECTION_KEY } from './tokens.mjs';
3
- import { dropdownMenuProps, DROPDOWN_COLLECTION_INJECTION_KEY as COLLECTION_INJECTION_KEY, FIRST_LAST_KEYS, LAST_KEYS } from './dropdown.mjs';
3
+ import { dropdownMenuProps, DROPDOWN_COLLECTION_INJECTION_KEY as COLLECTION_INJECTION_KEY, FIRST_LAST_KEYS, LAST_KEYS } from './dropdown2.mjs';
4
4
  import { useDropdown } from './useDropdown.mjs';
5
5
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
6
  import { ROVING_FOCUS_GROUP_INJECTION_KEY } from '../../roving-focus-group/src/tokens.mjs';
@@ -1,99 +1,312 @@
1
- import { useTooltipTriggerProps } from '../../tooltip/src/trigger.mjs';
2
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
3
- import { useTooltipContentProps } from '../../tooltip/src/content.mjs';
4
- import { iconPropType } from '../../../utils/vue/icon.mjs';
5
- import { createCollectionWithScope } from '../../collection/src/collection.mjs';
1
+ import { defineComponent, getCurrentInstance, ref, computed, watch, onBeforeUnmount, provide, toRef, unref, resolveComponent, openBlock, createElementBlock, normalizeClass, createVNode, createSlots, withCtx, renderSlot, createBlock, mergeProps, createCommentVNode } from 'vue';
2
+ import { ElButton } from '../../button/index.mjs';
3
+ import { ElTooltip } from '../../tooltip/index.mjs';
4
+ import { ElScrollbar } from '../../scrollbar/index.mjs';
5
+ import { ElIcon } from '../../icon/index.mjs';
6
+ import ElRovingFocusGroup from '../../roving-focus-group/src/roving-focus-group2.mjs';
7
+ import { ArrowDown } from '@element-plus/icons-vue';
8
+ import { ElCollection, dropdownProps } from './dropdown2.mjs';
9
+ import { DROPDOWN_INJECTION_KEY } from './tokens.mjs';
10
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
11
+ import { OnlyChild } from '../../slot/src/only-child.mjs';
12
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
13
+ import { useLocale } from '../../../hooks/use-locale/index.mjs';
14
+ import { addUnit } from '../../../utils/dom/style.mjs';
15
+ import { castArray } from 'lodash-unified';
16
+ import { useId } from '../../../hooks/use-id/index.mjs';
17
+ import { useFormSize } from '../../form/src/hooks/use-form-common-props.mjs';
6
18
  import { EVENT_CODE } from '../../../constants/aria.mjs';
7
19
 
8
- const dropdownProps = buildProps({
9
- trigger: useTooltipTriggerProps.trigger,
10
- effect: {
11
- ...useTooltipContentProps.effect,
12
- default: "light"
20
+ const { ButtonGroup: ElButtonGroup } = ElButton;
21
+ const _sfc_main = defineComponent({
22
+ name: "ElDropdown",
23
+ components: {
24
+ ElButton,
25
+ ElButtonGroup,
26
+ ElScrollbar,
27
+ ElDropdownCollection: ElCollection,
28
+ ElTooltip,
29
+ ElRovingFocusGroup,
30
+ ElOnlyChild: OnlyChild,
31
+ ElIcon,
32
+ ArrowDown
13
33
  },
14
- type: {
15
- type: definePropType(String)
16
- },
17
- placement: {
18
- type: definePropType(String),
19
- default: "bottom"
20
- },
21
- popperOptions: {
22
- type: definePropType(Object),
23
- default: () => ({})
24
- },
25
- id: String,
26
- size: {
27
- type: String,
28
- default: ""
29
- },
30
- splitButton: Boolean,
31
- hideOnClick: {
32
- type: Boolean,
33
- default: true
34
- },
35
- loop: {
36
- type: Boolean,
37
- default: true
38
- },
39
- showTimeout: {
40
- type: Number,
41
- default: 150
42
- },
43
- hideTimeout: {
44
- type: Number,
45
- default: 150
46
- },
47
- tabindex: {
48
- type: definePropType([Number, String]),
49
- default: 0
50
- },
51
- maxHeight: {
52
- type: definePropType([Number, String]),
53
- default: ""
54
- },
55
- popperClass: {
56
- type: String,
57
- default: ""
58
- },
59
- disabled: Boolean,
60
- role: {
61
- type: String,
62
- default: "menu"
63
- },
64
- buttonProps: {
65
- type: definePropType(Object)
66
- },
67
- teleported: useTooltipContentProps.teleported
68
- });
69
- const dropdownItemProps = buildProps({
70
- command: {
71
- type: [Object, String, Number],
72
- default: () => ({})
73
- },
74
- disabled: Boolean,
75
- divided: Boolean,
76
- textValue: String,
77
- icon: {
78
- type: iconPropType
34
+ props: dropdownProps,
35
+ emits: ["visible-change", "click", "command"],
36
+ setup(props, { emit }) {
37
+ const _instance = getCurrentInstance();
38
+ const ns = useNamespace("dropdown");
39
+ const { t } = useLocale();
40
+ const triggeringElementRef = ref();
41
+ const referenceElementRef = ref();
42
+ const popperRef = ref(null);
43
+ const contentRef = ref(null);
44
+ const scrollbar = ref(null);
45
+ const currentTabId = ref(null);
46
+ const isUsingKeyboard = ref(false);
47
+ const triggerKeys = [
48
+ EVENT_CODE.enter,
49
+ EVENT_CODE.numpadEnter,
50
+ EVENT_CODE.space,
51
+ EVENT_CODE.down
52
+ ];
53
+ const wrapStyle = computed(() => ({
54
+ maxHeight: addUnit(props.maxHeight)
55
+ }));
56
+ const dropdownTriggerKls = computed(() => [ns.m(dropdownSize.value)]);
57
+ const trigger = computed(() => castArray(props.trigger));
58
+ const defaultTriggerId = useId().value;
59
+ const triggerId = computed(() => props.id || defaultTriggerId);
60
+ watch([triggeringElementRef, trigger], ([triggeringElement, trigger2], [prevTriggeringElement]) => {
61
+ var _a, _b, _c;
62
+ if ((_a = prevTriggeringElement == null ? void 0 : prevTriggeringElement.$el) == null ? void 0 : _a.removeEventListener) {
63
+ prevTriggeringElement.$el.removeEventListener("pointerenter", onAutofocusTriggerEnter);
64
+ }
65
+ if ((_b = triggeringElement == null ? void 0 : triggeringElement.$el) == null ? void 0 : _b.removeEventListener) {
66
+ triggeringElement.$el.removeEventListener("pointerenter", onAutofocusTriggerEnter);
67
+ }
68
+ if (((_c = triggeringElement == null ? void 0 : triggeringElement.$el) == null ? void 0 : _c.addEventListener) && trigger2.includes("hover")) {
69
+ triggeringElement.$el.addEventListener("pointerenter", onAutofocusTriggerEnter);
70
+ }
71
+ }, { immediate: true });
72
+ onBeforeUnmount(() => {
73
+ var _a, _b;
74
+ if ((_b = (_a = triggeringElementRef.value) == null ? void 0 : _a.$el) == null ? void 0 : _b.removeEventListener) {
75
+ triggeringElementRef.value.$el.removeEventListener("pointerenter", onAutofocusTriggerEnter);
76
+ }
77
+ });
78
+ function handleClick() {
79
+ handleClose();
80
+ }
81
+ function handleClose() {
82
+ var _a;
83
+ (_a = popperRef.value) == null ? void 0 : _a.onClose();
84
+ }
85
+ function handleOpen() {
86
+ var _a;
87
+ (_a = popperRef.value) == null ? void 0 : _a.onOpen();
88
+ }
89
+ const dropdownSize = useFormSize();
90
+ function commandHandler(...args) {
91
+ emit("command", ...args);
92
+ }
93
+ function onAutofocusTriggerEnter() {
94
+ var _a, _b;
95
+ (_b = (_a = triggeringElementRef.value) == null ? void 0 : _a.$el) == null ? void 0 : _b.focus();
96
+ }
97
+ function onItemEnter() {
98
+ }
99
+ function onItemLeave() {
100
+ const contentEl = unref(contentRef);
101
+ trigger.value.includes("hover") && (contentEl == null ? void 0 : contentEl.focus());
102
+ currentTabId.value = null;
103
+ }
104
+ function handleCurrentTabIdChange(id) {
105
+ currentTabId.value = id;
106
+ }
107
+ function handleEntryFocus(e) {
108
+ if (!isUsingKeyboard.value) {
109
+ e.preventDefault();
110
+ e.stopImmediatePropagation();
111
+ }
112
+ }
113
+ function handleBeforeShowTooltip() {
114
+ emit("visible-change", true);
115
+ }
116
+ function handleShowTooltip(event) {
117
+ if ((event == null ? void 0 : event.type) === "keydown") {
118
+ contentRef.value.focus();
119
+ }
120
+ }
121
+ function handleBeforeHideTooltip() {
122
+ emit("visible-change", false);
123
+ }
124
+ provide(DROPDOWN_INJECTION_KEY, {
125
+ contentRef,
126
+ role: computed(() => props.role),
127
+ triggerId,
128
+ isUsingKeyboard,
129
+ onItemEnter,
130
+ onItemLeave
131
+ });
132
+ provide("elDropdown", {
133
+ instance: _instance,
134
+ dropdownSize,
135
+ handleClick,
136
+ commandHandler,
137
+ trigger: toRef(props, "trigger"),
138
+ hideOnClick: toRef(props, "hideOnClick")
139
+ });
140
+ const onFocusAfterTrapped = (e) => {
141
+ var _a, _b;
142
+ e.preventDefault();
143
+ (_b = (_a = contentRef.value) == null ? void 0 : _a.focus) == null ? void 0 : _b.call(_a, {
144
+ preventScroll: true
145
+ });
146
+ };
147
+ const handlerMainButtonClick = (event) => {
148
+ emit("click", event);
149
+ };
150
+ return {
151
+ t,
152
+ ns,
153
+ scrollbar,
154
+ wrapStyle,
155
+ dropdownTriggerKls,
156
+ dropdownSize,
157
+ triggerId,
158
+ triggerKeys,
159
+ currentTabId,
160
+ handleCurrentTabIdChange,
161
+ handlerMainButtonClick,
162
+ handleEntryFocus,
163
+ handleClose,
164
+ handleOpen,
165
+ handleBeforeShowTooltip,
166
+ handleShowTooltip,
167
+ handleBeforeHideTooltip,
168
+ onFocusAfterTrapped,
169
+ popperRef,
170
+ contentRef,
171
+ triggeringElementRef,
172
+ referenceElementRef
173
+ };
79
174
  }
80
175
  });
81
- const dropdownMenuProps = buildProps({
82
- onKeydown: { type: definePropType(Function) }
83
- });
84
- const FIRST_KEYS = [
85
- EVENT_CODE.down,
86
- EVENT_CODE.pageDown,
87
- EVENT_CODE.home
88
- ];
89
- const LAST_KEYS = [EVENT_CODE.up, EVENT_CODE.pageUp, EVENT_CODE.end];
90
- const FIRST_LAST_KEYS = [...FIRST_KEYS, ...LAST_KEYS];
91
- const {
92
- ElCollection,
93
- ElCollectionItem,
94
- COLLECTION_INJECTION_KEY,
95
- COLLECTION_ITEM_INJECTION_KEY
96
- } = createCollectionWithScope("Dropdown");
176
+ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
177
+ var _a;
178
+ const _component_el_dropdown_collection = resolveComponent("el-dropdown-collection");
179
+ const _component_el_roving_focus_group = resolveComponent("el-roving-focus-group");
180
+ const _component_el_scrollbar = resolveComponent("el-scrollbar");
181
+ const _component_el_only_child = resolveComponent("el-only-child");
182
+ const _component_el_tooltip = resolveComponent("el-tooltip");
183
+ const _component_el_button = resolveComponent("el-button");
184
+ const _component_arrow_down = resolveComponent("arrow-down");
185
+ const _component_el_icon = resolveComponent("el-icon");
186
+ const _component_el_button_group = resolveComponent("el-button-group");
187
+ return openBlock(), createElementBlock("div", {
188
+ class: normalizeClass([_ctx.ns.b(), _ctx.ns.is("disabled", _ctx.disabled)])
189
+ }, [
190
+ createVNode(_component_el_tooltip, {
191
+ ref: "popperRef",
192
+ role: _ctx.role,
193
+ effect: _ctx.effect,
194
+ "fallback-placements": ["bottom", "top"],
195
+ "popper-options": _ctx.popperOptions,
196
+ "gpu-acceleration": false,
197
+ "hide-after": _ctx.trigger === "hover" ? _ctx.hideTimeout : 0,
198
+ "manual-mode": true,
199
+ placement: _ctx.placement,
200
+ "popper-class": [_ctx.ns.e("popper"), _ctx.popperClass],
201
+ "reference-element": (_a = _ctx.referenceElementRef) == null ? void 0 : _a.$el,
202
+ trigger: _ctx.trigger,
203
+ "trigger-keys": _ctx.triggerKeys,
204
+ "trigger-target-el": _ctx.contentRef,
205
+ "show-after": _ctx.trigger === "hover" ? _ctx.showTimeout : 0,
206
+ "stop-popper-mouse-event": false,
207
+ "virtual-ref": _ctx.triggeringElementRef,
208
+ "virtual-triggering": _ctx.splitButton,
209
+ disabled: _ctx.disabled,
210
+ transition: `${_ctx.ns.namespace.value}-zoom-in-top`,
211
+ teleported: _ctx.teleported,
212
+ pure: "",
213
+ persistent: "",
214
+ onBeforeShow: _ctx.handleBeforeShowTooltip,
215
+ onShow: _ctx.handleShowTooltip,
216
+ onBeforeHide: _ctx.handleBeforeHideTooltip
217
+ }, createSlots({
218
+ content: withCtx(() => [
219
+ createVNode(_component_el_scrollbar, {
220
+ ref: "scrollbar",
221
+ "wrap-style": _ctx.wrapStyle,
222
+ tag: "div",
223
+ "view-class": _ctx.ns.e("list")
224
+ }, {
225
+ default: withCtx(() => [
226
+ createVNode(_component_el_roving_focus_group, {
227
+ loop: _ctx.loop,
228
+ "current-tab-id": _ctx.currentTabId,
229
+ orientation: "horizontal",
230
+ onCurrentTabIdChange: _ctx.handleCurrentTabIdChange,
231
+ onEntryFocus: _ctx.handleEntryFocus
232
+ }, {
233
+ default: withCtx(() => [
234
+ createVNode(_component_el_dropdown_collection, null, {
235
+ default: withCtx(() => [
236
+ renderSlot(_ctx.$slots, "dropdown")
237
+ ]),
238
+ _: 3
239
+ })
240
+ ]),
241
+ _: 3
242
+ }, 8, ["loop", "current-tab-id", "onCurrentTabIdChange", "onEntryFocus"])
243
+ ]),
244
+ _: 3
245
+ }, 8, ["wrap-style", "view-class"])
246
+ ]),
247
+ _: 2
248
+ }, [
249
+ !_ctx.splitButton ? {
250
+ name: "default",
251
+ fn: withCtx(() => [
252
+ createVNode(_component_el_only_child, {
253
+ id: _ctx.triggerId,
254
+ ref: "triggeringElementRef",
255
+ role: "button",
256
+ tabindex: _ctx.tabindex
257
+ }, {
258
+ default: withCtx(() => [
259
+ renderSlot(_ctx.$slots, "default")
260
+ ]),
261
+ _: 3
262
+ }, 8, ["id", "tabindex"])
263
+ ])
264
+ } : void 0
265
+ ]), 1032, ["role", "effect", "popper-options", "hide-after", "placement", "popper-class", "reference-element", "trigger", "trigger-keys", "trigger-target-el", "show-after", "virtual-ref", "virtual-triggering", "disabled", "transition", "teleported", "onBeforeShow", "onShow", "onBeforeHide"]),
266
+ _ctx.splitButton ? (openBlock(), createBlock(_component_el_button_group, { key: 0 }, {
267
+ default: withCtx(() => [
268
+ createVNode(_component_el_button, mergeProps({ ref: "referenceElementRef" }, _ctx.buttonProps, {
269
+ size: _ctx.dropdownSize,
270
+ type: _ctx.type,
271
+ disabled: _ctx.disabled,
272
+ tabindex: _ctx.tabindex,
273
+ onClick: _ctx.handlerMainButtonClick
274
+ }), {
275
+ default: withCtx(() => [
276
+ renderSlot(_ctx.$slots, "default")
277
+ ]),
278
+ _: 3
279
+ }, 16, ["size", "type", "disabled", "tabindex", "onClick"]),
280
+ createVNode(_component_el_button, mergeProps({
281
+ id: _ctx.triggerId,
282
+ ref: "triggeringElementRef"
283
+ }, _ctx.buttonProps, {
284
+ role: "button",
285
+ size: _ctx.dropdownSize,
286
+ type: _ctx.type,
287
+ class: _ctx.ns.e("caret-button"),
288
+ disabled: _ctx.disabled,
289
+ tabindex: _ctx.tabindex,
290
+ "aria-label": _ctx.t("el.dropdown.toggleDropdown")
291
+ }), {
292
+ default: withCtx(() => [
293
+ createVNode(_component_el_icon, {
294
+ class: normalizeClass(_ctx.ns.e("icon"))
295
+ }, {
296
+ default: withCtx(() => [
297
+ createVNode(_component_arrow_down)
298
+ ]),
299
+ _: 1
300
+ }, 8, ["class"])
301
+ ]),
302
+ _: 1
303
+ }, 16, ["id", "size", "type", "class", "disabled", "tabindex", "aria-label"])
304
+ ]),
305
+ _: 3
306
+ })) : createCommentVNode("v-if", true)
307
+ ], 2);
308
+ }
309
+ var Dropdown = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__file", "dropdown.vue"]]);
97
310
 
98
- export { COLLECTION_INJECTION_KEY as DROPDOWN_COLLECTION_INJECTION_KEY, COLLECTION_ITEM_INJECTION_KEY as DROPDOWN_COLLECTION_ITEM_INJECTION_KEY, ElCollection, ElCollectionItem, FIRST_KEYS, FIRST_LAST_KEYS, LAST_KEYS, dropdownItemProps, dropdownMenuProps, dropdownProps };
311
+ export { Dropdown as default };
99
312
  //# sourceMappingURL=dropdown.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"dropdown.mjs","sources":["../../../../../../packages/components/dropdown/src/dropdown.ts"],"sourcesContent":["// @ts-nocheck\nimport { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { createCollectionWithScope } from '@element-plus/components/collection'\nimport {\n useTooltipContentProps,\n useTooltipTriggerProps,\n} from '@element-plus/components/tooltip'\n\nimport type { Options } from '@popperjs/core'\nimport type { ButtonProps, ButtonType } from '@element-plus/components/button'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { ComponentInternalInstance, ComputedRef } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\n\nexport interface IElDropdownInstance {\n instance?: ComponentInternalInstance\n dropdownSize?: ComputedRef<string>\n handleClick?: () => void\n commandHandler?: (...arg) => void\n show?: () => void\n hide?: () => void\n trigger?: ComputedRef<string>\n hideOnClick?: ComputedRef<boolean>\n triggerElm?: ComputedRef<Nullable<HTMLButtonElement>>\n}\n\nexport const dropdownProps = buildProps({\n /**\n * @description how to trigger\n */\n trigger: useTooltipTriggerProps.trigger,\n effect: {\n ...useTooltipContentProps.effect,\n default: 'light',\n },\n /**\n * @description menu button type, refer to `Button` Component, only works when `split-button` is true\n */\n type: {\n type: definePropType<ButtonType>(String),\n },\n /**\n * @description placement of pop menu\n */\n placement: {\n type: definePropType<Placement>(String),\n default: 'bottom',\n },\n /**\n * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n */\n popperOptions: {\n type: definePropType<Partial<Options>>(Object),\n default: () => ({}),\n },\n id: String,\n /**\n * @description menu size, also works on the split button\n */\n size: {\n type: String,\n default: '',\n },\n /**\n * @description whether a button group is displayed\n */\n splitButton: Boolean,\n /**\n * @description whether to hide menu after clicking menu-item\n */\n hideOnClick: {\n type: Boolean,\n default: true,\n },\n loop: {\n type: Boolean,\n default: true,\n },\n /**\n * @description delay time before show a dropdown (only works when trigger is `hover`)\n */\n showTimeout: {\n type: Number,\n default: 150,\n },\n /**\n * @description delay time before hide a dropdown (only works when trigger is `hover`)\n */\n hideTimeout: {\n type: Number,\n default: 150,\n },\n /**\n * @description [tabindex](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) of Dropdown\n */\n tabindex: {\n type: definePropType<number | string>([Number, String]),\n default: 0,\n },\n /**\n * @description the max height of menu\n */\n maxHeight: {\n type: definePropType<number | string>([Number, String]),\n default: '',\n },\n /**\n * @description custom class name for Dropdown's dropdown\n */\n popperClass: {\n type: String,\n default: '',\n },\n /**\n * @description whether to disable\n */\n disabled: Boolean,\n /**\n * @description the ARIA role attribute for the dropdown menu. Depending on the use case, you may want to change this to 'navigation'\n */\n role: {\n type: String,\n default: 'menu',\n },\n buttonProps: {\n type: definePropType<ButtonProps>(Object),\n },\n /**\n * @description whether the dropdown popup is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n} as const)\n\nexport const dropdownItemProps = buildProps({\n /**\n * @description a command to be dispatched to Dropdown's `command` callback\n */\n command: {\n type: [Object, String, Number],\n default: () => ({}),\n },\n /**\n * @description whether the item is disabled\n */\n disabled: Boolean,\n /**\n * @description whether a divider is displayed\n */\n divided: Boolean,\n textValue: String,\n /**\n * @description custom icon\n */\n icon: {\n type: iconPropType,\n },\n} as const)\n\nexport const dropdownMenuProps = buildProps({\n onKeydown: { type: definePropType<(e: KeyboardEvent) => void>(Function) },\n})\n\nexport const FIRST_KEYS = [\n EVENT_CODE.down,\n EVENT_CODE.pageDown,\n EVENT_CODE.home,\n]\n\nexport const LAST_KEYS = [EVENT_CODE.up, EVENT_CODE.pageUp, EVENT_CODE.end]\n\nexport const FIRST_LAST_KEYS = [...FIRST_KEYS, ...LAST_KEYS]\n\nconst {\n ElCollection,\n ElCollectionItem,\n COLLECTION_INJECTION_KEY,\n COLLECTION_ITEM_INJECTION_KEY,\n} = createCollectionWithScope('Dropdown')\n\nexport {\n ElCollection,\n ElCollectionItem,\n COLLECTION_INJECTION_KEY as DROPDOWN_COLLECTION_INJECTION_KEY,\n COLLECTION_ITEM_INJECTION_KEY as DROPDOWN_COLLECTION_ITEM_INJECTION_KEY,\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dropdown.mjs","sources":["../../../../../../packages/components/dropdown/src/dropdown.vue"],"sourcesContent":["<template>\n <div :class=\"[ns.b(), ns.is('disabled', disabled)]\">\n <el-tooltip\n ref=\"popperRef\"\n :role=\"role\"\n :effect=\"effect\"\n :fallback-placements=\"['bottom', 'top']\"\n :popper-options=\"popperOptions\"\n :gpu-acceleration=\"false\"\n :hide-after=\"trigger === 'hover' ? hideTimeout : 0\"\n :manual-mode=\"true\"\n :placement=\"placement\"\n :popper-class=\"[ns.e('popper'), popperClass]\"\n :reference-element=\"referenceElementRef?.$el\"\n :trigger=\"trigger\"\n :trigger-keys=\"triggerKeys\"\n :trigger-target-el=\"contentRef\"\n :show-after=\"trigger === 'hover' ? showTimeout : 0\"\n :stop-popper-mouse-event=\"false\"\n :virtual-ref=\"triggeringElementRef\"\n :virtual-triggering=\"splitButton\"\n :disabled=\"disabled\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n :teleported=\"teleported\"\n pure\n persistent\n @before-show=\"handleBeforeShowTooltip\"\n @show=\"handleShowTooltip\"\n @before-hide=\"handleBeforeHideTooltip\"\n >\n <template #content>\n <el-scrollbar\n ref=\"scrollbar\"\n :wrap-style=\"wrapStyle\"\n tag=\"div\"\n :view-class=\"ns.e('list')\"\n >\n <el-roving-focus-group\n :loop=\"loop\"\n :current-tab-id=\"currentTabId\"\n orientation=\"horizontal\"\n @current-tab-id-change=\"handleCurrentTabIdChange\"\n @entry-focus=\"handleEntryFocus\"\n >\n <el-dropdown-collection>\n <slot name=\"dropdown\" />\n </el-dropdown-collection>\n </el-roving-focus-group>\n </el-scrollbar>\n </template>\n <template v-if=\"!splitButton\" #default>\n <el-only-child\n :id=\"triggerId\"\n ref=\"triggeringElementRef\"\n role=\"button\"\n :tabindex=\"tabindex\"\n >\n <slot name=\"default\" />\n </el-only-child>\n </template>\n </el-tooltip>\n <template v-if=\"splitButton\">\n <el-button-group>\n <el-button\n ref=\"referenceElementRef\"\n v-bind=\"buttonProps\"\n :size=\"dropdownSize\"\n :type=\"type\"\n :disabled=\"disabled\"\n :tabindex=\"tabindex\"\n @click=\"handlerMainButtonClick\"\n >\n <slot name=\"default\" />\n </el-button>\n <el-button\n :id=\"triggerId\"\n ref=\"triggeringElementRef\"\n v-bind=\"buttonProps\"\n role=\"button\"\n :size=\"dropdownSize\"\n :type=\"type\"\n :class=\"ns.e('caret-button')\"\n :disabled=\"disabled\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.dropdown.toggleDropdown')\"\n >\n <el-icon :class=\"ns.e('icon')\"><arrow-down /></el-icon>\n </el-button>\n </el-button-group>\n </template>\n </div>\n</template>\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n computed,\n defineComponent,\n getCurrentInstance,\n onBeforeUnmount,\n provide,\n ref,\n toRef,\n unref,\n watch,\n} from 'vue'\nimport ElButton from '@element-plus/components/button'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElIcon from '@element-plus/components/icon'\nimport ElRovingFocusGroup from '@element-plus/components/roving-focus-group'\nimport { ElOnlyChild } from '@element-plus/components/slot'\nimport { useFormSize } from '@element-plus/components/form'\nimport { addUnit, ensureArray } from '@element-plus/utils'\nimport { ArrowDown } from '@element-plus/icons-vue'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useId, useLocale, useNamespace } from '@element-plus/hooks'\nimport { ElCollection as ElDropdownCollection, dropdownProps } from './dropdown'\nimport { DROPDOWN_INJECTION_KEY } from './tokens'\n\nimport type { CSSProperties } from 'vue'\n\nconst { ButtonGroup: ElButtonGroup } = ElButton\n\nexport default defineComponent({\n name: 'ElDropdown',\n components: {\n ElButton,\n ElButtonGroup,\n ElScrollbar,\n ElDropdownCollection,\n ElTooltip,\n ElRovingFocusGroup,\n ElOnlyChild,\n ElIcon,\n ArrowDown,\n },\n props: dropdownProps,\n emits: ['visible-change', 'click', 'command'],\n setup(props, { emit }) {\n const _instance = getCurrentInstance()\n const ns = useNamespace('dropdown')\n const { t } = useLocale()\n\n const triggeringElementRef = ref()\n const referenceElementRef = ref()\n const popperRef = ref<InstanceType<typeof ElTooltip> | null>(null)\n const contentRef = ref<HTMLElement | null>(null)\n const scrollbar = ref(null)\n const currentTabId = ref<string | null>(null)\n const isUsingKeyboard = ref(false)\n const triggerKeys = [\n EVENT_CODE.enter,\n EVENT_CODE.numpadEnter,\n EVENT_CODE.space,\n EVENT_CODE.down,\n ]\n\n const wrapStyle = computed<CSSProperties>(() => ({\n maxHeight: addUnit(props.maxHeight),\n }))\n const dropdownTriggerKls = computed(() => [ns.m(dropdownSize.value)])\n const trigger = computed(() => ensureArray(props.trigger))\n\n const defaultTriggerId = useId().value\n const triggerId = computed<string>(() => props.id || defaultTriggerId)\n\n // The goal of this code is to focus on the tooltip triggering element when it is hovered.\n // This is a temporary fix for where closing the dropdown through pointerleave event focuses on a\n // completely different element. For a permanent solution, remove all calls to any \"element.focus()\"\n // that are triggered through pointer enter/leave events.\n watch(\n [triggeringElementRef, trigger],\n ([triggeringElement, trigger], [prevTriggeringElement]) => {\n if (prevTriggeringElement?.$el?.removeEventListener) {\n prevTriggeringElement.$el.removeEventListener(\n 'pointerenter',\n onAutofocusTriggerEnter\n )\n }\n if (triggeringElement?.$el?.removeEventListener) {\n triggeringElement.$el.removeEventListener(\n 'pointerenter',\n onAutofocusTriggerEnter\n )\n }\n if (\n triggeringElement?.$el?.addEventListener &&\n trigger.includes('hover')\n ) {\n triggeringElement.$el.addEventListener(\n 'pointerenter',\n onAutofocusTriggerEnter\n )\n }\n },\n { immediate: true }\n )\n\n onBeforeUnmount(() => {\n if (triggeringElementRef.value?.$el?.removeEventListener) {\n triggeringElementRef.value.$el.removeEventListener(\n 'pointerenter',\n onAutofocusTriggerEnter\n )\n }\n })\n\n function handleClick() {\n handleClose()\n }\n\n function handleClose() {\n popperRef.value?.onClose()\n }\n\n function handleOpen() {\n popperRef.value?.onOpen()\n }\n\n const dropdownSize = useFormSize()\n\n function commandHandler(...args: any[]) {\n emit('command', ...args)\n }\n\n function onAutofocusTriggerEnter() {\n triggeringElementRef.value?.$el?.focus()\n }\n\n function onItemEnter() {\n // NOOP for now\n }\n\n function onItemLeave() {\n const contentEl = unref(contentRef)\n\n trigger.value.includes('hover') && contentEl?.focus()\n currentTabId.value = null\n }\n\n function handleCurrentTabIdChange(id: string) {\n currentTabId.value = id\n }\n\n function handleEntryFocus(e: Event) {\n if (!isUsingKeyboard.value) {\n e.preventDefault()\n e.stopImmediatePropagation()\n }\n }\n\n function handleBeforeShowTooltip() {\n emit('visible-change', true)\n }\n\n function handleShowTooltip(event?: Event) {\n if (event?.type === 'keydown') {\n contentRef.value.focus()\n }\n }\n\n function handleBeforeHideTooltip() {\n emit('visible-change', false)\n }\n\n provide(DROPDOWN_INJECTION_KEY, {\n contentRef,\n role: computed(() => props.role),\n triggerId,\n isUsingKeyboard,\n onItemEnter,\n onItemLeave,\n })\n\n provide('elDropdown', {\n instance: _instance,\n dropdownSize,\n handleClick,\n commandHandler,\n trigger: toRef(props, 'trigger'),\n hideOnClick: toRef(props, 'hideOnClick'),\n })\n\n const onFocusAfterTrapped = (e: Event) => {\n e.preventDefault()\n contentRef.value?.focus?.({\n preventScroll: true,\n })\n }\n\n const handlerMainButtonClick = (event: MouseEvent) => {\n emit('click', event)\n }\n\n return {\n t,\n ns,\n scrollbar,\n wrapStyle,\n dropdownTriggerKls,\n dropdownSize,\n triggerId,\n triggerKeys,\n currentTabId,\n handleCurrentTabIdChange,\n handlerMainButtonClick,\n handleEntryFocus,\n handleClose,\n handleOpen,\n handleBeforeShowTooltip,\n handleShowTooltip,\n handleBeforeHideTooltip,\n onFocusAfterTrapped,\n popperRef,\n contentRef,\n triggeringElementRef,\n referenceElementRef,\n }\n },\n})\n</script>\n"],"names":["ElDropdownCollection","ElOnlyChild","ensureArray","_resolveComponent","_createSlots","_withCtx","_createVNode","_renderSlot","_openBlock","_createBlock","_mergeProps","_normalizeClass","_createCommentVNode"],"mappings":";;;;;;;;;;;;;;;;;;;AAyHA,MAAM,EAAE,WAAa,EAAA,aAAA,EAAkB,GAAA,QAAA,CAAA;AAEvC,MAAK,YAAa,eAAa,CAAA;AAAA,EAC7B,IAAM,EAAA,YAAA;AAAA,EACN,UAAY,EAAA;AAAA,IACV,QAAA;AAAA,IACA,aAAA;AAAA,IACA,WAAA;AAAA,0BACAA,YAAA;AAAA,IACA,SAAA;AAAA,IACA,kBAAA;AAAA,iBACAC,SAAA;AAAA,IACA,MAAA;AAAA,IACA,SAAA;AAAA,GACF;AAAA,EACA,KAAO,EAAA,aAAA;AAAA,EACP,KAAO,EAAA,CAAC,gBAAkB,EAAA,OAAA,EAAS,SAAS,CAAA;AAAA,EAC5C,KAAM,CAAA,KAAA,EAAO,EAAE,IAAA,EAAQ,EAAA;AACrB,IAAA,MAAM,YAAY,kBAAmB,EAAA,CAAA;AACrC,IAAM,MAAA,EAAA,GAAK,aAAa,UAAU,CAAA,CAAA;AAClC,IAAM,MAAA,EAAE,CAAE,EAAA,GAAI,SAAU,EAAA,CAAA;AAExB,IAAA,MAAM,uBAAuB,GAAI,EAAA,CAAA;AACjC,IAAA,MAAM,sBAAsB,GAAI,EAAA,CAAA;AAChC,IAAM,MAAA,SAAA,GAAY,IAA2C,IAAI,CAAA,CAAA;AACjE,IAAM,MAAA,UAAA,GAAa,IAAwB,IAAI,CAAA,CAAA;AAC/C,IAAM,MAAA,SAAA,GAAY,IAAI,IAAI,CAAA,CAAA;AAC1B,IAAM,MAAA,YAAA,GAAe,IAAmB,IAAI,CAAA,CAAA;AAC5C,IAAM,MAAA,eAAA,GAAkB,IAAI,KAAK,CAAA,CAAA;AACjC,IAAA,MAAM,WAAc,GAAA;AAAA,MAClB,UAAW,CAAA,KAAA;AAAA,MACX,UAAW,CAAA,WAAA;AAAA,MACX,UAAW,CAAA,KAAA;AAAA,MACX,UAAW,CAAA,IAAA;AAAA,KACb,CAAA;AAEA,IAAM,MAAA,SAAA,GAAY,SAAwB,OAAO;AAAA,MAC/C,SAAA,EAAW,OAAQ,CAAA,KAAA,CAAM,SAAS,CAAA;AAAA,KAClC,CAAA,CAAA,CAAA;AACF,IAAM,MAAA,kBAAA,GAAqB,SAAS,MAAM,CAAC,GAAG,CAAE,CAAA,YAAA,CAAa,KAAK,CAAC,CAAC,CAAA,CAAA;AACpE,IAAA,MAAM,UAAU,QAAS,CAAA,MAAMC,SAAY,CAAA,KAAA,CAAM,OAAO,CAAC,CAAA,CAAA;AAEzD,IAAM,MAAA,gBAAA,GAAmB,OAAQ,CAAA,KAAA,CAAA;AACjC,IAAA,MAAM,SAAY,GAAA,QAAA,CAAiB,MAAM,KAAA,CAAM,MAAM,gBAAgB,CAAA,CAAA;AAMrE,IAAA,KAAA,CAAA,CAAA,oBAAA,EAAA,OAAA,CAAA,EAAA,CAAA,CAAA,iBAAA,EAAA,QAAA,CAAA,EAAA,CAAA,qBAAA,CAAA,KAAA;AAAA,MACE;AAA8B,MAC9B,IAAE,CAAA,EAAA,GAAA,qBAA6B,yCAA4B,CAAA,GAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,mBAAA,EAAA;AACzD,QAAI,qBAAA,CAAA,GAAA,CAAA,mBAAiD,CAAA,cAAA,EAAA,uBAAA,CAAA,CAAA;AACnD,OAAA;AAA0B,MACxB,IAAA,CAAA,EAAA,GAAA,iBAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,iBAAA,CAAA,GAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,mBAAA,EAAA;AAAA,QACA,iBAAA,CAAA,GAAA,CAAA,mBAAA,CAAA,cAAA,EAAA,uBAAA,CAAA,CAAA;AAAA,OACF;AAAA,MACF,IAAA,CAAA,CAAA,EAAA,GAAA,iBAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,iBAAA,CAAA,GAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,gBAAA,KAAA,QAAA,CAAA,QAAA,CAAA,OAAA,CAAA,EAAA;AACA,QAAI,iBAAA,CAAA,GAAA,CAAA,gBAA6C,CAAA,cAAA,EAAA,uBAAA,CAAA,CAAA;AAC/C,OAAA;AAAsB,KACpB,EAAA,EAAA,SAAA,EAAA,IAAA,EAAA,CAAA,CAAA;AAAA,IACA,eAAA,CAAA,MAAA;AAAA,MACF,IAAA,EAAA,EAAA,EAAA,CAAA;AAAA,MACF,IAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,oBAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,GAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,mBAAA,EAAA;AACA,QAAA,0BAC0B,CAAA,GAAA,CAAA,mBAChB,CAAA,cAAA,yBACR,CAAA,CAAA;AACA,OAAA;AAAsB,KACpB,CAAA,CAAA;AAAA,IACA,SAAA,WAAA,GAAA;AAAA,MACF,WAAA,EAAA,CAAA;AAAA,KACF;AAAA,IACF,SAAA,WAAA,GAAA;AAAA,MACA;AAAkB,MACpB,CAAA,EAAA,GAAA,SAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,OAAA,EAAA,CAAA;AAEA,KAAA;AACE,IAAI,SAAA,UAAA,GAAA;AACF,MAAA,IAAA,EAAA,CAAA;AAA+B,MAC7B,CAAA,EAAA,GAAA,SAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,MAAA,EAAA,CAAA;AAAA,KACA;AAAA,IACF,MAAA,YAAA,GAAA,WAAA,EAAA,CAAA;AAAA,IACF,SAAA,cAAA,CAAA,GAAA,IAAA,EAAA;AAAA,MACD,IAAA,CAAA,SAAA,EAAA,GAAA,IAAA,CAAA,CAAA;AAED,KAAA;AACE,IAAY,SAAA,uBAAA,GAAA;AAAA,MACd,IAAA,EAAA,EAAA,EAAA,CAAA;AAEA,MAAA,CAAA,EAAA,GAAA,CAAS,EAAc,GAAA,oBAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,GAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,EAAA,CAAA;AACrB,KAAA;AAAyB,IAC3B,SAAA,WAAA,GAAA;AAEA,KAAA;AACE,IAAA,SAAA,WAAwB,GAAA;AAAA,MAC1B,MAAA,SAAA,GAAA,KAAA,CAAA,UAAA,CAAA,CAAA;AAEA,MAAA,sBAAiC,CAAA,OAAA,CAAA,KAAA,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAA,KAAA,EAAA,CAAA,CAAA;AAEjC,MAAA,yBAA2B,CAAa;AACtC,KAAK;AAAkB,IACzB,SAAA,wBAAA,CAAA,EAAA,EAAA;AAEA,MAAA,YAAmC,CAAA,KAAA,GAAA,EAAA,CAAA;AACjC,KAAqB;AAAkB,IACzC,SAAA,gBAAA,CAAA,CAAA,EAAA;AAEA,MAAA,IAAA,CAAA,eAAuB,CAAA,KAAA,EAAA;AAAA,QAEvB,CAAA,CAAA,cAAA,EAAA,CAAA;AAEA,QAAA,CAAA,CAAA,wBAAuB,EAAA,CAAA;AACrB,OAAM;AAEN,KAAA;AACA,IAAA,SAAA,uBAAqB,GAAA;AAAA,MACvB,IAAA,CAAA,gBAAA,EAAA,IAAA,CAAA,CAAA;AAEA,KAAA;AACE,IAAA,SAAA,iBAAqB,CAAA,KAAA,EAAA;AAAA,MACvB,IAAA,CAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAA,IAAA,MAAA,SAAA,EAAA;AAEA,QAAA,sBAA0B,EAAU,CAAA;AAClC,OAAI;AACF,KAAA;AACA,IAAA,SAA2B,uBAAA,GAAA;AAAA,MAC7B,IAAA,CAAA,gBAAA,EAAA,KAAA,CAAA,CAAA;AAAA,KACF;AAEA,IAAA,OAAA,CAAA,sBAAmC,EAAA;AACjC,MAAA;AAA2B,MAC7B,IAAA,EAAA,QAAA,CAAA,MAAA,KAAA,CAAA,IAAA,CAAA;AAEA,MAAA;AACE,MAAI;AACF,MAAA,WAAA;AAAuB,MACzB,WAAA;AAAA,KACF,CAAA,CAAA;AAEA,IAAA,OAAA,CAAA,YAAmC,EAAA;AACjC,MAAA;AAA4B,MAC9B,YAAA;AAEA,MAAA,WAAgC;AAAA,MAC9B,cAAA;AAAA,MACA,OAAM,EAAA,KAAA,CAAS,KAAM,EAAA,SAAU,CAAA;AAAA,MAC/B,WAAA,EAAA,KAAA,CAAA,KAAA,EAAA,aAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAAA,IACA,MAAA,mBAAA,GAAA,CAAA,CAAA,KAAA;AAAA,MACA,IAAA,EAAA,EAAA,EAAA,CAAA;AAAA,MACD,CAAA,CAAA,cAAA,EAAA,CAAA;AAED,MAAA,CAAA,EAAA,GAAQ,CAAc,EAAA,GAAA,UAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA,EAAA,EAAA;AAAA,QACV,aAAA,EAAA,IAAA;AAAA,OACV,CAAA,CAAA;AAAA,KACA,CAAA;AAAA,IACA,MAAA,sBAAA,GAAA,CAAA,KAAA,KAAA;AAAA,MACA,IAAA,CAAA,OAAe,EAAA,KAAA,CAAA,CAAA;AAAgB,KAC/B,CAAA;AAAuC,IACzC,OAAC;AAED,MAAM,CAAA;AACJ,MAAA,EAAE;AACF,MAAA,SAAA;AAA0B,MAAA,SACT;AAAA,MACjB,kBAAC;AAAA,MACH,YAAA;AAEA,MAAM,SAAA;AACJ,MAAA;AAAmB,MACrB,YAAA;AAEA,MAAO,wBAAA;AAAA,MACL,sBAAA;AAAA,MACA,gBAAA;AAAA,MACA,WAAA;AAAA,MACA,UAAA;AAAA,MACA,uBAAA;AAAA,MACA,iBAAA;AAAA,MACA,uBAAA;AAAA,MACA,mBAAA;AAAA,MACA,SAAA;AAAA,MACA,UAAA;AAAA,MACA,oBAAA;AAAA,MACA,mBAAA;AAAA,KACA,CAAA;AAAA,GACA;AAAA,CACA,CAAA,CAAA;AACA,SACA,WAAA,CAAA,IAAA,EAAA,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,KAAA,EAAA,QAAA,EAAA;AAAA,EACA,IAAA,EAAA,CAAA;AAAA,EACA,MAAA,iCAAA,GAAAC,gBAAA,CAAA,wBAAA,CAAA,CAAA;AAAA,EACA,MAAA,gCAAA,GAAAA,gBAAA,CAAA,uBAAA,CAAA,CAAA;AAAA,EACA,MAAA,uBAAA,GAAAA,gBAAA,CAAA,cAAA,CAAA,CAAA;AAAA,EACA,MAAA,wBAAA,GAAAA,gBAAA,CAAA,eAAA,CAAA,CAAA;AAAA,EACF,MAAA,qBAAA,GAAAA,gBAAA,CAAA,YAAA,CAAA,CAAA;AAAA,EACF,MAAA,oBAAA,GAAAA,gBAAA,CAAA,WAAA,CAAA,CAAA;AACF,EAAC,MAAA,qBAAA,GAAAA,gBAAA,CAAA,YAAA,CAAA,CAAA;;;;;;;;;;;;AA9TC,MAAA,kBAAA,EAAA,KAAA;AAAA,MAyFM,YAAA,EAAA,IAAA,CAAA,OAAA,KAAA,OAAA,GAAA,IAAA,CAAA,WAAA,GAAA,CAAA;AAAA,MAAA,aAAA,EAAA,IAAA;AAAA,MAzFA,yBAAW;AAA+B,MAAA,cAAA,EAAA,CAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,QAAA,CAAA,EAAA,IAAA,CAAA,WAAA,CAAA;;MAC9C,OA0Da,EAAA,IAAA,CAAA,OAAA;AAAA,MAAA,cAzDP,EAAA,IAAA,CAAA,WAAA;AAAA,MAAA,mBACG,EAAA,IAAA,CAAA,UAAA;AAAA,MAAA,YACE,EAAA,IAAA,CAAA,OAAA,KAAA,OAAA,GAAA,IAAA,CAAA,WAAA,GAAA,CAAA;AAAA,MAAA,yBACa,EAAA,KAAA;AAAA,MAAA,aACL,EAAA,IAAA,CAAA,oBAAA;AAAA,MAAA,oBACE,EAAA,IAAA,CAAA,WAAA;AAAA,MAClB,QAAA,EAAA,IAAA,CAAA,QAAmB;AAA0B,MAAA,UAChC,EAAA,CAAA,EAAA,IAAA,CAAA,EAAA,CAAA,SAAA,CAAA,KAAA,CAAA,YAAA,CAAA;AAAA,MAAA,UACF,EAAA,IAAA,CAAA,UAAA;AAAA,MAAA,IACC,EAAA,EAAA;AAA8B,MAAA;AACF,MAAA,YAC/B,EAAA,IAAA,CAAA,uBAAA;AAAA,MAAA,MACK,EAAA,IAAA,CAAA,iBAAA;AAAA,MAAA,YACK,EAAA,IAAA,CAAA,uBAAA;AAAA,KACnB,EAAAC,WAAA,CAAA;AAA6C,MAAA,OACpB,EAAAC,OAAA,CAAA,MAAA;AAAA,QACzBC,WAAa,CAAA,uBAAA,EAAA;AAAA,UACO,GAAA,EAAA,WAAA;AAAA,UACV,YAAA,EAAA,IAAA,CAAA,SAAA;AAAA,UACA,GAAA,EAAA,KAAA;AAAuB,UACrB,YAAA,EAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,MAAA,CAAA;AAAA,SACb,EAAA;AAAA,UACA,OAAA,EAAAD,OAAA,CAAA,MAAA;AAAA,YACcC,WAAA,CAAA,gCAAA,EAAA;AAAA,cACP,IAAA,EAAA,IAAA,CAAA,IAAA;AAAA,cACO,gBAAA,EAAA,IAAA,CAAA,YAAA;AAAA,cAAA,WAAA,EAAA,YAAA;AAEH,cAAA,oBAkBM,EAAA,IAAA,CAAA,wBAAA;AAAA,cAAA,YAAA,EAAA,IAAA,CAAA,gBAAA;AAAA,aAhBT,EAAA;AAAA,cACS,OAAA,EAAAD,OAAA,CAAA,MAAA;AAAA,gBACTC,WAAA,CAAA,iCAAA,EAAA,IAAA,EAAA;AAAA,kBACH,OAAA,SAAgB,CAAA,MAAA;AAAA,oBAAAC,UAAA,CAAA,IAAA,CAAA,MAAA,EAAA,UAAA,CAAA;;AAYO,kBAAA,CAAA,EAAA,CAAA;AAAA,iBATf,CAAA;AAAA,eAAA,CACN;AAAgB,cAAA,CAAA,EACL,CAAA;AAAA,aAAA,EAAA,CACX,EAAuB,CAAA,MAAA,EAAA,gBAAA,EAAA,sBAAA,EAAA,cAAA,CAAA,CAAA;AAAA,WAAA,CAAA;AACV,UAAA,CAAA,EAAA,CAAA;yCAIW,CAAA,CAAA;AAAA,OAAA,CAAA;AAAA,MAAA,CAAA,EAAA,CAAA;AADC,KAAA,EAAA;AAAA,MAAA,CAAA,IAAA,CAAA,WAAA,GAAA;;;;;;;;;;;;;;;;AAKf,KAAA,CAAA,EAAA,IAAA,EAAA,CAAA,MAAA,EAAA,QAAA,EAAA,gBAAA,EAAA,YAAA,EAAA,WAAA,EAAA,cAAA,EAAA,mBAAA,EAAA,SAAA,EAAA,cAAA,EAAA,mBAAA,EAAA,YAAA,EAAA,aAAA,EAAA,oBAAA,EAAA,UAAA,EAAA,YAAA,EAAA,YAAA,EAAA,cAAA,EAAA,QAAA,EAAA,cAAA,CAAA,CAAA;AAAc,IAAA,IAAA,CAAA,WAAA,IAAAC,SAAA,EAAA,EAAAC,WAAA,CAAA,0BAAA,EAAA,EAAA,GAAA,EAAA,CAAA,EAAA,EAAA;AAAA,MAAA,OAAA,EAAAJ,OAC7B,CAOgB,MAAA;AAAA,QAAAC,WAAA,CAAA,oBAAA,EAAAI,UAAA,CAAA,EAAA,GAAA,EAAA,qBAAA,EAAA,EAAA,IAAA,CAAA,WAAA,EAAA;AAAA,UAAA,IANb,EAAI,IAAA,CAAA,YAAA;AAAA,UAAA,IACL,EAAI,IAAA,CAAA,IAAA;AAAA,UAAA,QACC,EAAA,IAAA,CAAA,QAAA;AAAA,UAAA,QACM,EAAA,IAAA,CAAA,QAAA;AAAA,UAAA,OAAA,EAAA,IAAA,CAAA,sBAAA;;AAEY,UAAA,OAAA,EAAAL,OAAA,CAAA,MAAA;AAAA,YAAAE,UAAA,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,CAAA;;;;;;;AAIb,SAAA,EAAA,IAAA,CAAA,WAAA,EAAA;AA2BI,UAAA,IAAA,EAAA,QAAA;AAfJ,UAVZ,uBAAA;AAEqB,UAAA,IACZ,EAAA,IAAA,CAAA,IAAA;AAAA,UAAA,KACA,EAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,cAAA,CAAA;AAAA,UAAA,QACI,EAAA,IAAA,CAAA,QAAA;AAAA,UAAA,QACA,EAAA,IAAA,CAAA,QAAA;AAAA,UAAA,YACH,EAAA,IAAA,CAAA,CAAA,CAAA,4BAAA,CAAA;AAAA,SAAA,CAAA,EAAA;iCAEe;AAAA,YAAAD,WAAA,CAAA,kBAAA,EAAA;AAAA,cAAA,KAAA,EAAAK,cAAA,CAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA;;;;AAEzB,eAAA,CAAA;AAaY,cAZL,CAAA,EAAA,CAAA;AAAA,aACD,EAAA,CAAA,EAAA,CAAA,OAAA,CAAA,CAAA;AAAA,WAAA,CAAA;AACe,UAAA,CAAA,EACd,CAAA;AAAA,SAAA,EAAA,EACE,EAAA,CAAA,IAAA,EAAA,MAAA,EAAA,MAAA,EAAA,OAAA,EAAA,UAAA,EAAA,UAAA,EAAA,YAAA,CAAA,CAAA;AAAA,OAAA,CAAA;AACA,MACN,CAAA,EAAA,CAAA;AAAW,KAAA,CAAA,IAAAC,kBACD,CAAA,MAAA,EAAA,IAAA,CAAA;AAAA,GAAA,EAAA,CAAA,CAAA,CAAA;AACA,CAAA;+BAG4C,WAAA,CAAA,SAAA,EAAA,CAAA,CAAA,QAAA,EAAA,WAAA,CAAA,EAAA,CAAA,QAAA,EAAA,cAAA,CAAA,CAAA,CAAA;;;;"}