@element-plus/nightly 0.0.20240614 → 0.0.20240616

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 (302) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/index.full.js +9 -5
  3. package/dist/index.full.min.js +3 -3
  4. package/dist/index.full.min.js.map +1 -1
  5. package/dist/index.full.min.mjs +3 -3
  6. package/dist/index.full.min.mjs.map +1 -1
  7. package/dist/index.full.mjs +9 -5
  8. package/dist/locale/af.js +1 -1
  9. package/dist/locale/af.min.js +1 -1
  10. package/dist/locale/af.min.mjs +1 -1
  11. package/dist/locale/af.mjs +1 -1
  12. package/dist/locale/ar-eg.js +1 -1
  13. package/dist/locale/ar-eg.min.js +1 -1
  14. package/dist/locale/ar-eg.min.mjs +1 -1
  15. package/dist/locale/ar-eg.mjs +1 -1
  16. package/dist/locale/ar.js +1 -1
  17. package/dist/locale/ar.min.js +1 -1
  18. package/dist/locale/ar.min.mjs +1 -1
  19. package/dist/locale/ar.mjs +1 -1
  20. package/dist/locale/az.js +1 -1
  21. package/dist/locale/az.min.js +1 -1
  22. package/dist/locale/az.min.mjs +1 -1
  23. package/dist/locale/az.mjs +1 -1
  24. package/dist/locale/bg.js +1 -1
  25. package/dist/locale/bg.min.js +1 -1
  26. package/dist/locale/bg.min.mjs +1 -1
  27. package/dist/locale/bg.mjs +1 -1
  28. package/dist/locale/bn.js +1 -1
  29. package/dist/locale/bn.min.js +1 -1
  30. package/dist/locale/bn.min.mjs +1 -1
  31. package/dist/locale/bn.mjs +1 -1
  32. package/dist/locale/ca.js +1 -1
  33. package/dist/locale/ca.min.js +1 -1
  34. package/dist/locale/ca.min.mjs +1 -1
  35. package/dist/locale/ca.mjs +1 -1
  36. package/dist/locale/ckb.js +1 -1
  37. package/dist/locale/ckb.min.js +1 -1
  38. package/dist/locale/ckb.min.mjs +1 -1
  39. package/dist/locale/ckb.mjs +1 -1
  40. package/dist/locale/cs.js +1 -1
  41. package/dist/locale/cs.min.js +1 -1
  42. package/dist/locale/cs.min.mjs +1 -1
  43. package/dist/locale/cs.mjs +1 -1
  44. package/dist/locale/da.js +1 -1
  45. package/dist/locale/da.min.js +1 -1
  46. package/dist/locale/da.min.mjs +1 -1
  47. package/dist/locale/da.mjs +1 -1
  48. package/dist/locale/de.js +1 -1
  49. package/dist/locale/de.min.js +1 -1
  50. package/dist/locale/de.min.mjs +1 -1
  51. package/dist/locale/de.mjs +1 -1
  52. package/dist/locale/el.js +1 -1
  53. package/dist/locale/el.min.js +1 -1
  54. package/dist/locale/el.min.mjs +1 -1
  55. package/dist/locale/el.mjs +1 -1
  56. package/dist/locale/en.js +1 -1
  57. package/dist/locale/en.min.js +1 -1
  58. package/dist/locale/en.min.mjs +1 -1
  59. package/dist/locale/en.mjs +1 -1
  60. package/dist/locale/eo.js +1 -1
  61. package/dist/locale/eo.min.js +1 -1
  62. package/dist/locale/eo.min.mjs +1 -1
  63. package/dist/locale/eo.mjs +1 -1
  64. package/dist/locale/es.js +1 -1
  65. package/dist/locale/es.min.js +1 -1
  66. package/dist/locale/es.min.mjs +1 -1
  67. package/dist/locale/es.mjs +1 -1
  68. package/dist/locale/et.js +1 -1
  69. package/dist/locale/et.min.js +1 -1
  70. package/dist/locale/et.min.mjs +1 -1
  71. package/dist/locale/et.mjs +1 -1
  72. package/dist/locale/eu.js +1 -1
  73. package/dist/locale/eu.min.js +1 -1
  74. package/dist/locale/eu.min.mjs +1 -1
  75. package/dist/locale/eu.mjs +1 -1
  76. package/dist/locale/fa.js +1 -1
  77. package/dist/locale/fa.min.js +1 -1
  78. package/dist/locale/fa.min.mjs +1 -1
  79. package/dist/locale/fa.mjs +1 -1
  80. package/dist/locale/fi.js +1 -1
  81. package/dist/locale/fi.min.js +1 -1
  82. package/dist/locale/fi.min.mjs +1 -1
  83. package/dist/locale/fi.mjs +1 -1
  84. package/dist/locale/fr.js +1 -1
  85. package/dist/locale/fr.min.js +1 -1
  86. package/dist/locale/fr.min.mjs +1 -1
  87. package/dist/locale/fr.mjs +1 -1
  88. package/dist/locale/he.js +1 -1
  89. package/dist/locale/he.min.js +1 -1
  90. package/dist/locale/he.min.mjs +1 -1
  91. package/dist/locale/he.mjs +1 -1
  92. package/dist/locale/hr.js +1 -1
  93. package/dist/locale/hr.min.js +1 -1
  94. package/dist/locale/hr.min.mjs +1 -1
  95. package/dist/locale/hr.mjs +1 -1
  96. package/dist/locale/hu.js +1 -1
  97. package/dist/locale/hu.min.js +1 -1
  98. package/dist/locale/hu.min.mjs +1 -1
  99. package/dist/locale/hu.mjs +1 -1
  100. package/dist/locale/hy-am.js +1 -1
  101. package/dist/locale/hy-am.min.js +1 -1
  102. package/dist/locale/hy-am.min.mjs +1 -1
  103. package/dist/locale/hy-am.mjs +1 -1
  104. package/dist/locale/id.js +1 -1
  105. package/dist/locale/id.min.js +1 -1
  106. package/dist/locale/id.min.mjs +1 -1
  107. package/dist/locale/id.mjs +1 -1
  108. package/dist/locale/it.js +1 -1
  109. package/dist/locale/it.min.js +1 -1
  110. package/dist/locale/it.min.mjs +1 -1
  111. package/dist/locale/it.mjs +1 -1
  112. package/dist/locale/ja.js +1 -1
  113. package/dist/locale/ja.min.js +1 -1
  114. package/dist/locale/ja.min.mjs +1 -1
  115. package/dist/locale/ja.mjs +1 -1
  116. package/dist/locale/kk.js +1 -1
  117. package/dist/locale/kk.min.js +1 -1
  118. package/dist/locale/kk.min.mjs +1 -1
  119. package/dist/locale/kk.mjs +1 -1
  120. package/dist/locale/km.js +1 -1
  121. package/dist/locale/km.min.js +1 -1
  122. package/dist/locale/km.min.mjs +1 -1
  123. package/dist/locale/km.mjs +1 -1
  124. package/dist/locale/ko.js +1 -1
  125. package/dist/locale/ko.min.js +1 -1
  126. package/dist/locale/ko.min.mjs +1 -1
  127. package/dist/locale/ko.mjs +1 -1
  128. package/dist/locale/ku.js +1 -1
  129. package/dist/locale/ku.min.js +1 -1
  130. package/dist/locale/ku.min.mjs +1 -1
  131. package/dist/locale/ku.mjs +1 -1
  132. package/dist/locale/ky.js +1 -1
  133. package/dist/locale/ky.min.js +1 -1
  134. package/dist/locale/ky.min.mjs +1 -1
  135. package/dist/locale/ky.mjs +1 -1
  136. package/dist/locale/lt.js +1 -1
  137. package/dist/locale/lt.min.js +1 -1
  138. package/dist/locale/lt.min.mjs +1 -1
  139. package/dist/locale/lt.mjs +1 -1
  140. package/dist/locale/lv.js +1 -1
  141. package/dist/locale/lv.min.js +1 -1
  142. package/dist/locale/lv.min.mjs +1 -1
  143. package/dist/locale/lv.mjs +1 -1
  144. package/dist/locale/mg.js +1 -1
  145. package/dist/locale/mg.min.js +1 -1
  146. package/dist/locale/mg.min.mjs +1 -1
  147. package/dist/locale/mg.mjs +1 -1
  148. package/dist/locale/mn.js +1 -1
  149. package/dist/locale/mn.min.js +1 -1
  150. package/dist/locale/mn.min.mjs +1 -1
  151. package/dist/locale/mn.mjs +1 -1
  152. package/dist/locale/nb-no.js +1 -1
  153. package/dist/locale/nb-no.min.js +1 -1
  154. package/dist/locale/nb-no.min.mjs +1 -1
  155. package/dist/locale/nb-no.mjs +1 -1
  156. package/dist/locale/nl.js +1 -1
  157. package/dist/locale/nl.min.js +1 -1
  158. package/dist/locale/nl.min.mjs +1 -1
  159. package/dist/locale/nl.mjs +1 -1
  160. package/dist/locale/pa.js +1 -1
  161. package/dist/locale/pa.min.js +1 -1
  162. package/dist/locale/pa.min.mjs +1 -1
  163. package/dist/locale/pa.mjs +1 -1
  164. package/dist/locale/pl.js +1 -1
  165. package/dist/locale/pl.min.js +1 -1
  166. package/dist/locale/pl.min.mjs +1 -1
  167. package/dist/locale/pl.mjs +1 -1
  168. package/dist/locale/pt-br.js +1 -1
  169. package/dist/locale/pt-br.min.js +1 -1
  170. package/dist/locale/pt-br.min.mjs +1 -1
  171. package/dist/locale/pt-br.mjs +1 -1
  172. package/dist/locale/pt.js +1 -1
  173. package/dist/locale/pt.min.js +1 -1
  174. package/dist/locale/pt.min.mjs +1 -1
  175. package/dist/locale/pt.mjs +1 -1
  176. package/dist/locale/ro.js +1 -1
  177. package/dist/locale/ro.min.js +1 -1
  178. package/dist/locale/ro.min.mjs +1 -1
  179. package/dist/locale/ro.mjs +1 -1
  180. package/dist/locale/ru.js +1 -1
  181. package/dist/locale/ru.min.js +1 -1
  182. package/dist/locale/ru.min.mjs +1 -1
  183. package/dist/locale/ru.mjs +1 -1
  184. package/dist/locale/sk.js +1 -1
  185. package/dist/locale/sk.min.js +1 -1
  186. package/dist/locale/sk.min.mjs +1 -1
  187. package/dist/locale/sk.mjs +1 -1
  188. package/dist/locale/sl.js +1 -1
  189. package/dist/locale/sl.min.js +1 -1
  190. package/dist/locale/sl.min.mjs +1 -1
  191. package/dist/locale/sl.mjs +1 -1
  192. package/dist/locale/sr.js +1 -1
  193. package/dist/locale/sr.min.js +1 -1
  194. package/dist/locale/sr.min.mjs +1 -1
  195. package/dist/locale/sr.mjs +1 -1
  196. package/dist/locale/sv.js +1 -1
  197. package/dist/locale/sv.min.js +1 -1
  198. package/dist/locale/sv.min.mjs +1 -1
  199. package/dist/locale/sv.mjs +1 -1
  200. package/dist/locale/sw.js +1 -1
  201. package/dist/locale/sw.min.js +1 -1
  202. package/dist/locale/sw.min.mjs +1 -1
  203. package/dist/locale/sw.mjs +1 -1
  204. package/dist/locale/ta.js +1 -1
  205. package/dist/locale/ta.min.js +1 -1
  206. package/dist/locale/ta.min.mjs +1 -1
  207. package/dist/locale/ta.mjs +1 -1
  208. package/dist/locale/th.js +1 -1
  209. package/dist/locale/th.min.js +1 -1
  210. package/dist/locale/th.min.mjs +1 -1
  211. package/dist/locale/th.mjs +1 -1
  212. package/dist/locale/tk.js +1 -1
  213. package/dist/locale/tk.min.js +1 -1
  214. package/dist/locale/tk.min.mjs +1 -1
  215. package/dist/locale/tk.mjs +1 -1
  216. package/dist/locale/tr.js +1 -1
  217. package/dist/locale/tr.min.js +1 -1
  218. package/dist/locale/tr.min.mjs +1 -1
  219. package/dist/locale/tr.mjs +1 -1
  220. package/dist/locale/ug-cn.js +1 -1
  221. package/dist/locale/ug-cn.min.js +1 -1
  222. package/dist/locale/ug-cn.min.mjs +1 -1
  223. package/dist/locale/ug-cn.mjs +1 -1
  224. package/dist/locale/uk.js +1 -1
  225. package/dist/locale/uk.min.js +1 -1
  226. package/dist/locale/uk.min.mjs +1 -1
  227. package/dist/locale/uk.mjs +1 -1
  228. package/dist/locale/uz-uz.js +1 -1
  229. package/dist/locale/uz-uz.min.js +1 -1
  230. package/dist/locale/uz-uz.min.mjs +1 -1
  231. package/dist/locale/uz-uz.mjs +1 -1
  232. package/dist/locale/vi.js +1 -1
  233. package/dist/locale/vi.min.js +1 -1
  234. package/dist/locale/vi.min.mjs +1 -1
  235. package/dist/locale/vi.mjs +1 -1
  236. package/dist/locale/zh-cn.js +1 -1
  237. package/dist/locale/zh-cn.min.js +1 -1
  238. package/dist/locale/zh-cn.min.mjs +1 -1
  239. package/dist/locale/zh-cn.mjs +1 -1
  240. package/dist/locale/zh-tw.js +1 -1
  241. package/dist/locale/zh-tw.min.js +1 -1
  242. package/dist/locale/zh-tw.min.mjs +1 -1
  243. package/dist/locale/zh-tw.mjs +1 -1
  244. package/es/components/carousel/index.mjs +2 -2
  245. package/es/components/carousel/src/carousel.mjs +211 -60
  246. package/es/components/carousel/src/carousel.mjs.map +1 -1
  247. package/es/components/carousel/src/carousel2.mjs +60 -211
  248. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  249. package/es/components/dialog/index.mjs +2 -2
  250. package/es/components/dialog/src/dialog.mjs +162 -69
  251. package/es/components/dialog/src/dialog.mjs.map +1 -1
  252. package/es/components/dialog/src/dialog2.mjs +69 -162
  253. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  254. package/es/components/drawer/src/drawer.mjs +1 -1
  255. package/es/components/index.mjs +3 -3
  256. package/es/components/input/src/input2.mjs +7 -3
  257. package/es/components/input/src/input2.mjs.map +1 -1
  258. package/es/components/upload/index.mjs +2 -2
  259. package/es/components/upload/src/upload-content.mjs +1 -1
  260. package/es/components/upload/src/upload-content2.mjs +1 -1
  261. package/es/components/upload/src/upload-list.mjs +1 -1
  262. package/es/components/upload/src/upload.mjs +118 -104
  263. package/es/components/upload/src/upload.mjs.map +1 -1
  264. package/es/components/upload/src/upload2.mjs +104 -118
  265. package/es/components/upload/src/upload2.mjs.map +1 -1
  266. package/es/components/upload/src/use-handlers.mjs +1 -1
  267. package/es/index.mjs +3 -3
  268. package/es/version.d.ts +1 -1
  269. package/es/version.mjs +1 -1
  270. package/es/version.mjs.map +1 -1
  271. package/lib/components/carousel/index.js +2 -2
  272. package/lib/components/carousel/src/carousel.js +211 -61
  273. package/lib/components/carousel/src/carousel.js.map +1 -1
  274. package/lib/components/carousel/src/carousel2.js +61 -211
  275. package/lib/components/carousel/src/carousel2.js.map +1 -1
  276. package/lib/components/dialog/index.js +2 -2
  277. package/lib/components/dialog/src/dialog.js +162 -70
  278. package/lib/components/dialog/src/dialog.js.map +1 -1
  279. package/lib/components/dialog/src/dialog2.js +70 -162
  280. package/lib/components/dialog/src/dialog2.js.map +1 -1
  281. package/lib/components/drawer/src/drawer.js +1 -1
  282. package/lib/components/index.js +3 -3
  283. package/lib/components/input/src/input2.js +7 -3
  284. package/lib/components/input/src/input2.js.map +1 -1
  285. package/lib/components/upload/index.js +2 -2
  286. package/lib/components/upload/src/upload-content.js +1 -1
  287. package/lib/components/upload/src/upload-content2.js +1 -1
  288. package/lib/components/upload/src/upload-list.js +1 -1
  289. package/lib/components/upload/src/upload.js +118 -107
  290. package/lib/components/upload/src/upload.js.map +1 -1
  291. package/lib/components/upload/src/upload2.js +107 -118
  292. package/lib/components/upload/src/upload2.js.map +1 -1
  293. package/lib/components/upload/src/use-handlers.js +1 -1
  294. package/lib/index.js +3 -3
  295. package/lib/version.d.ts +1 -1
  296. package/lib/version.js +1 -1
  297. package/lib/version.js.map +1 -1
  298. package/package.json +2 -2
  299. package/theme-chalk/el-table.css +1 -1
  300. package/theme-chalk/index.css +1 -1
  301. package/theme-chalk/src/table.scss +25 -2
  302. package/web-types.json +1 -1
