@element-plus/nightly 0.0.20240825 → 0.0.20240826

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 (371) hide show
  1. package/dist/index.full.js +2 -7
  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 -7
  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/my.js +1 -1
  152. package/dist/locale/my.min.js +1 -1
  153. package/dist/locale/my.min.mjs +1 -1
  154. package/dist/locale/my.mjs +1 -1
  155. package/dist/locale/nb-no.js +1 -1
  156. package/dist/locale/nb-no.min.js +1 -1
  157. package/dist/locale/nb-no.min.mjs +1 -1
  158. package/dist/locale/nb-no.mjs +1 -1
  159. package/dist/locale/nl.js +1 -1
  160. package/dist/locale/nl.min.js +1 -1
  161. package/dist/locale/nl.min.mjs +1 -1
  162. package/dist/locale/nl.mjs +1 -1
  163. package/dist/locale/pa.js +1 -1
  164. package/dist/locale/pa.min.js +1 -1
  165. package/dist/locale/pa.min.mjs +1 -1
  166. package/dist/locale/pa.mjs +1 -1
  167. package/dist/locale/pl.js +1 -1
  168. package/dist/locale/pl.min.js +1 -1
  169. package/dist/locale/pl.min.mjs +1 -1
  170. package/dist/locale/pl.mjs +1 -1
  171. package/dist/locale/pt-br.js +1 -1
  172. package/dist/locale/pt-br.min.js +1 -1
  173. package/dist/locale/pt-br.min.mjs +1 -1
  174. package/dist/locale/pt-br.mjs +1 -1
  175. package/dist/locale/pt.js +1 -1
  176. package/dist/locale/pt.min.js +1 -1
  177. package/dist/locale/pt.min.mjs +1 -1
  178. package/dist/locale/pt.mjs +1 -1
  179. package/dist/locale/ro.js +1 -1
  180. package/dist/locale/ro.min.js +1 -1
  181. package/dist/locale/ro.min.mjs +1 -1
  182. package/dist/locale/ro.mjs +1 -1
  183. package/dist/locale/ru.js +1 -1
  184. package/dist/locale/ru.min.js +1 -1
  185. package/dist/locale/ru.min.mjs +1 -1
  186. package/dist/locale/ru.mjs +1 -1
  187. package/dist/locale/sk.js +1 -1
  188. package/dist/locale/sk.min.js +1 -1
  189. package/dist/locale/sk.min.mjs +1 -1
  190. package/dist/locale/sk.mjs +1 -1
  191. package/dist/locale/sl.js +1 -1
  192. package/dist/locale/sl.min.js +1 -1
  193. package/dist/locale/sl.min.mjs +1 -1
  194. package/dist/locale/sl.mjs +1 -1
  195. package/dist/locale/sr.js +1 -1
  196. package/dist/locale/sr.min.js +1 -1
  197. package/dist/locale/sr.min.mjs +1 -1
  198. package/dist/locale/sr.mjs +1 -1
  199. package/dist/locale/sv.js +1 -1
  200. package/dist/locale/sv.min.js +1 -1
  201. package/dist/locale/sv.min.mjs +1 -1
  202. package/dist/locale/sv.mjs +1 -1
  203. package/dist/locale/sw.js +1 -1
  204. package/dist/locale/sw.min.js +1 -1
  205. package/dist/locale/sw.min.mjs +1 -1
  206. package/dist/locale/sw.mjs +1 -1
  207. package/dist/locale/ta.js +1 -1
  208. package/dist/locale/ta.min.js +1 -1
  209. package/dist/locale/ta.min.mjs +1 -1
  210. package/dist/locale/ta.mjs +1 -1
  211. package/dist/locale/th.js +1 -1
  212. package/dist/locale/th.min.js +1 -1
  213. package/dist/locale/th.min.mjs +1 -1
  214. package/dist/locale/th.mjs +1 -1
  215. package/dist/locale/tk.js +1 -1
  216. package/dist/locale/tk.min.js +1 -1
  217. package/dist/locale/tk.min.mjs +1 -1
  218. package/dist/locale/tk.mjs +1 -1
  219. package/dist/locale/tr.js +1 -1
  220. package/dist/locale/tr.min.js +1 -1
  221. package/dist/locale/tr.min.mjs +1 -1
  222. package/dist/locale/tr.mjs +1 -1
  223. package/dist/locale/ug-cn.js +1 -1
  224. package/dist/locale/ug-cn.min.js +1 -1
  225. package/dist/locale/ug-cn.min.mjs +1 -1
  226. package/dist/locale/ug-cn.mjs +1 -1
  227. package/dist/locale/uk.js +1 -1
  228. package/dist/locale/uk.min.js +1 -1
  229. package/dist/locale/uk.min.mjs +1 -1
  230. package/dist/locale/uk.mjs +1 -1
  231. package/dist/locale/uz-uz.js +1 -1
  232. package/dist/locale/uz-uz.min.js +1 -1
  233. package/dist/locale/uz-uz.min.mjs +1 -1
  234. package/dist/locale/uz-uz.mjs +1 -1
  235. package/dist/locale/vi.js +1 -1
  236. package/dist/locale/vi.min.js +1 -1
  237. package/dist/locale/vi.min.mjs +1 -1
  238. package/dist/locale/vi.mjs +1 -1
  239. package/dist/locale/zh-cn.js +1 -1
  240. package/dist/locale/zh-cn.min.js +1 -1
  241. package/dist/locale/zh-cn.min.mjs +1 -1
  242. package/dist/locale/zh-cn.mjs +1 -1
  243. package/dist/locale/zh-tw.js +1 -1
  244. package/dist/locale/zh-tw.min.js +1 -1
  245. package/dist/locale/zh-tw.min.mjs +1 -1
  246. package/dist/locale/zh-tw.mjs +1 -1
  247. package/es/components/autocomplete/src/autocomplete.vue.d.ts +3 -3
  248. package/es/components/breadcrumb/index.mjs +2 -2
  249. package/es/components/breadcrumb/src/breadcrumb.mjs +11 -38
  250. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  251. package/es/components/breadcrumb/src/breadcrumb2.mjs +38 -11
  252. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  253. package/es/components/checkbox/index.mjs +2 -2
  254. package/es/components/checkbox/src/checkbox-group.mjs +30 -73
  255. package/es/components/checkbox/src/checkbox-group.mjs.map +1 -1
  256. package/es/components/checkbox/src/checkbox-group2.mjs +73 -30
  257. package/es/components/checkbox/src/checkbox-group2.mjs.map +1 -1
  258. package/es/components/date-picker/src/date-picker.d.ts +1 -1
  259. package/es/components/dropdown/src/dropdown.vue.d.ts +1 -1
  260. package/es/components/form/index.mjs +2 -2
  261. package/es/components/form/src/form.mjs +54 -153
  262. package/es/components/form/src/form.mjs.map +1 -1
  263. package/es/components/form/src/form2.mjs +153 -54
  264. package/es/components/form/src/form2.mjs.map +1 -1
  265. package/es/components/image/index.mjs +2 -2
  266. package/es/components/image/src/image.mjs +64 -233
  267. package/es/components/image/src/image.mjs.map +1 -1
  268. package/es/components/image/src/image2.mjs +233 -64
  269. package/es/components/image/src/image2.mjs.map +1 -1
  270. package/es/components/index.mjs +8 -8
  271. package/es/components/input/src/input.vue.d.ts +1 -1
  272. package/es/components/input-number/index.mjs +2 -2
  273. package/es/components/input-number/src/input-number.mjs +60 -329
  274. package/es/components/input-number/src/input-number.mjs.map +1 -1
  275. package/es/components/input-number/src/input-number2.mjs +329 -60
  276. package/es/components/input-number/src/input-number2.mjs.map +1 -1
  277. package/es/components/mention/src/mention-dropdown.mjs +15 -167
  278. package/es/components/mention/src/mention-dropdown.mjs.map +1 -1
  279. package/es/components/mention/src/mention-dropdown2.mjs +167 -15
  280. package/es/components/mention/src/mention-dropdown2.mjs.map +1 -1
  281. package/es/components/mention/src/mention.vue.d.ts +4 -4
  282. package/es/components/mention/src/mention2.mjs +1 -1
  283. package/es/components/popover/index.mjs +2 -2
  284. package/es/components/popover/src/popover.mjs +111 -66
  285. package/es/components/popover/src/popover.mjs.map +1 -1
  286. package/es/components/popover/src/popover.vue.d.ts +1 -1
  287. package/es/components/popover/src/popover2.mjs +66 -111
  288. package/es/components/popover/src/popover2.mjs.map +1 -1
  289. package/es/components/tabs/index.mjs +1 -1
  290. package/es/components/tabs/src/tab-bar.mjs +73 -7
  291. package/es/components/tabs/src/tab-bar.mjs.map +1 -1
  292. package/es/components/tabs/src/tab-bar2.mjs +7 -73
  293. package/es/components/tabs/src/tab-bar2.mjs.map +1 -1
  294. package/es/components/tabs/src/tab-nav.mjs +1 -1
  295. package/es/components/time-picker/src/common/picker.vue.d.ts +1 -1
  296. package/es/components/time-picker/src/time-picker.d.ts +1 -1
  297. package/es/components/watermark/index.mjs +2 -2
  298. package/es/components/watermark/src/watermark.mjs +209 -28
  299. package/es/components/watermark/src/watermark.mjs.map +1 -1
  300. package/es/components/watermark/src/watermark2.mjs +28 -209
  301. package/es/components/watermark/src/watermark2.mjs.map +1 -1
  302. package/es/hooks/use-focus-controller/index.mjs +1 -6
  303. package/es/hooks/use-focus-controller/index.mjs.map +1 -1
  304. package/es/index.mjs +8 -8
  305. package/es/version.d.ts +1 -1
  306. package/es/version.mjs +1 -1
  307. package/es/version.mjs.map +1 -1
  308. package/global.d.ts +1 -0
  309. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +3 -3
  310. package/lib/components/breadcrumb/index.js +2 -2
  311. package/lib/components/breadcrumb/src/breadcrumb.js +11 -38
  312. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  313. package/lib/components/breadcrumb/src/breadcrumb2.js +38 -11
  314. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  315. package/lib/components/checkbox/index.js +2 -2
  316. package/lib/components/checkbox/src/checkbox-group.js +31 -73
  317. package/lib/components/checkbox/src/checkbox-group.js.map +1 -1
  318. package/lib/components/checkbox/src/checkbox-group2.js +73 -31
  319. package/lib/components/checkbox/src/checkbox-group2.js.map +1 -1
  320. package/lib/components/date-picker/src/date-picker.d.ts +1 -1
  321. package/lib/components/dropdown/src/dropdown.vue.d.ts +1 -1
  322. package/lib/components/form/index.js +2 -2
  323. package/lib/components/form/src/form.js +55 -152
  324. package/lib/components/form/src/form.js.map +1 -1
  325. package/lib/components/form/src/form2.js +152 -55
  326. package/lib/components/form/src/form2.js.map +1 -1
  327. package/lib/components/image/index.js +2 -2
  328. package/lib/components/image/src/image.js +64 -232
  329. package/lib/components/image/src/image.js.map +1 -1
  330. package/lib/components/image/src/image2.js +232 -64
  331. package/lib/components/image/src/image2.js.map +1 -1
  332. package/lib/components/index.js +8 -8
  333. package/lib/components/input/src/input.vue.d.ts +1 -1
  334. package/lib/components/input-number/index.js +2 -2
  335. package/lib/components/input-number/src/input-number.js +59 -327
  336. package/lib/components/input-number/src/input-number.js.map +1 -1
  337. package/lib/components/input-number/src/input-number2.js +327 -59
  338. package/lib/components/input-number/src/input-number2.js.map +1 -1
  339. package/lib/components/mention/src/mention-dropdown.js +16 -167
  340. package/lib/components/mention/src/mention-dropdown.js.map +1 -1
  341. package/lib/components/mention/src/mention-dropdown2.js +167 -16
  342. package/lib/components/mention/src/mention-dropdown2.js.map +1 -1
  343. package/lib/components/mention/src/mention.vue.d.ts +4 -4
  344. package/lib/components/mention/src/mention2.js +1 -1
  345. package/lib/components/popover/index.js +2 -2
  346. package/lib/components/popover/src/popover.js +111 -67
  347. package/lib/components/popover/src/popover.js.map +1 -1
  348. package/lib/components/popover/src/popover.vue.d.ts +1 -1
  349. package/lib/components/popover/src/popover2.js +67 -111
  350. package/lib/components/popover/src/popover2.js.map +1 -1
  351. package/lib/components/tabs/index.js +1 -1
  352. package/lib/components/tabs/src/tab-bar.js +73 -7
  353. package/lib/components/tabs/src/tab-bar.js.map +1 -1
  354. package/lib/components/tabs/src/tab-bar2.js +7 -73
  355. package/lib/components/tabs/src/tab-bar2.js.map +1 -1
  356. package/lib/components/tabs/src/tab-nav.js +1 -1
  357. package/lib/components/time-picker/src/common/picker.vue.d.ts +1 -1
  358. package/lib/components/time-picker/src/time-picker.d.ts +1 -1
  359. package/lib/components/watermark/index.js +2 -2
  360. package/lib/components/watermark/src/watermark.js +209 -28
  361. package/lib/components/watermark/src/watermark.js.map +1 -1
  362. package/lib/components/watermark/src/watermark2.js +28 -209
  363. package/lib/components/watermark/src/watermark2.js.map +1 -1
  364. package/lib/hooks/use-focus-controller/index.js +0 -5
  365. package/lib/hooks/use-focus-controller/index.js.map +1 -1
  366. package/lib/index.js +8 -8
  367. package/lib/version.d.ts +1 -1
  368. package/lib/version.js +1 -1
  369. package/lib/version.js.map +1 -1
  370. package/package.json +2 -2
  371. package/web-types.json +1 -1
