vxe-pc-ui 3.13.11 → 3.13.13

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 (674) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +134 -134
  3. package/es/icon/style.css +1 -1
  4. package/es/style.css +1 -1
  5. package/es/style.min.css +1 -1
  6. package/es/tag/style.css +1 -3
  7. package/es/tag/style.min.css +1 -1
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/es/vxe-tag/style.css +1 -3
  11. package/es/vxe-tag/style.min.css +1 -1
  12. package/lib/components.js +2 -1
  13. package/lib/components.min.js +1 -1
  14. package/lib/drawer/index.js +2 -1
  15. package/lib/drawer/index.min.js +1 -1
  16. package/lib/icon/style/style.css +1 -1
  17. package/lib/icon/style/style.min.css +1 -1
  18. package/lib/index.common.js +2 -1
  19. package/lib/index.umd.js +7962 -8834
  20. package/lib/index.umd.min.js +1 -1
  21. package/lib/modal/index.js +2 -1
  22. package/lib/modal/index.min.js +1 -1
  23. package/lib/style.css +1 -1
  24. package/lib/style.min.css +1 -1
  25. package/lib/tag/style/style.css +1 -3
  26. package/lib/tag/style/style.min.css +1 -1
  27. package/lib/ui/index.js +1 -1
  28. package/lib/ui/index.min.js +1 -1
  29. package/lib/ui/src/log.js +1 -1
  30. package/lib/ui/src/log.min.js +1 -1
  31. package/lib/vxe-alert/index.js +2 -1
  32. package/lib/vxe-alert/index.min.js +1 -1
  33. package/lib/vxe-anchor/index.js +2 -1
  34. package/lib/vxe-anchor/index.min.js +1 -1
  35. package/lib/vxe-anchor-link/index.js +2 -1
  36. package/lib/vxe-anchor-link/index.min.js +1 -1
  37. package/lib/vxe-avatar/index.js +2 -1
  38. package/lib/vxe-avatar/index.min.js +1 -1
  39. package/lib/vxe-backtop/index.js +2 -1
  40. package/lib/vxe-backtop/index.min.js +1 -1
  41. package/lib/vxe-badge/index.js +2 -1
  42. package/lib/vxe-badge/index.min.js +1 -1
  43. package/lib/vxe-breadcrumb/index.js +2 -1
  44. package/lib/vxe-breadcrumb/index.min.js +1 -1
  45. package/lib/vxe-breadcrumb-item/index.js +2 -1
  46. package/lib/vxe-breadcrumb-item/index.min.js +1 -1
  47. package/lib/vxe-button/index.js +2 -1
  48. package/lib/vxe-button/index.min.js +1 -1
  49. package/lib/vxe-button-group/index.js +2 -1
  50. package/lib/vxe-button-group/index.min.js +1 -1
  51. package/lib/vxe-calendar/index.js +2 -1
  52. package/lib/vxe-calendar/index.min.js +1 -1
  53. package/lib/vxe-card/index.js +2 -1
  54. package/lib/vxe-card/index.min.js +1 -1
  55. package/lib/vxe-carousel/index.js +2 -1
  56. package/lib/vxe-carousel/index.min.js +1 -1
  57. package/lib/vxe-carousel-item/index.js +2 -1
  58. package/lib/vxe-carousel-item/index.min.js +1 -1
  59. package/lib/vxe-cascader/index.js +2 -1
  60. package/lib/vxe-cascader/index.min.js +1 -1
  61. package/lib/vxe-checkbox/index.js +2 -1
  62. package/lib/vxe-checkbox/index.min.js +1 -1
  63. package/lib/vxe-checkbox-button/index.js +2 -1
  64. package/lib/vxe-checkbox-button/index.min.js +1 -1
  65. package/lib/vxe-checkbox-group/index.js +2 -1
  66. package/lib/vxe-checkbox-group/index.min.js +1 -1
  67. package/lib/vxe-col/index.js +2 -1
  68. package/lib/vxe-col/index.min.js +1 -1
  69. package/lib/vxe-collapse/index.js +2 -1
  70. package/lib/vxe-collapse/index.min.js +1 -1
  71. package/lib/vxe-collapse-pane/index.js +2 -1
  72. package/lib/vxe-collapse-pane/index.min.js +1 -1
  73. package/lib/vxe-color-picker/index.js +2 -1
  74. package/lib/vxe-color-picker/index.min.js +1 -1
  75. package/lib/vxe-context-menu/index.js +2 -1
  76. package/lib/vxe-context-menu/index.min.js +1 -1
  77. package/lib/vxe-countdown/index.js +2 -1
  78. package/lib/vxe-countdown/index.min.js +1 -1
  79. package/lib/vxe-date-panel/index.js +2 -1
  80. package/lib/vxe-date-panel/index.min.js +1 -1
  81. package/lib/vxe-date-picker/index.js +2 -1
  82. package/lib/vxe-date-picker/index.min.js +1 -1
  83. package/lib/vxe-date-range-picker/index.js +2 -1
  84. package/lib/vxe-date-range-picker/index.min.js +1 -1
  85. package/lib/vxe-drawer/index.js +2 -1
  86. package/lib/vxe-drawer/index.min.js +1 -1
  87. package/lib/vxe-empty/index.js +2 -1
  88. package/lib/vxe-empty/index.min.js +1 -1
  89. package/lib/vxe-form/index.js +2 -1
  90. package/lib/vxe-form/index.min.js +1 -1
  91. package/lib/vxe-form-gather/index.js +2 -1
  92. package/lib/vxe-form-gather/index.min.js +1 -1
  93. package/lib/vxe-form-group/index.js +2 -1
  94. package/lib/vxe-form-group/index.min.js +1 -1
  95. package/lib/vxe-form-item/index.js +2 -1
  96. package/lib/vxe-form-item/index.min.js +1 -1
  97. package/lib/vxe-icon/index.js +2 -1
  98. package/lib/vxe-icon/index.min.js +1 -1
  99. package/lib/vxe-icon-picker/index.js +2 -1
  100. package/lib/vxe-icon-picker/index.min.js +1 -1
  101. package/lib/vxe-image/index.js +2 -1
  102. package/lib/vxe-image/index.min.js +1 -1
  103. package/lib/vxe-image-group/index.js +2 -1
  104. package/lib/vxe-image-group/index.min.js +1 -1
  105. package/lib/vxe-image-preview/index.js +2 -1
  106. package/lib/vxe-image-preview/index.min.js +1 -1
  107. package/lib/vxe-input/index.js +2 -1
  108. package/lib/vxe-input/index.min.js +1 -1
  109. package/lib/vxe-layout-aside/index.js +2 -1
  110. package/lib/vxe-layout-aside/index.min.js +1 -1
  111. package/lib/vxe-layout-body/index.js +2 -1
  112. package/lib/vxe-layout-body/index.min.js +1 -1
  113. package/lib/vxe-layout-container/index.js +2 -1
  114. package/lib/vxe-layout-container/index.min.js +1 -1
  115. package/lib/vxe-layout-footer/index.js +2 -1
  116. package/lib/vxe-layout-footer/index.min.js +1 -1
  117. package/lib/vxe-layout-header/index.js +2 -1
  118. package/lib/vxe-layout-header/index.min.js +1 -1
  119. package/lib/vxe-link/index.js +2 -1
  120. package/lib/vxe-link/index.min.js +1 -1
  121. package/lib/vxe-list/index.js +2 -1
  122. package/lib/vxe-list/index.min.js +1 -1
  123. package/lib/vxe-loading/index.js +2 -1
  124. package/lib/vxe-loading/index.min.js +1 -1
  125. package/lib/vxe-mention/index.js +2 -1
  126. package/lib/vxe-mention/index.min.js +1 -1
  127. package/lib/vxe-menu/index.js +2 -1
  128. package/lib/vxe-menu/index.min.js +1 -1
  129. package/lib/vxe-modal/index.js +2 -1
  130. package/lib/vxe-modal/index.min.js +1 -1
  131. package/lib/vxe-notice-bar/index.js +2 -1
  132. package/lib/vxe-notice-bar/index.min.js +1 -1
  133. package/lib/vxe-number-input/index.js +2 -1
  134. package/lib/vxe-number-input/index.min.js +1 -1
  135. package/lib/vxe-optgroup/index.js +2 -1
  136. package/lib/vxe-optgroup/index.min.js +1 -1
  137. package/lib/vxe-option/index.js +2 -1
  138. package/lib/vxe-option/index.min.js +1 -1
  139. package/lib/vxe-pager/index.js +2 -1
  140. package/lib/vxe-pager/index.min.js +1 -1
  141. package/lib/vxe-password-input/index.js +2 -1
  142. package/lib/vxe-password-input/index.min.js +1 -1
  143. package/lib/vxe-print/index.js +2 -1
  144. package/lib/vxe-print/index.min.js +1 -1
  145. package/lib/vxe-print-page-break/index.js +2 -1
  146. package/lib/vxe-print-page-break/index.min.js +1 -1
  147. package/lib/vxe-pulldown/index.js +2 -1
  148. package/lib/vxe-pulldown/index.min.js +1 -1
  149. package/lib/vxe-radio/index.js +2 -1
  150. package/lib/vxe-radio/index.min.js +1 -1
  151. package/lib/vxe-radio-button/index.js +2 -1
  152. package/lib/vxe-radio-button/index.min.js +1 -1
  153. package/lib/vxe-radio-group/index.js +2 -1
  154. package/lib/vxe-radio-group/index.min.js +1 -1
  155. package/lib/vxe-rate/index.js +2 -1
  156. package/lib/vxe-rate/index.min.js +1 -1
  157. package/lib/vxe-result/index.js +2 -1
  158. package/lib/vxe-result/index.min.js +1 -1
  159. package/lib/vxe-row/index.js +2 -1
  160. package/lib/vxe-row/index.min.js +1 -1
  161. package/lib/vxe-segmented/index.js +2 -1
  162. package/lib/vxe-segmented/index.min.js +1 -1
  163. package/lib/vxe-select/index.js +2 -1
  164. package/lib/vxe-select/index.min.js +1 -1
  165. package/lib/vxe-slider/index.js +2 -1
  166. package/lib/vxe-slider/index.min.js +1 -1
  167. package/lib/vxe-split/index.js +2 -1
  168. package/lib/vxe-split/index.min.js +1 -1
  169. package/lib/vxe-split-pane/index.js +2 -1
  170. package/lib/vxe-split-pane/index.min.js +1 -1
  171. package/lib/vxe-splitter/index.js +2 -1
  172. package/lib/vxe-splitter/index.min.js +1 -1
  173. package/lib/vxe-splitter-panel/index.js +2 -1
  174. package/lib/vxe-splitter-panel/index.min.js +1 -1
  175. package/lib/vxe-steps/index.js +2 -1
  176. package/lib/vxe-steps/index.min.js +1 -1
  177. package/lib/vxe-switch/index.js +2 -1
  178. package/lib/vxe-switch/index.min.js +1 -1
  179. package/lib/vxe-tab-pane/index.js +2 -1
  180. package/lib/vxe-tab-pane/index.min.js +1 -1
  181. package/lib/vxe-table-select/index.js +2 -1
  182. package/lib/vxe-table-select/index.min.js +1 -1
  183. package/lib/vxe-tabs/index.js +2 -1
  184. package/lib/vxe-tabs/index.min.js +1 -1
  185. package/lib/vxe-tag/index.js +2 -1
  186. package/lib/vxe-tag/index.min.js +1 -1
  187. package/lib/vxe-tag/style/style.css +1 -3
  188. package/lib/vxe-tag/style/style.min.css +1 -1
  189. package/lib/vxe-text/index.js +2 -1
  190. package/lib/vxe-text/index.min.js +1 -1
  191. package/lib/vxe-text-ellipsis/index.js +2 -1
  192. package/lib/vxe-text-ellipsis/index.min.js +1 -1
  193. package/lib/vxe-textarea/index.js +2 -1
  194. package/lib/vxe-textarea/index.min.js +1 -1
  195. package/lib/vxe-timeline/index.js +2 -1
  196. package/lib/vxe-timeline/index.min.js +1 -1
  197. package/lib/vxe-timeline-item/index.js +2 -1
  198. package/lib/vxe-timeline-item/index.min.js +1 -1
  199. package/lib/vxe-tip/index.js +2 -1
  200. package/lib/vxe-tip/index.min.js +1 -1
  201. package/lib/vxe-tooltip/index.js +2 -1
  202. package/lib/vxe-tooltip/index.min.js +1 -1
  203. package/lib/vxe-tour/index.js +2 -1
  204. package/lib/vxe-tour/index.min.js +1 -1
  205. package/lib/vxe-tree/index.js +2 -1
  206. package/lib/vxe-tree/index.min.js +1 -1
  207. package/lib/vxe-tree-select/index.js +2 -1
  208. package/lib/vxe-tree-select/index.min.js +1 -1
  209. package/lib/vxe-u-i/index.js +2 -1
  210. package/lib/vxe-u-i/index.min.js +1 -1
  211. package/lib/vxe-ui/index.js +2 -1
  212. package/lib/vxe-ui/index.min.js +1 -1
  213. package/lib/vxe-upload/index.js +2 -1
  214. package/lib/vxe-upload/index.min.js +1 -1
  215. package/lib/vxe-watermark/index.js +2 -1
  216. package/lib/vxe-watermark/index.min.js +1 -1
  217. package/package.json +89 -89
  218. package/packages/alert/index.ts +16 -16
  219. package/packages/alert/src/alert.ts +106 -106
  220. package/packages/anchor/index.ts +16 -16
  221. package/packages/anchor/src/anchor-link.ts +158 -158
  222. package/packages/anchor/src/anchor.ts +267 -267
  223. package/packages/anchor/src/util.ts +23 -23
  224. package/packages/anchor-link/index.ts +16 -16
  225. package/packages/avatar/index.ts +16 -16
  226. package/packages/avatar/src/avatar.ts +141 -141
  227. package/packages/backtop/index.ts +16 -16
  228. package/packages/backtop/src/backtop.ts +330 -330
  229. package/packages/badge/index.ts +16 -16
  230. package/packages/badge/src/badge.ts +87 -87
  231. package/packages/breadcrumb/index.ts +16 -16
  232. package/packages/breadcrumb/src/breadcrumb-item.ts +118 -118
  233. package/packages/breadcrumb/src/breadcrumb.ts +89 -89
  234. package/packages/breadcrumb-item/index.ts +16 -16
  235. package/packages/button/index.ts +16 -16
  236. package/packages/button/src/button-group.ts +113 -113
  237. package/packages/button/src/button.ts +955 -955
  238. package/packages/button-group/index.ts +16 -16
  239. package/packages/calendar/index.ts +16 -16
  240. package/packages/calendar/src/calendar.ts +1527 -1527
  241. package/packages/card/index.ts +16 -16
  242. package/packages/card/src/card.ts +162 -162
  243. package/packages/carousel/index.ts +16 -16
  244. package/packages/carousel/src/carousel-item.ts +117 -117
  245. package/packages/carousel/src/carousel.ts +460 -460
  246. package/packages/carousel/src/util.ts +21 -21
  247. package/packages/carousel-item/index.ts +16 -16
  248. package/packages/cascader/index.ts +16 -16
  249. package/packages/cascader/src/cascader.ts +941 -941
  250. package/packages/checkbox/index.ts +16 -16
  251. package/packages/checkbox/src/button.ts +185 -185
  252. package/packages/checkbox/src/checkbox.ts +189 -189
  253. package/packages/checkbox/src/group.ts +259 -259
  254. package/packages/checkbox-button/index.ts +16 -16
  255. package/packages/checkbox-group/index.ts +16 -16
  256. package/packages/col/index.ts +16 -16
  257. package/packages/collapse/index.ts +16 -16
  258. package/packages/collapse/src/collapse-pane.ts +136 -136
  259. package/packages/collapse/src/collapse.ts +259 -259
  260. package/packages/collapse/src/util.ts +21 -21
  261. package/packages/collapse-pane/index.ts +16 -16
  262. package/packages/color-picker/index.ts +16 -16
  263. package/packages/color-picker/src/color-picker.ts +1277 -1277
  264. package/packages/color-picker/src/util.ts +198 -198
  265. package/packages/components.ts +307 -307
  266. package/packages/context-menu/index.ts +54 -54
  267. package/packages/context-menu/src/context-menu.ts +709 -709
  268. package/packages/countdown/index.ts +16 -16
  269. package/packages/countdown/src/countdown.ts +276 -276
  270. package/packages/date-panel/index.ts +16 -16
  271. package/packages/date-panel/src/date-panel.ts +2024 -2024
  272. package/packages/date-panel/src/util.ts +244 -244
  273. package/packages/date-picker/index.ts +17 -17
  274. package/packages/date-picker/src/date-picker.ts +1238 -1238
  275. package/packages/date-range-picker/index.ts +16 -16
  276. package/packages/date-range-picker/src/date-range-picker.ts +1466 -1466
  277. package/packages/drawer/index.ts +87 -87
  278. package/packages/drawer/src/drawer.ts +767 -767
  279. package/packages/dynamics/index.ts +125 -125
  280. package/packages/empty/index.ts +16 -16
  281. package/packages/empty/src/empty.ts +80 -80
  282. package/packages/form/index.ts +16 -16
  283. package/packages/form/render/index.ts +617 -617
  284. package/packages/form/src/form-config-item.ts +86 -86
  285. package/packages/form/src/form-group.ts +125 -125
  286. package/packages/form/src/form-item.ts +217 -217
  287. package/packages/form/src/form.ts +1032 -1032
  288. package/packages/form/src/itemInfo.ts +80 -80
  289. package/packages/form/src/render.ts +398 -398
  290. package/packages/form/src/util.ts +92 -92
  291. package/packages/form-gather/index.ts +18 -18
  292. package/packages/form-group/index.ts +16 -16
  293. package/packages/form-item/index.ts +16 -16
  294. package/packages/icon/index.ts +16 -16
  295. package/packages/icon/src/icon.ts +75 -75
  296. package/packages/icon-picker/index.ts +16 -16
  297. package/packages/icon-picker/src/icon-picker.ts +752 -752
  298. package/packages/image/index.ts +16 -16
  299. package/packages/image/src/group.ts +162 -162
  300. package/packages/image/src/image.ts +286 -286
  301. package/packages/image/src/preview.ts +737 -737
  302. package/packages/image/src/util.ts +62 -62
  303. package/packages/image-group/index.ts +16 -16
  304. package/packages/image-preview/index.ts +19 -19
  305. package/packages/index.ts +8 -8
  306. package/packages/input/index.ts +16 -16
  307. package/packages/input/src/input.ts +3187 -3187
  308. package/packages/language/ar-EG.ts +832 -832
  309. package/packages/language/de-DE.ts +832 -832
  310. package/packages/language/en-US.ts +832 -832
  311. package/packages/language/es-ES.ts +832 -832
  312. package/packages/language/fr-FR.ts +832 -832
  313. package/packages/language/hu-HU.ts +832 -832
  314. package/packages/language/hy-AM.ts +832 -832
  315. package/packages/language/id-ID.ts +832 -832
  316. package/packages/language/it-IT.ts +832 -832
  317. package/packages/language/ja-JP.ts +832 -832
  318. package/packages/language/ko-KR.ts +832 -832
  319. package/packages/language/ms-MY.ts +832 -832
  320. package/packages/language/nb-NO.ts +832 -832
  321. package/packages/language/pt-BR.ts +832 -832
  322. package/packages/language/ru-RU.ts +832 -832
  323. package/packages/language/th-TH.ts +832 -832
  324. package/packages/language/ug-CN.ts +832 -832
  325. package/packages/language/uk-UA.ts +832 -832
  326. package/packages/language/uz-UZ.ts +832 -832
  327. package/packages/language/vi-VN.ts +832 -832
  328. package/packages/language/zh-CHT.ts +832 -832
  329. package/packages/language/zh-CN.ts +832 -832
  330. package/packages/language/zh-HK.ts +3 -3
  331. package/packages/language/zh-MO.ts +3 -3
  332. package/packages/language/zh-TC.ts +3 -3
  333. package/packages/language/zh-TW.ts +3 -3
  334. package/packages/layout-aside/index.ts +16 -16
  335. package/packages/layout-aside/src/layout-aside.ts +115 -115
  336. package/packages/layout-body/index.ts +16 -16
  337. package/packages/layout-body/src/layout-body.ts +137 -137
  338. package/packages/layout-container/index.ts +16 -16
  339. package/packages/layout-container/src/layout-container.ts +65 -65
  340. package/packages/layout-footer/index.ts +16 -16
  341. package/packages/layout-footer/src/layout-footer.ts +53 -53
  342. package/packages/layout-header/index.ts +16 -16
  343. package/packages/layout-header/src/layout-header.ts +49 -49
  344. package/packages/link/index.ts +16 -16
  345. package/packages/link/src/link.ts +153 -153
  346. package/packages/list/index.ts +16 -16
  347. package/packages/list/src/list.ts +492 -492
  348. package/packages/loading/index.ts +34 -34
  349. package/packages/loading/src/loading.ts +162 -162
  350. package/packages/mention/index.ts +16 -16
  351. package/packages/mention/src/mention.ts +54 -54
  352. package/packages/menu/index.ts +16 -16
  353. package/packages/menu/src/menu.ts +632 -632
  354. package/packages/modal/index.ts +150 -150
  355. package/packages/modal/src/modal.ts +1657 -1657
  356. package/packages/notice-bar/index.ts +16 -16
  357. package/packages/notice-bar/src/notice-bar.ts +182 -182
  358. package/packages/number-input/index.ts +16 -16
  359. package/packages/number-input/src/number-input.ts +1255 -1255
  360. package/packages/number-input/src/util.ts +12 -12
  361. package/packages/optgroup/index.ts +16 -16
  362. package/packages/option/index.ts +16 -16
  363. package/packages/pager/index.ts +16 -16
  364. package/packages/pager/src/pager.ts +913 -913
  365. package/packages/password-input/index.ts +16 -16
  366. package/packages/password-input/src/password-input.ts +466 -466
  367. package/packages/print/index.ts +18 -18
  368. package/packages/print/src/page-break.ts +78 -78
  369. package/packages/print/src/print.ts +266 -266
  370. package/packages/print/src/util.ts +284 -284
  371. package/packages/print-page-break/index.ts +14 -14
  372. package/packages/pulldown/index.ts +16 -16
  373. package/packages/pulldown/src/pulldown.ts +532 -532
  374. package/packages/radio/index.ts +16 -16
  375. package/packages/radio/src/button.ts +221 -221
  376. package/packages/radio/src/group.ts +252 -252
  377. package/packages/radio/src/radio.ts +228 -228
  378. package/packages/radio-button/index.ts +16 -16
  379. package/packages/radio-group/index.ts +16 -16
  380. package/packages/rate/index.ts +16 -16
  381. package/packages/rate/src/rate.ts +199 -199
  382. package/packages/result/index.ts +16 -16
  383. package/packages/result/src/result.ts +93 -93
  384. package/packages/row/index.ts +16 -16
  385. package/packages/row/src/col.ts +130 -130
  386. package/packages/row/src/row.ts +106 -106
  387. package/packages/segmented/index.ts +16 -16
  388. package/packages/segmented/src/segmented.ts +281 -281
  389. package/packages/select/index.ts +16 -16
  390. package/packages/select/src/optgroup.ts +107 -107
  391. package/packages/select/src/option-info.ts +20 -20
  392. package/packages/select/src/option.ts +103 -103
  393. package/packages/select/src/select.ts +2000 -2000
  394. package/packages/select/src/util.ts +47 -47
  395. package/packages/slider/index.ts +16 -16
  396. package/packages/slider/src/slider.ts +332 -332
  397. package/packages/split/index.ts +16 -16
  398. package/packages/split-pane/index.ts +17 -17
  399. package/packages/splitter/index.ts +16 -16
  400. package/packages/splitter/src/splitter-panel.ts +171 -171
  401. package/packages/splitter/src/splitter.ts +1032 -1032
  402. package/packages/splitter/src/util.ts +21 -21
  403. package/packages/splitter-panel/index.ts +16 -16
  404. package/packages/steps/index.ts +16 -16
  405. package/packages/steps/src/steps.ts +57 -57
  406. package/packages/switch/index.ts +16 -16
  407. package/packages/switch/src/switch.ts +279 -279
  408. package/packages/tab-pane/index.ts +16 -16
  409. package/packages/table-select/index.ts +16 -16
  410. package/packages/table-select/src/table-select.ts +903 -903
  411. package/packages/tabs/index.ts +16 -16
  412. package/packages/tabs/src/tab-pane.ts +137 -137
  413. package/packages/tabs/src/tabs.ts +1014 -1014
  414. package/packages/tabs/src/util.ts +21 -21
  415. package/packages/tag/index.ts +16 -16
  416. package/packages/tag/src/tag.ts +195 -195
  417. package/packages/text/index.ts +16 -16
  418. package/packages/text/src/text.ts +267 -267
  419. package/packages/text-ellipsis/index.ts +16 -16
  420. package/packages/text-ellipsis/src/text-ellipsis.ts +291 -291
  421. package/packages/textarea/index.ts +16 -16
  422. package/packages/textarea/src/textarea.ts +436 -436
  423. package/packages/timeline/index.ts +16 -16
  424. package/packages/timeline/src/timeline-item.ts +41 -41
  425. package/packages/timeline/src/timeline.ts +54 -54
  426. package/packages/timeline-item/index.ts +16 -16
  427. package/packages/tip/index.ts +19 -19
  428. package/packages/tip/src/tip.ts +112 -112
  429. package/packages/tooltip/index.ts +16 -16
  430. package/packages/tooltip/src/tooltip.ts +641 -641
  431. package/packages/tour/index.ts +16 -16
  432. package/packages/tour/src/tour.ts +54 -54
  433. package/packages/tree/index.ts +16 -16
  434. package/packages/tree/src/store.ts +15 -15
  435. package/packages/tree/src/tree.ts +3080 -3080
  436. package/packages/tree/src/util.ts +44 -44
  437. package/packages/tree-select/index.ts +16 -16
  438. package/packages/tree-select/src/tree-select.ts +1115 -1115
  439. package/packages/ui/index.ts +695 -695
  440. package/packages/ui/src/anime.ts +52 -52
  441. package/packages/ui/src/comp.ts +3 -3
  442. package/packages/ui/src/dom.ts +263 -263
  443. package/packages/ui/src/log.ts +6 -6
  444. package/packages/ui/src/utils.ts +49 -49
  445. package/packages/ui/src/vn.ts +60 -60
  446. package/packages/upload/index.ts +20 -20
  447. package/packages/upload/src/upload.ts +2127 -2127
  448. package/packages/upload/src/util.ts +109 -109
  449. package/packages/vxe-u-i/index.ts +4 -4
  450. package/packages/watermark/index.ts +31 -31
  451. package/packages/watermark/src/util.ts +176 -176
  452. package/packages/watermark/src/watermark.ts +166 -166
  453. package/styles/all.scss +90 -90
  454. package/styles/base.scss +16 -16
  455. package/styles/components/alert.scss +101 -101
  456. package/styles/components/anchor.scss +44 -44
  457. package/styles/components/avatar.scss +115 -115
  458. package/styles/components/backtop.scss +82 -82
  459. package/styles/components/badge.scss +45 -45
  460. package/styles/components/breadcrumb.scss +29 -29
  461. package/styles/components/button-group.scss +30 -30
  462. package/styles/components/button.scss +415 -415
  463. package/styles/components/calendar.scss +471 -471
  464. package/styles/components/card.scss +121 -121
  465. package/styles/components/carousel.scss +184 -184
  466. package/styles/components/cascader.scss +140 -140
  467. package/styles/components/checkbox-button.scss +57 -57
  468. package/styles/components/checkbox.scss +81 -81
  469. package/styles/components/collapse.scss +56 -56
  470. package/styles/components/color-picker.scss +409 -409
  471. package/styles/components/context-menu.scss +102 -102
  472. package/styles/components/countdown.scss +35 -35
  473. package/styles/components/date-panel.scss +505 -505
  474. package/styles/components/date-picker.scss +247 -247
  475. package/styles/components/date-range-picker.scss +252 -252
  476. package/styles/components/drawer.scss +298 -298
  477. package/styles/components/empty.scss +79 -79
  478. package/styles/components/form.scss +668 -668
  479. package/styles/components/icon-picker.scss +211 -211
  480. package/styles/components/icon.scss +1044 -1044
  481. package/styles/components/image-group.scss +2 -2
  482. package/styles/components/image-preview.scss +215 -215
  483. package/styles/components/image.scss +16 -16
  484. package/styles/components/input.scss +846 -846
  485. package/styles/components/layout-aside.scss +22 -22
  486. package/styles/components/layout-body.scss +14 -14
  487. package/styles/components/layout-container.scss +13 -13
  488. package/styles/components/layout-footer.scss +14 -14
  489. package/styles/components/layout-header.scss +11 -11
  490. package/styles/components/link.scss +115 -115
  491. package/styles/components/list.scss +40 -40
  492. package/styles/components/loading.scss +137 -137
  493. package/styles/components/menu.scss +150 -150
  494. package/styles/components/modal.scss +480 -480
  495. package/styles/components/notice-bar.scss +91 -91
  496. package/styles/components/number-input.scss +283 -283
  497. package/styles/components/old-icon.scss +4 -4
  498. package/styles/components/pager.scss +282 -282
  499. package/styles/components/password-input.scss +374 -374
  500. package/styles/components/print.scss +3 -3
  501. package/styles/components/pulldown.scss +75 -75
  502. package/styles/components/radio-button.scss +57 -57
  503. package/styles/components/radio.scss +79 -79
  504. package/styles/components/rate.scss +76 -76
  505. package/styles/components/result.scss +91 -91
  506. package/styles/components/row.scss +69 -69
  507. package/styles/components/segmented.scss +215 -215
  508. package/styles/components/select.scss +244 -244
  509. package/styles/components/slider.scss +139 -139
  510. package/styles/components/split.scss +1 -1
  511. package/styles/components/splitter.scss +318 -318
  512. package/styles/components/switch.scss +128 -128
  513. package/styles/components/table-select.scss +105 -105
  514. package/styles/components/tabs.scss +745 -745
  515. package/styles/components/tag.scss +184 -184
  516. package/styles/components/text-ellipsis.scss +130 -130
  517. package/styles/components/text.scss +123 -123
  518. package/styles/components/textarea.scss +106 -106
  519. package/styles/components/tip.scss +97 -97
  520. package/styles/components/tooltip.scss +140 -140
  521. package/styles/components/tree-select.scss +166 -166
  522. package/styles/components/tree.scss +294 -294
  523. package/styles/components/upload.scss +497 -497
  524. package/styles/components/watermark.scss +26 -26
  525. package/styles/helpers/baseMixin.scss +95 -95
  526. package/styles/helpers/baseVar.scss +3 -3
  527. package/styles/helpers/placement.scss +38 -38
  528. package/styles/theme/base.scss +214 -214
  529. package/styles/theme/dark.scss +119 -119
  530. package/styles/theme/light.scss +118 -118
  531. package/styles/variable.scss +111 -111
  532. package/types/all.d.ts +328 -328
  533. package/types/components/alert.d.ts +80 -80
  534. package/types/components/anchor-link.d.ts +84 -84
  535. package/types/components/anchor.d.ts +84 -84
  536. package/types/components/avatar.d.ts +81 -81
  537. package/types/components/backtop.d.ts +115 -115
  538. package/types/components/badge.d.ts +69 -69
  539. package/types/components/breadcrumb-item.d.ts +73 -73
  540. package/types/components/breadcrumb.d.ts +80 -80
  541. package/types/components/button-group.d.ts +113 -113
  542. package/types/components/button.d.ts +314 -314
  543. package/types/components/calendar.d.ts +254 -254
  544. package/types/components/card.d.ts +86 -86
  545. package/types/components/carousel-item.d.ts +68 -68
  546. package/types/components/carousel.d.ts +126 -126
  547. package/types/components/cascader.d.ts +242 -242
  548. package/types/components/checkbox-button.d.ts +93 -93
  549. package/types/components/checkbox-group.d.ts +135 -135
  550. package/types/components/checkbox.d.ts +115 -115
  551. package/types/components/col.d.ts +73 -73
  552. package/types/components/colgroup.d.ts +131 -131
  553. package/types/components/collapse-pane.d.ts +82 -82
  554. package/types/components/collapse.d.ts +115 -115
  555. package/types/components/color-picker.d.ts +127 -127
  556. package/types/components/column.d.ts +852 -852
  557. package/types/components/context-menu.d.ts +300 -300
  558. package/types/components/countdown.d.ts +99 -99
  559. package/types/components/date-panel.d.ts +269 -269
  560. package/types/components/date-picker.d.ts +302 -302
  561. package/types/components/date-range-picker.d.ts +316 -316
  562. package/types/components/drawer.d.ts +295 -295
  563. package/types/components/empty.d.ts +71 -71
  564. package/types/components/flow-design.d.ts +78 -78
  565. package/types/components/flow-view.d.ts +78 -78
  566. package/types/components/form-design.d.ts +364 -364
  567. package/types/components/form-gather.d.ts +72 -72
  568. package/types/components/form-group.d.ts +63 -63
  569. package/types/components/form-item.d.ts +405 -405
  570. package/types/components/form-view.d.ts +175 -175
  571. package/types/components/form.d.ts +463 -463
  572. package/types/components/gantt-module/gantt-view.d.ts +170 -170
  573. package/types/components/gantt-module/index.d.ts +1 -1
  574. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +114 -114
  575. package/types/components/gantt-plugins/index.d.ts +1 -1
  576. package/types/components/gantt.d.ts +1129 -1129
  577. package/types/components/grid.d.ts +1030 -1030
  578. package/types/components/icon-picker.d.ts +181 -181
  579. package/types/components/icon.d.ts +80 -80
  580. package/types/components/image-group.d.ts +120 -120
  581. package/types/components/image-preview.d.ts +159 -159
  582. package/types/components/image.d.ts +158 -158
  583. package/types/components/input.d.ts +425 -425
  584. package/types/components/layout-aside.d.ts +73 -73
  585. package/types/components/layout-body.d.ts +84 -84
  586. package/types/components/layout-container.d.ts +66 -66
  587. package/types/components/layout-footer.d.ts +66 -66
  588. package/types/components/layout-header.d.ts +64 -64
  589. package/types/components/link.d.ts +104 -104
  590. package/types/components/list-design.d.ts +177 -177
  591. package/types/components/list-view.d.ts +190 -190
  592. package/types/components/list.d.ts +196 -196
  593. package/types/components/loading.d.ts +96 -96
  594. package/types/components/mention.d.ts +70 -70
  595. package/types/components/menu.d.ts +203 -203
  596. package/types/components/modal.d.ts +540 -540
  597. package/types/components/notice-bar.d.ts +95 -95
  598. package/types/components/number-input.d.ts +300 -300
  599. package/types/components/optgroup.d.ts +81 -81
  600. package/types/components/option.d.ts +95 -95
  601. package/types/components/pager.d.ts +322 -322
  602. package/types/components/password-input.d.ts +129 -129
  603. package/types/components/print-page-break.d.ts +62 -62
  604. package/types/components/print.d.ts +199 -199
  605. package/types/components/pulldown.d.ts +222 -222
  606. package/types/components/radio-button.d.ts +104 -104
  607. package/types/components/radio-group.d.ts +136 -136
  608. package/types/components/radio.d.ts +121 -121
  609. package/types/components/rate.d.ts +75 -75
  610. package/types/components/result.d.ts +77 -77
  611. package/types/components/row.d.ts +72 -72
  612. package/types/components/segmented.d.ts +117 -117
  613. package/types/components/select.d.ts +515 -515
  614. package/types/components/slider.d.ts +117 -117
  615. package/types/components/split-pane.d.ts +135 -135
  616. package/types/components/split.d.ts +318 -318
  617. package/types/components/splitter-panel.d.ts +98 -98
  618. package/types/components/splitter.d.ts +283 -283
  619. package/types/components/steps.d.ts +61 -61
  620. package/types/components/switch.d.ts +124 -124
  621. package/types/components/tab-pane.d.ts +107 -107
  622. package/types/components/table-module/custom.d.ts +111 -111
  623. package/types/components/table-module/edit.d.ts +244 -244
  624. package/types/components/table-module/export.d.ts +96 -96
  625. package/types/components/table-module/filter.d.ts +140 -140
  626. package/types/components/table-module/index.d.ts +7 -7
  627. package/types/components/table-module/keyboard.d.ts +26 -26
  628. package/types/components/table-module/menu.d.ts +26 -26
  629. package/types/components/table-module/validator.d.ts +53 -53
  630. package/types/components/table-plugins/extend-cell-area.d.ts +734 -734
  631. package/types/components/table-plugins/extend-pivot-table.d.ts +62 -62
  632. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  633. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  634. package/types/components/table-plugins/index.d.ts +4 -4
  635. package/types/components/table-select.d.ts +212 -212
  636. package/types/components/table.d.ts +7222 -7206
  637. package/types/components/tabs.d.ts +324 -324
  638. package/types/components/tag.d.ts +107 -107
  639. package/types/components/text-ellipsis.d.ts +105 -105
  640. package/types/components/text.d.ts +115 -115
  641. package/types/components/textarea.d.ts +237 -237
  642. package/types/components/timeline-item.d.ts +68 -68
  643. package/types/components/timeline.d.ts +70 -70
  644. package/types/components/tip.d.ts +76 -76
  645. package/types/components/toolbar.d.ts +329 -329
  646. package/types/components/tooltip.d.ts +165 -165
  647. package/types/components/tour.d.ts +70 -70
  648. package/types/components/tree-select.d.ts +295 -295
  649. package/types/components/tree.d.ts +826 -826
  650. package/types/components/upload.d.ts +432 -432
  651. package/types/components/watermark.d.ts +113 -113
  652. package/types/index.d.ts +4 -4
  653. package/types/ui/commands.d.ts +57 -57
  654. package/types/ui/formats.d.ts +62 -62
  655. package/types/ui/global-config.d.ts +254 -254
  656. package/types/ui/global-icon.d.ts +292 -292
  657. package/types/ui/hooks.d.ts +11 -11
  658. package/types/ui/index.d.ts +95 -95
  659. package/types/ui/interceptor.d.ts +54 -54
  660. package/types/ui/menus.d.ts +77 -77
  661. package/types/ui/renderer.d.ts +1042 -1042
  662. package/types/ui/validators.d.ts +38 -38
  663. /package/es/icon/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  664. /package/es/icon/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  665. /package/es/icon/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  666. /package/es/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  667. /package/es/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  668. /package/es/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  669. /package/lib/icon/style/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  670. /package/lib/icon/style/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  671. /package/lib/icon/style/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  672. /package/lib/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  673. /package/lib/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  674. /package/lib/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