@@ -1,65 +1,216 @@
1
- import '../../../utils/index.mjs';
2
- import { buildProps } from '../../../utils/vue/props/runtime.mjs';
3
- import { isNumber } from '../../../utils/types.mjs';
1
+ import { createElementVNode, defineComponent, computed, unref, openBlock, createElementBlock, normalizeClass, withModifiers, createBlock, Transition, withCtx, withDirectives, createVNode, vShow, createCommentVNode, normalizeStyle, renderSlot, Fragment, renderList, toDisplayString } from 'vue';
2
+ import { ElIcon } from '../../icon/index.mjs';
3
+ import { ArrowLeft, ArrowRight } from '@element-plus/icons-vue';
4
+ import '../../../hooks/index.mjs';
5
+ import { carouselProps, carouselEmits } from './carousel2.mjs';
6
+ import { useCarousel } from './use-carousel.mjs';
7
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
8
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
9
+ import { useLocale } from '../../../hooks/use-locale/index.mjs';
4
10
 
5
- const carouselProps = buildProps({
6
- initialIndex: {
7
- type: Number,
8
- default: 0
9
- },
10
- height: {
11
- type: String,
12
- default: ""
13
- },
14
- trigger: {
15
- type: String,
16
- values: ["hover", "click"],
17
- default: "hover"
18
- },
19
- autoplay: {
20
- type: Boolean,
21
- default: true
22
- },
23
- interval: {
24
- type: Number,
25
- default: 3e3
26
- },
27
- indicatorPosition: {
28
- type: String,
29
- values: ["", "none", "outside"],
30
- default: ""
31
- },
32
- arrow: {
33
- type: String,
34
- values: ["always", "hover", "never"],
35
- default: "hover"
36
- },
37
- type: {
38
- type: String,
39
- values: ["", "card"],
40
- default: ""
41
- },
42
- loop: {
43
- type: Boolean,
44
- default: true
45
- },
46
- direction: {
47
- type: String,
48
- values: ["horizontal", "vertical"],
49
- default: "horizontal"
50
- },
51
- pauseOnHover: {
52
- type: Boolean,
53
- default: true
54
- },
55
- motionBlur: {
56
- type: Boolean,
57
- default: false
11
+ const _hoisted_1 = ["aria-label"];
12
+ const _hoisted_2 = ["aria-label"];
13
+ const _hoisted_3 = ["onMouseenter", "onClick"];
14
+ const _hoisted_4 = ["aria-label"];
15
+ const _hoisted_5 = { key: 0 };
16
+ const _hoisted_6 = {
17
+ key: 3,
18
+ xmlns: "http://www.w3.org/2000/svg",
19
+ version: "1.1",
20
+ style: { "display": "none" }
21
+ };
22
+ const _hoisted_7 = /* @__PURE__ */ createElementVNode("defs", null, [
23
+ /* @__PURE__ */ createElementVNode("filter", { id: "elCarouselHorizontal" }, [
24
+ /* @__PURE__ */ createElementVNode("feGaussianBlur", {
25
+ in: "SourceGraphic",
26
+ stdDeviation: "12,0"
27
+ })
28
+ ]),
29
+ /* @__PURE__ */ createElementVNode("filter", { id: "elCarouselVertical" }, [
30
+ /* @__PURE__ */ createElementVNode("feGaussianBlur", {
31
+ in: "SourceGraphic",
32
+ stdDeviation: "0,10"
33
+ })
34
+ ])
35
+ ], -1);
36
+ const _hoisted_8 = [
37
+ _hoisted_7
38
+ ];
39
+ const COMPONENT_NAME = "ElCarousel";
40
+ const __default__ = defineComponent({
41
+ name: COMPONENT_NAME
42
+ });
43
+ const _sfc_main = /* @__PURE__ */ defineComponent({
44
+ ...__default__,
45
+ props: carouselProps,
46
+ emits: carouselEmits,
47
+ setup(__props, { expose, emit }) {
48
+ const props = __props;
49
+ const {
50
+ root,
51
+ activeIndex,
52
+ arrowDisplay,
53
+ hasLabel,
54
+ hover,
55
+ isCardType,
56
+ items,
57
+ isVertical,
58
+ containerStyle,
59
+ handleButtonEnter,
60
+ handleButtonLeave,
61
+ isTransitioning,
62
+ handleIndicatorClick,
63
+ handleMouseEnter,
64
+ handleMouseLeave,
65
+ handleTransitionEnd,
66
+ setActiveItem,
67
+ prev,
68
+ next,
69
+ PlaceholderItem,
70
+ isTwoLengthShow,
71
+ throttledArrowClick,
72
+ throttledIndicatorHover
73
+ } = useCarousel(props, emit, COMPONENT_NAME);
74
+ const ns = useNamespace("carousel");
75
+ const { t } = useLocale();
76
+ const carouselClasses = computed(() => {
77
+ const classes = [ns.b(), ns.m(props.direction)];
78
+ if (unref(isCardType)) {
79
+ classes.push(ns.m("card"));
80
+ }
81
+ return classes;
82
+ });
83
+ const carouselContainer = computed(() => {
84
+ const classes = [ns.e("container")];
85
+ if (props.motionBlur && unref(isTransitioning)) {
86
+ classes.push(unref(isVertical) ? `${ns.namespace.value}-transitioning-vertical` : `${ns.namespace.value}-transitioning`);
87
+ }
88
+ return classes;
89
+ });
90
+ const indicatorsClasses = computed(() => {
91
+ const classes = [ns.e("indicators"), ns.em("indicators", props.direction)];
92
+ if (unref(hasLabel)) {
93
+ classes.push(ns.em("indicators", "labels"));
94
+ }
95
+ if (props.indicatorPosition === "outside") {
96
+ classes.push(ns.em("indicators", "outside"));
97
+ }
98
+ if (unref(isVertical)) {
99
+ classes.push(ns.em("indicators", "right"));
100
+ }
101
+ return classes;
102
+ });
103
+ expose({
104
+ setActiveItem,
105
+ prev,
106
+ next
107
+ });
108
+ return (_ctx, _cache) => {
109
+ return openBlock(), createElementBlock("div", {
110
+ ref_key: "root",
111
+ ref: root,
112
+ class: normalizeClass(unref(carouselClasses)),
113
+ onMouseenter: _cache[7] || (_cache[7] = withModifiers((...args) => unref(handleMouseEnter) && unref(handleMouseEnter)(...args), ["stop"])),
114
+ onMouseleave: _cache[8] || (_cache[8] = withModifiers((...args) => unref(handleMouseLeave) && unref(handleMouseLeave)(...args), ["stop"]))
115
+ }, [
116
+ unref(arrowDisplay) ? (openBlock(), createBlock(Transition, {
117
+ key: 0,
118
+ name: "carousel-arrow-left",
119
+ persisted: ""
120
+ }, {
121
+ default: withCtx(() => [
122
+ withDirectives(createElementVNode("button", {
123
+ type: "button",
124
+ class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "left")]),
125
+ "aria-label": unref(t)("el.carousel.leftArrow"),
126
+ onMouseenter: _cache[0] || (_cache[0] = ($event) => unref(handleButtonEnter)("left")),
127
+ onMouseleave: _cache[1] || (_cache[1] = (...args) => unref(handleButtonLeave) && unref(handleButtonLeave)(...args)),
128
+ onClick: _cache[2] || (_cache[2] = withModifiers(($event) => unref(throttledArrowClick)(unref(activeIndex) - 1), ["stop"]))
129
+ }, [
130
+ createVNode(unref(ElIcon), null, {
131
+ default: withCtx(() => [
132
+ createVNode(unref(ArrowLeft))
133
+ ]),
134
+ _: 1
135
+ })
136
+ ], 42, _hoisted_1), [
137
+ [
138
+ vShow,
139
+ (_ctx.arrow === "always" || unref(hover)) && (props.loop || unref(activeIndex) > 0)
140
+ ]
141
+ ])
142
+ ]),
143
+ _: 1
144
+ })) : createCommentVNode("v-if", true),
145
+ unref(arrowDisplay) ? (openBlock(), createBlock(Transition, {
146
+ key: 1,
147
+ name: "carousel-arrow-right",
148
+ persisted: ""
149
+ }, {
150
+ default: withCtx(() => [
151
+ withDirectives(createElementVNode("button", {
152
+ type: "button",
153
+ class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "right")]),
154
+ "aria-label": unref(t)("el.carousel.rightArrow"),
155
+ onMouseenter: _cache[3] || (_cache[3] = ($event) => unref(handleButtonEnter)("right")),
156
+ onMouseleave: _cache[4] || (_cache[4] = (...args) => unref(handleButtonLeave) && unref(handleButtonLeave)(...args)),
157
+ onClick: _cache[5] || (_cache[5] = withModifiers(($event) => unref(throttledArrowClick)(unref(activeIndex) + 1), ["stop"]))
158
+ }, [
159
+ createVNode(unref(ElIcon), null, {
160
+ default: withCtx(() => [
161
+ createVNode(unref(ArrowRight))
162
+ ]),
163
+ _: 1
164
+ })
165
+ ], 42, _hoisted_2), [
166
+ [
167
+ vShow,
168
+ (_ctx.arrow === "always" || unref(hover)) && (props.loop || unref(activeIndex) < unref(items).length - 1)
169
+ ]
170
+ ])
171
+ ]),
172
+ _: 1
173
+ })) : createCommentVNode("v-if", true),
174
+ createElementVNode("div", {
175
+ class: normalizeClass(unref(carouselContainer)),
176
+ style: normalizeStyle(unref(containerStyle)),
177
+ onTransitionend: _cache[6] || (_cache[6] = (...args) => unref(handleTransitionEnd) && unref(handleTransitionEnd)(...args))
178
+ }, [
179
+ createVNode(unref(PlaceholderItem)),
180
+ renderSlot(_ctx.$slots, "default")
181
+ ], 38),
182
+ _ctx.indicatorPosition !== "none" ? (openBlock(), createElementBlock("ul", {
183
+ key: 2,
184
+ class: normalizeClass(unref(indicatorsClasses))
185
+ }, [
186
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(items), (item, index) => {
187
+ return withDirectives((openBlock(), createElementBlock("li", {
188
+ key: index,
189
+ class: normalizeClass([
190
+ unref(ns).e("indicator"),
191
+ unref(ns).em("indicator", _ctx.direction),
192
+ unref(ns).is("active", index === unref(activeIndex))
193
+ ]),
194
+ onMouseenter: ($event) => unref(throttledIndicatorHover)(index),
195
+ onClick: withModifiers(($event) => unref(handleIndicatorClick)(index), ["stop"])
196
+ }, [
197
+ createElementVNode("button", {
198
+ class: normalizeClass(unref(ns).e("button")),
199
+ "aria-label": unref(t)("el.carousel.indicator", { index: index + 1 })
200
+ }, [
201
+ unref(hasLabel) ? (openBlock(), createElementBlock("span", _hoisted_5, toDisplayString(item.props.label), 1)) : createCommentVNode("v-if", true)
202
+ ], 10, _hoisted_4)
203
+ ], 42, _hoisted_3)), [
204
+ [vShow, unref(isTwoLengthShow)(index)]
205
+ ]);
206
+ }), 128))
207
+ ], 2)) : createCommentVNode("v-if", true),
208
+ props.motionBlur ? (openBlock(), createElementBlock("svg", _hoisted_6, _hoisted_8)) : createCommentVNode("v-if", true)
209
+ ], 34);
210
+ };
58
211
  }