@@ -2,72 +2,340 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var vue = require('vue');
5
6
  var lodashUnified = require('lodash-unified');
7
+ var index$4 = require('../../input/index.js');
8
+ var index$2 = require('../../icon/index.js');
9
+ require('../../form/index.js');
10
+ require('../../../directives/index.js');
6
11
  require('../../../hooks/index.js');
7
12
  require('../../../utils/index.js');
13
+ var iconsVue = require('@element-plus/icons-vue');
8
14
  require('../../../constants/index.js');
9
- var runtime = require('../../../utils/vue/props/runtime.js');
10
- var index = require('../../../hooks/use-size/index.js');
15
+ var inputNumber = require('./input-number.js');
16
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
17
+ var index = require('../../../hooks/use-locale/index.js');
18
+ var index$1 = require('../../../hooks/use-namespace/index.js');
19
+ var useFormItem = require('../../form/src/hooks/use-form-item.js');
11
20
  var types = require('../../../utils/types.js');
12
- var index$1 = require('../../../hooks/use-aria/index.js');
21
+ var error = require('../../../utils/error.js');
22
+ var useFormCommonProps = require('../../form/src/hooks/use-form-common-props.js');
13
23
  var event = require('../../../constants/event.js');
24
+ var shared = require('@vue/shared');
25
+ var index$3 = require('../../../directives/repeat-click/index.js');
14
26
 
