@element-plus/nightly 0.0.20241130 → 0.0.20241202

Sign up to get free protection for your applications and to get access to all the features.
Files changed (334) hide show
  1. package/dist/index.full.js +2 -2
  2. package/dist/index.full.min.js +2 -2
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +2 -2
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +2 -2
  7. package/dist/locale/af.js +1 -1
  8. package/dist/locale/af.min.js +1 -1
  9. package/dist/locale/af.min.mjs +1 -1
  10. package/dist/locale/af.mjs +1 -1
  11. package/dist/locale/ar-eg.js +1 -1
  12. package/dist/locale/ar-eg.min.js +1 -1
  13. package/dist/locale/ar-eg.min.mjs +1 -1
  14. package/dist/locale/ar-eg.mjs +1 -1
  15. package/dist/locale/ar.js +1 -1
  16. package/dist/locale/ar.min.js +1 -1
  17. package/dist/locale/ar.min.mjs +1 -1
  18. package/dist/locale/ar.mjs +1 -1
  19. package/dist/locale/az.js +1 -1
  20. package/dist/locale/az.min.js +1 -1
  21. package/dist/locale/az.min.mjs +1 -1
  22. package/dist/locale/az.mjs +1 -1
  23. package/dist/locale/bg.js +1 -1
  24. package/dist/locale/bg.min.js +1 -1
  25. package/dist/locale/bg.min.mjs +1 -1
  26. package/dist/locale/bg.mjs +1 -1
  27. package/dist/locale/bn.js +1 -1
  28. package/dist/locale/bn.min.js +1 -1
  29. package/dist/locale/bn.min.mjs +1 -1
  30. package/dist/locale/bn.mjs +1 -1
  31. package/dist/locale/ca.js +1 -1
  32. package/dist/locale/ca.min.js +1 -1
  33. package/dist/locale/ca.min.mjs +1 -1
  34. package/dist/locale/ca.mjs +1 -1
  35. package/dist/locale/ckb.js +1 -1
  36. package/dist/locale/ckb.min.js +1 -1
  37. package/dist/locale/ckb.min.mjs +1 -1
  38. package/dist/locale/ckb.mjs +1 -1
  39. package/dist/locale/cs.js +1 -1
  40. package/dist/locale/cs.min.js +1 -1
  41. package/dist/locale/cs.min.mjs +1 -1
  42. package/dist/locale/cs.mjs +1 -1
  43. package/dist/locale/da.js +1 -1
  44. package/dist/locale/da.min.js +1 -1
  45. package/dist/locale/da.min.mjs +1 -1
  46. package/dist/locale/da.mjs +1 -1
  47. package/dist/locale/de.js +1 -1
  48. package/dist/locale/de.min.js +1 -1
  49. package/dist/locale/de.min.mjs +1 -1
  50. package/dist/locale/de.mjs +1 -1
  51. package/dist/locale/el.js +1 -1
  52. package/dist/locale/el.min.js +1 -1
  53. package/dist/locale/el.min.mjs +1 -1
  54. package/dist/locale/el.mjs +1 -1
  55. package/dist/locale/en.js +1 -1
  56. package/dist/locale/en.min.js +1 -1
  57. package/dist/locale/en.min.mjs +1 -1
  58. package/dist/locale/en.mjs +1 -1
  59. package/dist/locale/eo.js +1 -1
  60. package/dist/locale/eo.min.js +1 -1
  61. package/dist/locale/eo.min.mjs +1 -1
  62. package/dist/locale/eo.mjs +1 -1
  63. package/dist/locale/es.js +1 -1
  64. package/dist/locale/es.min.js +1 -1
  65. package/dist/locale/es.min.mjs +1 -1
  66. package/dist/locale/es.mjs +1 -1
  67. package/dist/locale/et.js +1 -1
  68. package/dist/locale/et.min.js +1 -1
  69. package/dist/locale/et.min.mjs +1 -1
  70. package/dist/locale/et.mjs +1 -1
  71. package/dist/locale/eu.js +1 -1
  72. package/dist/locale/eu.min.js +1 -1
  73. package/dist/locale/eu.min.mjs +1 -1
  74. package/dist/locale/eu.mjs +1 -1
  75. package/dist/locale/fa.js +1 -1
  76. package/dist/locale/fa.min.js +1 -1
  77. package/dist/locale/fa.min.mjs +1 -1
  78. package/dist/locale/fa.mjs +1 -1
  79. package/dist/locale/fi.js +1 -1
  80. package/dist/locale/fi.min.js +1 -1
  81. package/dist/locale/fi.min.mjs +1 -1
  82. package/dist/locale/fi.mjs +1 -1
  83. package/dist/locale/fr.js +1 -1
  84. package/dist/locale/fr.min.js +1 -1
  85. package/dist/locale/fr.min.mjs +1 -1
  86. package/dist/locale/fr.mjs +1 -1
  87. package/dist/locale/he.js +1 -1
  88. package/dist/locale/he.min.js +1 -1
  89. package/dist/locale/he.min.mjs +1 -1
  90. package/dist/locale/he.mjs +1 -1
  91. package/dist/locale/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 +68 -32
  253. package/es/components/badge/src/badge.mjs.map +1 -1
  254. package/es/components/badge/src/badge2.mjs +32 -68
  255. package/es/components/badge/src/badge2.mjs.map +1 -1
  256. package/es/components/carousel/index.mjs +2 -2
  257. package/es/components/carousel/src/carousel-item.mjs +7 -69
  258. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  259. package/es/components/carousel/src/carousel-item2.mjs +69 -7
  260. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  261. package/es/components/check-tag/index.mjs +2 -2
  262. package/es/components/check-tag/src/check-tag.mjs +38 -14
  263. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  264. package/es/components/check-tag/src/check-tag2.mjs +14 -38
  265. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  266. package/es/components/dialog/src/dialog-content.mjs +26 -87
  267. package/es/components/dialog/src/dialog-content.mjs.map +1 -1
  268. package/es/components/dialog/src/dialog-content2.mjs +87 -26
  269. package/es/components/dialog/src/dialog-content2.mjs.map +1 -1
  270. package/es/components/dialog/src/dialog.mjs +1 -1
  271. package/es/components/dialog/src/dialog2.mjs +1 -1
  272. package/es/components/index.mjs +5 -5
  273. package/es/components/input-tag/index.mjs +2 -2
  274. package/es/components/input-tag/src/input-tag.mjs +65 -215
  275. package/es/components/input-tag/src/input-tag.mjs.map +1 -1
  276. package/es/components/input-tag/src/input-tag2.mjs +215 -65
  277. package/es/components/input-tag/src/input-tag2.mjs.map +1 -1
  278. package/es/components/pagination/src/components/pager.mjs +209 -16
  279. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  280. package/es/components/pagination/src/components/pager2.mjs +16 -209
  281. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  282. package/es/components/pagination/src/pagination.mjs +1 -1
  283. package/es/components/tour/index.mjs +2 -2
  284. package/es/components/tour/src/step.mjs +44 -168
  285. package/es/components/tour/src/step.mjs.map +1 -1
  286. package/es/components/tour/src/step2.mjs +168 -44
  287. package/es/components/tour/src/step2.mjs.map +1 -1
  288. package/es/index.mjs +5 -5
  289. package/es/version.d.ts +1 -1
  290. package/es/version.mjs +1 -1
  291. package/es/version.mjs.map +1 -1
  292. package/lib/components/badge/index.js +2 -2
  293. package/lib/components/badge/src/badge.js +68 -32
  294. package/lib/components/badge/src/badge.js.map +1 -1
  295. package/lib/components/badge/src/badge2.js +32 -68
  296. package/lib/components/badge/src/badge2.js.map +1 -1
  297. package/lib/components/carousel/index.js +2 -2
  298. package/lib/components/carousel/src/carousel-item.js +7 -69
  299. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  300. package/lib/components/carousel/src/carousel-item2.js +69 -7
  301. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  302. package/lib/components/check-tag/index.js +2 -2
  303. package/lib/components/check-tag/src/check-tag.js +38 -15
  304. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  305. package/lib/components/check-tag/src/check-tag2.js +15 -38
  306. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  307. package/lib/components/dialog/src/dialog-content.js +26 -86
  308. package/lib/components/dialog/src/dialog-content.js.map +1 -1
  309. package/lib/components/dialog/src/dialog-content2.js +86 -26
  310. package/lib/components/dialog/src/dialog-content2.js.map +1 -1
  311. package/lib/components/dialog/src/dialog.js +1 -1
  312. package/lib/components/dialog/src/dialog2.js +1 -1
  313. package/lib/components/index.js +5 -5
  314. package/lib/components/input-tag/index.js +2 -2
  315. package/lib/components/input-tag/src/input-tag.js +65 -214
  316. package/lib/components/input-tag/src/input-tag.js.map +1 -1
  317. package/lib/components/input-tag/src/input-tag2.js +214 -65
  318. package/lib/components/input-tag/src/input-tag2.js.map +1 -1
  319. package/lib/components/pagination/src/components/pager.js +209 -16
  320. package/lib/components/pagination/src/components/pager.js.map +1 -1
  321. package/lib/components/pagination/src/components/pager2.js +16 -209
  322. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  323. package/lib/components/pagination/src/pagination.js +1 -1
  324. package/lib/components/tour/index.js +2 -2
  325. package/lib/components/tour/src/step.js +44 -167
  326. package/lib/components/tour/src/step.js.map +1 -1
  327. package/lib/components/tour/src/step2.js +167 -44
  328. package/lib/components/tour/src/step2.js.map +1 -1
  329. package/lib/index.js +5 -5
  330. package/lib/version.d.ts +1 -1
  331. package/lib/version.js +1 -1
  332. package/lib/version.js.map +1 -1
  333. package/package.json +1 -1
  334. package/web-types.json +1 -1