@@ -1,1255 +1,1255 @@
1
- import { CreateElement, PropType, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getConfig, getIcon, getI18n, globalEvents, GLOBAL_EVENT_KEYS, createEvent, globalMixins, renderEmptyElement } from '../../ui'
5
- import { getFuncText, eqEmptyValue, isEnableConf } from '../../ui/src/utils'
6
- import { hasClass, getEventTargetNode, hasControlKey } from '../../ui/src/dom'
7
- import { getSlotVNs } from '../../ui/src/vn'
8
- import { handleNumber, toFloatValueFixed } from './util'
9
-
10
- import type { NumberInputInternalData, VxeNumberInputEmits, NumberInputReactData, VxeNumberInputPropTypes, VxeComponentSizeType, VxeFormConstructor, ValueOf, VxeFormPrivateMethods, VxeFormDefines } from '../../../types'
11
-
12
- const handleNumberString = (val: any) => {
13
- if (XEUtils.eqNull(val)) {
14
- return ''
15
- }
16
- return `${val}`
17
- }
18
-
19
- export default /* define-vxe-component start */ defineVxeComponent({
20
- name: 'VxeNumberInput',
21
- mixins: [
22
- globalMixins.sizeMixin
23
- ],
24
- model: {
25
- prop: 'value',
26
- event: 'modelValue'
27
- },
28
- props: {
29
- value: [String, Number] as PropType<VxeNumberInputPropTypes.ModelValue>,
30
- immediate: {
31
- type: Boolean as PropType<VxeNumberInputPropTypes.Immediate>,
32
- default: true
33
- },
34
- name: String as PropType<VxeNumberInputPropTypes.Name>,
35
- type: {
36
- type: String as PropType<VxeNumberInputPropTypes.Type>,
37
- default: 'number'
38
- },
39
- clearable: {
40
- type: Boolean as PropType<VxeNumberInputPropTypes.Clearable>,
41
- default: () => getConfig().numberInput.clearable
42
- },
43
- readonly: {
44
- type: Boolean as PropType<VxeNumberInputPropTypes.Readonly>,
45
- default: null
46
- },
47
- disabled: {
48
- type: Boolean as PropType<VxeNumberInputPropTypes.Disabled>,
49
- default: null
50
- },
51
- placeholder: String as PropType<VxeNumberInputPropTypes.Placeholder>,
52
- maxLength: {
53
- type: [String, Number] as PropType<VxeNumberInputPropTypes.MaxLength>,
54
- default: () => getConfig().numberInput.maxLength
55
- },
56
- autoComplete: {
57
- type: String as PropType<VxeNumberInputPropTypes.AutoComplete>,
58
- default: 'off'
59
- },
60
- align: String as PropType<VxeNumberInputPropTypes.Align>,
61
- form: String as PropType<VxeNumberInputPropTypes.Form>,
62
- className: String as PropType<VxeNumberInputPropTypes.ClassName>,
63
- size: {
64
- type: String as PropType<VxeNumberInputPropTypes.Size>,
65
- default: () => getConfig().numberInput.size || getConfig().size
66
- },
67
-
68
- // number、integer、float
69
- min: {
70
- type: [String, Number] as PropType<VxeNumberInputPropTypes.Min>,
71
- default: null
72
- },
73
- max: {
74
- type: [String, Number] as PropType<VxeNumberInputPropTypes.Max>,
75
- default: null
76
- },
77
- step: [String, Number] as PropType<VxeNumberInputPropTypes.Step>,
78
- exponential: {
79
- type: Boolean as PropType<VxeNumberInputPropTypes.Exponential>,
80
- default: () => getConfig().numberInput.exponential
81
- },
82
- showCurrency: {
83
- type: Boolean as PropType<VxeNumberInputPropTypes.ShowCurrency>,
84
- default: () => getConfig().numberInput.showCurrency
85
- },
86
- currencySymbol: {
87
- type: String as PropType<VxeNumberInputPropTypes.CurrencySymbol>,
88
- default: () => getConfig().numberInput.currencySymbol
89
- },
90
- controlConfig: Object as PropType<VxeNumberInputPropTypes.ControlConfig>,
91
-
92
- // float
93
- digits: {
94
- type: [String, Number] as PropType<VxeNumberInputPropTypes.Digits>,
95
- default: null
96
- },
97
- autoFill: {
98
- type: Boolean as PropType<VxeNumberInputPropTypes.AutoFill>,
99
- default: () => getConfig().numberInput.autoFill
100
- },
101
- editable: {
102
- type: Boolean as PropType<VxeNumberInputPropTypes.Editable>,
103
- default: true
104
- },
105
-
106
- plusIcon: String as PropType<VxeNumberInputPropTypes.PlusIcon>,
107
- minusIcon: String as PropType<VxeNumberInputPropTypes.MinusIcon>,
108
- prefixIcon: String as PropType<VxeNumberInputPropTypes.PrefixIcon>,
109
- prefixConfig: Object as PropType<VxeNumberInputPropTypes.PrefixConfig>,
110
- suffixIcon: String as PropType<VxeNumberInputPropTypes.SuffixIcon>,
111
- suffixConfig: Object as PropType<VxeNumberInputPropTypes.SuffixConfig>,
112
-
113
- // 已废弃
114
- controls: {
115
- type: Boolean as PropType<VxeNumberInputPropTypes.Controls>,
116
- default: null
117
- },
118
- // 已废弃
119
- maxlength: [String, Number] as PropType<VxeNumberInputPropTypes.Maxlength>,
120
- // 已废弃
121
- autocomplete: String as PropType<VxeNumberInputPropTypes.Autocomplete>
122
- },
123
- inject: {
124
- $xeForm: {
125
- default: null
126
- },
127
- formItemInfo: {
128
- from: 'xeFormItemInfo',
129
- default: null
130
- }
131
- },
132
- data () {
133
- const xID = XEUtils.uniqueId()
134
- const reactData: NumberInputReactData = {
135
- isFocus: false,
136
- isActivated: false,
137
- inputValue: ''
138
- }
139
- const internalData: NumberInputInternalData = {
140
- // dnTimeout: undefined,
141
- // ainTimeout: undefined,
142
- // isMouseDown: undefined,
143
- // isUM: undefined
144
- }
145
- return {
146
- xID,
147
- reactData,
148
- internalData
149
- }
150
- },
151
- computed: {
152
- ...({} as {
153
- computeSize(): VxeComponentSizeType
154
- $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
155
- formItemInfo(): VxeFormDefines.ProvideItemInfo | null
156
- }),
157
- computeFormReadonly () {
158
- const $xeNumberInput = this
159
- const props = $xeNumberInput
160
- const $xeForm = $xeNumberInput.$xeForm
161
-
162
- const { readonly } = props
163
- if (readonly === null) {
164
- if ($xeForm) {
165
- return $xeForm.readonly
166
- }
167
- return false
168
- }
169
- return readonly
170
- },
171
- computeIsDisabled () {
172
- const $xeNumberInput = this
173
- const props = $xeNumberInput
174
- const $xeForm = $xeNumberInput.$xeForm
175
-
176
- const { disabled } = props
177
- if (disabled === null) {
178
- if ($xeForm) {
179
- return $xeForm.disabled
180
- }
181
- return false
182
- }
183
- return disabled
184
- },
185
- computeDigitsValue () {
186
- const $xeNumberInput = this
187
- const props = $xeNumberInput
188
-
189
- const { type, digits } = props
190
- let defDigits: any = digits
191
- if (defDigits === null) {
192
- defDigits = getConfig().numberInput.digits
193
- if (defDigits === null) {
194
- if (type === 'amount') {
195
- defDigits = 2
196
- }
197
- }
198
- }
199
- return XEUtils.toInteger(defDigits) || 1
200
- },
201
- computeControlOpts () {
202
- const $xeNumberInput = this
203
- const props = $xeNumberInput
204
-
205
- return Object.assign({}, getConfig().numberInput.controlConfig, props.controlConfig)
206
- },
207
- computePrefixOpts () {
208
- const $xeNumberInput = this
209
- const props = $xeNumberInput
210
-
211
- return Object.assign({}, getConfig().numberInput.prefixConfig, props.prefixConfig)
212
- },
213
- computeSuffixOpts () {
214
- const $xeNumberInput = this
215
- const props = $xeNumberInput
216
-
217
- return Object.assign({}, getConfig().numberInput.suffixConfig, props.suffixConfig)
218
- },
219
- computeDecimalsType () {
220
- const $xeNumberInput = this
221
- const props = $xeNumberInput
222
-
223
- const { type } = props
224
- return type === 'float' || type === 'amount'
225
- },
226
- computeStepValue () {
227
- const $xeNumberInput = this
228
- const props = $xeNumberInput
229
-
230
- const { type } = props
231
- const digitsValue = $xeNumberInput.computeDigitsValue as number
232
- const decimalsType = $xeNumberInput.computeDecimalsType
233
- const step = props.step
234
- if (type === 'integer') {
235
- return XEUtils.toInteger(step) || 1
236
- } else if (decimalsType) {
237
- return XEUtils.toNumber(step) || (1 / Math.pow(10, digitsValue))
238
- }
239
- return XEUtils.toNumber(step) || 1
240
- },
241
- computeIsClearable () {
242
- const $xeNumberInput = this
243
- const props = $xeNumberInput
244
-
245
- return props.clearable
246
- },
247
- computeInputReadonly () {
248
- const $xeNumberInput = this
249
- const props = $xeNumberInput
250
-
251
- const { editable } = props
252
- const formReadonly = $xeNumberInput.computeFormReadonly
253
- return formReadonly || !editable
254
- },
255
- computeInpPlaceholder () {
256
- const $xeNumberInput = this
257
- const props = $xeNumberInput
258
-
259
- const { placeholder } = props
260
- if (placeholder) {
261
- return getFuncText(placeholder)
262
- }
263
- const globalPlaceholder = getConfig().numberInput.placeholder
264
- if (globalPlaceholder) {
265
- return getFuncText(globalPlaceholder)
266
- }
267
- return getI18n('vxe.base.pleaseInput')
268
- },
269
- computeInpMaxLength () {
270
- const $xeNumberInput = this
271
- const props = $xeNumberInput
272
-
273
- const { type, maxLength, maxlength, min, max } = props
274
- const digitsValue = $xeNumberInput.computeDigitsValue as number
275
- // 数值最大长度默认限制 16 位,包含小数
276
- const maxDefLen = 16
277
- if (!eqEmptyValue(min) && !eqEmptyValue(max)) {
278
- return `${max}`.length + (type === 'integer' ? 0 : (digitsValue + 1)) + (XEUtils.toNumber(min) >= 0 ? 0 : 1)
279
- }
280
- if (maxLength || maxlength) {
281
- return XEUtils.toNumber(maxLength || maxlength)
282
- }
283
- return maxDefLen
284
- },
285
- computeInpImmediate () {
286
- const $xeNumberInput = this
287
- const props = $xeNumberInput
288
-
289
- const { immediate } = props
290
- return immediate
291
- },
292
- computeNumValue () {
293
- const $xeNumberInput = this as any
294
- const props = $xeNumberInput
295
- const reactData = $xeNumberInput.reactData
296
-
297
- const { type } = props
298
- const { inputValue } = reactData
299
- return type === 'integer' ? XEUtils.toInteger(handleNumber(inputValue)) : XEUtils.toNumber(handleNumber(inputValue))
300
- },
301
- computeNumLabel () {
302
- const $xeNumberInput = this as any
303
- const props = $xeNumberInput
304
- const reactData = $xeNumberInput.reactData
305
-
306
- const { type, showCurrency, currencySymbol, autoFill } = props
307
- const { inputValue } = reactData
308
- const digitsValue = $xeNumberInput.computeDigitsValue
309
- if (type === 'amount') {
310
- const num = XEUtils.toNumber(inputValue)
311
- let amountLabel = XEUtils.commafy(num, { digits: digitsValue })
312
- if (!autoFill) {
313
- const [iStr, dStr] = amountLabel.split('.')
314
- if (dStr) {
315
- const dRest = dStr.replace(/0+$/, '')
316
- amountLabel = dRest ? [iStr, '.', dRest].join('') : iStr
317
- }
318
- }
319
- if (showCurrency) {
320
- return `${currencySymbol || getI18n('vxe.numberInput.currencySymbol') || ''}${amountLabel}`
321
- }
322
- return amountLabel
323
- }
324
- return XEUtils.toString(inputValue)
325
- },
326
- computeIsDisabledSubtractNumber () {
327
- const $xeNumberInput = this as any
328
- const props = $xeNumberInput
329
- const reactData = $xeNumberInput.reactData
330
-
331
- const { min } = props
332
- const { inputValue } = reactData
333
- const numValue = $xeNumberInput.computeNumValue as number
334
- // 当有值时再进行判断
335
- if ((inputValue || inputValue === 0) && min !== null) {
336
- return numValue <= XEUtils.toNumber(min)
337
- }
338
- return false
339
- },
340
- computeIsDisabledAddNumber () {
341
- const $xeNumberInput = this as any
342
- const props = $xeNumberInput
343
- const reactData = $xeNumberInput.reactData
344
-
345
- const { max } = props
346
- const { inputValue } = reactData
347
- const numValue = $xeNumberInput.computeNumValue as number
348
- // 当有值时再进行判断
349
- if ((inputValue || inputValue === 0) && max !== null) {
350
- return numValue >= XEUtils.toNumber(max)
351
- }
352
- return false
353
- }
354
- },
355
- methods: {
356
- //
357
- // Method
358
- //
359
- dispatchEvent (type: ValueOf<VxeNumberInputEmits>, params: Record<string, any>, evnt: Event | null) {
360
- const $xeNumberInput = this
361
- $xeNumberInput.$emit(type, createEvent(evnt, { $numberInput: $xeNumberInput }, params))
362
- },
363
- emitModel (value: any) {
364
- const $xeNumberInput = this
365
-
366
- const { _events } = $xeNumberInput as any
367
- if (_events && _events.modelValue) {
368
- $xeNumberInput.$emit('modelValue', value)
369
- } else {
370
- $xeNumberInput.$emit('model-value', value)
371
- }
372
- },
373
- focus () {
374
- const $xeNumberInput = this
375
- const reactData = $xeNumberInput.reactData
376
-
377
- const inputReadonly = $xeNumberInput.computeInputReadonly
378
- if (!inputReadonly) {
379
- const inputElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
380
- reactData.isActivated = true
381
- inputElem.focus()
382
- }
383
- return $xeNumberInput.$nextTick()
384
- },
385
- blur () {
386
- const $xeNumberInput = this
387
- const reactData = $xeNumberInput.reactData
388
-
389
- const inputElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
390
- inputElem.blur()
391
- reactData.isActivated = false
392
- return $xeNumberInput.$nextTick()
393
- },
394
- select () {
395
- const $xeNumberInput = this
396
- const reactData = $xeNumberInput.reactData
397
-
398
- const inputElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
399
- inputElem.select()
400
- reactData.isActivated = false
401
- return $xeNumberInput.$nextTick()
402
- },
403
- getNumberValue (val: any) {
404
- const $xeNumberInput = this
405
- const props = $xeNumberInput
406
-
407
- const { exponential, autoFill } = props
408
- const inpMaxLength = $xeNumberInput.computeInpMaxLength
409
- const digitsValue = $xeNumberInput.computeDigitsValue
410
- const decimalsType = $xeNumberInput.computeDecimalsType
411
- let restVal = ''
412
- if (decimalsType) {
413
- restVal = toFloatValueFixed(val, digitsValue)
414
- if (!autoFill) {
415
- restVal = handleNumberString(XEUtils.toNumber(restVal))
416
- }
417
- } else {
418
- restVal = handleNumberString(val)
419
- }
420
- if (exponential && (val === restVal || handleNumberString(val).toLowerCase() === XEUtils.toNumber(restVal).toExponential())) {
421
- return val
422
- }
423
- return restVal.slice(0, inpMaxLength)
424
- },
425
- triggerEvent (evnt: Event & { type: 'input' | 'change' | 'keydown' | 'keyup' | 'wheel' | 'click' | 'focus' | 'blur' }) {
426
- const $xeNumberInput = this
427
- const reactData = $xeNumberInput.reactData
428
-
429
- const { inputValue } = reactData
430
- $xeNumberInput.dispatchEvent(evnt.type, { value: inputValue }, evnt)
431
- },
432
- handleChange (val: number | null, inputValue: string, evnt: Event | { type: string }) {
433
- const $xeNumberInput = this
434
- const props = $xeNumberInput
435
- const reactData = $xeNumberInput.reactData
436
- const internalData = $xeNumberInput.internalData
437
- const $xeForm = $xeNumberInput.$xeForm
438
- const formItemInfo = $xeNumberInput.formItemInfo
439
-
440
- const value = eqEmptyValue(val) ? null : Number(val)
441
- const isChange = value !== props.value
442
- if (isChange) {
443
- internalData.isUM = true
444
- $xeNumberInput.emitModel(value)
445
- }
446
- if (reactData.inputValue !== inputValue) {
447
- $xeNumberInput.$nextTick(() => {
448
- reactData.inputValue = inputValue || ''
449
- })
450
- }
451
- $xeNumberInput.dispatchEvent('input', { value }, evnt as Event)
452
- if (isChange) {
453
- $xeNumberInput.dispatchEvent('change', { value }, evnt as Event)
454
- // 自动更新校验状态
455
- if ($xeForm && formItemInfo) {
456
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
457
- }
458
- }
459
- },
460
- emitInputEvent (inputValue: any, evnt: Event) {
461
- const $xeNumberInput = this
462
- const reactData = $xeNumberInput.reactData
463
-
464
- const inpImmediate = $xeNumberInput.computeInpImmediate
465
- const value = inputValue === eqEmptyValue(inputValue) ? null : XEUtils.toNumber(inputValue)
466
- reactData.inputValue = inputValue
467
- if (inpImmediate) {
468
- $xeNumberInput.handleChange(value, inputValue, evnt)
469
- } else {
470
- $xeNumberInput.dispatchEvent('input', { value }, evnt)
471
- }
472
- },
473
- inputEvent (evnt: Event & { type: 'input' }) {
474
- const $xeNumberInput = this
475
-
476
- const inputElem = evnt.target as HTMLInputElement
477
- const value = inputElem.value
478
- $xeNumberInput.emitInputEvent(value, evnt)
479
- },
480
- changeEvent (evnt: Event & { type: 'change' }) {
481
- const $xeNumberInput = this
482
- const reactData = $xeNumberInput.reactData
483
-
484
- const inpImmediate = $xeNumberInput.computeInpImmediate
485
- if (!inpImmediate) {
486
- $xeNumberInput.triggerEvent(evnt)
487
- }
488
- $xeNumberInput.dispatchEvent('lazy-change', { value: reactData.inputValue }, evnt)
489
- },
490
- focusEvent (evnt: Event & { type: 'focus' }) {
491
- const $xeNumberInput = this
492
- const reactData = $xeNumberInput.reactData
493
-
494
- const inputReadonly = $xeNumberInput.computeInputReadonly
495
- if (!inputReadonly) {
496
- const { inputValue } = reactData
497
- reactData.inputValue = eqEmptyValue(inputValue) ? '' : `${XEUtils.toNumber(inputValue)}`
498
- reactData.isFocus = true
499
- reactData.isActivated = true
500
- $xeNumberInput.triggerEvent(evnt)
501
- }
502
- },
503
- clickPrefixEvent (evnt: Event) {
504
- const $xeNumberInput = this
505
- const reactData = $xeNumberInput.reactData
506
-
507
- const isDisabled = $xeNumberInput.computeIsDisabled
508
- if (!isDisabled) {
509
- const { inputValue } = reactData
510
- $xeNumberInput.dispatchEvent('prefix-click', { value: inputValue }, evnt)
511
- }
512
- },
513
- clearValueEvent (evnt: Event, value: VxeNumberInputPropTypes.ModelValue) {
514
- const $xeNumberInput = this
515
-
516
- $xeNumberInput.focus()
517
- $xeNumberInput.handleChange(null, '', evnt)
518
- $xeNumberInput.dispatchEvent('clear', { value }, evnt)
519
- $xeNumberInput.dispatchEvent('lazy-change', { value }, evnt)
520
- },
521
- clickSuffixEvent (evnt: Event) {
522
- const $xeNumberInput = this
523
- const reactData = $xeNumberInput.reactData
524
-
525
- const isDisabled = $xeNumberInput.computeIsDisabled
526
- if (!isDisabled) {
527
- const { inputValue } = reactData
528
- $xeNumberInput.dispatchEvent('suffix-click', { value: inputValue }, evnt)
529
- }
530
- },
531
- updateModel (val: any) {
532
- const $xeNumberInput = this
533
- const props = $xeNumberInput
534
- const reactData = $xeNumberInput.reactData
535
-
536
- const { autoFill } = props
537
- const { inputValue } = reactData
538
- const digitsValue = $xeNumberInput.computeDigitsValue
539
- const decimalsType = $xeNumberInput.computeDecimalsType
540
- if (eqEmptyValue(val)) {
541
- reactData.inputValue = ''
542
- } else {
543
- let textValue = `${val}`
544
- if (decimalsType) {
545
- textValue = toFloatValueFixed(val, digitsValue)
546
- if (!autoFill) {
547
- textValue = `${XEUtils.toNumber(textValue)}`
548
- }
549
- }
550
- if (textValue !== inputValue) {
551
- reactData.inputValue = textValue
552
- }
553
- }
554
- },
555
- /**
556
- * 检查初始值
557
- */
558
- initValue () {
559
- const $xeNumberInput = this
560
- const props = $xeNumberInput
561
- const reactData = $xeNumberInput.reactData
562
-
563
- const { autoFill } = props
564
- const { inputValue } = reactData
565
- const digitsValue = $xeNumberInput.computeDigitsValue
566
- const decimalsType = $xeNumberInput.computeDecimalsType
567
- if (decimalsType) {
568
- if (inputValue) {
569
- let textValue = ''
570
- let validValue: number | null = null
571
- if (inputValue) {
572
- textValue = toFloatValueFixed(inputValue, digitsValue)
573
- validValue = XEUtils.toNumber(textValue)
574
- if (!autoFill) {
575
- textValue = `${validValue}`
576
- }
577
- }
578
- if (inputValue !== validValue) {
579
- $xeNumberInput.handleChange(validValue, textValue, { type: 'init' })
580
- } else {
581
- reactData.inputValue = textValue
582
- }
583
- }
584
- }
585
- },
586
- validMaxNum (num: number | string) {
587
- const $xeNumberInput = this
588
- const props = $xeNumberInput
589
-
590
- return props.max === null || props.max === '' || XEUtils.toNumber(num) <= XEUtils.toNumber(props.max)
591
- },
592
- validMinNum (num: number | string) {
593
- const $xeNumberInput = this
594
- const props = $xeNumberInput
595
-
596
- return props.min === null || props.min === '' || XEUtils.toNumber(num) >= XEUtils.toNumber(props.min)
597
- },
598
- afterCheckValue () {
599
- const $xeNumberInput = this
600
- const props = $xeNumberInput
601
- const reactData = $xeNumberInput.reactData
602
-
603
- const { type, min, max, exponential } = props
604
- const { inputValue } = reactData
605
- const inputReadonly = $xeNumberInput.computeInputReadonly
606
- if (!inputReadonly) {
607
- if (eqEmptyValue(inputValue)) {
608
- let inpNumVal = null
609
- let inpValue = inputValue
610
- if (min || min === 0) {
611
- inpNumVal = XEUtils.toNumber(min)
612
- inpValue = `${inpNumVal}`
613
- }
614
- $xeNumberInput.handleChange(inpNumVal, `${inpValue || ''}`, { type: 'check' })
615
- return
616
- }
617
- if (inputValue || (min || max)) {
618
- let inpNumVal: number | string = type === 'integer' ? XEUtils.toInteger(handleNumber(inputValue)) : XEUtils.toNumber(handleNumber(inputValue))
619
- if (!$xeNumberInput.validMinNum(inpNumVal)) {
620
- inpNumVal = min as number
621
- } else if (!$xeNumberInput.validMaxNum(inpNumVal)) {
622
- inpNumVal = max as number
623
- }
624
- if (exponential) {
625
- const inpStringVal = handleNumberString(inputValue).toLowerCase()
626
- if (inpStringVal === XEUtils.toNumber(inpNumVal).toExponential()) {
627
- inpNumVal = inpStringVal
628
- }
629
- }
630
- const inpValue = $xeNumberInput.getNumberValue(inpNumVal)
631
- $xeNumberInput.handleChange(eqEmptyValue(inpValue) ? null : Number(inpValue), inpValue, { type: 'check' })
632
- }
633
- }
634
- },
635
- blurEvent (evnt: Event & { type: 'blur' }) {
636
- const $xeNumberInput = this
637
- const reactData = $xeNumberInput.reactData
638
- const $xeForm = $xeNumberInput.$xeForm
639
- const formItemInfo = $xeNumberInput.formItemInfo
640
-
641
- const { inputValue } = reactData
642
- const inpImmediate = $xeNumberInput.computeInpImmediate
643
- const value = inputValue ? Number(inputValue) : null
644
- if (!inpImmediate) {
645
- $xeNumberInput.handleChange(value, handleNumberString(inputValue), evnt)
646
- }
647
- $xeNumberInput.afterCheckValue()
648
- reactData.isFocus = false
649
- reactData.isActivated = false
650
- $xeNumberInput.dispatchEvent('blur', { value }, evnt)
651
- // 自动更新校验状态
652
- if ($xeForm && formItemInfo) {
653
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
654
- }
655
- },
656
- // 数值
657
- numberChange (isPlus: boolean, evnt: Event) {
658
- const $xeNumberInput = this
659
- const props = $xeNumberInput
660
- const reactData = $xeNumberInput.reactData
661
-
662
- const { min, max, type } = props
663
- const { inputValue } = reactData
664
- const stepValue = $xeNumberInput.computeStepValue
665
- const numValue = type === 'integer' ? XEUtils.toInteger(handleNumber(inputValue)) : XEUtils.toNumber(handleNumber(inputValue))
666
- const newValue = isPlus ? XEUtils.add(numValue, stepValue) : XEUtils.subtract(numValue, stepValue)
667
- let restNum: number | string
668
- if (!$xeNumberInput.validMinNum(newValue)) {
669
- restNum = min as number
670
- } else if (!$xeNumberInput.validMaxNum(newValue)) {
671
- restNum = max as number
672
- } else {
673
- restNum = newValue
674
- }
675
- $xeNumberInput.emitInputEvent($xeNumberInput.getNumberValue(restNum), evnt as (Event & { type: 'input' }))
676
- },
677
- numberPlusEvent (evnt: Event) {
678
- const $xeNumberInput = this
679
- const reactData = $xeNumberInput.reactData
680
-
681
- const isDisabled = $xeNumberInput.computeIsDisabled
682
- const formReadonly = $xeNumberInput.computeFormReadonly
683
- const isDisabledAddNumber = $xeNumberInput.computeIsDisabledAddNumber
684
- if (!isDisabled && !formReadonly && !isDisabledAddNumber) {
685
- $xeNumberInput.numberChange(true, evnt)
686
- }
687
- reactData.isActivated = true
688
- $xeNumberInput.dispatchEvent('plus-number', { value: reactData.inputValue }, evnt)
689
- $xeNumberInput.dispatchEvent('lazy-change', { value: reactData.inputValue }, evnt)
690
- // 已废弃
691
- $xeNumberInput.dispatchEvent('next-number', { value: reactData.inputValue }, evnt)
692
- },
693
- numberMinusEvent (evnt: Event) {
694
- const $xeNumberInput = this
695
- const reactData = $xeNumberInput.reactData
696
-
697
- const isDisabled = $xeNumberInput.computeIsDisabled
698
- const formReadonly = $xeNumberInput.computeFormReadonly
699
- const isDisabledSubtractNumber = $xeNumberInput.computeIsDisabledSubtractNumber
700
- if (!isDisabled && !formReadonly && !isDisabledSubtractNumber) {
701
- $xeNumberInput.numberChange(false, evnt)
702
- }
703
- reactData.isActivated = true
704
- $xeNumberInput.dispatchEvent('minus-number', { value: reactData.inputValue }, evnt)
705
- $xeNumberInput.dispatchEvent('lazy-change', { value: reactData.inputValue }, evnt)
706
- // 已废弃
707
- $xeNumberInput.dispatchEvent('prev-number', { value: reactData.inputValue }, evnt)
708
- },
709
- numberKeydownEvent (evnt: KeyboardEvent) {
710
- const $xeNumberInput = this
711
-
712
- const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
713
- const isDwArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
714
- if (isUpArrow || isDwArrow) {
715
- evnt.preventDefault()
716
- if (isUpArrow) {
717
- $xeNumberInput.numberPlusEvent(evnt)
718
- } else {
719
- $xeNumberInput.numberMinusEvent(evnt)
720
- }
721
- }
722
- },
723
- keydownEvent (evnt: KeyboardEvent & { type: 'keydown' }) {
724
- const $xeNumberInput = this
725
- const props = $xeNumberInput
726
-
727
- const { type, exponential, controls } = props
728
- const controlOpts = $xeNumberInput.computeControlOpts
729
- const { isArrow } = controlOpts
730
- const inputReadonly = $xeNumberInput.computeInputReadonly
731
- const isControlKey = hasControlKey(evnt)
732
- const isShiftKey = evnt.shiftKey
733
- const isAltKey = evnt.altKey
734
- const keyCode = evnt.keyCode
735
- const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE)
736
- const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
737
- const isDwArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
738
- if (!isControlKey && !isShiftKey && !isAltKey) {
739
- if (globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.SPACEBAR) || (type === 'integer' && keyCode === 110) || ((!exponential || keyCode !== 69) && (keyCode >= 65 && keyCode <= 90)) || (keyCode >= 186 && keyCode <= 188) || keyCode >= 191) {
740
- evnt.preventDefault()
741
- }
742
- }
743
- if (isEsc) {
744
- $xeNumberInput.afterCheckValue()
745
- } else if (isUpArrow || isDwArrow) {
746
- if (isEnableConf(controlOpts) && (controls === false ? controls : isArrow) && !inputReadonly) {
747
- $xeNumberInput.numberKeydownEvent(evnt)
748
- }
749
- }
750
- $xeNumberInput.triggerEvent(evnt)
751
- },
752
- keyupEvent (evnt: KeyboardEvent & { type: 'keyup' }) {
753
- const $xeNumberInput = this
754
-
755
- $xeNumberInput.triggerEvent(evnt)
756
- },
757
- // 数值
758
- stopDown () {
759
- const $xeNumberInput = this
760
- const internalData = $xeNumberInput.internalData
761
-
762
- const { dnTimeout } = internalData
763
- if (dnTimeout) {
764
- clearTimeout(dnTimeout)
765
- internalData.dnTimeout = undefined
766
- }
767
- },
768
- stopAutoIncrement () {
769
- const $xeNumberInput = this
770
- const internalData = $xeNumberInput.internalData
771
-
772
- const { ainTimeout } = internalData
773
- if (ainTimeout) {
774
- clearTimeout(ainTimeout)
775
- internalData.ainTimeout = undefined
776
- }
777
- },
778
- numberDownMinusEvent (evnt: Event) {
779
- const $xeNumberInput = this
780
- const internalData = $xeNumberInput.internalData
781
-
782
- $xeNumberInput.numberStopAll()
783
- internalData.ainTimeout = setTimeout(() => {
784
- $xeNumberInput.numberMinusEvent(evnt)
785
- $xeNumberInput.numberDownMinusEvent(evnt)
786
- }, 60)
787
- },
788
- numberDownPlusEvent (evnt: Event) {
789
- const $xeNumberInput = this
790
- const internalData = $xeNumberInput.internalData
791
-
792
- $xeNumberInput.numberStopAll()
793
- internalData.ainTimeout = setTimeout(() => {
794
- $xeNumberInput.numberPlusEvent(evnt)
795
- $xeNumberInput.numberDownPlusEvent(evnt)
796
- }, 60)
797
- },
798
- numberStopAll () {
799
- const $xeNumberInput = this
800
-
801
- $xeNumberInput.stopDown()
802
- $xeNumberInput.stopAutoIncrement()
803
- },
804
- numberClickEvent (evnt: MouseEvent) {
805
- const $xeNumberInput = this
806
- const internalData = $xeNumberInput.internalData
807
-
808
- if (internalData.isMouseDown) {
809
- internalData.isMouseDown = false
810
- } else {
811
- $xeNumberInput.numberStopAll()
812
- const isAddNumber = hasClass(evnt.currentTarget, 'is--plus')
813
- if (isAddNumber) {
814
- $xeNumberInput.numberPlusEvent(evnt)
815
- } else {
816
- $xeNumberInput.numberMinusEvent(evnt)
817
- }
818
- }
819
- },
820
- numberMousedownEvent (evnt: MouseEvent) {
821
- const $xeNumberInput = this
822
- const internalData = $xeNumberInput.internalData
823
-
824
- $xeNumberInput.numberStopAll()
825
- internalData.isMouseDown = true
826
- if (evnt.button === 0) {
827
- const isAddNumber = hasClass(evnt.currentTarget, 'is--plus')
828
- if (isAddNumber) {
829
- $xeNumberInput.numberPlusEvent(evnt)
830
- } else {
831
- $xeNumberInput.numberMinusEvent(evnt)
832
- }
833
- internalData.dnTimeout = setTimeout(() => {
834
- if (isAddNumber) {
835
- $xeNumberInput.numberDownPlusEvent(evnt)
836
- } else {
837
- $xeNumberInput.numberDownMinusEvent(evnt)
838
- }
839
- }, 500)
840
- }
841
- },
842
- wheelEvent (evnt: WheelEvent) {
843
- const $xeNumberInput = this
844
- const props = $xeNumberInput
845
- const reactData = $xeNumberInput.reactData
846
-
847
- const { controls } = props
848
- const controlOpts = $xeNumberInput.computeControlOpts
849
- const { isWheel } = controlOpts
850
- const inputReadonly = $xeNumberInput.computeInputReadonly
851
- if (isEnableConf(controlOpts) && (controls === false ? controls : isWheel) && !inputReadonly) {
852
- if (reactData.isActivated) {
853
- evnt.stopPropagation()
854
- evnt.preventDefault()
855
- const delta = evnt.deltaY
856
- if (delta > 0) {
857
- // 向下
858
- $xeNumberInput.numberMinusEvent(evnt)
859
- } else if (delta < 0) {
860
- // 向上
861
- $xeNumberInput.numberPlusEvent(evnt)
862
- }
863
- }
864
- }
865
- $xeNumberInput.triggerEvent(evnt as WheelEvent & { type: 'wheel' })
866
- },
867
- clickEvent (evnt: Event & { type: 'click' }) {
868
- const $xeNumberInput = this
869
-
870
- $xeNumberInput.triggerEvent(evnt)
871
- },
872
- // 全局事件
873
- handleGlobalMousedownEvent (evnt: Event) {
874
- const $xeNumberInput = this
875
- const reactData = $xeNumberInput.reactData
876
-
877
- const { isActivated } = reactData
878
- const el = $xeNumberInput.$refs.refElem as HTMLElement
879
- const panelElem = $xeNumberInput.$refs.refInputPanel as HTMLDivElement
880
- const isDisabled = $xeNumberInput.computeIsDisabled
881
- const inpImmediate = $xeNumberInput.computeInpImmediate
882
- const inputReadonly = $xeNumberInput.computeInputReadonly
883
- if (!isDisabled && !inputReadonly && isActivated) {
884
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
885
- if (!reactData.isActivated) {
886
- if (!inpImmediate) {
887
- const { inputValue } = reactData
888
- const value = inputValue ? Number(inputValue) : null
889
- $xeNumberInput.handleChange(value, handleNumberString(inputValue), evnt)
890
- }
891
- $xeNumberInput.afterCheckValue()
892
- }
893
- }
894
- },
895
- handleGlobalKeydownEvent (evnt: KeyboardEvent) {
896
- const $xeNumberInput = this
897
- const props = $xeNumberInput
898
- const reactData = $xeNumberInput.reactData
899
-
900
- const { clearable } = props
901
- const isDisabled = $xeNumberInput.computeIsDisabled
902
- const inputReadonly = $xeNumberInput.computeInputReadonly
903
- if (!isDisabled && !inputReadonly) {
904
- const isTab = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.TAB)
905
- const isDel = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.DELETE)
906
- let isActivated = reactData.isActivated
907
- if (isTab) {
908
- if (isActivated) {
909
- $xeNumberInput.afterCheckValue()
910
- }
911
- isActivated = false
912
- reactData.isActivated = isActivated
913
- }
914
- if (isDel && clearable) {
915
- if (isActivated) {
916
- $xeNumberInput.clearValueEvent(evnt, null)
917
- }
918
- }
919
- }
920
- },
921
- handleGlobalBlurEvent () {
922
- const $xeNumberInput = this
923
- const reactData = $xeNumberInput.reactData
924
-
925
- const { isActivated } = reactData
926
- if (isActivated) {
927
- $xeNumberInput.afterCheckValue()
928
- }
929
- },
930
-
931
- //
932
- // Render
933
- //
934
- renderPrefixIcon (h: CreateElement) {
935
- const $xeNumberInput = this
936
- const props = $xeNumberInput
937
- const slots = $xeNumberInput.$scopedSlots
938
-
939
- const { prefixIcon } = props
940
- const prefixOpts = $xeNumberInput.computePrefixOpts
941
- const prefixSlot = slots.prefix
942
- const preIcon = prefixIcon || prefixOpts.icon
943
- const sufContent = prefixOpts.content
944
- return prefixSlot || preIcon || sufContent
945
- ? h('div', {
946
- class: 'vxe-number-input--prefix',
947
- on: {
948
- click: $xeNumberInput.clickPrefixEvent
949
- }
950
- }, [
951
- h('div', {
952
- class: 'vxe-number-input--prefix-icon'
953
- }, prefixSlot
954
- ? getSlotVNs(prefixSlot({}))
955
- : [
956
- preIcon
957
- ? h('i', {
958
- class: preIcon
959
- })
960
- : renderEmptyElement($xeNumberInput),
961
- sufContent
962
- ? h('span', {
963
- class: 'vxe-prefix-input--suffix-text'
964
- }, `${sufContent}`)
965
- : renderEmptyElement($xeNumberInput)
966
- ])
967
- ])
968
- : renderEmptyElement($xeNumberInput)
969
- },
970
- renderSuffixIcon (h: CreateElement) {
971
- const $xeNumberInput = this
972
- const props = $xeNumberInput
973
- const reactData = $xeNumberInput.reactData
974
- const slots = $xeNumberInput.$scopedSlots
975
-
976
- const { suffixIcon } = props
977
- const { inputValue } = reactData
978
- const suffixSlot = slots.suffix
979
- const suffixOpts = $xeNumberInput.computeSuffixOpts
980
- const isDisabled = $xeNumberInput.computeIsDisabled
981
- const isClearable = $xeNumberInput.computeIsClearable
982
- const sufIcon = suffixIcon || suffixOpts.icon
983
- const sufContent = suffixOpts.content
984
- return h('div', {
985
- class: ['vxe-number-input--suffix', {
986
- 'is--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
987
- }]
988
- }, [
989
- isClearable
990
- ? h('div', {
991
- class: 'vxe-number-input--clear-icon',
992
- on: {
993
- click: $xeNumberInput.clearValueEvent
994
- }
995
- }, [
996
- h('i', {
997
- class: getIcon().INPUT_CLEAR
998
- })
999
- ])
1000
- : renderEmptyElement($xeNumberInput),
1001
- suffixSlot || sufIcon || sufContent
1002
- ? h('div', {
1003
- class: 'vxe-number-input--suffix-icon',
1004
- on: {
1005
- click: $xeNumberInput.clickSuffixEvent
1006
- }
1007
- }, suffixSlot
1008
- ? getSlotVNs(suffixSlot({}))
1009
- : [
1010
- sufIcon
1011
- ? h('i', {
1012
- class: sufIcon
1013
- })
1014
- : renderEmptyElement($xeNumberInput),
1015
- sufContent
1016
- ? h('span', {
1017
- class: 'vxe-number-input--suffix-text'
1018
- }, `${sufContent}`)
1019
- : renderEmptyElement($xeNumberInput)
1020
- ])
1021
- : renderEmptyElement($xeNumberInput)
1022
- ])
1023
- },
1024
- renderInput (h: CreateElement) {
1025
- const $xeNumberInput = this
1026
- const props = $xeNumberInput
1027
- const reactData = $xeNumberInput.reactData
1028
-
1029
- const { type, name, autocomplete, autoComplete } = props
1030
- const { inputValue, isFocus } = reactData
1031
- const isDisabled = $xeNumberInput.computeIsDisabled
1032
- const numLabel = $xeNumberInput.computeNumLabel
1033
- const inputReadonly = $xeNumberInput.computeInputReadonly
1034
- const inpMaxLength = $xeNumberInput.computeInpMaxLength
1035
- const inpPlaceholder = $xeNumberInput.computeInpPlaceholder
1036
- return h('div', {
1037
- key: 'ni',
1038
- class: 'vxe-number-input--input-wrapper'
1039
- }, [
1040
- $xeNumberInput.renderPrefixIcon(h),
1041
- h('div', {
1042
- class: 'vxe-number-input--input-inner'
1043
- }, [
1044
- h('input', {
1045
- ref: 'refInputTarget',
1046
- class: 'vxe-number-input--input',
1047
- domProps: {
1048
- value: !isFocus && type === 'amount' ? numLabel : inputValue
1049
- },
1050
- attrs: {
1051
- name,
1052
- type: 'text',
1053
- placeholder: inpPlaceholder,
1054
- maxlength: inpMaxLength,
1055
- readonly: inputReadonly,
1056
- disabled: isDisabled,
1057
- autocomplete: autoComplete || autocomplete
1058
- },
1059
- on: {
1060
- keydown: $xeNumberInput.keydownEvent,
1061
- keyup: $xeNumberInput.keyupEvent,
1062
- click: $xeNumberInput.clickEvent,
1063
- input: $xeNumberInput.inputEvent,
1064
- change: $xeNumberInput.changeEvent,
1065
- focus: $xeNumberInput.focusEvent,
1066
- blur: $xeNumberInput.blurEvent
1067
- }
1068
- })
1069
- ]),
1070
- $xeNumberInput.renderSuffixIcon(h)
1071
- ])
1072
- },
1073
- renderMinusBtn (h: CreateElement) {
1074
- const $xeNumberInput = this
1075
- const props = $xeNumberInput
1076
-
1077
- const { minusIcon } = props
1078
- const isDisabledSubtractNumber = $xeNumberInput.computeIsDisabledSubtractNumber
1079
- return h('button', {
1080
- key: 'prev',
1081
- class: ['vxe-number-input--minus-btn is--minus', {
1082
- 'is--disabled': isDisabledSubtractNumber
1083
- }],
1084
- attrs: {
1085
- type: 'button'
1086
- },
1087
- on: {
1088
- click: $xeNumberInput.numberClickEvent,
1089
- mousedown: $xeNumberInput.numberMousedownEvent,
1090
- mouseup: $xeNumberInput.numberStopAll,
1091
- mouseleave: $xeNumberInput.numberStopAll
1092
- }
1093
- }, [
1094
- h('i', {
1095
- class: minusIcon || getIcon().NUMBER_INPUT_MINUS_NUM
1096
- })
1097
- ])
1098
- },
1099
- renderPlusBtn (h: CreateElement) {
1100
- const $xeNumberInput = this
1101
- const props = $xeNumberInput
1102
-
1103
- const { plusIcon } = props
1104
- const isDisabledAddNumber = $xeNumberInput.computeIsDisabledAddNumber
1105
- return h('button', {
1106
- key: 'next',
1107
- class: ['vxe-number-input--plus-btn is--plus', {
1108
- 'is--disabled': isDisabledAddNumber
1109
- }],
1110
- attrs: {
1111
- type: 'button'
1112
- },
1113
- on: {
1114
- click: $xeNumberInput.numberClickEvent,
1115
- mousedown: $xeNumberInput.numberMousedownEvent,
1116
- mouseup: $xeNumberInput.numberStopAll,
1117
- mouseleave: $xeNumberInput.numberStopAll
1118
- }
1119
- }, [
1120
- h('i', {
1121
- class: plusIcon || getIcon().NUMBER_INPUT_PLUS_NUM
1122
- })
1123
- ])
1124
- },
1125
- renderSideControl (h: CreateElement) {
1126
- const $xeNumberInput = this
1127
-
1128
- return h('div', {
1129
- key: 'cplr',
1130
- class: 'vxe-number-input--side-control'
1131
- }, [
1132
- $xeNumberInput.renderPlusBtn(h),
1133
- $xeNumberInput.renderMinusBtn(h)
1134
- ])
1135
- },
1136
- renderVN (h: CreateElement): VNode {
1137
- const $xeNumberInput = this
1138
- const props = $xeNumberInput
1139
- const reactData = $xeNumberInput.reactData
1140
- const slots = $xeNumberInput.$scopedSlots
1141
-
1142
- const { className, controls, type, align, prefixIcon, suffixIcon } = props
1143
- const { inputValue, isActivated } = reactData
1144
- const vSize = $xeNumberInput.computeSize
1145
- const controlOpts = $xeNumberInput.computeControlOpts
1146
- const { layout, showButton } = controlOpts
1147
- const isDisabled = $xeNumberInput.computeIsDisabled
1148
- const formReadonly = $xeNumberInput.computeFormReadonly
1149
- const numLabel = $xeNumberInput.computeNumLabel
1150
- const prefixSlot = slots.prefix
1151
- const suffixSlot = slots.suffix
1152
- if (formReadonly) {
1153
- return h('div', {
1154
- ref: 'refElem',
1155
- class: ['vxe-number-input--readonly', `type--${type}`, className]
1156
- }, numLabel)
1157
- }
1158
- const inputReadonly = $xeNumberInput.computeInputReadonly
1159
- const isClearable = $xeNumberInput.computeIsClearable
1160
- const isControls = isEnableConf(controlOpts) && (controls === false ? controls : showButton)
1161
- return h('div', {
1162
- ref: 'refElem',
1163
- class: ['vxe-number-input', `type--${type}`, `ctl--${layout === 'right' || layout === 'left' ? layout : 'default'}`, className, {
1164
- [`size--${vSize}`]: vSize,
1165
- [`is--${align}`]: align,
1166
- 'is--controls': isControls && !inputReadonly,
1167
- 'is--prefix': !!prefixSlot || prefixIcon,
1168
- 'is--suffix': !!suffixSlot || suffixIcon,
1169
- 'is--disabled': isDisabled,
1170
- 'is--active': isActivated,
1171
- 'show--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
1172
- }],
1173
- attrs: {
1174
- spellcheck: false
1175
- }
1176
- }, isControls
1177
- ? (layout === 'right'
1178
- ? [
1179
- $xeNumberInput.renderInput(h),
1180
- $xeNumberInput.renderSideControl(h)
1181
- ]
1182
- : (layout === 'left'
1183
- ? [
1184
- $xeNumberInput.renderSideControl(h),
1185
- $xeNumberInput.renderInput(h)
1186
- ]
1187
- : [
1188
- $xeNumberInput.renderMinusBtn(h),
1189
- $xeNumberInput.renderInput(h),
1190
- $xeNumberInput.renderPlusBtn(h)
1191
- ]))
1192
- : [
1193
- $xeNumberInput.renderInput(h)
1194
- ])
1195
- }
1196
- },
1197
- watch: {
1198
- value (val) {
1199
- const $xeNumberInput = this
1200
- const internalData = $xeNumberInput.internalData
1201
-
1202
- if (!internalData.isUM) {
1203
- this.updateModel(val)
1204
- }
1205
- internalData.isUM = false
1206
- },
1207
- type () {
1208
- const $xeNumberInput = this
1209
- const props = $xeNumberInput
1210
- const reactData = $xeNumberInput.reactData
1211
-
1212
- // 切换类型是重置内置变量
1213
- Object.assign(reactData, {
1214
- inputValue: props.value
1215
- })
1216
- $xeNumberInput.initValue()
1217
- }
1218
- },
1219
- created () {
1220
- const $xeNumberInput = this
1221
- const props = $xeNumberInput
1222
-
1223
- this.updateModel(props.value)
1224
- $xeNumberInput.initValue()
1225
- },
1226
- mounted () {
1227
- const $xeNumberInput = this
1228
-
1229
- const targetElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
1230
- if (targetElem) {
1231
- targetElem.addEventListener('wheel', $xeNumberInput.wheelEvent, { passive: false })
1232
- }
1233
- globalEvents.on($xeNumberInput, 'mousedown', $xeNumberInput.handleGlobalMousedownEvent)
1234
- globalEvents.on($xeNumberInput, 'keydown', $xeNumberInput.handleGlobalKeydownEvent)
1235
- globalEvents.on($xeNumberInput, 'blur', $xeNumberInput.handleGlobalBlurEvent)
1236
- },
1237
- beforeDestroy () {
1238
- const $xeNumberInput = this
1239
- const reactData = $xeNumberInput.reactData
1240
-
1241
- reactData.isFocus = false
1242
- $xeNumberInput.numberStopAll()
1243
- $xeNumberInput.afterCheckValue()
1244
- const targetElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
1245
- if (targetElem) {
1246
- targetElem.removeEventListener('wheel', $xeNumberInput.wheelEvent)
1247
- }
1248
- globalEvents.off($xeNumberInput, 'mousedown')
1249
- globalEvents.off($xeNumberInput, 'keydown')
1250
- globalEvents.off($xeNumberInput, 'blur')
1251
- },
1252
- render (this: any, h) {
1253
- return this.renderVN(h)
1254
- }
1255
- }) /* define-vxe-component end */
1
+ import { CreateElement, PropType, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { getConfig, getIcon, getI18n, globalEvents, GLOBAL_EVENT_KEYS, createEvent, globalMixins, renderEmptyElement } from '../../ui'
5
+ import { getFuncText, eqEmptyValue, isEnableConf } from '../../ui/src/utils'
6
+ import { hasClass, getEventTargetNode, hasControlKey } from '../../ui/src/dom'
7
+ import { getSlotVNs } from '../../ui/src/vn'
8
+ import { handleNumber, toFloatValueFixed } from './util'
9
+
10
+ import type { NumberInputInternalData, VxeNumberInputEmits, NumberInputReactData, VxeNumberInputPropTypes, VxeComponentSizeType, VxeFormConstructor, ValueOf, VxeFormPrivateMethods, VxeFormDefines } from '../../../types'
11
+
12
+ const handleNumberString = (val: any) => {
13
+ if (XEUtils.eqNull(val)) {
14
+ return ''
15
+ }
16
+ return `${val}`
17
+ }
18
+
19
+ export default /* define-vxe-component start */ defineVxeComponent({
20
+ name: 'VxeNumberInput',
21
+ mixins: [
22
+ globalMixins.sizeMixin
23
+ ],
24
+ model: {
25
+ prop: 'value',
26
+ event: 'modelValue'
27
+ },
28
+ props: {
29
+ value: [String, Number] as PropType<VxeNumberInputPropTypes.ModelValue>,
30
+ immediate: {
31
+ type: Boolean as PropType<VxeNumberInputPropTypes.Immediate>,
32
+ default: true
33
+ },
34
+ name: String as PropType<VxeNumberInputPropTypes.Name>,
35
+ type: {
36
+ type: String as PropType<VxeNumberInputPropTypes.Type>,
37
+ default: 'number'
38
+ },
39
+ clearable: {
40
+ type: Boolean as PropType<VxeNumberInputPropTypes.Clearable>,
41
+ default: () => getConfig().numberInput.clearable
42
+ },
43
+ readonly: {
44
+ type: Boolean as PropType<VxeNumberInputPropTypes.Readonly>,
45
+ default: null
46
+ },
47
+ disabled: {
48
+ type: Boolean as PropType<VxeNumberInputPropTypes.Disabled>,
49
+ default: null
50
+ },
51
+ placeholder: String as PropType<VxeNumberInputPropTypes.Placeholder>,
52
+ maxLength: {
53
+ type: [String, Number] as PropType<VxeNumberInputPropTypes.MaxLength>,
54
+ default: () => getConfig().numberInput.maxLength
55
+ },
56
+ autoComplete: {
57
+ type: String as PropType<VxeNumberInputPropTypes.AutoComplete>,
58
+ default: 'off'
59
+ },
60
+ align: String as PropType<VxeNumberInputPropTypes.Align>,
61
+ form: String as PropType<VxeNumberInputPropTypes.Form>,
62
+ className: String as PropType<VxeNumberInputPropTypes.ClassName>,
63
+ size: {
64
+ type: String as PropType<VxeNumberInputPropTypes.Size>,
65
+ default: () => getConfig().numberInput.size || getConfig().size
66
+ },
67
+
68
+ // number、integer、float
69
+ min: {
70
+ type: [String, Number] as PropType<VxeNumberInputPropTypes.Min>,
71
+ default: null
72
+ },
73
+ max: {
74
+ type: [String, Number] as PropType<VxeNumberInputPropTypes.Max>,
75
+ default: null
76
+ },
77
+ step: [String, Number] as PropType<VxeNumberInputPropTypes.Step>,
78
+ exponential: {
79
+ type: Boolean as PropType<VxeNumberInputPropTypes.Exponential>,
80
+ default: () => getConfig().numberInput.exponential
81
+ },
82
+ showCurrency: {
83
+ type: Boolean as PropType<VxeNumberInputPropTypes.ShowCurrency>,
84
+ default: () => getConfig().numberInput.showCurrency
85
+ },
86
+ currencySymbol: {
87
+ type: String as PropType<VxeNumberInputPropTypes.CurrencySymbol>,
88
+ default: () => getConfig().numberInput.currencySymbol
89
+ },
90
+ controlConfig: Object as PropType<VxeNumberInputPropTypes.ControlConfig>,
91
+
92
+ // float
93
+ digits: {
94
+ type: [String, Number] as PropType<VxeNumberInputPropTypes.Digits>,
95
+ default: null
96
+ },
97
+ autoFill: {
98
+ type: Boolean as PropType<VxeNumberInputPropTypes.AutoFill>,
99
+ default: () => getConfig().numberInput.autoFill
100
+ },
101
+ editable: {
102
+ type: Boolean as PropType<VxeNumberInputPropTypes.Editable>,
103
+ default: true
104
+ },
105
+
106
+ plusIcon: String as PropType<VxeNumberInputPropTypes.PlusIcon>,
107
+ minusIcon: String as PropType<VxeNumberInputPropTypes.MinusIcon>,
108
+ prefixIcon: String as PropType<VxeNumberInputPropTypes.PrefixIcon>,
109
+ prefixConfig: Object as PropType<VxeNumberInputPropTypes.PrefixConfig>,
110
+ suffixIcon: String as PropType<VxeNumberInputPropTypes.SuffixIcon>,
111
+ suffixConfig: Object as PropType<VxeNumberInputPropTypes.SuffixConfig>,
112
+
113
+ // 已废弃
114
+ controls: {
115
+ type: Boolean as PropType<VxeNumberInputPropTypes.Controls>,
116
+ default: null
117
+ },
118
+ // 已废弃
119
+ maxlength: [String, Number] as PropType<VxeNumberInputPropTypes.Maxlength>,
120
+ // 已废弃
121
+ autocomplete: String as PropType<VxeNumberInputPropTypes.Autocomplete>
122
+ },
123
+ inject: {
124
+ $xeForm: {
125
+ default: null
126
+ },
127
+ formItemInfo: {
128
+ from: 'xeFormItemInfo',
129
+ default: null
130
+ }
131
+ },
132
+ data () {
133
+ const xID = XEUtils.uniqueId()
134
+ const reactData: NumberInputReactData = {
135
+ isFocus: false,
136
+ isActivated: false,
137
+ inputValue: ''
138
+ }
139
+ const internalData: NumberInputInternalData = {
140
+ // dnTimeout: undefined,
141
+ // ainTimeout: undefined,
142
+ // isMouseDown: undefined,
143
+ // isUM: undefined
144
+ }
145
+ return {
146
+ xID,
147
+ reactData,
148
+ internalData
149
+ }
150
+ },
151
+ computed: {
152
+ ...({} as {
153
+ computeSize(): VxeComponentSizeType
154
+ $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
155
+ formItemInfo(): VxeFormDefines.ProvideItemInfo | null
156
+ }),
157
+ computeFormReadonly () {
158
+ const $xeNumberInput = this
159
+ const props = $xeNumberInput
160
+ const $xeForm = $xeNumberInput.$xeForm
161
+
162
+ const { readonly } = props
163
+ if (readonly === null) {
164
+ if ($xeForm) {
165
+ return $xeForm.readonly
166
+ }
167
+ return false
168
+ }
169
+ return readonly
170
+ },
171
+ computeIsDisabled () {
172
+ const $xeNumberInput = this
173
+ const props = $xeNumberInput
174
+ const $xeForm = $xeNumberInput.$xeForm
175
+
176
+ const { disabled } = props
177
+ if (disabled === null) {
178
+ if ($xeForm) {
179
+ return $xeForm.disabled
180
+ }
181
+ return false
182
+ }
183
+ return disabled
184
+ },
185
+ computeDigitsValue () {
186
+ const $xeNumberInput = this
187
+ const props = $xeNumberInput
188
+
189
+ const { type, digits } = props
190
+ let defDigits: any = digits
191
+ if (defDigits === null) {
192
+ defDigits = getConfig().numberInput.digits
193
+ if (defDigits === null) {
194
+ if (type === 'amount') {
195
+ defDigits = 2
196
+ }
197
+ }
198
+ }
199
+ return XEUtils.toInteger(defDigits) || 1
200
+ },
201
+ computeControlOpts () {
202
+ const $xeNumberInput = this
203
+ const props = $xeNumberInput
204
+
205
+ return Object.assign({}, getConfig().numberInput.controlConfig, props.controlConfig)
206
+ },
207
+ computePrefixOpts () {
208
+ const $xeNumberInput = this
209
+ const props = $xeNumberInput
210
+
211
+ return Object.assign({}, getConfig().numberInput.prefixConfig, props.prefixConfig)
212
+ },
213
+ computeSuffixOpts () {
214
+ const $xeNumberInput = this
215
+ const props = $xeNumberInput
216
+
217
+ return Object.assign({}, getConfig().numberInput.suffixConfig, props.suffixConfig)
218
+ },
219
+ computeDecimalsType () {
220
+ const $xeNumberInput = this
221
+ const props = $xeNumberInput
222
+
223
+ const { type } = props
224
+ return type === 'float' || type === 'amount'
225
+ },
226
+ computeStepValue () {
227
+ const $xeNumberInput = this
228
+ const props = $xeNumberInput
229
+
230
+ const { type } = props
231
+ const digitsValue = $xeNumberInput.computeDigitsValue as number
232
+ const decimalsType = $xeNumberInput.computeDecimalsType
233
+ const step = props.step
234
+ if (type === 'integer') {
235
+ return XEUtils.toInteger(step) || 1
236
+ } else if (decimalsType) {
237
+ return XEUtils.toNumber(step) || (1 / Math.pow(10, digitsValue))
238
+ }
239
+ return XEUtils.toNumber(step) || 1
240
+ },
241
+ computeIsClearable () {
242
+ const $xeNumberInput = this
243
+ const props = $xeNumberInput
244
+
245
+ return props.clearable
246
+ },
247
+ computeInputReadonly () {
248
+ const $xeNumberInput = this
249
+ const props = $xeNumberInput
250
+
251
+ const { editable } = props
252
+ const formReadonly = $xeNumberInput.computeFormReadonly
253
+ return formReadonly || !editable
254
+ },
255
+ computeInpPlaceholder () {
256
+ const $xeNumberInput = this
257
+ const props = $xeNumberInput
258
+
259
+ const { placeholder } = props
260
+ if (placeholder) {
261
+ return getFuncText(placeholder)
262
+ }
263
+ const globalPlaceholder = getConfig().numberInput.placeholder
264
+ if (globalPlaceholder) {
265
+ return getFuncText(globalPlaceholder)
266
+ }
267
+ return getI18n('vxe.base.pleaseInput')
268
+ },
269
+ computeInpMaxLength () {
270
+ const $xeNumberInput = this
271
+ const props = $xeNumberInput
272
+
273
+ const { type, maxLength, maxlength, min, max } = props
274
+ const digitsValue = $xeNumberInput.computeDigitsValue as number
275
+ // 数值最大长度默认限制 16 位,包含小数
276
+ const maxDefLen = 16
277
+ if (!eqEmptyValue(min) && !eqEmptyValue(max)) {
278
+ return `${max}`.length + (type === 'integer' ? 0 : (digitsValue + 1)) + (XEUtils.toNumber(min) >= 0 ? 0 : 1)
279
+ }
280
+ if (maxLength || maxlength) {
281
+ return XEUtils.toNumber(maxLength || maxlength)
282
+ }
283
+ return maxDefLen
284
+ },
285
+ computeInpImmediate () {
286
+ const $xeNumberInput = this
287
+ const props = $xeNumberInput
288
+
289
+ const { immediate } = props
290
+ return immediate
291
+ },
292
+ computeNumValue () {
293
+ const $xeNumberInput = this as any
294
+ const props = $xeNumberInput
295
+ const reactData = $xeNumberInput.reactData
296
+
297
+ const { type } = props
298
+ const { inputValue } = reactData
299
+ return type === 'integer' ? XEUtils.toInteger(handleNumber(inputValue)) : XEUtils.toNumber(handleNumber(inputValue))
300
+ },
301
+ computeNumLabel () {
302
+ const $xeNumberInput = this as any
303
+ const props = $xeNumberInput
304
+ const reactData = $xeNumberInput.reactData
305
+
306
+ const { type, showCurrency, currencySymbol, autoFill } = props
307
+ const { inputValue } = reactData
308
+ const digitsValue = $xeNumberInput.computeDigitsValue
309
+ if (type === 'amount') {
310
+ const num = XEUtils.toNumber(inputValue)
311
+ let amountLabel = XEUtils.commafy(num, { digits: digitsValue })
312
+ if (!autoFill) {
313
+ const [iStr, dStr] = amountLabel.split('.')
314
+ if (dStr) {
315
+ const dRest = dStr.replace(/0+$/, '')
316
+ amountLabel = dRest ? [iStr, '.', dRest].join('') : iStr
317
+ }
318
+ }
319
+ if (showCurrency) {
320
+ return `${currencySymbol || getI18n('vxe.numberInput.currencySymbol') || ''}${amountLabel}`
321
+ }
322
+ return amountLabel
323
+ }
324
+ return XEUtils.toString(inputValue)
325
+ },
326
+ computeIsDisabledSubtractNumber () {
327
+ const $xeNumberInput = this as any
328
+ const props = $xeNumberInput
329
+ const reactData = $xeNumberInput.reactData
330
+
331
+ const { min } = props
332
+ const { inputValue } = reactData
333
+ const numValue = $xeNumberInput.computeNumValue as number
334
+ // 当有值时再进行判断
335
+ if ((inputValue || inputValue === 0) && min !== null) {
336
+ return numValue <= XEUtils.toNumber(min)
337
+ }
338
+ return false
339
+ },
340
+ computeIsDisabledAddNumber () {
341
+ const $xeNumberInput = this as any
342
+ const props = $xeNumberInput
343
+ const reactData = $xeNumberInput.reactData
344
+
345
+ const { max } = props
346
+ const { inputValue } = reactData
347
+ const numValue = $xeNumberInput.computeNumValue as number
348
+ // 当有值时再进行判断
349
+ if ((inputValue || inputValue === 0) && max !== null) {
350
+ return numValue >= XEUtils.toNumber(max)
351
+ }
352
+ return false
353
+ }
354
+ },
355
+ methods: {
356
+ //
357
+ // Method
358
+ //
359
+ dispatchEvent (type: ValueOf<VxeNumberInputEmits>, params: Record<string, any>, evnt: Event | null) {
360
+ const $xeNumberInput = this
361
+ $xeNumberInput.$emit(type, createEvent(evnt, { $numberInput: $xeNumberInput }, params))
362
+ },
363
+ emitModel (value: any) {
364
+ const $xeNumberInput = this
365
+
366
+ const { _events } = $xeNumberInput as any
367
+ if (_events && _events.modelValue) {
368
+ $xeNumberInput.$emit('modelValue', value)
369
+ } else {
370
+ $xeNumberInput.$emit('model-value', value)
371
+ }
372
+ },
373
+ focus () {
374
+ const $xeNumberInput = this
375
+ const reactData = $xeNumberInput.reactData
376
+
377
+ const inputReadonly = $xeNumberInput.computeInputReadonly
378
+ if (!inputReadonly) {
379
+ const inputElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
380
+ reactData.isActivated = true
381
+ inputElem.focus()
382
+ }
383
+ return $xeNumberInput.$nextTick()
384
+ },
385
+ blur () {
386
+ const $xeNumberInput = this
387
+ const reactData = $xeNumberInput.reactData
388
+
389
+ const inputElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
390
+ inputElem.blur()
391
+ reactData.isActivated = false
392
+ return $xeNumberInput.$nextTick()
393
+ },
394
+ select () {
395
+ const $xeNumberInput = this
396
+ const reactData = $xeNumberInput.reactData
397
+
398
+ const inputElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
399
+ inputElem.select()
400
+ reactData.isActivated = false
401
+ return $xeNumberInput.$nextTick()
402
+ },
403
+ getNumberValue (val: any) {
404
+ const $xeNumberInput = this
405
+ const props = $xeNumberInput
406
+
407
+ const { exponential, autoFill } = props
408
+ const inpMaxLength = $xeNumberInput.computeInpMaxLength
409
+ const digitsValue = $xeNumberInput.computeDigitsValue
410
+ const decimalsType = $xeNumberInput.computeDecimalsType
411
+ let restVal = ''
412
+ if (decimalsType) {
413
+ restVal = toFloatValueFixed(val, digitsValue)
414
+ if (!autoFill) {
415
+ restVal = handleNumberString(XEUtils.toNumber(restVal))
416
+ }
417
+ } else {
418
+ restVal = handleNumberString(val)
419
+ }
420
+ if (exponential && (val === restVal || handleNumberString(val).toLowerCase() === XEUtils.toNumber(restVal).toExponential())) {
421
+ return val
422
+ }
423
+ return restVal.slice(0, inpMaxLength)
424
+ },
425
+ triggerEvent (evnt: Event & { type: 'input' | 'change' | 'keydown' | 'keyup' | 'wheel' | 'click' | 'focus' | 'blur' }) {
426
+ const $xeNumberInput = this
427
+ const reactData = $xeNumberInput.reactData
428
+
429
+ const { inputValue } = reactData
430
+ $xeNumberInput.dispatchEvent(evnt.type, { value: inputValue }, evnt)
431
+ },
432
+ handleChange (val: number | null, inputValue: string, evnt: Event | { type: string }) {
433
+ const $xeNumberInput = this
434
+ const props = $xeNumberInput
435
+ const reactData = $xeNumberInput.reactData
436
+ const internalData = $xeNumberInput.internalData
437
+ const $xeForm = $xeNumberInput.$xeForm
438
+ const formItemInfo = $xeNumberInput.formItemInfo
439
+
440
+ const value = eqEmptyValue(val) ? null : Number(val)
441
+ const isChange = value !== props.value
442
+ if (isChange) {
443
+ internalData.isUM = true
444
+ $xeNumberInput.emitModel(value)
445
+ }
446
+ if (reactData.inputValue !== inputValue) {
447
+ $xeNumberInput.$nextTick(() => {
448
+ reactData.inputValue = inputValue || ''
449
+ })
450
+ }
451
+ $xeNumberInput.dispatchEvent('input', { value }, evnt as Event)
452
+ if (isChange) {
453
+ $xeNumberInput.dispatchEvent('change', { value }, evnt as Event)
454
+ // 自动更新校验状态
455
+ if ($xeForm && formItemInfo) {
456
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
457
+ }
458
+ }
459
+ },
460
+ emitInputEvent (inputValue: any, evnt: Event) {
461
+ const $xeNumberInput = this
462
+ const reactData = $xeNumberInput.reactData
463
+
464
+ const inpImmediate = $xeNumberInput.computeInpImmediate
465
+ const value = inputValue === eqEmptyValue(inputValue) ? null : XEUtils.toNumber(inputValue)
466
+ reactData.inputValue = inputValue
467
+ if (inpImmediate) {
468
+ $xeNumberInput.handleChange(value, inputValue, evnt)
469
+ } else {
470
+ $xeNumberInput.dispatchEvent('input', { value }, evnt)
471
+ }
472
+ },
473
+ inputEvent (evnt: Event & { type: 'input' }) {
474
+ const $xeNumberInput = this
475
+
476
+ const inputElem = evnt.target as HTMLInputElement
477
+ const value = inputElem.value
478
+ $xeNumberInput.emitInputEvent(value, evnt)
479
+ },
480
+ changeEvent (evnt: Event & { type: 'change' }) {
481
+ const $xeNumberInput = this
482
+ const reactData = $xeNumberInput.reactData
483
+
484
+ const inpImmediate = $xeNumberInput.computeInpImmediate
485
+ if (!inpImmediate) {
486
+ $xeNumberInput.triggerEvent(evnt)
487
+ }
488
+ $xeNumberInput.dispatchEvent('lazy-change', { value: reactData.inputValue }, evnt)
489
+ },
490
+ focusEvent (evnt: Event & { type: 'focus' }) {
491
+ const $xeNumberInput = this
492
+ const reactData = $xeNumberInput.reactData
493
+
494
+ const inputReadonly = $xeNumberInput.computeInputReadonly
495
+ if (!inputReadonly) {
496
+ const { inputValue } = reactData
497
+ reactData.inputValue = eqEmptyValue(inputValue) ? '' : `${XEUtils.toNumber(inputValue)}`
498
+ reactData.isFocus = true
499
+ reactData.isActivated = true
500
+ $xeNumberInput.triggerEvent(evnt)
501
+ }
502
+ },
503
+ clickPrefixEvent (evnt: Event) {
504
+ const $xeNumberInput = this
505
+ const reactData = $xeNumberInput.reactData
506
+
507
+ const isDisabled = $xeNumberInput.computeIsDisabled
508
+ if (!isDisabled) {
509
+ const { inputValue } = reactData
510
+ $xeNumberInput.dispatchEvent('prefix-click', { value: inputValue }, evnt)
511
+ }
512
+ },
513
+ clearValueEvent (evnt: Event, value: VxeNumberInputPropTypes.ModelValue) {
514
+ const $xeNumberInput = this
515
+
516
+ $xeNumberInput.focus()
517
+ $xeNumberInput.handleChange(null, '', evnt)
518
+ $xeNumberInput.dispatchEvent('clear', { value }, evnt)
519
+ $xeNumberInput.dispatchEvent('lazy-change', { value }, evnt)
520
+ },
521
+ clickSuffixEvent (evnt: Event) {
522
+ const $xeNumberInput = this
523
+ const reactData = $xeNumberInput.reactData
524
+
525
+ const isDisabled = $xeNumberInput.computeIsDisabled
526
+ if (!isDisabled) {
527
+ const { inputValue } = reactData
528
+ $xeNumberInput.dispatchEvent('suffix-click', { value: inputValue }, evnt)
529
+ }
530
+ },
531
+ updateModel (val: any) {
532
+ const $xeNumberInput = this
533
+ const props = $xeNumberInput
534
+ const reactData = $xeNumberInput.reactData
535
+
536
+ const { autoFill } = props
537
+ const { inputValue } = reactData
538
+ const digitsValue = $xeNumberInput.computeDigitsValue
539
+ const decimalsType = $xeNumberInput.computeDecimalsType
540
+ if (eqEmptyValue(val)) {
541
+ reactData.inputValue = ''
542
+ } else {
543
+ let textValue = `${val}`
544
+ if (decimalsType) {
545
+ textValue = toFloatValueFixed(val, digitsValue)
546
+ if (!autoFill) {
547
+ textValue = `${XEUtils.toNumber(textValue)}`
548
+ }
549
+ }
550
+ if (textValue !== inputValue) {
551
+ reactData.inputValue = textValue
552
+ }
553
+ }
554
+ },
555
+ /**
556
+ * 检查初始值
557
+ */
558
+ initValue () {
559
+ const $xeNumberInput = this
560
+ const props = $xeNumberInput
561
+ const reactData = $xeNumberInput.reactData
562
+
563
+ const { autoFill } = props
564
+ const { inputValue } = reactData
565
+ const digitsValue = $xeNumberInput.computeDigitsValue
566
+ const decimalsType = $xeNumberInput.computeDecimalsType
567
+ if (decimalsType) {
568
+ if (inputValue) {
569
+ let textValue = ''
570
+ let validValue: number | null = null
571
+ if (inputValue) {
572
+ textValue = toFloatValueFixed(inputValue, digitsValue)
573
+ validValue = XEUtils.toNumber(textValue)
574
+ if (!autoFill) {
575
+ textValue = `${validValue}`
576
+ }
577
+ }
578
+ if (inputValue !== validValue) {
579
+ $xeNumberInput.handleChange(validValue, textValue, { type: 'init' })
580
+ } else {
581
+ reactData.inputValue = textValue
582
+ }
583
+ }
584
+ }
585
+ },
586
+ validMaxNum (num: number | string) {
587
+ const $xeNumberInput = this
588
+ const props = $xeNumberInput
589
+
590
+ return props.max === null || props.max === '' || XEUtils.toNumber(num) <= XEUtils.toNumber(props.max)
591
+ },
592
+ validMinNum (num: number | string) {
593
+ const $xeNumberInput = this
594
+ const props = $xeNumberInput
595
+
596
+ return props.min === null || props.min === '' || XEUtils.toNumber(num) >= XEUtils.toNumber(props.min)
597
+ },
598
+ afterCheckValue () {
599
+ const $xeNumberInput = this
600
+ const props = $xeNumberInput
601
+ const reactData = $xeNumberInput.reactData
602
+
603
+ const { type, min, max, exponential } = props
604
+ const { inputValue } = reactData
605
+ const inputReadonly = $xeNumberInput.computeInputReadonly
606
+ if (!inputReadonly) {
607
+ if (eqEmptyValue(inputValue)) {
608
+ let inpNumVal = null
609
+ let inpValue = inputValue
610
+ if (min || min === 0) {
611
+ inpNumVal = XEUtils.toNumber(min)
612
+ inpValue = `${inpNumVal}`
613
+ }
614
+ $xeNumberInput.handleChange(inpNumVal, `${inpValue || ''}`, { type: 'check' })
615
+ return
616
+ }
617
+ if (inputValue || (min || max)) {
618
+ let inpNumVal: number | string = type === 'integer' ? XEUtils.toInteger(handleNumber(inputValue)) : XEUtils.toNumber(handleNumber(inputValue))
619
+ if (!$xeNumberInput.validMinNum(inpNumVal)) {
620
+ inpNumVal = min as number
621
+ } else if (!$xeNumberInput.validMaxNum(inpNumVal)) {
622
+ inpNumVal = max as number
623
+ }
624
+ if (exponential) {
625
+ const inpStringVal = handleNumberString(inputValue).toLowerCase()
626
+ if (inpStringVal === XEUtils.toNumber(inpNumVal).toExponential()) {
627
+ inpNumVal = inpStringVal
628
+ }
629
+ }
630
+ const inpValue = $xeNumberInput.getNumberValue(inpNumVal)
631
+ $xeNumberInput.handleChange(eqEmptyValue(inpValue) ? null : Number(inpValue), inpValue, { type: 'check' })
632
+ }
633
+ }
634
+ },
635
+ blurEvent (evnt: Event & { type: 'blur' }) {
636
+ const $xeNumberInput = this
637
+ const reactData = $xeNumberInput.reactData
638
+ const $xeForm = $xeNumberInput.$xeForm
639
+ const formItemInfo = $xeNumberInput.formItemInfo
640
+
641
+ const { inputValue } = reactData
642
+ const inpImmediate = $xeNumberInput.computeInpImmediate
643
+ const value = inputValue ? Number(inputValue) : null
644
+ if (!inpImmediate) {
645
+ $xeNumberInput.handleChange(value, handleNumberString(inputValue), evnt)
646
+ }
647
+ $xeNumberInput.afterCheckValue()
648
+ reactData.isFocus = false
649
+ reactData.isActivated = false
650
+ $xeNumberInput.dispatchEvent('blur', { value }, evnt)
651
+ // 自动更新校验状态
652
+ if ($xeForm && formItemInfo) {
653
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
654
+ }
655
+ },
656
+ // 数值
657
+ numberChange (isPlus: boolean, evnt: Event) {
658
+ const $xeNumberInput = this
659
+ const props = $xeNumberInput
660
+ const reactData = $xeNumberInput.reactData
661
+
662
+ const { min, max, type } = props
663
+ const { inputValue } = reactData
664
+ const stepValue = $xeNumberInput.computeStepValue
665
+ const numValue = type === 'integer' ? XEUtils.toInteger(handleNumber(inputValue)) : XEUtils.toNumber(handleNumber(inputValue))
666
+ const newValue = isPlus ? XEUtils.add(numValue, stepValue) : XEUtils.subtract(numValue, stepValue)
667
+ let restNum: number | string
668
+ if (!$xeNumberInput.validMinNum(newValue)) {
669
+ restNum = min as number
670
+ } else if (!$xeNumberInput.validMaxNum(newValue)) {
671
+ restNum = max as number
672
+ } else {
673
+ restNum = newValue
674
+ }
675
+ $xeNumberInput.emitInputEvent($xeNumberInput.getNumberValue(restNum), evnt as (Event & { type: 'input' }))
676
+ },
677
+ numberPlusEvent (evnt: Event) {
678
+ const $xeNumberInput = this
679
+ const reactData = $xeNumberInput.reactData
680
+
681
+ const isDisabled = $xeNumberInput.computeIsDisabled
682
+ const formReadonly = $xeNumberInput.computeFormReadonly
683
+ const isDisabledAddNumber = $xeNumberInput.computeIsDisabledAddNumber
684
+ if (!isDisabled && !formReadonly && !isDisabledAddNumber) {
685
+ $xeNumberInput.numberChange(true, evnt)
686
+ }
687
+ reactData.isActivated = true
688
+ $xeNumberInput.dispatchEvent('plus-number', { value: reactData.inputValue }, evnt)
689
+ $xeNumberInput.dispatchEvent('lazy-change', { value: reactData.inputValue }, evnt)
690
+ // 已废弃
691
+ $xeNumberInput.dispatchEvent('next-number', { value: reactData.inputValue }, evnt)
692
+ },
693
+ numberMinusEvent (evnt: Event) {
694
+ const $xeNumberInput = this
695
+ const reactData = $xeNumberInput.reactData
696
+
697
+ const isDisabled = $xeNumberInput.computeIsDisabled
698
+ const formReadonly = $xeNumberInput.computeFormReadonly
699
+ const isDisabledSubtractNumber = $xeNumberInput.computeIsDisabledSubtractNumber
700
+ if (!isDisabled && !formReadonly && !isDisabledSubtractNumber) {
701
+ $xeNumberInput.numberChange(false, evnt)
702
+ }
703
+ reactData.isActivated = true
704
+ $xeNumberInput.dispatchEvent('minus-number', { value: reactData.inputValue }, evnt)
705
+ $xeNumberInput.dispatchEvent('lazy-change', { value: reactData.inputValue }, evnt)
706
+ // 已废弃
707
+ $xeNumberInput.dispatchEvent('prev-number', { value: reactData.inputValue }, evnt)
708
+ },
709
+ numberKeydownEvent (evnt: KeyboardEvent) {
710
+ const $xeNumberInput = this
711
+
712
+ const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
713
+ const isDwArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
714
+ if (isUpArrow || isDwArrow) {
715
+ evnt.preventDefault()
716
+ if (isUpArrow) {
717
+ $xeNumberInput.numberPlusEvent(evnt)
718
+ } else {
719
+ $xeNumberInput.numberMinusEvent(evnt)
720
+ }
721
+ }
722
+ },
723
+ keydownEvent (evnt: KeyboardEvent & { type: 'keydown' }) {
724
+ const $xeNumberInput = this
725
+ const props = $xeNumberInput
726
+
727
+ const { type, exponential, controls } = props
728
+ const controlOpts = $xeNumberInput.computeControlOpts
729
+ const { isArrow } = controlOpts
730
+ const inputReadonly = $xeNumberInput.computeInputReadonly
731
+ const isControlKey = hasControlKey(evnt)
732
+ const isShiftKey = evnt.shiftKey
733
+ const isAltKey = evnt.altKey
734
+ const keyCode = evnt.keyCode
735
+ const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE)
736
+ const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
737
+ const isDwArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
738
+ if (!isControlKey && !isShiftKey && !isAltKey) {
739
+ if (globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.SPACEBAR) || (type === 'integer' && keyCode === 110) || ((!exponential || keyCode !== 69) && (keyCode >= 65 && keyCode <= 90)) || (keyCode >= 186 && keyCode <= 188) || keyCode >= 191) {
740
+ evnt.preventDefault()
741
+ }
742
+ }
743
+ if (isEsc) {
744
+ $xeNumberInput.afterCheckValue()
745
+ } else if (isUpArrow || isDwArrow) {
746
+ if (isEnableConf(controlOpts) && (controls === false ? controls : isArrow) && !inputReadonly) {
747
+ $xeNumberInput.numberKeydownEvent(evnt)
748
+ }
749
+ }
750
+ $xeNumberInput.triggerEvent(evnt)
751
+ },
752
+ keyupEvent (evnt: KeyboardEvent & { type: 'keyup' }) {
753
+ const $xeNumberInput = this
754
+
755
+ $xeNumberInput.triggerEvent(evnt)
756
+ },
757
+ // 数值
758
+ stopDown () {
759
+ const $xeNumberInput = this
760
+ const internalData = $xeNumberInput.internalData
761
+
762
+ const { dnTimeout } = internalData
763
+ if (dnTimeout) {
764
+ clearTimeout(dnTimeout)
765
+ internalData.dnTimeout = undefined
766
+ }
767
+ },
768
+ stopAutoIncrement () {
769
+ const $xeNumberInput = this
770
+ const internalData = $xeNumberInput.internalData
771
+
772
+ const { ainTimeout } = internalData
773
+ if (ainTimeout) {
774
+ clearTimeout(ainTimeout)
775
+ internalData.ainTimeout = undefined
776
+ }
777
+ },
778
+ numberDownMinusEvent (evnt: Event) {
779
+ const $xeNumberInput = this
780
+ const internalData = $xeNumberInput.internalData
781
+
782
+ $xeNumberInput.numberStopAll()
783
+ internalData.ainTimeout = setTimeout(() => {
784
+ $xeNumberInput.numberMinusEvent(evnt)
785
+ $xeNumberInput.numberDownMinusEvent(evnt)
786
+ }, 60)
787
+ },
788
+ numberDownPlusEvent (evnt: Event) {
789
+ const $xeNumberInput = this
790
+ const internalData = $xeNumberInput.internalData
791
+
792
+ $xeNumberInput.numberStopAll()
793
+ internalData.ainTimeout = setTimeout(() => {
794
+ $xeNumberInput.numberPlusEvent(evnt)
795
+ $xeNumberInput.numberDownPlusEvent(evnt)
796
+ }, 60)
797
+ },
798
+ numberStopAll () {
799
+ const $xeNumberInput = this
800
+
801
+ $xeNumberInput.stopDown()
802
+ $xeNumberInput.stopAutoIncrement()
803
+ },
804
+ numberClickEvent (evnt: MouseEvent) {
805
+ const $xeNumberInput = this
806
+ const internalData = $xeNumberInput.internalData
807
+
808
+ if (internalData.isMouseDown) {
809
+ internalData.isMouseDown = false
810
+ } else {
811
+ $xeNumberInput.numberStopAll()
812
+ const isAddNumber = hasClass(evnt.currentTarget, 'is--plus')
813
+ if (isAddNumber) {
814
+ $xeNumberInput.numberPlusEvent(evnt)
815
+ } else {
816
+ $xeNumberInput.numberMinusEvent(evnt)
817
+ }
818
+ }
819
+ },
820
+ numberMousedownEvent (evnt: MouseEvent) {
821
+ const $xeNumberInput = this
822
+ const internalData = $xeNumberInput.internalData
823
+
824
+ $xeNumberInput.numberStopAll()
825
+ internalData.isMouseDown = true
826
+ if (evnt.button === 0) {
827
+ const isAddNumber = hasClass(evnt.currentTarget, 'is--plus')
828
+ if (isAddNumber) {
829
+ $xeNumberInput.numberPlusEvent(evnt)
830
+ } else {
831
+ $xeNumberInput.numberMinusEvent(evnt)
832
+ }
833
+ internalData.dnTimeout = setTimeout(() => {
834
+ if (isAddNumber) {
835
+ $xeNumberInput.numberDownPlusEvent(evnt)
836
+ } else {
837
+ $xeNumberInput.numberDownMinusEvent(evnt)
838
+ }
839
+ }, 500)
840
+ }
841
+ },
842
+ wheelEvent (evnt: WheelEvent) {
843
+ const $xeNumberInput = this
844
+ const props = $xeNumberInput
845
+ const reactData = $xeNumberInput.reactData
846
+
847
+ const { controls } = props
848
+ const controlOpts = $xeNumberInput.computeControlOpts
849
+ const { isWheel } = controlOpts
850
+ const inputReadonly = $xeNumberInput.computeInputReadonly
851
+ if (isEnableConf(controlOpts) && (controls === false ? controls : isWheel) && !inputReadonly) {
852
+ if (reactData.isActivated) {
853
+ evnt.stopPropagation()
854
+ evnt.preventDefault()
855
+ const delta = evnt.deltaY
856
+ if (delta > 0) {
857
+ // 向下
858
+ $xeNumberInput.numberMinusEvent(evnt)
859
+ } else if (delta < 0) {
860
+ // 向上
861
+ $xeNumberInput.numberPlusEvent(evnt)
862
+ }
863
+ }
864
+ }
865
+ $xeNumberInput.triggerEvent(evnt as WheelEvent & { type: 'wheel' })
866
+ },
867
+ clickEvent (evnt: Event & { type: 'click' }) {
868
+ const $xeNumberInput = this
869
+
870
+ $xeNumberInput.triggerEvent(evnt)
871
+ },
872
+ // 全局事件
873
+ handleGlobalMousedownEvent (evnt: Event) {
874
+ const $xeNumberInput = this
875
+ const reactData = $xeNumberInput.reactData
876
+
877
+ const { isActivated } = reactData
878
+ const el = $xeNumberInput.$refs.refElem as HTMLElement
879
+ const panelElem = $xeNumberInput.$refs.refInputPanel as HTMLDivElement
880
+ const isDisabled = $xeNumberInput.computeIsDisabled
881
+ const inpImmediate = $xeNumberInput.computeInpImmediate
882
+ const inputReadonly = $xeNumberInput.computeInputReadonly
883
+ if (!isDisabled && !inputReadonly && isActivated) {
884
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
885
+ if (!reactData.isActivated) {
886
+ if (!inpImmediate) {
887
+ const { inputValue } = reactData
888
+ const value = inputValue ? Number(inputValue) : null
889
+ $xeNumberInput.handleChange(value, handleNumberString(inputValue), evnt)
890
+ }
891
+ $xeNumberInput.afterCheckValue()
892
+ }
893
+ }
894
+ },
895
+ handleGlobalKeydownEvent (evnt: KeyboardEvent) {
896
+ const $xeNumberInput = this
897
+ const props = $xeNumberInput
898
+ const reactData = $xeNumberInput.reactData
899
+
900
+ const { clearable } = props
901
+ const isDisabled = $xeNumberInput.computeIsDisabled
902
+ const inputReadonly = $xeNumberInput.computeInputReadonly
903
+ if (!isDisabled && !inputReadonly) {
904
+ const isTab = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.TAB)
905
+ const isDel = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.DELETE)
906
+ let isActivated = reactData.isActivated
907
+ if (isTab) {
908
+ if (isActivated) {
909
+ $xeNumberInput.afterCheckValue()
910
+ }
911
+ isActivated = false
912
+ reactData.isActivated = isActivated
913
+ }
914
+ if (isDel && clearable) {
915
+ if (isActivated) {
916
+ $xeNumberInput.clearValueEvent(evnt, null)
917
+ }
918
+ }
919
+ }
920
+ },
921
+ handleGlobalBlurEvent () {
922
+ const $xeNumberInput = this
923
+ const reactData = $xeNumberInput.reactData
924
+
925
+ const { isActivated } = reactData
926
+ if (isActivated) {
927
+ $xeNumberInput.afterCheckValue()
928
+ }
929
+ },
930
+
931
+ //
932
+ // Render
933
+ //
934
+ renderPrefixIcon (h: CreateElement) {
935
+ const $xeNumberInput = this
936
+ const props = $xeNumberInput
937
+ const slots = $xeNumberInput.$scopedSlots
938
+
939
+ const { prefixIcon } = props
940
+ const prefixOpts = $xeNumberInput.computePrefixOpts
941
+ const prefixSlot = slots.prefix
942
+ const preIcon = prefixIcon || prefixOpts.icon
943
+ const sufContent = prefixOpts.content
944
+ return prefixSlot || preIcon || sufContent
945
+ ? h('div', {
946
+ class: 'vxe-number-input--prefix',
947
+ on: {
948
+ click: $xeNumberInput.clickPrefixEvent
949
+ }
950
+ }, [
951
+ h('div', {
952
+ class: 'vxe-number-input--prefix-icon'
953
+ }, prefixSlot
954
+ ? getSlotVNs(prefixSlot({}))
955
+ : [
956
+ preIcon
957
+ ? h('i', {
958
+ class: preIcon
959
+ })
960
+ : renderEmptyElement($xeNumberInput),
961
+ sufContent
962
+ ? h('span', {
963
+ class: 'vxe-prefix-input--suffix-text'
964
+ }, `${sufContent}`)
965
+ : renderEmptyElement($xeNumberInput)
966
+ ])
967
+ ])
968
+ : renderEmptyElement($xeNumberInput)
969
+ },
970
+ renderSuffixIcon (h: CreateElement) {
971
+ const $xeNumberInput = this
972
+ const props = $xeNumberInput
973
+ const reactData = $xeNumberInput.reactData
974
+ const slots = $xeNumberInput.$scopedSlots
975
+
976
+ const { suffixIcon } = props
977
+ const { inputValue } = reactData
978
+ const suffixSlot = slots.suffix
979
+ const suffixOpts = $xeNumberInput.computeSuffixOpts
980
+ const isDisabled = $xeNumberInput.computeIsDisabled
981
+ const isClearable = $xeNumberInput.computeIsClearable
982
+ const sufIcon = suffixIcon || suffixOpts.icon
983
+ const sufContent = suffixOpts.content
984
+ return h('div', {
985
+ class: ['vxe-number-input--suffix', {
986
+ 'is--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
987
+ }]
988
+ }, [
989
+ isClearable
990
+ ? h('div', {
991
+ class: 'vxe-number-input--clear-icon',
992
+ on: {
993
+ click: $xeNumberInput.clearValueEvent
994
+ }
995
+ }, [
996
+ h('i', {
997
+ class: getIcon().INPUT_CLEAR
998
+ })
999
+ ])
1000
+ : renderEmptyElement($xeNumberInput),
1001
+ suffixSlot || sufIcon || sufContent
1002
+ ? h('div', {
1003
+ class: 'vxe-number-input--suffix-icon',
1004
+ on: {
1005
+ click: $xeNumberInput.clickSuffixEvent
1006
+ }
1007
+ }, suffixSlot
1008
+ ? getSlotVNs(suffixSlot({}))
1009
+ : [
1010
+ sufIcon
1011
+ ? h('i', {
1012
+ class: sufIcon
1013
+ })
1014
+ : renderEmptyElement($xeNumberInput),
1015
+ sufContent
1016
+ ? h('span', {
1017
+ class: 'vxe-number-input--suffix-text'
1018
+ }, `${sufContent}`)
1019
+ : renderEmptyElement($xeNumberInput)
1020
+ ])
1021
+ : renderEmptyElement($xeNumberInput)
1022
+ ])
1023
+ },
1024
+ renderInput (h: CreateElement) {
1025
+ const $xeNumberInput = this
1026
+ const props = $xeNumberInput
1027
+ const reactData = $xeNumberInput.reactData
1028
+
1029
+ const { type, name, autocomplete, autoComplete } = props
1030
+ const { inputValue, isFocus } = reactData
1031
+ const isDisabled = $xeNumberInput.computeIsDisabled
1032
+ const numLabel = $xeNumberInput.computeNumLabel
1033
+ const inputReadonly = $xeNumberInput.computeInputReadonly
1034
+ const inpMaxLength = $xeNumberInput.computeInpMaxLength
1035
+ const inpPlaceholder = $xeNumberInput.computeInpPlaceholder
1036
+ return h('div', {
1037
+ key: 'ni',
1038
+ class: 'vxe-number-input--input-wrapper'
1039
+ }, [
1040
+ $xeNumberInput.renderPrefixIcon(h),
1041
+ h('div', {
1042
+ class: 'vxe-number-input--input-inner'
1043
+ }, [
1044
+ h('input', {
1045
+ ref: 'refInputTarget',
1046
+ class: 'vxe-number-input--input',
1047
+ domProps: {
1048
+ value: !isFocus && type === 'amount' ? numLabel : inputValue
1049
+ },
1050
+ attrs: {
1051
+ name,
1052
+ type: 'text',
1053
+ placeholder: inpPlaceholder,
1054
+ maxlength: inpMaxLength,
1055
+ readonly: inputReadonly,
1056
+ disabled: isDisabled,
1057
+ autocomplete: autoComplete || autocomplete
1058
+ },
1059
+ on: {
1060
+ keydown: $xeNumberInput.keydownEvent,
1061
+ keyup: $xeNumberInput.keyupEvent,
1062
+ click: $xeNumberInput.clickEvent,
1063
+ input: $xeNumberInput.inputEvent,
1064
+ change: $xeNumberInput.changeEvent,
1065
+ focus: $xeNumberInput.focusEvent,
1066
+ blur: $xeNumberInput.blurEvent
1067
+ }
1068
+ })
1069
+ ]),
1070
+ $xeNumberInput.renderSuffixIcon(h)
1071
+ ])
1072
+ },
1073
+ renderMinusBtn (h: CreateElement) {
1074
+ const $xeNumberInput = this
1075
+ const props = $xeNumberInput
1076
+
1077
+ const { minusIcon } = props
1078
+ const isDisabledSubtractNumber = $xeNumberInput.computeIsDisabledSubtractNumber
1079
+ return h('button', {
1080
+ key: 'prev',
1081
+ class: ['vxe-number-input--minus-btn is--minus', {
1082
+ 'is--disabled': isDisabledSubtractNumber
1083
+ }],
1084
+ attrs: {
1085
+ type: 'button'
1086
+ },
1087
+ on: {
1088
+ click: $xeNumberInput.numberClickEvent,
1089
+ mousedown: $xeNumberInput.numberMousedownEvent,
1090
+ mouseup: $xeNumberInput.numberStopAll,
1091
+ mouseleave: $xeNumberInput.numberStopAll
1092
+ }
1093
+ }, [
1094
+ h('i', {
1095
+ class: minusIcon || getIcon().NUMBER_INPUT_MINUS_NUM
1096
+ })
1097
+ ])
1098
+ },
1099
+ renderPlusBtn (h: CreateElement) {
1100
+ const $xeNumberInput = this
1101
+ const props = $xeNumberInput
1102
+
1103
+ const { plusIcon } = props
1104
+ const isDisabledAddNumber = $xeNumberInput.computeIsDisabledAddNumber
1105
+ return h('button', {
1106
+ key: 'next',
1107
+ class: ['vxe-number-input--plus-btn is--plus', {
1108
+ 'is--disabled': isDisabledAddNumber
1109
+ }],
1110
+ attrs: {
1111
+ type: 'button'
1112
+ },
1113
+ on: {
1114
+ click: $xeNumberInput.numberClickEvent,
1115
+ mousedown: $xeNumberInput.numberMousedownEvent,
1116
+ mouseup: $xeNumberInput.numberStopAll,
1117
+ mouseleave: $xeNumberInput.numberStopAll
1118
+ }
1119
+ }, [
1120
+ h('i', {
1121
+ class: plusIcon || getIcon().NUMBER_INPUT_PLUS_NUM
1122
+ })
1123
+ ])
1124
+ },
1125
+ renderSideControl (h: CreateElement) {
1126
+ const $xeNumberInput = this
1127
+
1128
+ return h('div', {
1129
+ key: 'cplr',
1130
+ class: 'vxe-number-input--side-control'
1131
+ }, [
1132
+ $xeNumberInput.renderPlusBtn(h),
1133
+ $xeNumberInput.renderMinusBtn(h)
1134
+ ])
1135
+ },
1136
+ renderVN (h: CreateElement): VNode {
1137
+ const $xeNumberInput = this
1138
+ const props = $xeNumberInput
1139
+ const reactData = $xeNumberInput.reactData
1140
+ const slots = $xeNumberInput.$scopedSlots
1141
+
1142
+ const { className, controls, type, align, prefixIcon, suffixIcon } = props
1143
+ const { inputValue, isActivated } = reactData
1144
+ const vSize = $xeNumberInput.computeSize
1145
+ const controlOpts = $xeNumberInput.computeControlOpts
1146
+ const { layout, showButton } = controlOpts
1147
+ const isDisabled = $xeNumberInput.computeIsDisabled
1148
+ const formReadonly = $xeNumberInput.computeFormReadonly
1149
+ const numLabel = $xeNumberInput.computeNumLabel
1150
+ const prefixSlot = slots.prefix
1151
+ const suffixSlot = slots.suffix
1152
+ if (formReadonly) {
1153
+ return h('div', {
1154
+ ref: 'refElem',
1155
+ class: ['vxe-number-input--readonly', `type--${type}`, className]
1156
+ }, numLabel)
1157
+ }
1158
+ const inputReadonly = $xeNumberInput.computeInputReadonly
1159
+ const isClearable = $xeNumberInput.computeIsClearable
1160
+ const isControls = isEnableConf(controlOpts) && (controls === false ? controls : showButton)
1161
+ return h('div', {
1162
+ ref: 'refElem',
1163
+ class: ['vxe-number-input', `type--${type}`, `ctl--${layout === 'right' || layout === 'left' ? layout : 'default'}`, className, {
1164
+ [`size--${vSize}`]: vSize,
1165
+ [`is--${align}`]: align,
1166
+ 'is--controls': isControls && !inputReadonly,
1167
+ 'is--prefix': !!prefixSlot || prefixIcon,
1168
+ 'is--suffix': !!suffixSlot || suffixIcon,
1169
+ 'is--disabled': isDisabled,
1170
+ 'is--active': isActivated,
1171
+ 'show--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
1172
+ }],
1173
+ attrs: {
1174
+ spellcheck: false
1175
+ }
1176
+ }, isControls
1177
+ ? (layout === 'right'
1178
+ ? [
1179
+ $xeNumberInput.renderInput(h),
1180
+ $xeNumberInput.renderSideControl(h)
1181
+ ]
1182
+ : (layout === 'left'
1183
+ ? [
1184
+ $xeNumberInput.renderSideControl(h),
1185
+ $xeNumberInput.renderInput(h)
1186
+ ]
1187
+ : [
1188
+ $xeNumberInput.renderMinusBtn(h),
1189
+ $xeNumberInput.renderInput(h),
1190
+ $xeNumberInput.renderPlusBtn(h)
1191
+ ]))
1192
+ : [
1193
+ $xeNumberInput.renderInput(h)
1194
+ ])
1195
+ }
1196
+ },
1197
+ watch: {
1198
+ value (val) {
1199
+ const $xeNumberInput = this
1200
+ const internalData = $xeNumberInput.internalData
1201
+
1202
+ if (!internalData.isUM) {
1203
+ this.updateModel(val)
1204
+ }
1205
+ internalData.isUM = false
1206
+ },
1207
+ type () {
1208
+ const $xeNumberInput = this
1209
+ const props = $xeNumberInput
1210
+ const reactData = $xeNumberInput.reactData
1211
+
1212
+ // 切换类型是重置内置变量
1213
+ Object.assign(reactData, {
1214
+ inputValue: props.value
1215
+ })
1216
+ $xeNumberInput.initValue()
1217
+ }
1218
+ },
1219
+ created () {
1220
+ const $xeNumberInput = this
1221
+ const props = $xeNumberInput
1222
+
1223
+ this.updateModel(props.value)
1224
+ $xeNumberInput.initValue()
1225
+ },
1226
+ mounted () {
1227
+ const $xeNumberInput = this
1228
+
1229
+ const targetElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
1230
+ if (targetElem) {
1231
+ targetElem.addEventListener('wheel', $xeNumberInput.wheelEvent, { passive: false })
1232
+ }
1233
+ globalEvents.on($xeNumberInput, 'mousedown', $xeNumberInput.handleGlobalMousedownEvent)
1234
+ globalEvents.on($xeNumberInput, 'keydown', $xeNumberInput.handleGlobalKeydownEvent)
1235
+ globalEvents.on($xeNumberInput, 'blur', $xeNumberInput.handleGlobalBlurEvent)
1236
+ },
1237
+ beforeDestroy () {
1238
+ const $xeNumberInput = this
1239
+ const reactData = $xeNumberInput.reactData
1240
+
1241
+ reactData.isFocus = false
1242
+ $xeNumberInput.numberStopAll()
1243
+ $xeNumberInput.afterCheckValue()
1244
+ const targetElem = $xeNumberInput.$refs.refInputTarget as HTMLInputElement
1245
+ if (targetElem) {
1246
+ targetElem.removeEventListener('wheel', $xeNumberInput.wheelEvent)
1247
+ }
1248
+ globalEvents.off($xeNumberInput, 'mousedown')
1249
+ globalEvents.off($xeNumberInput, 'keydown')
1250
+ globalEvents.off($xeNumberInput, 'blur')
1251
+ },
1252
+ render (this: any, h) {
1253
+ return this.renderVN(h)
1254
+ }
1255
+ }) /* define-vxe-component end */