15
- const inputNumberProps = runtime.buildProps({
16
- id: {
17
- type: String,
18
- default: void 0
19
- },
20
- step: {
21
- type: Number,
22
- default: 1
23
- },
24
- stepStrictly: Boolean,
25
- max: {
26
- type: Number,
27
- default: Number.POSITIVE_INFINITY
28
- },
29
- min: {
30
- type: Number,
31
- default: Number.NEGATIVE_INFINITY
32
- },
33
- modelValue: Number,
34
- readonly: Boolean,
35
- disabled: Boolean,
36
- size: index.useSizeProp,
37
- controls: {
38
- type: Boolean,
39
- default: true
40
- },
41
- controlsPosition: {
42
- type: String,
43
- default: "",
44
- values: ["", "right"]
45
- },
46
- valueOnClear: {
47
- type: [String, Number, null],
48
- validator: (val) => val === null || types.isNumber(val) || ["min", "max"].includes(val),
49
- default: null
50
- },
51
- name: String,
52
- placeholder: String,
53
- precision: {
54
- type: Number,
55
- validator: (val) => val >= 0 && val === Number.parseInt(`${val}`, 10)
56
- },
57
- validateEvent: {
58
- type: Boolean,
59
- default: true
60
- },
61
- ...index$1.useAriaProps(["ariaLabel"])
27
+ const __default__ = vue.defineComponent({
28
+ name: "ElInputNumber"
62
29
  });
63
- const inputNumberEmits = {
64
- [event.CHANGE_EVENT]: (cur, prev) => prev !== cur,
65
- blur: (e) => e instanceof FocusEvent,
66
- focus: (e) => e instanceof FocusEvent,
67
- [event.INPUT_EVENT]: (val) => types.isNumber(val) || lodashUnified.isNil(val),
68
- [event.UPDATE_MODEL_EVENT]: (val) => types.isNumber(val) || lodashUnified.isNil(val)
69
- };
30
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
31
+ ...__default__,
32
+ props: inputNumber.inputNumberProps,
33
+ emits: inputNumber.inputNumberEmits,
34
+ setup(__props, { expose, emit }) {
35
+ const props = __props;
36
+ const { t } = index.useLocale();
37
+ const ns = index$1.useNamespace("input-number");
38
+ const input = vue.ref();
39
+ const data = vue.reactive({
40
+ currentValue: props.modelValue,
41
+ userInput: null
42
+ });
43
+ const { formItem } = useFormItem.useFormItem();
44
+ const minDisabled = vue.computed(() => types.isNumber(props.modelValue) && props.modelValue <= props.min);
45
+ const maxDisabled = vue.computed(() => types.isNumber(props.modelValue) && props.modelValue >= props.max);
46
+ const numPrecision = vue.computed(() => {
47
+ const stepPrecision = getPrecision(props.step);
48
+ if (!types.isUndefined(props.precision)) {
49
+ if (stepPrecision > props.precision) {
50
+ error.debugWarn("InputNumber", "precision should not be less than the decimal places of step");
51
+ }
52
+ return props.precision;
53
+ } else {
54
+ return Math.max(getPrecision(props.modelValue), stepPrecision);
55
+ }
56
+ });
57
+ const controlsAtRight = vue.computed(() => {
58
+ return props.controls && props.controlsPosition === "right";
59
+ });
60
+ const inputNumberSize = useFormCommonProps.useFormSize();
61
+ const inputNumberDisabled = useFormCommonProps.useFormDisabled();
62
+ const displayValue = vue.computed(() => {
63
+ if (data.userInput !== null) {
64
+ return data.userInput;
65
+ }
66
+ let currentValue = data.currentValue;
67
+ if (lodashUnified.isNil(currentValue))
68
+ return "";
69
+ if (types.isNumber(currentValue)) {
70
+ if (Number.isNaN(currentValue))
71
+ return "";
72
+ if (!types.isUndefined(props.precision)) {
73
+ currentValue = currentValue.toFixed(props.precision);
74
+ }
75
+ }
76
+ return currentValue;
77
+ });
78
+ const toPrecision = (num, pre) => {
79
+ if (types.isUndefined(pre))
80
+ pre = numPrecision.value;
81
+ if (pre === 0)
82
+ return Math.round(num);
83
+ let snum = String(num);
84
+ const pointPos = snum.indexOf(".");
85
+ if (pointPos === -1)
86
+ return num;
87
+ const nums = snum.replace(".", "").split("");
88
+ const datum = nums[pointPos + pre];
89
+ if (!datum)
90
+ return num;
91
+ const length = snum.length;
92
+ if (snum.charAt(length - 1) === "5") {
93
+ snum = `${snum.slice(0, Math.max(0, length - 1))}6`;
94
+ }
95
+ return Number.parseFloat(Number(snum).toFixed(pre));
96
+ };
97
+ const getPrecision = (value) => {
98
+ if (lodashUnified.isNil(value))
99
+ return 0;
100
+ const valueString = value.toString();
101
+ const dotPosition = valueString.indexOf(".");
102
+ let precision = 0;
103
+ if (dotPosition !== -1) {
104
+ precision = valueString.length - dotPosition - 1;
105
+ }
106
+ return precision;
107
+ };
108
+ const ensurePrecision = (val, coefficient = 1) => {
109
+ if (!types.isNumber(val))
110
+ return data.currentValue;
111
+ return toPrecision(val + props.step * coefficient);
112
+ };
113
+ const increase = () => {
114
+ if (props.readonly || inputNumberDisabled.value || maxDisabled.value)
115
+ return;
116
+ const value = Number(displayValue.value) || 0;
117
+ const newVal = ensurePrecision(value);
118
+ setCurrentValue(newVal);
119
+ emit(event.INPUT_EVENT, data.currentValue);
120
+ setCurrentValueToModelValue();
121
+ };
122
+ const decrease = () => {
123
+ if (props.readonly || inputNumberDisabled.value || minDisabled.value)
124
+ return;
125
+ const value = Number(displayValue.value) || 0;
126
+ const newVal = ensurePrecision(value, -1);
127
+ setCurrentValue(newVal);
128
+ emit(event.INPUT_EVENT, data.currentValue);
129
+ setCurrentValueToModelValue();
130
+ };
131
+ const verifyValue = (value, update) => {
132
+ const { max, min, step, precision, stepStrictly, valueOnClear } = props;
133
+ if (max < min) {
134
+ error.throwError("InputNumber", "min should not be greater than max.");
135
+ }
136
+ let newVal = Number(value);
137
+ if (lodashUnified.isNil(value) || Number.isNaN(newVal)) {
138
+ return null;
139
+ }
140
+ if (value === "") {
141
+ if (valueOnClear === null) {
142
+ return null;
143
+ }
144
+ newVal = shared.isString(valueOnClear) ? { min, max }[valueOnClear] : valueOnClear;
145
+ }
146
+ if (stepStrictly) {
147
+ newVal = toPrecision(Math.round(newVal / step) * step, precision);
148
+ }
149
+ if (!types.isUndefined(precision)) {
150
+ newVal = toPrecision(newVal, precision);
151
+ }
152
+ if (newVal > max || newVal < min) {
153
+ newVal = newVal > max ? max : min;
154
+ update && emit(event.UPDATE_MODEL_EVENT, newVal);
155
+ }
156
+ return newVal;
157
+ };
158
+ const setCurrentValue = (value, emitChange = true) => {
159
+ var _a;
160
+ const oldVal = data.currentValue;
161
+ const newVal = verifyValue(value);
162
+ if (!emitChange) {
163
+ emit(event.UPDATE_MODEL_EVENT, newVal);
164
+ return;
165
+ }
166
+ if (oldVal === newVal && value)
167
+ return;
168
+ data.userInput = null;
169
+ emit(event.UPDATE_MODEL_EVENT, newVal);
170
+ if (oldVal !== newVal) {
171
+ emit(event.CHANGE_EVENT, newVal, oldVal);
172
+ }
173
+ if (props.validateEvent) {
174
+ (_a = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a.call(formItem, "change").catch((err) => error.debugWarn(err));
175
+ }
176
+ data.currentValue = newVal;
177
+ };
178
+ const handleInput = (value) => {
179
+ data.userInput = value;
180
+ const newVal = value === "" ? null : Number(value);
181
+ emit(event.INPUT_EVENT, newVal);
182
+ setCurrentValue(newVal, false);
183
+ };
184
+ const handleInputChange = (value) => {
185
+ const newVal = value !== "" ? Number(value) : "";
186
+ if (types.isNumber(newVal) && !Number.isNaN(newVal) || value === "") {
187
+ setCurrentValue(newVal);
188
+ }
189
+ setCurrentValueToModelValue();
190
+ data.userInput = null;
191
+ };
192
+ const focus = () => {
193
+ var _a, _b;
194
+ (_b = (_a = input.value) == null ? void 0 : _a.focus) == null ? void 0 : _b.call(_a);
195
+ };
196
+ const blur = () => {
197
+ var _a, _b;
198
+ (_b = (_a = input.value) == null ? void 0 : _a.blur) == null ? void 0 : _b.call(_a);
199
+ };
200
+ const handleFocus = (event) => {
201
+ emit("focus", event);
202
+ };
203
+ const handleBlur = (event) => {
204
+ var _a;
205
+ data.userInput = null;
206
+ emit("blur", event);
207
+ if (props.validateEvent) {
208
+ (_a = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a.call(formItem, "blur").catch((err) => error.debugWarn(err));
209
+ }
210
+ };
211
+ const setCurrentValueToModelValue = () => {
212
+ if (data.currentValue !== props.modelValue) {
213
+ data.currentValue = props.modelValue;
214
+ }
215
+ };
216
+ const handleWheel = (e) => {
217
+ if (document.activeElement === e.target)
218
+ e.preventDefault();
219
+ };
220
+ vue.watch(() => props.modelValue, (value, oldValue) => {
221
+ const newValue = verifyValue(value, true);
222
+ if (data.userInput === null && newValue !== oldValue) {
223
+ data.currentValue = newValue;
224
+ }
225
+ }, { immediate: true });
226
+ vue.onMounted(() => {
227
+ var _a;
228
+ const { min, max, modelValue } = props;
229
+ const innerInput = (_a = input.value) == null ? void 0 : _a.input;
230
+ innerInput.setAttribute("role", "spinbutton");
231
+ if (Number.isFinite(max)) {
232
+ innerInput.setAttribute("aria-valuemax", String(max));
233
+ } else {
234
+ innerInput.removeAttribute("aria-valuemax");
235
+ }
236
+ if (Number.isFinite(min)) {
237
+ innerInput.setAttribute("aria-valuemin", String(min));
238
+ } else {
239
+ innerInput.removeAttribute("aria-valuemin");
240
+ }
241
+ innerInput.setAttribute("aria-valuenow", data.currentValue || data.currentValue === 0 ? String(data.currentValue) : "");
242
+ innerInput.setAttribute("aria-disabled", String(inputNumberDisabled.value));
243
+ if (!types.isNumber(modelValue) && modelValue != null) {
244
+ let val = Number(modelValue);
245
+ if (Number.isNaN(val)) {
246
+ val = null;
247
+ }
248
+ emit(event.UPDATE_MODEL_EVENT, val);
249
+ }
250
+ innerInput.addEventListener("wheel", handleWheel, { passive: false });
251
+ });
252
+ vue.onUpdated(() => {
253
+ var _a, _b;
254
+ const innerInput = (_a = input.value) == null ? void 0 : _a.input;
255
+ innerInput == null ? void 0 : innerInput.setAttribute("aria-valuenow", `${(_b = data.currentValue) != null ? _b : ""}`);
256
+ });
257
+ expose({
258
+ focus,
259
+ blur
260
+ });
261
+ return (_ctx, _cache) => {
262
+ return vue.openBlock(), vue.createElementBlock("div", {
263
+ class: vue.normalizeClass([
264
+ vue.unref(ns).b(),
265
+ vue.unref(ns).m(vue.unref(inputNumberSize)),
266
+ vue.unref(ns).is("disabled", vue.unref(inputNumberDisabled)),
267
+ vue.unref(ns).is("without-controls", !_ctx.controls),
268
+ vue.unref(ns).is("controls-right", vue.unref(controlsAtRight))
269
+ ]),
270
+ onDragstart: vue.withModifiers(() => {
271
+ }, ["prevent"])
272
+ }, [
273
+ _ctx.controls ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("span", {
274
+ key: 0,
275
+ role: "button",
276
+ "aria-label": vue.unref(t)("el.inputNumber.decrease"),
277
+ class: vue.normalizeClass([vue.unref(ns).e("decrease"), vue.unref(ns).is("disabled", vue.unref(minDisabled))]),
278
+ onKeydown: vue.withKeys(decrease, ["enter"])
279
+ }, [
280
+ vue.renderSlot(_ctx.$slots, "decrease-icon", {}, () => [
281
+ vue.createVNode(vue.unref(index$2.ElIcon), null, {
282
+ default: vue.withCtx(() => [
283
+ vue.unref(controlsAtRight) ? (vue.openBlock(), vue.createBlock(vue.unref(iconsVue.ArrowDown), { key: 0 })) : (vue.openBlock(), vue.createBlock(vue.unref(iconsVue.Minus), { key: 1 }))
284
+ ]),
285
+ _: 1
286
+ })
287
+ ])
288
+ ], 42, ["aria-label", "onKeydown"])), [
289
+ [vue.unref(index$3.vRepeatClick), decrease]
290
+ ]) : vue.createCommentVNode("v-if", true),
291
+ _ctx.controls ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("span", {
292
+ key: 1,
293
+ role: "button",
294
+ "aria-label": vue.unref(t)("el.inputNumber.increase"),
295
+ class: vue.normalizeClass([vue.unref(ns).e("increase"), vue.unref(ns).is("disabled", vue.unref(maxDisabled))]),
296
+ onKeydown: vue.withKeys(increase, ["enter"])
297
+ }, [
298
+ vue.renderSlot(_ctx.$slots, "increase-icon", {}, () => [
299
+ vue.createVNode(vue.unref(index$2.ElIcon), null, {
300
+ default: vue.withCtx(() => [
301
+ vue.unref(controlsAtRight) ? (vue.openBlock(), vue.createBlock(vue.unref(iconsVue.ArrowUp), { key: 0 })) : (vue.openBlock(), vue.createBlock(vue.unref(iconsVue.Plus), { key: 1 }))
302
+ ]),
303
+ _: 1
304
+ })
305
+ ])
306
+ ], 42, ["aria-label", "onKeydown"])), [
307
+ [vue.unref(index$3.vRepeatClick), increase]
308
+ ]) : vue.createCommentVNode("v-if", true),
309
+ vue.createVNode(vue.unref(index$4.ElInput), {
310
+ id: _ctx.id,
311
+ ref_key: "input",
312
+ ref: input,
313
+ type: "number",
314
+ step: _ctx.step,
315
+ "model-value": vue.unref(displayValue),
316
+ placeholder: _ctx.placeholder,
317
+ readonly: _ctx.readonly,
318
+ disabled: vue.unref(inputNumberDisabled),
319
+ size: vue.unref(inputNumberSize),
320
+ max: _ctx.max,
321
+ min: _ctx.min,
322
+ name: _ctx.name,
323
+ "aria-label": _ctx.ariaLabel,
324
+ "validate-event": false,
325
+ onKeydown: [
326
+ vue.withKeys(vue.withModifiers(increase, ["prevent"]), ["up"]),
327
+ vue.withKeys(vue.withModifiers(decrease, ["prevent"]), ["down"])
328
+ ],
329
+ onBlur: handleBlur,
330
+ onFocus: handleFocus,
331
+ onInput: handleInput,
332
+ onChange: handleInputChange
333
+ }, null, 8, ["id", "step", "model-value", "placeholder", "readonly", "disabled", "size", "max", "min", "name", "aria-label", "onKeydown"])
334
+ ], 42, ["onDragstart"]);
335
+ };
336
+ }
337
+ });
338
+ var InputNumber = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "input-number.vue"]]);
70
339
 