@@ -1,69 +1,219 @@
1
- import { tagProps } from '../../tag/src/tag.mjs';
2
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
3
- import { EVENT_CODE } from '../../../constants/aria.mjs';
4
- import { useSizeProp } from '../../../hooks/use-size/index.mjs';
5
- import { UPDATE_MODEL_EVENT, CHANGE_EVENT, INPUT_EVENT } from '../../../constants/event.mjs';
6
- import { isArray, isString } from '@vue/shared';
7
- import { isUndefined } from '../../../utils/types.mjs';
1
+ import { defineComponent, useSlots, computed, openBlock, createElementBlock, normalizeClass, unref, normalizeStyle, renderSlot, createCommentVNode, createElementVNode, Fragment, renderList, createBlock, withModifiers, withCtx, createTextVNode, toDisplayString, withDirectives, mergeProps, isRef, vModelText, vShow, createVNode, resolveDynamicComponent } from 'vue';
2
+ import { CircleClose } from '@element-plus/icons-vue';
3
+ import { ElIcon } from '../../icon/index.mjs';
4
+ import { ElTag } from '../../tag/index.mjs';
5
+ import { inputTagProps, inputTagEmits } from './input-tag.mjs';
6
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
7
+ import { useInputTag } from './composables/use-input-tag.mjs';
8
+ import { useHovering } from './composables/use-hovering.mjs';
9
+ import { useCalcInputWidth } from '../../../hooks/use-calc-input-width/index.mjs';
10
+ import { useDragTag } from './composables/use-drag-tag.mjs';
11
+ import { useInputTagDom } from './composables/use-input-tag-dom.mjs';
12
+ import { useAttrs } from '../../../hooks/use-attrs/index.mjs';
13
+ import { useFormItem, useFormItemInputId } from '../../form/src/hooks/use-form-item.mjs';
14
+ import { ValidateComponentsMap } from '../../../utils/vue/icon.mjs';
15
+ import { NOOP } from '@vue/shared';
8
16
 