59
212
  });
60
- const carouselEmits = {
61
- change: (current, prev) => [current, prev].every(isNumber)
62
- };
213
+ var Carousel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "carousel.vue"]]);
63
214
 
64
- export { carouselEmits, carouselProps };
215
+ export { Carousel as default };
65
216
  //# sourceMappingURL=carousel.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"carousel.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.ts"],"sourcesContent":["import { buildProps, isNumber } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const carouselProps = buildProps({\n initialIndex: {\n type: Number,\n default: 0,\n },\n height: {\n type: String,\n default: '',\n },\n trigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n autoplay: {\n type: Boolean,\n default: true,\n },\n interval: {\n type: Number,\n default: 3000,\n },\n indicatorPosition: {\n type: String,\n values: ['', 'none', 'outside'],\n default: '',\n },\n arrow: {\n type: String,\n values: ['always', 'hover', 'never'],\n default: 'hover',\n },\n type: {\n type: String,\n values: ['', 'card'],\n default: '',\n },\n loop: {\n type: Boolean,\n default: true,\n },\n direction: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'horizontal',\n },\n pauseOnHover: {\n type: Boolean,\n default: true,\n },\n motionBlur: {\n type: Boolean,\n default: false,\n },\n} as const)\n\nexport const carouselEmits = {\n change: (current: number, prev: number) => [current, prev].every(isNumber),\n}\n\nexport type CarouselProps = ExtractPropTypes<typeof carouselProps>\nexport type CarouselEmits = typeof carouselEmits\n"],"names":[],"mappings":";;;;AACY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;AAC9B,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,iBAAiB,EAAE;AACrB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,CAAC;AACnC,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC;AACxC,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC;AACxB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,YAAY,EAAE,UAAU,CAAC;AACtC,IAAI,OAAO,EAAE,YAAY;AACzB,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,aAAa,GAAG;AAC7B,EAAE,MAAM,EAAE,CAAC,OAAO,EAAE,IAAI,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;AAC5D;;;;"}