71
- exports.inputNumberEmits = inputNumberEmits;
72
- exports.inputNumberProps = inputNumberProps;
340
+ exports["default"] = InputNumber;
73
341
  //# sourceMappingURL=input-number2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"input-number2.js","sources":["../../../../../../packages/components/input-number/src/input-number.ts"],"sourcesContent":["import { isNil } from 'lodash-unified'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { buildProps, isNumber } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type InputNumber from './input-number.vue'\n\nexport const inputNumberProps = buildProps({\n /**\n * @description same as `id` in native input\n */\n id: {\n type: String,\n default: undefined,\n },\n /**\n * @description incremental step\n */\n step: {\n type: Number,\n default: 1,\n },\n /**\n * @description whether input value can only be multiple of step\n */\n stepStrictly: Boolean,\n /**\n * @description the maximum allowed value\n */\n max: {\n type: Number,\n default: Number.POSITIVE_INFINITY,\n },\n /**\n * @description the minimum allowed value\n */\n min: {\n type: Number,\n default: Number.NEGATIVE_INFINITY,\n },\n /**\n * @description binding value\n */\n modelValue: Number,\n /**\n * @description same as `readonly` in native input\n */\n readonly: Boolean,\n /**\n * @description whether the component is disabled\n */\n disabled: Boolean,\n /**\n * @description size of the component\n */\n size: useSizeProp,\n /**\n * @description whether to enable the control buttons\n */\n controls: {\n type: Boolean,\n default: true,\n },\n /**\n * @description position of the control buttons\n */\n controlsPosition: {\n type: String,\n default: '',\n values: ['', 'right'],\n },\n /**\n * @description value should be set when input box is cleared\n */\n valueOnClear: {\n type: [String, Number, null],\n validator: (val: 'min' | 'max' | number | null) =>\n val === null || isNumber(val) || ['min', 'max'].includes(val),\n default: null,\n },\n /**\n * @description same as `name` in native input\n */\n name: String,\n /**\n * @description same as `placeholder` in native input\n */\n placeholder: String,\n /**\n * @description precision of input value\n */\n precision: {\n type: Number,\n validator: (val: number) =>\n val >= 0 && val === Number.parseInt(`${val}`, 10),\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n ...useAriaProps(['ariaLabel']),\n} as const)\nexport type InputNumberProps = ExtractPropTypes<typeof inputNumberProps>\n\nexport const inputNumberEmits = {\n [CHANGE_EVENT]: (cur: number | undefined, prev: number | undefined) =>\n prev !== cur,\n blur: (e: FocusEvent) => e instanceof FocusEvent,\n focus: (e: FocusEvent) => e instanceof FocusEvent,\n [INPUT_EVENT]: (val: number | null | undefined) =>\n isNumber(val) || isNil(val),\n [UPDATE_MODEL_EVENT]: (val: number | undefined) =>\n isNumber(val) || isNil(val),\n}\nexport type InputNumberEmits = typeof inputNumberEmits\n\nexport type InputNumberInstance = InstanceType<typeof InputNumber>\n"],"names":["buildProps","useSizeProp","isNumber","useAriaProps","CHANGE_EVENT","INPUT_EVENT","isNil","UPDATE_MODEL_EVENT"],"mappings":";;;;;;;;;;;;;;AAQY,MAAC,gBAAgB,GAAGA,kBAAU,CAAC;AAC3C,EAAE,EAAE,EAAE;AACN,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,KAAK,CAAC;AACnB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,YAAY,EAAE,OAAO;AACvB,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,MAAM,CAAC,iBAAiB;AACrC,GAAG;AACH,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,MAAM,CAAC,iBAAiB;AACrC,GAAG;AACH,EAAE,UAAU,EAAE,MAAM;AACpB,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,IAAI,EAAEC,iBAAW;AACnB,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,gBAAgB,EAAE;AACpB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,IAAI,MAAM,EAAE,CAAC,EAAE,EAAE,OAAO,CAAC;AACzB,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC;AAChC,IAAI,SAAS,EAAE,CAAC,GAAG,KAAK,GAAG,KAAK,IAAI,IAAIC,cAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC;AACrF,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE,MAAM;AACd,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,SAAS,EAAE,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC;AACzE,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,GAAGC,oBAAY,CAAC,CAAC,WAAW,CAAC,CAAC;AAChC,CAAC,EAAE;AACS,MAAC,gBAAgB,GAAG;AAChC,EAAE,CAACC,kBAAY,GAAG,CAAC,GAAG,EAAE,IAAI,KAAK,IAAI,KAAK,GAAG;AAC7C,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,YAAY,UAAU;AACtC,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,YAAY,UAAU;AACvC,EAAE,CAACC,iBAAW,GAAG,CAAC,GAAG,KAAKH,cAAQ,CAAC,GAAG,CAAC,IAAII,mBAAK,CAAC,GAAG,CAAC;AACrD,EAAE,CAACC,wBAAkB,GAAG,CAAC,GAAG,KAAKL,cAAQ,CAAC,GAAG,CAAC,IAAII,mBAAK,CAAC,GAAG,CAAC;AAC5D;;;;;"}