9
- const inputTagProps = buildProps({
10
- modelValue: {
11
- type: definePropType(Array)
12
- },
13
- max: Number,
14
- tagType: { ...tagProps.type, default: "info" },
15
- tagEffect: tagProps.effect,
16
- trigger: {
17
- type: definePropType(String),
18
- default: EVENT_CODE.enter
19
- },
20
- draggable: {
21
- type: Boolean,
22
- default: false
23
- },
24
- size: useSizeProp,
25
- clearable: Boolean,
26
- disabled: {
27
- type: Boolean,
28
- default: void 0
29
- },
30
- validateEvent: {
31
- type: Boolean,
32
- default: true
33
- },
34
- readonly: Boolean,
35
- autofocus: Boolean,
36
- id: {
37
- type: String,
38
- default: void 0
39
- },
40
- tabindex: {
41
- type: [String, Number],
42
- default: 0
43
- },
44
- maxlength: {
45
- type: [String, Number]
46
- },
47
- minlength: {
48
- type: [String, Number]
49
- },
50
- placeholder: String,
51
- autocomplete: {
52
- type: String,
53
- default: "off"
54
- },
55
- ariaLabel: String
17
+ const __default__ = defineComponent({
18
+ name: "ElInputTag",
19
+ inheritAttrs: false
56
20
  });
57
- const inputTagEmits = {
58
- [UPDATE_MODEL_EVENT]: (value) => isArray(value) || isUndefined(value),
59
- [CHANGE_EVENT]: (value) => isArray(value) || isUndefined(value),
60
- [INPUT_EVENT]: (value) => isString(value),
61
- "add-tag": (value) => isString(value),
62
- "remove-tag": (value) => isString(value),
63
- focus: (evt) => evt instanceof FocusEvent,
64
- blur: (evt) => evt instanceof FocusEvent,
65
- clear: () => true
66
- };
21
+ const _sfc_main = /* @__PURE__ */ defineComponent({
22
+ ...__default__,
23
+ props: inputTagProps,
24
+ emits: inputTagEmits,
25
+ setup(__props, { expose, emit }) {
26
+ const props = __props;
27
+ const attrs = useAttrs();
28
+ const slots = useSlots();
29
+ const { form, formItem } = useFormItem();
30
+ const { inputId } = useFormItemInputId(props, { formItemContext: formItem });
31
+ const needStatusIcon = computed(() => {
32
+ var _a;
33
+ return (_a = form == null ? void 0 : form.statusIcon) != null ? _a : false;
34
+ });
35
+ const validateState = computed(() => (formItem == null ? void 0 : formItem.validateState) || "");
36
+ const validateIcon = computed(() => {
37
+ return validateState.value && ValidateComponentsMap[validateState.value];
38
+ });
39
+ const {
40
+ inputRef,
41
+ wrapperRef,
42
+ isFocused,
43
+ inputValue,
44
+ size,
45
+ tagSize,
46
+ placeholder,
47
+ closable,
48
+ disabled,
49
+ handleDragged,
50
+ handleInput,
51
+ handleKeydown,
52
+ handleRemoveTag,
53
+ handleClear,
54
+ handleCompositionStart,
55
+ handleCompositionUpdate,
56
+ handleCompositionEnd,
57
+ focus,
58
+ blur
59
+ } = useInputTag({ props, emit, formItem });
60
+ const { hovering, handleMouseEnter, handleMouseLeave } = useHovering();
61
+ const { calculatorRef, inputStyle } = useCalcInputWidth();
62
+ const {
63
+ dropIndicatorRef,
64
+ showDropIndicator,
65
+ handleDragStart,
66
+ handleDragOver,
67
+ handleDragEnd
68
+ } = useDragTag({ wrapperRef, handleDragged, afterDragged: focus });
69
+ const {
70
+ ns,
71
+ nsInput,
72
+ containerKls,
73
+ containerStyle,
74
+ innerKls,
75
+ showClear,
76
+ showSuffix
77
+ } = useInputTagDom({
78
+ props,
79
+ hovering,
80
+ isFocused,
81
+ inputValue,
82
+ disabled,
83
+ size,
84
+ validateState,
85
+ validateIcon,
86
+ needStatusIcon
87
+ });
88
+ expose({
89
+ focus,
90
+ blur
91
+ });
92
+ return (_ctx, _cache) => {
93
+ return openBlock(), createElementBlock("div", {
94
+ ref_key: "wrapperRef",
95
+ ref: wrapperRef,
96
+ class: normalizeClass(unref(containerKls)),
97
+ style: normalizeStyle(unref(containerStyle)),
98
+ onMouseenter: unref(handleMouseEnter),
99
+ onMouseleave: unref(handleMouseLeave)
100
+ }, [
101
+ unref(slots).prefix ? (openBlock(), createElementBlock("div", {
102
+ key: 0,
103
+ class: normalizeClass(unref(ns).e("prefix"))
104
+ }, [
105
+ renderSlot(_ctx.$slots, "prefix")
106
+ ], 2)) : createCommentVNode("v-if", true),
107
+ createElementVNode("div", {
108
+ class: normalizeClass(unref(innerKls))
109
+ }, [
110
+ (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.modelValue, (item, index) => {
111
+ return openBlock(), createBlock(unref(ElTag), {
112
+ key: index,
113
+ size: unref(tagSize),
114
+ closable: unref(closable),
115
+ type: _ctx.tagType,
116
+ effect: _ctx.tagEffect,
117
+ draggable: unref(closable) && _ctx.draggable,
118
+ "disable-transitions": "",
119
+ onClose: ($event) => unref(handleRemoveTag)(index),
120
+ onDragstart: (event) => unref(handleDragStart)(event, index),
121
+ onDragover: (event) => unref(handleDragOver)(event, index),
122
+ onDragend: unref(handleDragEnd),
123
+ onDrop: withModifiers(() => {
124
+ }, ["stop"])
125
+ }, {
126
+ default: withCtx(() => [
127
+ renderSlot(_ctx.$slots, "tag", {
128
+ value: item,
129
+ index
130
+ }, () => [
131
+ createTextVNode(toDisplayString(item), 1)
132
+ ])
133
+ ]),
134
+ _: 2
135
+ }, 1032, ["size", "closable", "type", "effect", "draggable", "onClose", "onDragstart", "onDragover", "onDragend", "onDrop"]);
136
+ }), 128)),
137
+ createElementVNode("div", {
138
+ class: normalizeClass(unref(ns).e("input-wrapper"))
139
+ }, [
140
+ withDirectives(createElementVNode("input", mergeProps({
141
+ id: unref(inputId),
142
+ ref_key: "inputRef",
143
+ ref: inputRef,
144
+ "onUpdate:modelValue": ($event) => isRef(inputValue) ? inputValue.value = $event : null
145
+ }, unref(attrs), {
146
+ type: "text",
147
+ minlength: _ctx.minlength,
148
+ maxlength: _ctx.maxlength,
149
+ disabled: unref(disabled),
150
+ readonly: _ctx.readonly,
151
+ autocomplete: _ctx.autocomplete,
152
+ tabindex: _ctx.tabindex,
153
+ placeholder: unref(placeholder),
154
+ autofocus: _ctx.autofocus,
155
+ ariaLabel: _ctx.ariaLabel,
156
+ class: unref(ns).e("input"),
157
+ style: unref(inputStyle),
158
+ onCompositionstart: unref(handleCompositionStart),
159
+ onCompositionupdate: unref(handleCompositionUpdate),
160
+ onCompositionend: unref(handleCompositionEnd),
161
+ onInput: unref(handleInput),
162
+ onKeydown: unref(handleKeydown)
163
+ }), null, 16, ["id", "onUpdate:modelValue", "minlength", "maxlength", "disabled", "readonly", "autocomplete", "tabindex", "placeholder", "autofocus", "ariaLabel", "onCompositionstart", "onCompositionupdate", "onCompositionend", "onInput", "onKeydown"]), [
164
+ [vModelText, unref(inputValue)]
165
+ ]),
166
+ createElementVNode("span", {
167
+ ref_key: "calculatorRef",
168
+ ref: calculatorRef,
169
+ "aria-hidden": "true",
170
+ class: normalizeClass(unref(ns).e("input-calculator")),
171
+ textContent: toDisplayString(unref(inputValue))
172
+ }, null, 10, ["textContent"])
173
+ ], 2),
174
+ withDirectives(createElementVNode("div", {
175
+ ref_key: "dropIndicatorRef",
176
+ ref: dropIndicatorRef,
177
+ class: normalizeClass(unref(ns).e("drop-indicator"))
178
+ }, null, 2), [
179
+ [vShow, unref(showDropIndicator)]
180
+ ])
181
+ ], 2),
182
+ unref(showSuffix) ? (openBlock(), createElementBlock("div", {
183
+ key: 1,
184
+ class: normalizeClass(unref(ns).e("suffix"))
185
+ }, [
186
+ renderSlot(_ctx.$slots, "suffix"),
187
+ unref(showClear) ? (openBlock(), createBlock(unref(ElIcon), {
188
+ key: 0,
189
+ class: normalizeClass([unref(ns).e("icon"), unref(ns).e("clear")]),
190
+ onMousedown: withModifiers(unref(NOOP), ["prevent"]),
191
+ onClick: unref(handleClear)
192
+ }, {
193
+ default: withCtx(() => [
194
+ createVNode(unref(CircleClose))
195
+ ]),
196
+ _: 1
197
+ }, 8, ["class", "onMousedown", "onClick"])) : createCommentVNode("v-if", true),
198
+ unref(validateState) && unref(validateIcon) && unref(needStatusIcon) ? (openBlock(), createBlock(unref(ElIcon), {
199
+ key: 1,
200
+ class: normalizeClass([
201
+ unref(nsInput).e("icon"),
202
+ unref(nsInput).e("validateIcon"),
203
+ unref(nsInput).is("loading", unref(validateState) === "validating")
204
+ ])
205
+ }, {
206
+ default: withCtx(() => [
207
+ (openBlock(), createBlock(resolveDynamicComponent(unref(validateIcon))))
208
+ ]),
209
+ _: 1
210
+ }, 8, ["class"])) : createCommentVNode("v-if", true)
211
+ ], 2)) : createCommentVNode("v-if", true)
212
+ ], 46, ["onMouseenter", "onMouseleave"]);
213
+ };
214
+ }
215
+ });
216
+ var InputTag = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "input-tag.vue"]]);
67
217
 