1
+ {"version":3,"file":"carousel.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.vue"],"sourcesContent":["<template>\n <div\n ref=\"root\"\n :class=\"carouselClasses\"\n @mouseenter.stop=\"handleMouseEnter\"\n @mouseleave.stop=\"handleMouseLeave\"\n >\n <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-left\">\n <button\n v-show=\"\n (arrow === 'always' || hover) && (props.loop || activeIndex > 0)\n \"\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'left')]\"\n :aria-label=\"t('el.carousel.leftArrow')\"\n @mouseenter=\"handleButtonEnter('left')\"\n @mouseleave=\"handleButtonLeave\"\n @click.stop=\"throttledArrowClick(activeIndex - 1)\"\n >\n <ElIcon>\n <ArrowLeft />\n </ElIcon>\n </button>\n </transition>\n <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-right\">\n <button\n v-show=\"\n (arrow === 'always' || hover) &&\n (props.loop || activeIndex < items.length - 1)\n \"\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'right')]\"\n :aria-label=\"t('el.carousel.rightArrow')\"\n @mouseenter=\"handleButtonEnter('right')\"\n @mouseleave=\"handleButtonLeave\"\n @click.stop=\"throttledArrowClick(activeIndex + 1)\"\n >\n <ElIcon>\n <ArrowRight />\n </ElIcon>\n </button>\n </transition>\n <div\n :class=\"carouselContainer\"\n :style=\"containerStyle\"\n @transitionend=\"handleTransitionEnd\"\n >\n <PlaceholderItem />\n <slot />\n </div>\n <ul v-if=\"indicatorPosition !== 'none'\" :class=\"indicatorsClasses\">\n <li\n v-for=\"(item, index) in items\"\n v-show=\"isTwoLengthShow(index)\"\n :key=\"index\"\n :class=\"[\n ns.e('indicator'),\n ns.em('indicator', direction),\n ns.is('active', index === activeIndex),\n ]\"\n @mouseenter=\"throttledIndicatorHover(index)\"\n @click.stop=\"handleIndicatorClick(index)\"\n >\n <button\n :class=\"ns.e('button')\"\n :aria-label=\"t('el.carousel.indicator', { index: index + 1 })\"\n >\n <span v-if=\"hasLabel\">{{ item.props.label }}</span>\n </button>\n </li>\n </ul>\n <svg\n v-if=\"props.motionBlur\"\n xmlns=\"http://www.w3.org/2000/svg\"\n version=\"1.1\"\n style=\"display: none\"\n >\n <defs>\n <filter id=\"elCarouselHorizontal\">\n <feGaussianBlur in=\"SourceGraphic\" stdDeviation=\"12,0\" />\n </filter>\n <filter id=\"elCarouselVertical\">\n <feGaussianBlur in=\"SourceGraphic\" stdDeviation=\"0,10\" />\n </filter>\n </defs>\n </svg>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, unref } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { carouselEmits, carouselProps } from './carousel'\nimport { useCarousel } from './use-carousel'\n\nconst COMPONENT_NAME = 'ElCarousel'\ndefineOptions({\n name: COMPONENT_NAME,\n})\n\nconst props = defineProps(carouselProps)\nconst emit = defineEmits(carouselEmits)\nconst {\n root,\n activeIndex,\n arrowDisplay,\n hasLabel,\n hover,\n isCardType,\n items,\n isVertical,\n containerStyle,\n handleButtonEnter,\n handleButtonLeave,\n isTransitioning,\n handleIndicatorClick,\n handleMouseEnter,\n handleMouseLeave,\n handleTransitionEnd,\n setActiveItem,\n prev,\n next,\n PlaceholderItem,\n isTwoLengthShow,\n throttledArrowClick,\n throttledIndicatorHover,\n} = useCarousel(props, emit, COMPONENT_NAME)\nconst ns = useNamespace('carousel')\n\nconst { t } = useLocale()\n\nconst carouselClasses = computed(() => {\n const classes = [ns.b(), ns.m(props.direction)]\n if (unref(isCardType)) {\n classes.push(ns.m('card'))\n }\n return classes\n})\n\nconst carouselContainer = computed(() => {\n const classes = [ns.e('container')]\n if (props.motionBlur && unref(isTransitioning)) {\n classes.push(\n unref(isVertical)\n ? `${ns.namespace.value}-transitioning-vertical`\n : `${ns.namespace.value}-transitioning`\n )\n }\n return classes\n})\n\nconst indicatorsClasses = computed(() => {\n const classes = [ns.e('indicators'), ns.em('indicators', props.direction)]\n if (unref(hasLabel)) {\n classes.push(ns.em('indicators', 'labels'))\n }\n if (props.indicatorPosition === 'outside') {\n classes.push(ns.em('indicators', 'outside'))\n }\n if (unref(isVertical)) {\n classes.push(ns.em('indicators', 'right'))\n }\n return classes\n})\n\ndefineExpose({\n /** @description manually switch slide */\n setActiveItem,\n /** @description switch to the previous slide */\n prev,\n /** @description switch to the next slide */\n next,\n})\n</script>\n"],"names":[],"mappings":"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"}
@@ -1,216 +1,65 @@
1
- import { createElementVNode, defineComponent, computed, unref, openBlock, createElementBlock, normalizeClass, withModifiers, createBlock, Transition, withCtx, withDirectives, createVNode, vShow, createCommentVNode, normalizeStyle, renderSlot, Fragment, renderList, toDisplayString } from 'vue';
2
- import { ElIcon } from '../../icon/index.mjs';
3
- import { ArrowLeft, ArrowRight } from '@element-plus/icons-vue';
4
- import '../../../hooks/index.mjs';
5
- import { carouselProps, carouselEmits } from './carousel.mjs';
6
- import { useCarousel } from './use-carousel.mjs';
7
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
8
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
9
- import { useLocale } from '../../../hooks/use-locale/index.mjs';
1
+ import '../../../utils/index.mjs';
2
+ import { buildProps } from '../../../utils/vue/props/runtime.mjs';
3
+ import { isNumber } from '../../../utils/types.mjs';
10
4
 