1
+ {"version":3,"file":"input-number2.js","sources":["../../../../../../packages/components/input-number/src/input-number.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ns.b(),\n ns.m(inputNumberSize),\n ns.is('disabled', inputNumberDisabled),\n ns.is('without-controls', !controls),\n ns.is('controls-right', controlsAtRight),\n ]\"\n @dragstart.prevent\n >\n <span\n v-if=\"controls\"\n v-repeat-click=\"decrease\"\n role=\"button\"\n :aria-label=\"t('el.inputNumber.decrease')\"\n :class=\"[ns.e('decrease'), ns.is('disabled', minDisabled)]\"\n @keydown.enter=\"decrease\"\n >\n <slot name=\"decrease-icon\">\n <el-icon>\n <arrow-down v-if=\"controlsAtRight\" />\n <minus v-else />\n </el-icon>\n </slot>\n </span>\n <span\n v-if=\"controls\"\n v-repeat-click=\"increase\"\n role=\"button\"\n :aria-label=\"t('el.inputNumber.increase')\"\n :class=\"[ns.e('increase'), ns.is('disabled', maxDisabled)]\"\n @keydown.enter=\"increase\"\n >\n <slot name=\"increase-icon\">\n <el-icon>\n <arrow-up v-if=\"controlsAtRight\" />\n <plus v-else />\n </el-icon>\n </slot>\n </span>\n <el-input\n :id=\"id\"\n ref=\"input\"\n type=\"number\"\n :step=\"step\"\n :model-value=\"displayValue\"\n :placeholder=\"placeholder\"\n :readonly=\"readonly\"\n :disabled=\"inputNumberDisabled\"\n :size=\"inputNumberSize\"\n :max=\"max\"\n :min=\"min\"\n :name=\"name\"\n :aria-label=\"ariaLabel\"\n :validate-event=\"false\"\n @keydown.up.prevent=\"increase\"\n @keydown.down.prevent=\"decrease\"\n @blur=\"handleBlur\"\n @focus=\"handleFocus\"\n @input=\"handleInput\"\n @change=\"handleInputChange\"\n />\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, onMounted, onUpdated, reactive, ref, watch } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { ElInput } from '@element-plus/components/input'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { vRepeatClick } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport {\n debugWarn,\n isNumber,\n isString,\n isUndefined,\n throwError,\n} from '@element-plus/utils'\nimport { ArrowDown, ArrowUp, Minus, Plus } from '@element-plus/icons-vue'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputNumberEmits, inputNumberProps } from './input-number'\n\nimport type { InputInstance } from '@element-plus/components/input'\n\ndefineOptions({\n name: 'ElInputNumber',\n})\n\nconst props = defineProps(inputNumberProps)\nconst emit = defineEmits(inputNumberEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('input-number')\nconst input = ref<InputInstance>()\n\ninterface Data {\n currentValue: number | null | undefined\n userInput: null | number | string\n}\nconst data = reactive<Data>({\n currentValue: props.modelValue,\n userInput: null,\n})\n\nconst { formItem } = useFormItem()\n\nconst minDisabled = computed(\n () => isNumber(props.modelValue) && props.modelValue <= props.min\n)\nconst maxDisabled = computed(\n () => isNumber(props.modelValue) && props.modelValue >= props.max\n)\n\nconst numPrecision = computed(() => {\n const stepPrecision = getPrecision(props.step)\n if (!isUndefined(props.precision)) {\n if (stepPrecision > props.precision) {\n debugWarn(\n 'InputNumber',\n 'precision should not be less than the decimal places of step'\n )\n }\n return props.precision\n } else {\n return Math.max(getPrecision(props.modelValue), stepPrecision)\n }\n})\nconst controlsAtRight = computed(() => {\n return props.controls && props.controlsPosition === 'right'\n})\n\nconst inputNumberSize = useFormSize()\nconst inputNumberDisabled = useFormDisabled()\n\nconst displayValue = computed(() => {\n if (data.userInput !== null) {\n return data.userInput\n }\n let currentValue: number | string | undefined | null = data.currentValue\n if (isNil(currentValue)) return ''\n if (isNumber(currentValue)) {\n if (Number.isNaN(currentValue)) return ''\n if (!isUndefined(props.precision)) {\n currentValue = currentValue.toFixed(props.precision)\n }\n }\n return currentValue\n})\nconst toPrecision = (num: number, pre?: number) => {\n if (isUndefined(pre)) pre = numPrecision.value\n if (pre === 0) return Math.round(num)\n let snum = String(num)\n const pointPos = snum.indexOf('.')\n if (pointPos === -1) return num\n const nums = snum.replace('.', '').split('')\n const datum = nums[pointPos + pre]\n if (!datum) return num\n const length = snum.length\n if (snum.charAt(length - 1) === '5') {\n snum = `${snum.slice(0, Math.max(0, length - 1))}6`\n }\n return Number.parseFloat(Number(snum).toFixed(pre))\n}\nconst getPrecision = (value: number | null | undefined) => {\n if (isNil(value)) return 0\n const valueString = value.toString()\n const dotPosition = valueString.indexOf('.')\n let precision = 0\n if (dotPosition !== -1) {\n precision = valueString.length - dotPosition - 1\n }\n return precision\n}\nconst ensurePrecision = (val: number, coefficient: 1 | -1 = 1) => {\n if (!isNumber(val)) return data.currentValue\n // Solve the accuracy problem of JS decimal calculation by converting the value to integer.\n return toPrecision(val + props.step * coefficient)\n}\nconst increase = () => {\n if (props.readonly || inputNumberDisabled.value || maxDisabled.value) return\n const value = Number(displayValue.value) || 0\n const newVal = ensurePrecision(value)\n setCurrentValue(newVal)\n emit(INPUT_EVENT, data.currentValue)\n setCurrentValueToModelValue()\n}\nconst decrease = () => {\n if (props.readonly || inputNumberDisabled.value || minDisabled.value) return\n const value = Number(displayValue.value) || 0\n const newVal = ensurePrecision(value, -1)\n setCurrentValue(newVal)\n emit(INPUT_EVENT, data.currentValue)\n setCurrentValueToModelValue()\n}\nconst verifyValue = (\n value: number | string | null | undefined,\n update?: boolean\n): number | null | undefined => {\n const { max, min, step, precision, stepStrictly, valueOnClear } = props\n if (max < min) {\n throwError('InputNumber', 'min should not be greater than max.')\n }\n let newVal = Number(value)\n if (isNil(value) || Number.isNaN(newVal)) {\n return null\n }\n if (value === '') {\n if (valueOnClear === null) {\n return null\n }\n newVal = isString(valueOnClear) ? { min, max }[valueOnClear] : valueOnClear\n }\n if (stepStrictly) {\n newVal = toPrecision(Math.round(newVal / step) * step, precision)\n }\n if (!isUndefined(precision)) {\n newVal = toPrecision(newVal, precision)\n }\n if (newVal > max || newVal < min) {\n newVal = newVal > max ? max : min\n update && emit(UPDATE_MODEL_EVENT, newVal)\n }\n return newVal\n}\nconst setCurrentValue = (\n value: number | string | null | undefined,\n emitChange = true\n) => {\n const oldVal = data.currentValue\n const newVal = verifyValue(value)\n if (!emitChange) {\n emit(UPDATE_MODEL_EVENT, newVal!)\n return\n }\n if (oldVal === newVal && value) return\n data.userInput = null\n emit(UPDATE_MODEL_EVENT, newVal!)\n if (oldVal !== newVal) {\n emit(CHANGE_EVENT, newVal!, oldVal!)\n }\n if (props.validateEvent) {\n formItem?.validate?.('change').catch((err) => debugWarn(err))\n }\n data.currentValue = newVal\n}\nconst handleInput = (value: string) => {\n data.userInput = value\n const newVal = value === '' ? null : Number(value)\n emit(INPUT_EVENT, newVal)\n setCurrentValue(newVal, false)\n}\nconst handleInputChange = (value: string) => {\n const newVal = value !== '' ? Number(value) : ''\n if ((isNumber(newVal) && !Number.isNaN(newVal)) || value === '') {\n setCurrentValue(newVal)\n }\n setCurrentValueToModelValue()\n data.userInput = null\n}\n\nconst focus = () => {\n input.value?.focus?.()\n}\n\nconst blur = () => {\n input.value?.blur?.()\n}\n\nconst handleFocus = (event: MouseEvent | FocusEvent) => {\n emit('focus', event)\n}\n\nconst handleBlur = (event: MouseEvent | FocusEvent) => {\n data.userInput = null\n emit('blur', event)\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch((err) => debugWarn(err))\n }\n}\n\nconst setCurrentValueToModelValue = () => {\n if (data.currentValue !== props.modelValue) {\n data.currentValue = props.modelValue\n }\n}\nconst handleWheel = (e: WheelEvent) => {\n if (document.activeElement === e.target) e.preventDefault()\n}\n\nwatch(\n () => props.modelValue,\n (value, oldValue) => {\n const newValue = verifyValue(value, true)\n if (data.userInput === null && newValue !== oldValue) {\n data.currentValue = newValue\n }\n },\n { immediate: true }\n)\nonMounted(() => {\n const { min, max, modelValue } = props\n const innerInput = input.value?.input as HTMLInputElement\n innerInput.setAttribute('role', 'spinbutton')\n if (Number.isFinite(max)) {\n innerInput.setAttribute('aria-valuemax', String(max))\n } else {\n innerInput.removeAttribute('aria-valuemax')\n }\n if (Number.isFinite(min)) {\n innerInput.setAttribute('aria-valuemin', String(min))\n } else {\n innerInput.removeAttribute('aria-valuemin')\n }\n innerInput.setAttribute(\n 'aria-valuenow',\n data.currentValue || data.currentValue === 0\n ? String(data.currentValue)\n : ''\n )\n innerInput.setAttribute('aria-disabled', String(inputNumberDisabled.value))\n if (!isNumber(modelValue) && modelValue != null) {\n let val: number | null = Number(modelValue)\n if (Number.isNaN(val)) {\n val = null\n }\n emit(UPDATE_MODEL_EVENT, val!)\n }\n innerInput.addEventListener('wheel', handleWheel, { passive: false })\n})\nonUpdated(() => {\n const innerInput = input.value?.input\n innerInput?.setAttribute('aria-valuenow', `${data.currentValue ?? ''}`)\n})\ndefineExpose({\n /** @description get focus the input component */\n focus,\n /** @description remove focus the input component */\n blur,\n})\n</script>\n"],"names":["useLocale","useNamespace","ref","reactive","useFormItem","computed","isNumber","isUndefined","debugWarn","useFormSize","useFormDisabled","isNil","INPUT_EVENT","throwError","isString","UPDATE_MODEL_EVENT","CHANGE_EVENT","watch","onMounted","onUpdated"],"mappings":"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"}
@@ -2,175 +2,24 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var vue = require('vue');
6
- require('../../../hooks/index.js');
7
5
  require('../../../utils/index.js');