68
- export { inputTagEmits, inputTagProps };
218
+ export { InputTag as default };
69
219
  //# sourceMappingURL=input-tag2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"input-tag2.mjs","sources":["../../../../../../packages/components/input-tag/src/input-tag.ts"],"sourcesContent":["import {\n buildProps,\n definePropType,\n isArray,\n isString,\n isUndefined,\n} from '@element-plus/utils'\nimport { useSizeProp } from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { tagProps } from '@element-plus/components/tag/src/tag'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const inputTagProps = buildProps({\n /**\n * @description binding value\n */\n modelValue: {\n type: definePropType<string[]>(Array),\n },\n /**\n * @description max number tags that can be enter\n */\n max: Number,\n /**\n * @description tag type\n */\n tagType: { ...tagProps.type, default: 'info' },\n /**\n * @description tag effect\n */\n tagEffect: tagProps.effect,\n /**\n * @description the key to trigger input tag\n */\n trigger: {\n type: definePropType<'Enter' | 'Space'>(String),\n default: EVENT_CODE.enter,\n },\n /**\n * @description whether tags can be dragged\n */\n draggable: {\n type: Boolean,\n default: false,\n },\n /**\n * @description input box size\n */\n size: useSizeProp,\n /**\n * @description whether to show clear button\n */\n clearable: Boolean,\n /**\n * @description whether to disable input-tag\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description native input readonly\n */\n readonly: Boolean,\n /**\n * @description native input autofocus\n */\n autofocus: Boolean,\n /**\n * @description same as `id` in native input\n */\n id: {\n type: String,\n default: undefined,\n },\n /**\n * @description same as `tabindex` in native input\n */\n tabindex: {\n type: [String, Number],\n default: 0,\n },\n /**\n * @description same as `maxlength` in native input\n */\n maxlength: {\n type: [String, Number],\n },\n /**\n * @description same as `minlength` in native input\n */\n minlength: {\n type: [String, Number],\n },\n /**\n * @description placeholder of input\n */\n placeholder: String,\n /**\n * @description native input autocomplete\n */\n autocomplete: {\n type: String,\n default: 'off',\n },\n /**\n * @description native `aria-label` attribute\n */\n ariaLabel: String,\n} as const)\nexport type InputTagProps = ExtractPropTypes<typeof inputTagProps>\n\nexport const inputTagEmits = {\n [UPDATE_MODEL_EVENT]: (value?: string[]) =>\n isArray(value) || isUndefined(value),\n [CHANGE_EVENT]: (value?: string[]) => isArray(value) || isUndefined(value),\n [INPUT_EVENT]: (value: string) => isString(value),\n 'add-tag': (value: string) => isString(value),\n 'remove-tag': (value: string) => isString(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n}\nexport type InputTagEmits = typeof inputTagEmits\n"],"names":[],"mappings":";;;;;;;;AAeY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,GAAG;AACH,EAAE,GAAG,EAAE,MAAM;AACb,EAAE,OAAO,EAAE,EAAE,GAAG,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE;AAChD,EAAE,SAAS,EAAE,QAAQ,CAAC,MAAM;AAC5B,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,UAAU,CAAC,KAAK;AAC7B,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,IAAI,EAAE,WAAW;AACnB,EAAE,SAAS,EAAE,OAAO;AACpB,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK,CAAC;AACnB,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,SAAS,EAAE,OAAO;AACpB,EAAE,EAAE,EAAE;AACN,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,KAAK,CAAC;AACnB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,SAAS,EAAE,MAAM;AACnB,CAAC,EAAE;AACS,MAAC,aAAa,GAAG;AAC7B,EAAE,CAAC,kBAAkB,GAAG,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK,CAAC,IAAI,WAAW,CAAC,KAAK,CAAC;AACvE,EAAE,CAAC,YAAY,GAAG,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK,CAAC,IAAI,WAAW,CAAC,KAAK,CAAC;AACjE,EAAE,CAAC,WAAW,GAAG,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAC3C,EAAE,SAAS,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACvC,EAAE,YAAY,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAC1C,EAAE,KAAK,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC3C,EAAE,IAAI,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC1C,EAAE,KAAK,EAAE,MAAM,IAAI;AACnB;;;;"}