11
- const _hoisted_1 = ["aria-label"];
12
- const _hoisted_2 = ["aria-label"];
13
- const _hoisted_3 = ["onMouseenter", "onClick"];
14
- const _hoisted_4 = ["aria-label"];
15
- const _hoisted_5 = { key: 0 };
16
- const _hoisted_6 = {
17
- key: 3,
18
- xmlns: "http://www.w3.org/2000/svg",
19
- version: "1.1",
20
- style: { "display": "none" }
21
- };
22
- const _hoisted_7 = /* @__PURE__ */ createElementVNode("defs", null, [
23
- /* @__PURE__ */ createElementVNode("filter", { id: "elCarouselHorizontal" }, [
24
- /* @__PURE__ */ createElementVNode("feGaussianBlur", {
25
- in: "SourceGraphic",
26
- stdDeviation: "12,0"
27
- })
28
- ]),
29
- /* @__PURE__ */ createElementVNode("filter", { id: "elCarouselVertical" }, [
30
- /* @__PURE__ */ createElementVNode("feGaussianBlur", {
31
- in: "SourceGraphic",
32
- stdDeviation: "0,10"
33
- })
34
- ])
35
- ], -1);
36
- const _hoisted_8 = [
37
- _hoisted_7
38
- ];
39
- const COMPONENT_NAME = "ElCarousel";
40
- const __default__ = defineComponent({
41
- name: COMPONENT_NAME
42
- });
43
- const _sfc_main = /* @__PURE__ */ defineComponent({
44
- ...__default__,
45
- props: carouselProps,
46
- emits: carouselEmits,
47
- setup(__props, { expose, emit }) {
48
- const props = __props;
49
- const {
50
- root,
51
- activeIndex,
52
- arrowDisplay,
53
- hasLabel,
54
- hover,
55
- isCardType,
56
- items,
57
- isVertical,
58
- containerStyle,
59
- handleButtonEnter,
60
- handleButtonLeave,
61
- isTransitioning,
62
- handleIndicatorClick,
63
- handleMouseEnter,
64
- handleMouseLeave,
65
- handleTransitionEnd,
66
- setActiveItem,
67
- prev,
68
- next,
69
- PlaceholderItem,
70
- isTwoLengthShow,
71
- throttledArrowClick,
72
- throttledIndicatorHover
73
- } = useCarousel(props, emit, COMPONENT_NAME);
74
- const ns = useNamespace("carousel");
75
- const { t } = useLocale();
76
- const carouselClasses = computed(() => {
77
- const classes = [ns.b(), ns.m(props.direction)];
78
- if (unref(isCardType)) {
79
- classes.push(ns.m("card"));
80
- }
81
- return classes;
82
- });
83
- const carouselContainer = computed(() => {
84
- const classes = [ns.e("container")];
85
- if (props.motionBlur && unref(isTransitioning)) {
86
- classes.push(unref(isVertical) ? `${ns.namespace.value}-transitioning-vertical` : `${ns.namespace.value}-transitioning`);
87
- }
88
- return classes;
89
- });
90
- const indicatorsClasses = computed(() => {
91
- const classes = [ns.e("indicators"), ns.em("indicators", props.direction)];
92
- if (unref(hasLabel)) {
93
- classes.push(ns.em("indicators", "labels"));
94
- }
95
- if (props.indicatorPosition === "outside") {
96
- classes.push(ns.em("indicators", "outside"));
97
- }
98
- if (unref(isVertical)) {
99
- classes.push(ns.em("indicators", "right"));
100
- }
101
- return classes;
102
- });
103
- expose({
104
- setActiveItem,
105
- prev,
106
- next
107
- });
108
- return (_ctx, _cache) => {
109
- return openBlock(), createElementBlock("div", {
110
- ref_key: "root",
111
- ref: root,
112
- class: normalizeClass(unref(carouselClasses)),
113
- onMouseenter: _cache[7] || (_cache[7] = withModifiers((...args) => unref(handleMouseEnter) && unref(handleMouseEnter)(...args), ["stop"])),
114
- onMouseleave: _cache[8] || (_cache[8] = withModifiers((...args) => unref(handleMouseLeave) && unref(handleMouseLeave)(...args), ["stop"]))
115
- }, [
116
- unref(arrowDisplay) ? (openBlock(), createBlock(Transition, {
117
- key: 0,
118
- name: "carousel-arrow-left",
119
- persisted: ""
120
- }, {
121
- default: withCtx(() => [
122
- withDirectives(createElementVNode("button", {
123
- type: "button",
124
- class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "left")]),
125
- "aria-label": unref(t)("el.carousel.leftArrow"),
126
- onMouseenter: _cache[0] || (_cache[0] = ($event) => unref(handleButtonEnter)("left")),
127
- onMouseleave: _cache[1] || (_cache[1] = (...args) => unref(handleButtonLeave) && unref(handleButtonLeave)(...args)),
128
- onClick: _cache[2] || (_cache[2] = withModifiers(($event) => unref(throttledArrowClick)(unref(activeIndex) - 1), ["stop"]))
129
- }, [
130
- createVNode(unref(ElIcon), null, {
131
- default: withCtx(() => [
132
- createVNode(unref(ArrowLeft))
133
- ]),
134
- _: 1
135
- })
136
- ], 42, _hoisted_1), [
137
- [
138
- vShow,
139
- (_ctx.arrow === "always" || unref(hover)) && (props.loop || unref(activeIndex) > 0)
140
- ]
141
- ])
142
- ]),
143
- _: 1
144
- })) : createCommentVNode("v-if", true),
145
- unref(arrowDisplay) ? (openBlock(), createBlock(Transition, {
146
- key: 1,
147
- name: "carousel-arrow-right",
148
- persisted: ""
149
- }, {
150
- default: withCtx(() => [
151
- withDirectives(createElementVNode("button", {
152
- type: "button",
153
- class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "right")]),
154
- "aria-label": unref(t)("el.carousel.rightArrow"),
155
- onMouseenter: _cache[3] || (_cache[3] = ($event) => unref(handleButtonEnter)("right")),
156
- onMouseleave: _cache[4] || (_cache[4] = (...args) => unref(handleButtonLeave) && unref(handleButtonLeave)(...args)),
157
- onClick: _cache[5] || (_cache[5] = withModifiers(($event) => unref(throttledArrowClick)(unref(activeIndex) + 1), ["stop"]))
158
- }, [
159
- createVNode(unref(ElIcon), null, {
160
- default: withCtx(() => [
161
- createVNode(unref(ArrowRight))
162
- ]),
163
- _: 1
164
- })
165
- ], 42, _hoisted_2), [
166
- [
167
- vShow,
168
- (_ctx.arrow === "always" || unref(hover)) && (props.loop || unref(activeIndex) < unref(items).length - 1)
169
- ]
170
- ])
171
- ]),
172
- _: 1
173
- })) : createCommentVNode("v-if", true),
174
- createElementVNode("div", {
175
- class: normalizeClass(unref(carouselContainer)),
176
- style: normalizeStyle(unref(containerStyle)),
177
- onTransitionend: _cache[6] || (_cache[6] = (...args) => unref(handleTransitionEnd) && unref(handleTransitionEnd)(...args))
178
- }, [
179
- createVNode(unref(PlaceholderItem)),
180
- renderSlot(_ctx.$slots, "default")
181
- ], 38),
182
- _ctx.indicatorPosition !== "none" ? (openBlock(), createElementBlock("ul", {
183
- key: 2,
184
- class: normalizeClass(unref(indicatorsClasses))
185
- }, [
186
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(items), (item, index) => {
187
- return withDirectives((openBlock(), createElementBlock("li", {
188
- key: index,
189
- class: normalizeClass([
190
- unref(ns).e("indicator"),
191
- unref(ns).em("indicator", _ctx.direction),
192
- unref(ns).is("active", index === unref(activeIndex))
193
- ]),
194
- onMouseenter: ($event) => unref(throttledIndicatorHover)(index),
195
- onClick: withModifiers(($event) => unref(handleIndicatorClick)(index), ["stop"])
196
- }, [
197
- createElementVNode("button", {
198
- class: normalizeClass(unref(ns).e("button")),
199
- "aria-label": unref(t)("el.carousel.indicator", { index: index + 1 })
200
- }, [
201
- unref(hasLabel) ? (openBlock(), createElementBlock("span", _hoisted_5, toDisplayString(item.props.label), 1)) : createCommentVNode("v-if", true)
202
- ], 10, _hoisted_4)
203
- ], 42, _hoisted_3)), [
204
- [vShow, unref(isTwoLengthShow)(index)]
205
- ]);
206
- }), 128))
207
- ], 2)) : createCommentVNode("v-if", true),
208
- props.motionBlur ? (openBlock(), createElementBlock("svg", _hoisted_6, _hoisted_8)) : createCommentVNode("v-if", true)
209
- ], 34);
210
- };
5
+ const carouselProps = buildProps({
6
+ initialIndex: {
7
+ type: Number,
8
+ default: 0
9
+ },
10
+ height: {
11
+ type: String,
12
+ default: ""
13
+ },
14
+ trigger: {
15
+ type: String,
16
+ values: ["hover", "click"],
17
+ default: "hover"
18
+ },
19
+ autoplay: {
20
+ type: Boolean,
21
+ default: true
22
+ },
23
+ interval: {
24
+ type: Number,
25
+ default: 3e3
26
+ },
27
+ indicatorPosition: {
28
+ type: String,
29
+ values: ["", "none", "outside"],
30
+ default: ""
31
+ },
32
+ arrow: {
33
+ type: String,
34
+ values: ["always", "hover", "never"],
35
+ default: "hover"
36
+ },
37
+ type: {
38
+ type: String,
39
+ values: ["", "card"],
40
+ default: ""
41
+ },
42
+ loop: {
43
+ type: Boolean,
44
+ default: true
45
+ },
46
+ direction: {
47
+ type: String,
48
+ values: ["horizontal", "vertical"],
49
+ default: "horizontal"
50
+ },
51
+ pauseOnHover: {
52
+ type: Boolean,
53
+ default: true
54
+ },
55
+ motionBlur: {
56
+ type: Boolean,
57
+ default: false
211
58
  }
212
59
  });