8
- var index$2 = require('../../scrollbar/index.js');
9
- var mentionDropdown = require('./mention-dropdown2.js');
10
- var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
11
- var index = require('../../../hooks/use-namespace/index.js');
12
- var index$1 = require('../../../hooks/use-locale/index.js');
13
- var scroll = require('../../../utils/dom/scroll.js');
6
+ var runtime = require('../../../utils/vue/props/runtime.js');
7
+ var shared = require('@vue/shared');
14
8
 
15
- const __default__ = vue.defineComponent({
16
- name: "ElMentionDropdown"
9
+ const mentionDropdownProps = runtime.buildProps({
10
+ options: {
11
+ type: runtime.definePropType(Array),
12
+ default: () => []
13
+ },
14
+ loading: Boolean,
15
+ disabled: Boolean,
16
+ contentId: String,
17
+ ariaLabel: String
17
18
  });
18
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
19
- ...__default__,
20
- props: mentionDropdown.mentionDropdownProps,
21
- emits: mentionDropdown.mentionDropdownEmits,
22
- setup(__props, { expose, emit }) {
23
- const props = __props;
24
- const ns = index.useNamespace("mention");
25
- const { t } = index$1.useLocale();
26
- const hoveringIndex = vue.ref(-1);
27
- const scrollbarRef = vue.ref();
28
- const optionRefs = vue.ref();
29
- const dropdownRef = vue.ref();
30
- const optionkls = (item, index) => [
31
- ns.be("dropdown", "item"),
32
- ns.is("hovering", hoveringIndex.value === index),
33
- ns.is("disabled", item.disabled || props.disabled)
34
- ];
35
- const handleSelect = (item) => {
36
- if (item.disabled || props.disabled)
37
- return;
38
- emit("select", item);
39
- };
40
- const handleMouseEnter = (index) => {
41
- hoveringIndex.value = index;
42
- };
43
- const filteredAllDisabled = vue.computed(() => props.disabled || props.options.every((item) => item.disabled));
44
- const hoverOption = vue.computed(() => props.options[hoveringIndex.value]);
45
- const selectHoverOption = () => {
46
- if (!hoverOption.value)
47
- return;
48
- emit("select", hoverOption.value);
49
- };
50
- const navigateOptions = (direction) => {
51
- const { options } = props;
52
- if (options.length === 0 || filteredAllDisabled.value)
53
- return;
54
- if (direction === "next") {
55
- hoveringIndex.value++;
56
- if (hoveringIndex.value === options.length) {
57
- hoveringIndex.value = 0;
58
- }
59
- } else if (direction === "prev") {
60
- hoveringIndex.value--;
61
- if (hoveringIndex.value < 0) {
62
- hoveringIndex.value = options.length - 1;
63
- }
64
- }
65
- const option = options[hoveringIndex.value];
66
- if (option.disabled) {
67
- navigateOptions(direction);
68
- return;
69
- }
70
- vue.nextTick(() => scrollToOption(option));
71
- };
72
- const scrollToOption = (option) => {
73
- var _a, _b, _c, _d;
74
- const { options } = props;
75
- const index = options.findIndex((item) => item.value === option.value);
76
- const target = (_a = optionRefs.value) == null ? void 0 : _a[index];
77
- if (target) {
78
- const menu = (_c = (_b = dropdownRef.value) == null ? void 0 : _b.querySelector) == null ? void 0 : _c.call(_b, `.${ns.be("dropdown", "wrap")}`);
79
- if (menu) {
80
- scroll.scrollIntoView(menu, target);
81
- }
82
- }
83
- (_d = scrollbarRef.value) == null ? void 0 : _d.handleScroll();
84
- };
85
- const resetHoveringIndex = () => {
86
- if (filteredAllDisabled.value || props.options.length === 0) {
87
- hoveringIndex.value = -1;
88
- } else {
89
- hoveringIndex.value = 0;
90
- }
91
- };
92
- vue.watch(() => props.options, resetHoveringIndex, {
93
- immediate: true
94
- });
95
- expose({
96
- hoveringIndex,
97
- navigateOptions,
98
- selectHoverOption,
99
- hoverOption
100
- });
101
- return (_ctx, _cache) => {
102
- return vue.openBlock(), vue.createElementBlock("div", {
103
- ref_key: "dropdownRef",
104
- ref: dropdownRef,
105
- class: vue.normalizeClass(vue.unref(ns).b("dropdown"))
106
- }, [
107
- _ctx.$slots.header ? (vue.openBlock(), vue.createElementBlock("div", {
108
- key: 0,
109
- class: vue.normalizeClass(vue.unref(ns).be("dropdown", "header"))
110
- }, [
111
- vue.renderSlot(_ctx.$slots, "header")
112
- ], 2)) : vue.createCommentVNode("v-if", true),
113
- vue.withDirectives(vue.createVNode(vue.unref(index$2.ElScrollbar), {
114
- id: _ctx.contentId,
115
- ref_key: "scrollbarRef",
116
- ref: scrollbarRef,
117
- tag: "ul",
118
- "wrap-class": vue.unref(ns).be("dropdown", "wrap"),
119
- "view-class": vue.unref(ns).be("dropdown", "list"),
120
- role: "listbox",
121
- "aria-label": _ctx.ariaLabel,
122
- "aria-orientation": "vertical"
123
- }, {
124
- default: vue.withCtx(() => [
125
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(_ctx.options, (item, index) => {
126
- return vue.openBlock(), vue.createElementBlock("li", {
127
- id: `${_ctx.contentId}-${index}`,
128
- ref_for: true,
129
- ref_key: "optionRefs",
130
- ref: optionRefs,
131
- key: item.value,
132
- class: vue.normalizeClass(optionkls(item, index)),
133
- role: "option",
134
- "aria-disabled": item.disabled || _ctx.disabled || void 0,
135
- "aria-selected": hoveringIndex.value === index,
136
- onMouseenter: ($event) => handleMouseEnter(index),
137
- onClick: vue.withModifiers(($event) => handleSelect(item), ["stop"])
138
- }, [
139
- vue.renderSlot(_ctx.$slots, "label", {
140
- item,
141
- index
142
- }, () => {
143
- var _a;
144
- return [
145
- vue.createElementVNode("span", null, vue.toDisplayString((_a = item.label) != null ? _a : item.value), 1)
146
- ];
147
- })
148
- ], 42, ["id", "aria-disabled", "aria-selected", "onMouseenter", "onClick"]);
149
- }), 128))
150
- ]),
151
- _: 3
152
- }, 8, ["id", "wrap-class", "view-class", "aria-label"]), [
153
- [vue.vShow, _ctx.options.length > 0 && !_ctx.loading]
154
- ]),
155
- _ctx.loading ? (vue.openBlock(), vue.createElementBlock("div", {
156
- key: 1,
157
- class: vue.normalizeClass(vue.unref(ns).be("dropdown", "loading"))
158
- }, [
159
- vue.renderSlot(_ctx.$slots, "loading", {}, () => [
160
- vue.createTextVNode(vue.toDisplayString(vue.unref(t)("el.mention.loading")), 1)
161
- ])
162
- ], 2)) : vue.createCommentVNode("v-if", true),
163
- _ctx.$slots.footer ? (vue.openBlock(), vue.createElementBlock("div", {
164
- key: 2,
165
- class: vue.normalizeClass(vue.unref(ns).be("dropdown", "footer"))
166
- }, [
167
- vue.renderSlot(_ctx.$slots, "footer")
168
- ], 2)) : vue.createCommentVNode("v-if", true)
169
- ], 2);
170
- };
171
- }
172
- });
173
- var ElMentionDropdown = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "mention-dropdown.vue"]]);
19
+ const mentionDropdownEmits = {
20
+ select: (option) => shared.isString(option.value)
21
+ };
174
22
 
175
- exports["default"] = ElMentionDropdown;
23
+ exports.mentionDropdownEmits = mentionDropdownEmits;
24
+ exports.mentionDropdownProps = mentionDropdownProps;
176
25
  //# sourceMappingURL=mention-dropdown.js.map