1
+ {"version":3,"file":"input-tag2.mjs","sources":["../../../../../../packages/components/input-tag/src/input-tag.vue"],"sourcesContent":["<template>\n <div\n ref=\"wrapperRef\"\n :class=\"containerKls\"\n :style=\"containerStyle\"\n @mouseenter=\"handleMouseEnter\"\n @mouseleave=\"handleMouseLeave\"\n >\n <div v-if=\"slots.prefix\" :class=\"ns.e('prefix')\">\n <slot name=\"prefix\" />\n </div>\n <div :class=\"innerKls\">\n <el-tag\n v-for=\"(item, index) in modelValue\"\n :key=\"index\"\n :size=\"tagSize\"\n :closable=\"closable\"\n :type=\"tagType\"\n :effect=\"tagEffect\"\n :draggable=\"closable && draggable\"\n disable-transitions\n @close=\"handleRemoveTag(index)\"\n @dragstart=\"(event: DragEvent) => handleDragStart(event, index)\"\n @dragover=\"(event: DragEvent) => handleDragOver(event, index)\"\n @dragend=\"handleDragEnd\"\n @drop.stop\n >\n <slot name=\"tag\" :value=\"item\" :index=\"index\">\n {{ item }}\n </slot>\n </el-tag>\n <div :class=\"ns.e('input-wrapper')\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n v-model=\"inputValue\"\n v-bind=\"attrs\"\n type=\"text\"\n :minlength=\"minlength\"\n :maxlength=\"maxlength\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :autocomplete=\"autocomplete\"\n :tabindex=\"tabindex\"\n :placeholder=\"placeholder\"\n :autofocus=\"autofocus\"\n :ariaLabel=\"ariaLabel\"\n :class=\"ns.e('input')\"\n :style=\"inputStyle\"\n @compositionstart=\"handleCompositionStart\"\n @compositionupdate=\"handleCompositionUpdate\"\n @compositionend=\"handleCompositionEnd\"\n @input=\"handleInput\"\n @keydown=\"handleKeydown\"\n />\n <span\n ref=\"calculatorRef\"\n aria-hidden=\"true\"\n :class=\"ns.e('input-calculator')\"\n v-text=\"inputValue\"\n />\n </div>\n <div\n v-show=\"showDropIndicator\"\n ref=\"dropIndicatorRef\"\n :class=\"ns.e('drop-indicator')\"\n />\n </div>\n <div v-if=\"showSuffix\" :class=\"ns.e('suffix')\">\n <slot name=\"suffix\" />\n <el-icon\n v-if=\"showClear\"\n :class=\"[ns.e('icon'), ns.e('clear')]\"\n @mousedown.prevent=\"NOOP\"\n @click=\"handleClear\"\n >\n <circle-close />\n </el-icon>\n <el-icon\n v-if=\"validateState && validateIcon && needStatusIcon\"\n :class=\"[\n nsInput.e('icon'),\n nsInput.e('validateIcon'),\n nsInput.is('loading', validateState === 'validating'),\n ]\"\n >\n <component :is=\"validateIcon\" />\n </el-icon>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, useSlots } from 'vue'\nimport { CircleClose } from '@element-plus/icons-vue'\nimport { useAttrs, useCalcInputWidth } from '@element-plus/hooks'\nimport { NOOP, ValidateComponentsMap } from '@element-plus/utils'\nimport ElIcon from '@element-plus/components/icon'\nimport ElTag from '@element-plus/components/tag'\nimport { useFormItem, useFormItemInputId } from '@element-plus/components/form'\nimport { inputTagEmits, inputTagProps } from './input-tag'\nimport {\n useDragTag,\n useHovering,\n useInputTag,\n useInputTagDom,\n} from './composables'\n\ndefineOptions({\n name: 'ElInputTag',\n inheritAttrs: false,\n})\n\nconst props = defineProps(inputTagProps)\nconst emit = defineEmits(inputTagEmits)\n\nconst attrs = useAttrs()\nconst slots = useSlots()\nconst { form, formItem } = useFormItem()\nconst { inputId } = useFormItemInputId(props, { formItemContext: formItem })\n\nconst needStatusIcon = computed(() => form?.statusIcon ?? false)\nconst validateState = computed(() => formItem?.validateState || '')\nconst validateIcon = computed(() => {\n return validateState.value && ValidateComponentsMap[validateState.value]\n})\n\nconst {\n inputRef,\n wrapperRef,\n isFocused,\n inputValue,\n size,\n tagSize,\n placeholder,\n closable,\n disabled,\n handleDragged,\n handleInput,\n handleKeydown,\n handleRemoveTag,\n handleClear,\n handleCompositionStart,\n handleCompositionUpdate,\n handleCompositionEnd,\n focus,\n blur,\n} = useInputTag({ props, emit, formItem })\nconst { hovering, handleMouseEnter, handleMouseLeave } = useHovering()\nconst { calculatorRef, inputStyle } = useCalcInputWidth()\nconst {\n dropIndicatorRef,\n showDropIndicator,\n handleDragStart,\n handleDragOver,\n handleDragEnd,\n} = useDragTag({ wrapperRef, handleDragged, afterDragged: focus })\nconst {\n ns,\n nsInput,\n containerKls,\n containerStyle,\n innerKls,\n showClear,\n showSuffix,\n} = useInputTagDom({\n props,\n hovering,\n isFocused,\n inputValue,\n disabled,\n size,\n validateState,\n validateIcon,\n needStatusIcon,\n})\n\ndefineExpose({\n focus,\n blur,\n})\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;mCA4Gc,CAAA;AAAA,EACZ,IAAM,EAAA,YAAA;AAAA,EACN,YAAc,EAAA,KAAA;AAChB,CAAA,CAAA,CAAA;;;;;;;AAKA,IAAA,MAAM,QAAQ,QAAS,EAAA,CAAA;AACvB,IAAA,MAAM,QAAQ,QAAS,EAAA,CAAA;AACvB,IAAA,MAAM,EAAE,IAAA,EAAM,QAAS,EAAA,GAAI,WAAY,EAAA,CAAA;AACvC,IAAM,MAAA,EAAE,SAAY,GAAA,kBAAA,CAAmB,OAAO,EAAE,eAAA,EAAiB,UAAU,CAAA,CAAA;AAE3E,IAAA,MAAM,cAAiB,GAAA,QAAA,CAAS,MAAM;AACtC,MAAA,IAAM,EAAgB,CAAA;AACtB,MAAM,OAAA,CAAA,EAAA,GAAA,IAAA,WAAwB,KAAM,CAAA,GAAA,IAAA,CAAA,UAAA,KAAA,IAAA,GAAA,EAAA,GAAA,KAAA,CAAA;AAClC,KAAA,CAAA,CAAA;AAAuE,IACzE,MAAC,aAAA,GAAA,QAAA,CAAA,MAAA,CAAA,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,aAAA,KAAA,EAAA,CAAA,CAAA;AAED,IAAM,MAAA,YAAA,GAAA,QAAA,CAAA,MAAA;AAAA,MACJ,OAAA,aAAA,CAAA,KAAA,IAAA,qBAAA,CAAA,aAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAAA,IACA,MAAA;AAAA,MACA,QAAA;AAAA,MACA,UAAA;AAAA,MACA,SAAA;AAAA,MACA,UAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,WAAA;AAAA,MACA,QAAA;AAAA,MACA,QAAA;AAAA,MACA,aAAA;AAAA,MACA,WAAA;AAAA,MACA,aAAA;AAAA,MACA,eAAA;AAAA,MACA,WAAA;AAAA,MACA,sBAAA;AAAA,MACA,uBAAA;AAAA,0BACuB;AACzB,MAAA,KAAQ;AACR,MAAA,IAAM;AACN,KAAM,GAAA,WAAA,CAAA,EAAA,KAAA,EAAA,IAAA,EAAA,QAAA,EAAA,CAAA,CAAA;AAAA,IACJ,MAAA,EAAA,QAAA,EAAA,gBAAA,EAAA,gBAAA,EAAA,GAAA,WAAA,EAAA,CAAA;AAAA,IACA,MAAA,EAAA,aAAA,EAAA,UAAA,EAAA,GAAA,iBAAA,EAAA,CAAA;AAAA,IACA,MAAA;AAAA,MACA,gBAAA;AAAA,MACA,iBAAA;AAAA,qBACe;AACjB,MAAM,cAAA;AAAA,MACJ,aAAA;AAAA,KACA,GAAA,UAAA,CAAA,EAAA,UAAA,EAAA,aAAA,EAAA,YAAA,EAAA,KAAA,EAAA,CAAA,CAAA;AAAA,IACA,MAAA;AAAA,MACA,EAAA;AAAA,MACA,OAAA;AAAA,MACA,YAAA;AAAA,MACA,cAAA;AAAA,cACiB;AAAA,MACjB,SAAA;AAAA,MACA,UAAA;AAAA,KACA,GAAA,cAAA,CAAA;AAAA,MACA,KAAA;AAAA,MACA,QAAA;AAAA,MACA,SAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,IAAA;AAAA,MACD,aAAA;AAED,MAAa,YAAA;AAAA,MACX,cAAA;AAAA,KACA,CAAA,CAAA;AAAA,IACF,MAAC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,20 +1,213 @@
1
- import { buildProps } from '../../../../utils/vue/props/runtime.mjs';
1
+ import { defineComponent, ref, computed, watchEffect, openBlock, createElementBlock, normalizeClass, unref, withKeys, createCommentVNode, createBlock, Fragment, renderList, toDisplayString } from 'vue';
2
+ import { DArrowLeft, MoreFilled, DArrowRight } from '@element-plus/icons-vue';
3
+ import { paginationPagerProps } from './pager2.mjs';
4
+ import _export_sfc from '../../../../_virtual/plugin-vue_export-helper.mjs';
5
+ import { useNamespace } from '../../../../hooks/use-namespace/index.mjs';
6
+ import { useLocale } from '../../../../hooks/use-locale/index.mjs';
2
7
 
3
- const paginationPagerProps = buildProps({
4
- currentPage: {
5
- type: Number,
6
- default: 1
7
- },
8
- pageCount: {
9
- type: Number,
10
- required: true
11
- },
12
- pagerCount: {
13
- type: Number,
14
- default: 7
15
- },
16
- disabled: Boolean
8
+ const __default__ = defineComponent({
9
+ name: "ElPaginationPager"
17
10
  });
11
+ const _sfc_main = /* @__PURE__ */ defineComponent({
12
+ ...__default__,
13
+ props: paginationPagerProps,
14
+ emits: ["change"],
15
+ setup(__props, { emit }) {
16
+ const props = __props;
17
+ const nsPager = useNamespace("pager");
18
+ const nsIcon = useNamespace("icon");
19
+ const { t } = useLocale();
20
+ const showPrevMore = ref(false);
21
+ const showNextMore = ref(false);
22
+ const quickPrevHover = ref(false);
23
+ const quickNextHover = ref(false);
24
+ const quickPrevFocus = ref(false);
25
+ const quickNextFocus = ref(false);
26
+ const pagers = computed(() => {
27
+ const pagerCount = props.pagerCount;
28
+ const halfPagerCount = (pagerCount - 1) / 2;
29
+ const currentPage = Number(props.currentPage);
30
+ const pageCount = Number(props.pageCount);
31
+ let showPrevMore2 = false;
32
+ let showNextMore2 = false;
33
+ if (pageCount > pagerCount) {
34
+ if (currentPage > pagerCount - halfPagerCount) {
35
+ showPrevMore2 = true;
36
+ }
37
+ if (currentPage < pageCount - halfPagerCount) {
38
+ showNextMore2 = true;
39
+ }
40
+ }
41
+ const array = [];
42
+ if (showPrevMore2 && !showNextMore2) {
43
+ const startPage = pageCount - (pagerCount - 2);
44
+ for (let i = startPage; i < pageCount; i++) {
45
+ array.push(i);
46
+ }
47
+ } else if (!showPrevMore2 && showNextMore2) {
48
+ for (let i = 2; i < pagerCount; i++) {
49
+ array.push(i);
50
+ }
51
+ } else if (showPrevMore2 && showNextMore2) {
52
+ const offset = Math.floor(pagerCount / 2) - 1;
53
+ for (let i = currentPage - offset; i <= currentPage + offset; i++) {
54
+ array.push(i);
55
+ }
56
+ } else {
57
+ for (let i = 2; i < pageCount; i++) {
58
+ array.push(i);
59
+ }
60
+ }
61
+ return array;
62
+ });
63
+ const prevMoreKls = computed(() => [
64
+ "more",
65
+ "btn-quickprev",
66
+ nsIcon.b(),
67
+ nsPager.is("disabled", props.disabled)
68
+ ]);
69
+ const nextMoreKls = computed(() => [
70
+ "more",
71
+ "btn-quicknext",
72
+ nsIcon.b(),
73
+ nsPager.is("disabled", props.disabled)
74
+ ]);
75
+ const tabindex = computed(() => props.disabled ? -1 : 0);
76
+ watchEffect(() => {
77
+ const halfPagerCount = (props.pagerCount - 1) / 2;
78
+ showPrevMore.value = false;
79
+ showNextMore.value = false;
80
+ if (props.pageCount > props.pagerCount) {
81
+ if (props.currentPage > props.pagerCount - halfPagerCount) {
82
+ showPrevMore.value = true;
83
+ }
84
+ if (props.currentPage < props.pageCount - halfPagerCount) {
85
+ showNextMore.value = true;
86
+ }
87
+ }
88
+ });
89
+ function onMouseEnter(forward = false) {
90
+ if (props.disabled)
91
+ return;
92
+ if (forward) {
93
+ quickPrevHover.value = true;
94
+ } else {
95
+ quickNextHover.value = true;
96
+ }
97
+ }
98
+ function onFocus(forward = false) {
99
+ if (forward) {
100
+ quickPrevFocus.value = true;
101
+ } else {
102
+ quickNextFocus.value = true;
103
+ }
104
+ }
105
+ function onEnter(e) {
106
+ const target = e.target;
107
+ if (target.tagName.toLowerCase() === "li" && Array.from(target.classList).includes("number")) {
108
+ const newPage = Number(target.textContent);
109
+ if (newPage !== props.currentPage) {
110
+ emit("change", newPage);
111
+ }
112
+ } else if (target.tagName.toLowerCase() === "li" && Array.from(target.classList).includes("more")) {
113
+ onPagerClick(e);
114
+ }
115
+ }
116
+ function onPagerClick(event) {
117
+ const target = event.target;
118
+ if (target.tagName.toLowerCase() === "ul" || props.disabled) {
119
+ return;
120
+ }
121
+ let newPage = Number(target.textContent);
122
+ const pageCount = props.pageCount;
123
+ const currentPage = props.currentPage;
124
+ const pagerCountOffset = props.pagerCount - 2;
125
+ if (target.className.includes("more")) {
126
+ if (target.className.includes("quickprev")) {
127
+ newPage = currentPage - pagerCountOffset;
128
+ } else if (target.className.includes("quicknext")) {
129
+ newPage = currentPage + pagerCountOffset;
130
+ }
131
+ }
132
+ if (!Number.isNaN(+newPage)) {
133
+ if (newPage < 1) {
134
+ newPage = 1;
135
+ }
136
+ if (newPage > pageCount) {
137
+ newPage = pageCount;
138
+ }
139
+ }
140
+ if (newPage !== currentPage) {
141
+ emit("change", newPage);
142
+ }
143
+ }
144
+ return (_ctx, _cache) => {
145
+ return openBlock(), createElementBlock("ul", {
146
+ class: normalizeClass(unref(nsPager).b()),
147
+ onClick: onPagerClick,
148
+ onKeyup: withKeys(onEnter, ["enter"])
149
+ }, [
150
+ _ctx.pageCount > 0 ? (openBlock(), createElementBlock("li", {
151
+ key: 0,
152
+ class: normalizeClass([[
153
+ unref(nsPager).is("active", _ctx.currentPage === 1),
154
+ unref(nsPager).is("disabled", _ctx.disabled)
155
+ ], "number"]),
156
+ "aria-current": _ctx.currentPage === 1,
157
+ "aria-label": unref(t)("el.pagination.currentPage", { pager: 1 }),
158
+ tabindex: unref(tabindex)
159
+ }, " 1 ", 10, ["aria-current", "aria-label", "tabindex"])) : createCommentVNode("v-if", true),
160
+ showPrevMore.value ? (openBlock(), createElementBlock("li", {
161
+ key: 1,
162
+ class: normalizeClass(unref(prevMoreKls)),
163
+ tabindex: unref(tabindex),
164
+ "aria-label": unref(t)("el.pagination.prevPages", { pager: _ctx.pagerCount - 2 }),
165
+ onMouseenter: ($event) => onMouseEnter(true),
166
+ onMouseleave: ($event) => quickPrevHover.value = false,
167
+ onFocus: ($event) => onFocus(true),
168
+ onBlur: ($event) => quickPrevFocus.value = false
169
+ }, [
170
+ (quickPrevHover.value || quickPrevFocus.value) && !_ctx.disabled ? (openBlock(), createBlock(unref(DArrowLeft), { key: 0 })) : (openBlock(), createBlock(unref(MoreFilled), { key: 1 }))
171
+ ], 42, ["tabindex", "aria-label", "onMouseenter", "onMouseleave", "onFocus", "onBlur"])) : createCommentVNode("v-if", true),
172
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(pagers), (pager) => {
173
+ return openBlock(), createElementBlock("li", {
174
+ key: pager,
175
+ class: normalizeClass([[
176
+ unref(nsPager).is("active", _ctx.currentPage === pager),
177
+ unref(nsPager).is("disabled", _ctx.disabled)
178
+ ], "number"]),
179
+ "aria-current": _ctx.currentPage === pager,
180
+ "aria-label": unref(t)("el.pagination.currentPage", { pager }),
181
+ tabindex: unref(tabindex)
182
+ }, toDisplayString(pager), 11, ["aria-current", "aria-label", "tabindex"]);
183
+ }), 128)),
184
+ showNextMore.value ? (openBlock(), createElementBlock("li", {
185
+ key: 2,
186
+ class: normalizeClass(unref(nextMoreKls)),
187
+ tabindex: unref(tabindex),
188
+ "aria-label": unref(t)("el.pagination.nextPages", { pager: _ctx.pagerCount - 2 }),
189
+ onMouseenter: ($event) => onMouseEnter(),
190
+ onMouseleave: ($event) => quickNextHover.value = false,
191
+ onFocus: ($event) => onFocus(),
192
+ onBlur: ($event) => quickNextFocus.value = false
193
+ }, [
194
+ (quickNextHover.value || quickNextFocus.value) && !_ctx.disabled ? (openBlock(), createBlock(unref(DArrowRight), { key: 0 })) : (openBlock(), createBlock(unref(MoreFilled), { key: 1 }))
195
+ ], 42, ["tabindex", "aria-label", "onMouseenter", "onMouseleave", "onFocus", "onBlur"])) : createCommentVNode("v-if", true),
196
+ _ctx.pageCount > 1 ? (openBlock(), createElementBlock("li", {
197
+ key: 3,
198
+ class: normalizeClass([[
199
+ unref(nsPager).is("active", _ctx.currentPage === _ctx.pageCount),
200
+ unref(nsPager).is("disabled", _ctx.disabled)
201
+ ], "number"]),
202
+ "aria-current": _ctx.currentPage === _ctx.pageCount,
203
+ "aria-label": unref(t)("el.pagination.currentPage", { pager: _ctx.pageCount }),
204
+ tabindex: unref(tabindex)
205
+ }, toDisplayString(_ctx.pageCount), 11, ["aria-current", "aria-label", "tabindex"])) : createCommentVNode("v-if", true)
206
+ ], 42, ["onKeyup"]);
207
+ };
208
+ }
209
+ });
210
+ var Pager = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pager.vue"]]);
18
211
 
19
- export { paginationPagerProps };
212
+ export { Pager as default };
20
213
  //# sourceMappingURL=pager.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"pager.mjs","sources":["../../../../../../../packages/components/pagination/src/components/pager.ts"],"sourcesContent":["import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Pager from './pager.vue'\n\nexport const paginationPagerProps = buildProps({\n currentPage: {\n type: Number,\n default: 1,\n },\n pageCount: {\n type: Number,\n required: true,\n },\n pagerCount: {\n type: Number,\n default: 7,\n },\n disabled: Boolean,\n} as const)\n\nexport type PaginationPagerProps = ExtractPropTypes<typeof paginationPagerProps>\n\nexport type PagerInstance = InstanceType<typeof Pager>\n"],"names":[],"mappings":";;AACY,MAAC,oBAAoB,GAAG,UAAU,CAAC;AAC/C,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,QAAQ,EAAE,IAAI;AAClB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC;;;;"}
1
+ {"version":3,"file":"pager.mjs","sources":["../../../../../../../packages/components/pagination/src/components/pager.vue"],"sourcesContent":["<template>\n <ul :class=\"nsPager.b()\" @click=\"onPagerClick\" @keyup.enter=\"onEnter\">\n <li\n v-if=\"pageCount > 0\"\n :class=\"[\n nsPager.is('active', currentPage === 1),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === 1\"\n :aria-label=\"t('el.pagination.currentPage', { pager: 1 })\"\n :tabindex=\"tabindex\"\n >\n 1\n </li>\n <li\n v-if=\"showPrevMore\"\n :class=\"prevMoreKls\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.pagination.prevPages', { pager: pagerCount - 2 })\"\n @mouseenter=\"onMouseEnter(true)\"\n @mouseleave=\"quickPrevHover = false\"\n @focus=\"onFocus(true)\"\n @blur=\"quickPrevFocus = false\"\n >\n <d-arrow-left v-if=\"(quickPrevHover || quickPrevFocus) && !disabled\" />\n <more-filled v-else />\n </li>\n <li\n v-for=\"pager in pagers\"\n :key=\"pager\"\n :class=\"[\n nsPager.is('active', currentPage === pager),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === pager\"\n :aria-label=\"t('el.pagination.currentPage', { pager })\"\n :tabindex=\"tabindex\"\n >\n {{ pager }}\n </li>\n <li\n v-if=\"showNextMore\"\n :class=\"nextMoreKls\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.pagination.nextPages', { pager: pagerCount - 2 })\"\n @mouseenter=\"onMouseEnter()\"\n @mouseleave=\"quickNextHover = false\"\n @focus=\"onFocus()\"\n @blur=\"quickNextFocus = false\"\n >\n <d-arrow-right v-if=\"(quickNextHover || quickNextFocus) && !disabled\" />\n <more-filled v-else />\n </li>\n <li\n v-if=\"pageCount > 1\"\n :class=\"[\n nsPager.is('active', currentPage === pageCount),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === pageCount\"\n :aria-label=\"t('el.pagination.currentPage', { pager: pageCount })\"\n :tabindex=\"tabindex\"\n >\n {{ pageCount }}\n </li>\n </ul>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, watchEffect } from 'vue'\nimport { DArrowLeft, DArrowRight, MoreFilled } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { paginationPagerProps } from './pager'\ndefineOptions({\n name: 'ElPaginationPager',\n})\nconst props = defineProps(paginationPagerProps)\nconst emit = defineEmits(['change'])\nconst nsPager = useNamespace('pager')\nconst nsIcon = useNamespace('icon')\nconst { t } = useLocale()\n\nconst showPrevMore = ref(false)\nconst showNextMore = ref(false)\nconst quickPrevHover = ref(false)\nconst quickNextHover = ref(false)\nconst quickPrevFocus = ref(false)\nconst quickNextFocus = ref(false)\nconst pagers = computed(() => {\n const pagerCount = props.pagerCount\n const halfPagerCount = (pagerCount - 1) / 2\n const currentPage = Number(props.currentPage)\n const pageCount = Number(props.pageCount)\n let showPrevMore = false\n let showNextMore = false\n if (pageCount > pagerCount) {\n if (currentPage > pagerCount - halfPagerCount) {\n showPrevMore = true\n }\n if (currentPage < pageCount - halfPagerCount) {\n showNextMore = true\n }\n }\n const array: number[] = []\n if (showPrevMore && !showNextMore) {\n const startPage = pageCount - (pagerCount - 2)\n for (let i = startPage; i < pageCount; i++) {\n array.push(i)\n }\n } else if (!showPrevMore && showNextMore) {\n for (let i = 2; i < pagerCount; i++) {\n array.push(i)\n }\n } else if (showPrevMore && showNextMore) {\n const offset = Math.floor(pagerCount / 2) - 1\n for (let i = currentPage - offset; i <= currentPage + offset; i++) {\n array.push(i)\n }\n } else {\n for (let i = 2; i < pageCount; i++) {\n array.push(i)\n }\n }\n return array\n})\n\nconst prevMoreKls = computed(() => [\n 'more',\n 'btn-quickprev',\n nsIcon.b(),\n nsPager.is('disabled', props.disabled),\n])\nconst nextMoreKls = computed(() => [\n 'more',\n 'btn-quicknext',\n nsIcon.b(),\n nsPager.is('disabled', props.disabled),\n])\n\nconst tabindex = computed(() => (props.disabled ? -1 : 0))\nwatchEffect(() => {\n const halfPagerCount = (props.pagerCount - 1) / 2\n showPrevMore.value = false\n showNextMore.value = false\n if (props.pageCount! > props.pagerCount) {\n if (props.currentPage > props.pagerCount - halfPagerCount) {\n showPrevMore.value = true\n }\n if (props.currentPage < props.pageCount! - halfPagerCount) {\n showNextMore.value = true\n }\n }\n})\nfunction onMouseEnter(forward = false) {\n if (props.disabled) return\n if (forward) {\n quickPrevHover.value = true\n } else {\n quickNextHover.value = true\n }\n}\nfunction onFocus(forward = false) {\n if (forward) {\n quickPrevFocus.value = true\n } else {\n quickNextFocus.value = true\n }\n}\nfunction onEnter(e: UIEvent) {\n const target = e.target as HTMLElement\n if (\n target.tagName.toLowerCase() === 'li' &&\n Array.from(target.classList).includes('number')\n ) {\n const newPage = Number(target.textContent)\n if (newPage !== props.currentPage) {\n emit('change', newPage)\n }\n } else if (\n target.tagName.toLowerCase() === 'li' &&\n Array.from(target.classList).includes('more')\n ) {\n onPagerClick(e)\n }\n}\nfunction onPagerClick(event: UIEvent) {\n const target = event.target as HTMLElement\n if (target.tagName.toLowerCase() === 'ul' || props.disabled) {\n return\n }\n let newPage = Number(target.textContent)\n const pageCount = props.pageCount!\n const currentPage = props.currentPage\n const pagerCountOffset = props.pagerCount - 2\n if (target.className.includes('more')) {\n if (target.className.includes('quickprev')) {\n newPage = currentPage - pagerCountOffset\n } else if (target.className.includes('quicknext')) {\n newPage = currentPage + pagerCountOffset\n }\n }\n if (!Number.isNaN(+newPage)) {\n if (newPage < 1) {\n newPage = 1\n }\n if (newPage > pageCount) {\n newPage = pageCount\n }\n }\n if (newPage !== currentPage) {\n emit('change', newPage)\n }\n}\n</script>\n"],"names":["showPrevMore","showNextMore"],"mappings":"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"}