213
- var Carousel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "carousel.vue"]]);
60
+ const carouselEmits = {
61
+ change: (current, prev) => [current, prev].every(isNumber)
62
+ };
214
63
 
215
- export { Carousel as default };
64
+ export { carouselEmits, carouselProps };
216
65
  //# sourceMappingURL=carousel2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"carousel2.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.vue"],"sourcesContent":["<template>\n <div\n ref=\"root\"\n :class=\"carouselClasses\"\n @mouseenter.stop=\"handleMouseEnter\"\n @mouseleave.stop=\"handleMouseLeave\"\n >\n <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-left\">\n <button\n v-show=\"\n (arrow === 'always' || hover) && (props.loop || activeIndex > 0)\n \"\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'left')]\"\n :aria-label=\"t('el.carousel.leftArrow')\"\n @mouseenter=\"handleButtonEnter('left')\"\n @mouseleave=\"handleButtonLeave\"\n @click.stop=\"throttledArrowClick(activeIndex - 1)\"\n >\n <ElIcon>\n <ArrowLeft />\n </ElIcon>\n </button>\n </transition>\n <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-right\">\n <button\n v-show=\"\n (arrow === 'always' || hover) &&\n (props.loop || activeIndex < items.length - 1)\n \"\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'right')]\"\n :aria-label=\"t('el.carousel.rightArrow')\"\n @mouseenter=\"handleButtonEnter('right')\"\n @mouseleave=\"handleButtonLeave\"\n @click.stop=\"throttledArrowClick(activeIndex + 1)\"\n >\n <ElIcon>\n <ArrowRight />\n </ElIcon>\n </button>\n </transition>\n <div\n :class=\"carouselContainer\"\n :style=\"containerStyle\"\n @transitionend=\"handleTransitionEnd\"\n >\n <PlaceholderItem />\n <slot />\n </div>\n <ul v-if=\"indicatorPosition !== 'none'\" :class=\"indicatorsClasses\">\n <li\n v-for=\"(item, index) in items\"\n v-show=\"isTwoLengthShow(index)\"\n :key=\"index\"\n :class=\"[\n ns.e('indicator'),\n ns.em('indicator', direction),\n ns.is('active', index === activeIndex),\n ]\"\n @mouseenter=\"throttledIndicatorHover(index)\"\n @click.stop=\"handleIndicatorClick(index)\"\n >\n <button\n :class=\"ns.e('button')\"\n :aria-label=\"t('el.carousel.indicator', { index: index + 1 })\"\n >\n <span v-if=\"hasLabel\">{{ item.props.label }}</span>\n </button>\n </li>\n </ul>\n <svg\n v-if=\"props.motionBlur\"\n xmlns=\"http://www.w3.org/2000/svg\"\n version=\"1.1\"\n style=\"display: none\"\n >\n <defs>\n <filter id=\"elCarouselHorizontal\">\n <feGaussianBlur in=\"SourceGraphic\" stdDeviation=\"12,0\" />\n </filter>\n <filter id=\"elCarouselVertical\">\n <feGaussianBlur in=\"SourceGraphic\" stdDeviation=\"0,10\" />\n </filter>\n </defs>\n </svg>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, unref } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { carouselEmits, carouselProps } from './carousel'\nimport { useCarousel } from './use-carousel'\n\nconst COMPONENT_NAME = 'ElCarousel'\ndefineOptions({\n name: COMPONENT_NAME,\n})\n\nconst props = defineProps(carouselProps)\nconst emit = defineEmits(carouselEmits)\nconst {\n root,\n activeIndex,\n arrowDisplay,\n hasLabel,\n hover,\n isCardType,\n items,\n isVertical,\n containerStyle,\n handleButtonEnter,\n handleButtonLeave,\n isTransitioning,\n handleIndicatorClick,\n handleMouseEnter,\n handleMouseLeave,\n handleTransitionEnd,\n setActiveItem,\n prev,\n next,\n PlaceholderItem,\n isTwoLengthShow,\n throttledArrowClick,\n throttledIndicatorHover,\n} = useCarousel(props, emit, COMPONENT_NAME)\nconst ns = useNamespace('carousel')\n\nconst { t } = useLocale()\n\nconst carouselClasses = computed(() => {\n const classes = [ns.b(), ns.m(props.direction)]\n if (unref(isCardType)) {\n classes.push(ns.m('card'))\n }\n return classes\n})\n\nconst carouselContainer = computed(() => {\n const classes = [ns.e('container')]\n if (props.motionBlur && unref(isTransitioning)) {\n classes.push(\n unref(isVertical)\n ? `${ns.namespace.value}-transitioning-vertical`\n : `${ns.namespace.value}-transitioning`\n )\n }\n return classes\n})\n\nconst indicatorsClasses = computed(() => {\n const classes = [ns.e('indicators'), ns.em('indicators', props.direction)]\n if (unref(hasLabel)) {\n classes.push(ns.em('indicators', 'labels'))\n }\n if (props.indicatorPosition === 'outside') {\n classes.push(ns.em('indicators', 'outside'))\n }\n if (unref(isVertical)) {\n classes.push(ns.em('indicators', 'right'))\n }\n return classes\n})\n\ndefineExpose({\n /** @description manually switch slide */\n setActiveItem,\n /** @description switch to the previous slide */\n prev,\n /** @description switch to the next slide */\n next,\n})\n</script>\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"carousel2.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.ts"],"sourcesContent":["import { buildProps, isNumber } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const carouselProps = buildProps({\n initialIndex: {\n type: Number,\n default: 0,\n },\n height: {\n type: String,\n default: '',\n },\n trigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n autoplay: {\n type: Boolean,\n default: true,\n },\n interval: {\n type: Number,\n default: 3000,\n },\n indicatorPosition: {\n type: String,\n values: ['', 'none', 'outside'],\n default: '',\n },\n arrow: {\n type: String,\n values: ['always', 'hover', 'never'],\n default: 'hover',\n },\n type: {\n type: String,\n values: ['', 'card'],\n default: '',\n },\n loop: {\n type: Boolean,\n default: true,\n },\n direction: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'horizontal',\n },\n pauseOnHover: {\n type: Boolean,\n default: true,\n },\n motionBlur: {\n type: Boolean,\n default: false,\n },\n} as const)\n\nexport const carouselEmits = {\n change: (current: number, prev: number) => [current, prev].every(isNumber),\n}\n\nexport type CarouselProps = ExtractPropTypes<typeof carouselProps>\nexport type CarouselEmits = typeof carouselEmits\n"],"names":[],"mappings":";;;;AACY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;AAC9B,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,iBAAiB,EAAE;AACrB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,CAAC;AACnC,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC;AACxC,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC;AACxB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,YAAY,EAAE,UAAU,CAAC;AACtC,IAAI,OAAO,EAAE,YAAY;AACzB,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,aAAa,GAAG;AAC7B,EAAE,MAAM,EAAE,CAAC,OAAO,EAAE,IAAI,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;AAC5D;;;;"}