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,1238 +1,1238 @@
1
- import { PropType, CreateElement } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getConfig, getIcon, getI18n, commands, createEvent, globalEvents, GLOBAL_EVENT_KEYS, globalMixins, renderEmptyElement } from '../../ui'
5
- import { getFuncText, getLastZIndex, nextZIndex, isEnableConf } from '../../ui/src/utils'
6
- import { updatePanelPlacement, getEventTargetNode } from '../../ui/src/dom'
7
- import { getSlotVNs } from '../../ui/src/vn'
8
- import { parseDateObj, parseDateValue, getDateByCode, handleValueFormat, hasDateValueType, hasTimestampValueType } from '../../date-panel/src/util'
9
- import { errLog } from '../../ui/src/log'
10
- import VxeDatePanelComponent from '../../date-panel/src/date-panel'
11
- import VxeButtonComponent from '../../button/src/button'
12
- import VxeButtonGroupComponent from '../../button/src/button-group'
13
-
14
- import type { VxeDatePickerConstructor, VxeDatePickerEmits, DatePickerInternalData, DatePickerReactData, VxeButtonGroupDefines, VxeComponentSizeType, VxeDatePickerPropTypes, VxeFormConstructor, VxeFormPrivateMethods, VxeFormDefines, ValueOf, VxeModalConstructor, VxeDrawerConstructor, VxeModalMethods, VxeDrawerMethods, VxeDatePickerDefines, VxeDatePanelConstructor } from '../../../types'
15
- import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
16
-
17
- export default /* define-vxe-component start */ defineVxeComponent({
18
- name: 'VxeDatePicker',
19
- mixins: [
20
- globalMixins.sizeMixin
21
- ],
22
- model: {
23
- prop: 'value',
24
- event: 'modelValue'
25
- },
26
- props: {
27
- value: [String, Number, Date] as PropType<VxeDatePickerPropTypes.ModelValue>,
28
- immediate: {
29
- type: Boolean as PropType<VxeDatePickerPropTypes.Immediate>,
30
- default: true
31
- },
32
- name: String as PropType<VxeDatePickerPropTypes.Name>,
33
- type: {
34
- type: String as PropType<VxeDatePickerPropTypes.Type>,
35
- default: 'date' as VxeDatePickerPropTypes.Type
36
- },
37
- clearable: {
38
- type: Boolean as PropType<VxeDatePickerPropTypes.Clearable>,
39
- default: () => getConfig().datePicker.clearable
40
- },
41
- readonly: {
42
- type: Boolean as PropType<VxeDatePickerPropTypes.Readonly>,
43
- default: null
44
- },
45
- disabled: {
46
- type: Boolean as PropType<VxeDatePickerPropTypes.Disabled>,
47
- default: null
48
- },
49
- placeholder: String as PropType<VxeDatePickerPropTypes.Placeholder>,
50
- autoComplete: {
51
- type: String as PropType<VxeDatePickerPropTypes.AutoComplete>,
52
- default: 'off'
53
- },
54
- form: String as PropType<VxeDatePickerPropTypes.Form>,
55
- className: String as PropType<VxeDatePickerPropTypes.ClassName>,
56
- zIndex: Number as PropType<VxeDatePickerPropTypes.ZIndex>,
57
- size: {
58
- type: String as PropType<VxeDatePickerPropTypes.Size>,
59
- default: () => getConfig().datePicker.size || getConfig().size
60
- },
61
- multiple: Boolean as PropType<VxeDatePickerPropTypes.Multiple>,
62
- limitCount: {
63
- type: [String, Number] as PropType<VxeDatePickerPropTypes.LimitCount>,
64
- default: () => getConfig().datePicker.limitCount
65
- },
66
-
67
- // date、week、month、quarter、year
68
- startDate: {
69
- type: [String, Number, Date] as PropType<VxeDatePickerPropTypes.StartDate>,
70
- default: () => getConfig().datePicker.startDate
71
- },
72
- endDate: {
73
- type: [String, Number, Date] as PropType<VxeDatePickerPropTypes.EndDate>,
74
- default: () => getConfig().datePicker.endDate
75
- },
76
- defaultDate: [String, Number, Date] as PropType<VxeDatePickerPropTypes.DefaultDate>,
77
- defaultTime: [String, Number, Date] as PropType<VxeDatePickerPropTypes.DefaultTime>,
78
- minDate: [String, Number, Date] as PropType<VxeDatePickerPropTypes.MinDate>,
79
- maxDate: [String, Number, Date] as PropType<VxeDatePickerPropTypes.MaxDate>,
80
- startDay: {
81
- type: [String, Number] as PropType<VxeDatePickerPropTypes.StartDay>,
82
- default: () => getConfig().datePicker.startDay
83
- },
84
- labelFormat: String as PropType<VxeDatePickerPropTypes.LabelFormat>,
85
- valueFormat: String as PropType<VxeDatePickerPropTypes.ValueFormat>,
86
- timeFormat: String as PropType<VxeDatePickerPropTypes.TimeFormat>,
87
- editable: {
88
- type: Boolean as PropType<VxeDatePickerPropTypes.Editable>,
89
- default: true
90
- },
91
- festivalMethod: {
92
- type: Function as PropType<VxeDatePickerPropTypes.FestivalMethod>,
93
- default: () => getConfig().datePicker.festivalMethod
94
- },
95
- disabledMethod: {
96
- type: Function as PropType<VxeDatePickerPropTypes.DisabledMethod>,
97
- default: () => getConfig().datePicker.disabledMethod
98
- },
99
-
100
- // week
101
- selectDay: {
102
- type: [String, Number] as PropType<VxeDatePickerPropTypes.SelectDay>,
103
- default: () => getConfig().datePicker.selectDay
104
- },
105
- showClearButton: {
106
- type: Boolean as PropType<VxeDatePickerPropTypes.ShowClearButton>,
107
- default: () => getConfig().datePicker.showClearButton
108
- },
109
- showConfirmButton: {
110
- type: Boolean as PropType<VxeDatePickerPropTypes.ShowConfirmButton>,
111
- default: () => getConfig().datePicker.showConfirmButton
112
- },
113
- autoClose: {
114
- type: Boolean as PropType<VxeDatePickerPropTypes.AutoClose>,
115
- default: () => getConfig().datePicker.autoClose
116
- },
117
-
118
- prefixIcon: String as PropType<VxeDatePickerPropTypes.PrefixIcon>,
119
- suffixIcon: String as PropType<VxeDatePickerPropTypes.SuffixIcon>,
120
- placement: String as PropType<VxeDatePickerPropTypes.Placement>,
121
- transfer: {
122
- type: Boolean as PropType<VxeDatePickerPropTypes.Transfer>,
123
- default: null
124
- },
125
-
126
- timeConfig: Object as PropType<VxeDatePickerPropTypes.TimeConfig>,
127
- popupConfig: Object as PropType<VxeDatePickerPropTypes.PopupConfig>,
128
- shortcutConfig: Object as PropType<VxeDatePickerPropTypes.ShortcutConfig>,
129
-
130
- // 已废弃 startWeek,被 startDay 替换
131
- startWeek: Number as PropType<VxeDatePickerPropTypes.StartDay>
132
- },
133
- inject: {
134
- $xeModal: {
135
- default: null
136
- },
137
- $xeDrawer: {
138
- default: null
139
- },
140
- $xeTable: {
141
- default: null
142
- },
143
- $xeForm: {
144
- default: null
145
- },
146
- formItemInfo: {
147
- from: 'xeFormItemInfo',
148
- default: null
149
- }
150
- },
151
- provide () {
152
- const $xeDatePicker = this
153
-
154
- return {
155
- $xeDatePicker
156
- }
157
- },
158
- data () {
159
- const xID = XEUtils.uniqueId()
160
-
161
- const reactData: DatePickerReactData = {
162
- initialized: false,
163
- panelIndex: 0,
164
- visiblePanel: false,
165
- isAniVisible: false,
166
- panelStyle: {},
167
- panelPlacement: '',
168
- isActivated: false,
169
- inputValue: '',
170
- inputLabel: ''
171
- }
172
-
173
- const internalData: DatePickerInternalData = {
174
- hpTimeout: undefined
175
- }
176
-
177
- return {
178
- xID,
179
- reactData,
180
- internalData
181
- }
182
- },
183
- computed: {
184
- ...({} as {
185
- computeSize(): VxeComponentSizeType
186
- $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
187
- $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
188
- $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
189
- $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
190
- formItemInfo(): VxeFormDefines.ProvideItemInfo | null
191
- }),
192
- computeBtnTransfer () {
193
- const $xeDatePicker = this
194
- const props = $xeDatePicker
195
- const $xeTable = $xeDatePicker.$xeTable
196
- const $xeModal = $xeDatePicker.$xeModal
197
- const $xeDrawer = $xeDatePicker.$xeDrawer
198
- const $xeForm = $xeDatePicker.$xeForm
199
-
200
- const { transfer } = props
201
- const popupOpts = $xeDatePicker.computePopupOpts as VxeDatePickerPropTypes.PopupConfig
202
- if (XEUtils.isBoolean(popupOpts.transfer)) {
203
- return popupOpts.transfer
204
- }
205
- if (transfer === null) {
206
- const globalTransfer = getConfig().datePicker.transfer
207
- if (XEUtils.isBoolean(globalTransfer)) {
208
- return globalTransfer
209
- }
210
- if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
211
- return true
212
- }
213
- }
214
- return transfer
215
- },
216
- computeFormReadonly () {
217
- const $xeDatePicker = this
218
- const props = $xeDatePicker
219
- const $xeForm = $xeDatePicker.$xeForm
220
-
221
- const { readonly } = props
222
- if (readonly === null) {
223
- if ($xeForm) {
224
- return $xeForm.readonly
225
- }
226
- return false
227
- }
228
- return readonly
229
- },
230
- computeIsDisabled () {
231
- const $xeDatePicker = this
232
- const props = $xeDatePicker
233
- const $xeForm = $xeDatePicker.$xeForm
234
-
235
- const { disabled } = props
236
- if (disabled === null) {
237
- if ($xeForm) {
238
- return $xeForm.disabled
239
- }
240
- return false
241
- }
242
- return disabled
243
- },
244
- computeIsDateTimeType () {
245
- const $xeDatePicker = this
246
- const props = $xeDatePicker
247
-
248
- const { type } = props
249
- return type === 'time' || type === 'datetime'
250
- },
251
- computeIsDatePickerType () {
252
- const $xeDatePicker = this
253
- const props = $xeDatePicker
254
-
255
- const isDateTimeType = $xeDatePicker.computeIsDateTimeType
256
- return isDateTimeType || ['date', 'week', 'month', 'quarter', 'year'].indexOf(props.type) > -1
257
- },
258
- computeIsClearable () {
259
- const $xeDatePicker = this
260
- const props = $xeDatePicker
261
-
262
- return props.clearable
263
- },
264
- computeInputReadonly () {
265
- const $xeDatePicker = this
266
- const props = $xeDatePicker
267
-
268
- const { type, editable, multiple } = props
269
- const formReadonly = $xeDatePicker.computeFormReadonly
270
- return formReadonly || multiple || !editable || type === 'week' || type === 'quarter'
271
- },
272
- computeInpPlaceholder () {
273
- const $xeDatePicker = this
274
- const props = $xeDatePicker
275
-
276
- const { placeholder } = props
277
- if (placeholder) {
278
- return getFuncText(placeholder)
279
- }
280
- const globalPlaceholder = getConfig().datePicker.placeholder
281
- if (globalPlaceholder) {
282
- return getFuncText(globalPlaceholder)
283
- }
284
- return getI18n('vxe.base.pleaseSelect')
285
- },
286
- computeInpImmediate () {
287
- const $xeDatePicker = this
288
- const props = $xeDatePicker
289
-
290
- const { immediate } = props
291
- return immediate
292
- },
293
- computeTimeOpts () {
294
- const $xeDatePicker = this
295
- const props = $xeDatePicker
296
-
297
- return Object.assign({}, getConfig().datePicker.timeConfig, props.timeConfig)
298
- },
299
- computePopupOpts () {
300
- const $xeDatePicker = this
301
- const props = $xeDatePicker
302
-
303
- return Object.assign({}, getConfig().datePicker.popupConfig, props.popupConfig)
304
- },
305
- computeShortcutOpts () {
306
- const $xeDatePicker = this
307
- const props = $xeDatePicker
308
-
309
- return Object.assign({}, getConfig().datePicker.shortcutConfig, props.shortcutConfig)
310
- },
311
- computeShortcutList () {
312
- const $xeDatePicker = this
313
-
314
- const shortcutOpts = $xeDatePicker.computeShortcutOpts as VxeDatePickerPropTypes.ShortcutConfig
315
- const { options } = shortcutOpts
316
- if (options) {
317
- return options.map((option, index) => {
318
- return Object.assign({
319
- name: `${option.name || option.code || index}`
320
- }, option)
321
- })
322
- }
323
- return []
324
- },
325
- computeDateLabelFormat () {
326
- const $xeDatePicker = this
327
- const props = $xeDatePicker
328
-
329
- const { labelFormat } = props
330
- return labelFormat || getI18n(`vxe.input.date.labelFormat.${props.type}`)
331
- },
332
- computeDateValueFormat () {
333
- const $xeDatePicker = this
334
- const props = $xeDatePicker
335
-
336
- const { type, valueFormat } = props
337
- return handleValueFormat(type, valueFormat)
338
- },
339
- computeFirstDayOfWeek () {
340
- const $xeDatePicker = this
341
- const props = $xeDatePicker
342
-
343
- const { startDay } = props
344
- return XEUtils.toNumber(startDay) as VxeDatePickerPropTypes.StartDay
345
- },
346
- computePanelLabel () {
347
- const $xeDatePicker = this
348
- const props = $xeDatePicker
349
- const reactData = $xeDatePicker.reactData
350
-
351
- const { type, multiple } = props
352
- const { inputValue } = reactData
353
- const dateLabelFormat = $xeDatePicker.computeDateLabelFormat
354
- const dateValueFormat = $xeDatePicker.computeDateValueFormat
355
- const firstDayOfWeek = $xeDatePicker.computeFirstDayOfWeek
356
- const vals: string[] = inputValue ? (multiple ? inputValue.split(',') : [inputValue]) : []
357
- return vals.map(val => {
358
- const dateObj = parseDateObj(val, type, {
359
- valueFormat: dateValueFormat,
360
- labelFormat: dateLabelFormat,
361
- firstDay: firstDayOfWeek
362
- })
363
- return dateObj.label
364
- }).join(', ')
365
- }
366
- },
367
- methods: {
368
-
369
- //
370
- // Method
371
- //
372
- dispatchEvent (type: ValueOf<VxeDatePickerEmits>, params: Record<string, any>, evnt: Event | null) {
373
- const $xeDatePicker = this
374
- $xeDatePicker.$emit(type, createEvent(evnt, { $datePicker: $xeDatePicker }, params))
375
- },
376
- emitModel (value: any) {
377
- const $xeDatePicker = this
378
-
379
- const { _events } = $xeDatePicker as any
380
- if (_events && _events.modelValue) {
381
- $xeDatePicker.$emit('modelValue', value)
382
- } else {
383
- $xeDatePicker.$emit('model-value', value)
384
- }
385
- },
386
- updateModelValue () {
387
- const $xeDatePicker = this
388
- const props = $xeDatePicker
389
- const reactData = $xeDatePicker.reactData
390
-
391
- const { value: modelValue } = props
392
- let val: any = ''
393
- if (modelValue) {
394
- if (XEUtils.isNumber(modelValue) && /^[0-9]{11,15}$/.test(`${modelValue}`)) {
395
- val = new Date(modelValue)
396
- } else {
397
- val = modelValue
398
- }
399
- }
400
- reactData.inputValue = val
401
- },
402
- triggerEvent (evnt: Event & { type: 'input' | 'change' | 'keydown' | 'keyup' | 'click' | 'focus' | 'blur' }) {
403
- const $xeDatePicker = this
404
- const reactData = $xeDatePicker.reactData
405
-
406
- const { inputValue } = reactData
407
- $xeDatePicker.dispatchEvent(evnt.type, { value: inputValue }, evnt)
408
- },
409
- handleChange (value: string | number | Date, evnt: Event | { type: string }) {
410
- const $xeDatePicker = this
411
- const props = $xeDatePicker
412
- const reactData = $xeDatePicker.reactData
413
- const $xeForm = $xeDatePicker.$xeForm
414
- const formItemInfo = $xeDatePicker.formItemInfo
415
-
416
- const { type, value: modelValue, valueFormat } = props
417
- const dateValueFormat = $xeDatePicker.computeDateValueFormat
418
- reactData.inputValue = value
419
- if (hasTimestampValueType(valueFormat)) {
420
- const dateVal = parseDateValue(value, type, { valueFormat: dateValueFormat })
421
- const timeNum = dateVal ? dateVal.getTime() : null
422
- $xeDatePicker.emitModel(timeNum)
423
- if (modelValue !== timeNum) {
424
- $xeDatePicker.dispatchEvent('change', { value: timeNum }, evnt as Event)
425
- // 自动更新校验状态
426
- if ($xeForm && formItemInfo) {
427
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, timeNum)
428
- }
429
- }
430
- } else if (hasDateValueType(valueFormat)) {
431
- const dateVal = parseDateValue(value, type, { valueFormat: dateValueFormat })
432
- $xeDatePicker.emitModel(dateVal)
433
- if (modelValue && dateVal ? XEUtils.toStringDate(modelValue).getTime() !== dateVal.getTime() : modelValue !== dateVal) {
434
- $xeDatePicker.dispatchEvent('change', { value: dateVal }, evnt as Event)
435
- // 自动更新校验状态
436
- if ($xeForm && formItemInfo) {
437
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, dateVal)
438
- }
439
- }
440
- } else {
441
- $xeDatePicker.emitModel(value)
442
- if (XEUtils.toValueString(modelValue) !== value) {
443
- $xeDatePicker.dispatchEvent('change', { value }, evnt as Event)
444
- // 自动更新校验状态
445
- if ($xeForm && formItemInfo) {
446
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
447
- }
448
- }
449
- }
450
- },
451
- inputEvent (evnt: Event & { type: 'input' }) {
452
- const $xeDatePicker = this
453
- const reactData = $xeDatePicker.reactData
454
-
455
- const inputElem = evnt.target as HTMLInputElement
456
- const value = inputElem.value
457
- reactData.inputLabel = value
458
- $xeDatePicker.dispatchEvent('input', { value }, evnt)
459
- },
460
- changeEvent (evnt: Event & { type: 'change' }) {
461
- const $xeDatePicker = this
462
-
463
- const inpImmediate = $xeDatePicker.computeInpImmediate
464
- if (!inpImmediate) {
465
- $xeDatePicker.triggerEvent(evnt)
466
- }
467
- },
468
- focusEvent (evnt: Event & { type: 'focus' }) {
469
- const $xeDatePicker = this
470
- const reactData = $xeDatePicker.reactData
471
-
472
- reactData.isActivated = true
473
- const isDatePickerType = $xeDatePicker.computeIsDatePickerType
474
- if (isDatePickerType) {
475
- $xeDatePicker.datePickerOpenEvent(evnt)
476
- }
477
- $xeDatePicker.triggerEvent(evnt)
478
- },
479
- clickPrefixEvent (evnt: Event) {
480
- const $xeDatePicker = this
481
- const reactData = $xeDatePicker.reactData
482
-
483
- const isDisabled = $xeDatePicker.computeIsDisabled
484
- if (!isDisabled) {
485
- const { inputValue } = reactData
486
- $xeDatePicker.dispatchEvent('prefix-click', { value: inputValue }, evnt)
487
- }
488
- },
489
- hidePanel () {
490
- const $xeDatePicker = this
491
- const reactData = $xeDatePicker.reactData
492
- const internalData = $xeDatePicker.internalData
493
-
494
- return new Promise<void>(resolve => {
495
- reactData.visiblePanel = false
496
- internalData.hpTimeout = setTimeout(() => {
497
- reactData.isAniVisible = false
498
- resolve()
499
- }, 350)
500
- })
501
- },
502
- clearValueEvent (evnt: Event, value: VxeDatePickerPropTypes.ModelValue) {
503
- const $xeDatePicker = this
504
-
505
- const isDatePickerType = $xeDatePicker.computeIsDatePickerType
506
- if (isDatePickerType) {
507
- $xeDatePicker.hidePanel()
508
- }
509
- $xeDatePicker.handleChange('', evnt)
510
- $xeDatePicker.dispatchEvent('clear', { value }, evnt)
511
- },
512
- clickSuffixEvent (evnt: Event) {
513
- const $xeDatePicker = this
514
- const reactData = $xeDatePicker.reactData
515
-
516
- const isDisabled = $xeDatePicker.computeIsDisabled
517
- if (!isDisabled) {
518
- const { inputValue } = reactData
519
- $xeDatePicker.dispatchEvent('suffix-click', { value: inputValue }, evnt)
520
- }
521
- },
522
- blurEvent (evnt: Event & { type: 'blur' }) {
523
- const $xeDatePicker = this
524
- const reactData = $xeDatePicker.reactData
525
- const $xeForm = $xeDatePicker.$xeForm
526
- const formItemInfo = $xeDatePicker.formItemInfo
527
-
528
- const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
529
- const { inputValue } = reactData
530
- const inpImmediate = $xeDatePicker.computeInpImmediate
531
- const value = inputValue
532
- if (!inpImmediate) {
533
- $xeDatePicker.handleChange(value, evnt)
534
- }
535
- if (!reactData.visiblePanel) {
536
- reactData.isActivated = false
537
- // 未打开面板时才校验
538
- if ($datePanel) {
539
- $datePanel.checkValue(reactData.inputLabel)
540
- }
541
- }
542
- $xeDatePicker.dispatchEvent('blur', { value }, evnt)
543
- // 自动更新校验状态
544
- if ($xeForm && formItemInfo) {
545
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
546
- }
547
- },
548
- keydownEvent (evnt: KeyboardEvent & { type: 'keydown' }) {
549
- const $xeDatePicker = this
550
-
551
- $xeDatePicker.triggerEvent(evnt)
552
- },
553
- keyupEvent (evnt: KeyboardEvent & { type: 'keyup' }) {
554
- const $xeDatePicker = this
555
-
556
- $xeDatePicker.triggerEvent(evnt)
557
- },
558
- confirmEvent (evnt: MouseEvent) {
559
- const $xeDatePicker = this
560
-
561
- const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
562
- if ($datePanel) {
563
- $datePanel.confirmByEvent(evnt)
564
- }
565
- $xeDatePicker.hidePanel()
566
- },
567
- panelChangeEvent (params: VxeDatePickerDefines.ChangeEventParams) {
568
- const $xeDatePicker = this
569
- const props = $xeDatePicker
570
-
571
- const { multiple, autoClose } = props
572
- const { value, $event } = params
573
- const isDateTimeType = $xeDatePicker.computeIsDateTimeType
574
- $xeDatePicker.handleChange(value, $event)
575
- if (!multiple && !isDateTimeType) {
576
- if (autoClose) {
577
- $xeDatePicker.hidePanel()
578
- }
579
- }
580
- },
581
- panelConfirmEvent (params: VxeDatePickerDefines.ConfirmEventParams) {
582
- const $xeDatePicker = this
583
-
584
- $xeDatePicker.dispatchEvent('confirm', params, params.$event)
585
- },
586
- // 全局事件
587
- handleGlobalMousedownEvent (evnt: Event) {
588
- const $xeDatePicker = this
589
- const reactData = $xeDatePicker.reactData
590
-
591
- const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
592
- const { visiblePanel, isActivated } = reactData
593
- const el = $xeDatePicker.$refs.refElem as HTMLDivElement
594
- const panelWrapperElem = $xeDatePicker.$refs.refPanelWrapper as HTMLDivElement
595
- const isDisabled = $xeDatePicker.computeIsDisabled
596
- if (!isDisabled && isActivated) {
597
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelWrapperElem).flag
598
- if (!reactData.isActivated) {
599
- if (visiblePanel) {
600
- $xeDatePicker.hidePanel()
601
- if ($datePanel) {
602
- $datePanel.checkValue(reactData.inputLabel)
603
- }
604
- }
605
- }
606
- }
607
- },
608
- handleGlobalKeydownEvent (evnt: KeyboardEvent) {
609
- const $xeDatePicker = this
610
- const reactData = $xeDatePicker.reactData
611
-
612
- const { visiblePanel } = reactData
613
- const isDisabled = $xeDatePicker.computeIsDisabled
614
- if (!isDisabled) {
615
- const isTab = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.TAB)
616
- const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE)
617
- if (isTab) {
618
- reactData.isActivated = false
619
- }
620
- if (visiblePanel) {
621
- if (isEsc || isTab) {
622
- $xeDatePicker.hidePanel()
623
- }
624
- }
625
- }
626
- },
627
- handleGlobalMousewheelEvent (evnt: Event) {
628
- const $xeDatePicker = this
629
- const reactData = $xeDatePicker.reactData
630
-
631
- const { visiblePanel } = reactData
632
- const isDisabled = $xeDatePicker.computeIsDisabled
633
- if (!isDisabled) {
634
- if (visiblePanel) {
635
- const panelWrapperElem = $xeDatePicker.$refs.refPanelWrapper as HTMLDivElement
636
- if (getEventTargetNode(evnt, panelWrapperElem).flag) {
637
- $xeDatePicker.updatePlacement()
638
- } else {
639
- $xeDatePicker.hidePanel()
640
- }
641
- }
642
- }
643
- },
644
- handleGlobalBlurEvent () {
645
- const $xeDatePicker = this
646
- const reactData = $xeDatePicker.reactData
647
-
648
- const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
649
- const { isActivated, visiblePanel } = reactData
650
- if (visiblePanel) {
651
- $xeDatePicker.hidePanel()
652
- }
653
- if (isActivated) {
654
- reactData.isActivated = false
655
- }
656
- if (visiblePanel || isActivated) {
657
- if ($datePanel) {
658
- $datePanel.checkValue(reactData.inputLabel)
659
- }
660
- const targetElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
661
- if (targetElem) {
662
- targetElem.blur()
663
- }
664
- }
665
- },
666
- handleGlobalResizeEvent () {
667
- const $xeDatePicker = this
668
- const reactData = $xeDatePicker.reactData
669
-
670
- const { visiblePanel } = reactData
671
- if (visiblePanel) {
672
- $xeDatePicker.updatePlacement()
673
- }
674
- },
675
- // 弹出面板
676
- updateZindex () {
677
- const $xeDatePicker = this
678
- const props = $xeDatePicker
679
- const reactData = $xeDatePicker.reactData
680
-
681
- const popupOpts = $xeDatePicker.computePopupOpts
682
- const customZIndex = popupOpts.zIndex || props.zIndex
683
- if (customZIndex) {
684
- reactData.panelIndex = XEUtils.toNumber(customZIndex)
685
- } else if (reactData.panelIndex < getLastZIndex()) {
686
- reactData.panelIndex = nextZIndex()
687
- }
688
- },
689
- updatePlacement () {
690
- const $xeDatePicker = this
691
- const props = $xeDatePicker
692
- const reactData = $xeDatePicker.reactData
693
-
694
- const { placement } = props
695
- const { panelIndex } = reactData
696
- const targetElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
697
- const panelElem = $xeDatePicker.$refs.refInputPanel as HTMLDivElement
698
- const btnTransfer = $xeDatePicker.computeBtnTransfer
699
- const popupOpts = $xeDatePicker.computePopupOpts
700
- const handleStyle = () => {
701
- const ppObj = updatePanelPlacement(targetElem, panelElem, {
702
- placement: popupOpts.placement || placement,
703
- teleportTo: btnTransfer
704
- })
705
- const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
706
- zIndex: panelIndex
707
- })
708
- reactData.panelStyle = panelStyle
709
- reactData.panelPlacement = ppObj.placement
710
- }
711
- handleStyle()
712
- return $xeDatePicker.$nextTick().then(handleStyle)
713
- },
714
- showPanel () {
715
- const $xeDatePicker = this
716
- const reactData = $xeDatePicker.reactData
717
- const internalData = $xeDatePicker.internalData
718
-
719
- const { visiblePanel } = reactData
720
- const isDisabled = $xeDatePicker.computeIsDisabled
721
- const btnTransfer = $xeDatePicker.computeBtnTransfer
722
- const panelElem = $xeDatePicker.$refs.refInputPanel as HTMLElement
723
- if (!isDisabled && !visiblePanel) {
724
- if (!reactData.initialized) {
725
- reactData.initialized = true
726
- if (btnTransfer) {
727
- if (panelElem) {
728
- document.body.appendChild(panelElem)
729
- }
730
- }
731
- }
732
- if (internalData.hpTimeout) {
733
- clearTimeout(internalData.hpTimeout)
734
- internalData.hpTimeout = undefined
735
- }
736
- reactData.isActivated = true
737
- reactData.isAniVisible = true
738
- setTimeout(() => {
739
- reactData.visiblePanel = true
740
- $xeDatePicker.updatePlacement()
741
- }, 10)
742
- $xeDatePicker.updateZindex()
743
- return $xeDatePicker.updatePlacement()
744
- }
745
- return $xeDatePicker.$nextTick()
746
- },
747
- datePickerOpenEvent (evnt: Event) {
748
- const $xeDatePicker = this
749
-
750
- const formReadonly = $xeDatePicker.computeFormReadonly
751
- if (!formReadonly) {
752
- evnt.preventDefault()
753
- $xeDatePicker.showPanel()
754
- }
755
- },
756
- clickEvent (evnt: Event & { type: 'click' }) {
757
- const $xeDatePicker = this
758
-
759
- $xeDatePicker.triggerEvent(evnt)
760
- },
761
- handleShortcutEvent ({ option, $event }: VxeButtonGroupDefines.ClickEventParams) {
762
- const $xeDatePicker = this
763
- const props = $xeDatePicker
764
- const reactData = $xeDatePicker.reactData
765
-
766
- const { type } = props
767
- const { inputValue } = reactData
768
- const shortcutOpts = $xeDatePicker.computeShortcutOpts
769
- const { autoClose } = shortcutOpts
770
- const { code, clickMethod } = option as VxeDatePickerDefines.ShortcutOption
771
- let value = inputValue
772
- const shortcutParams = {
773
- $datePicker: $xeDatePicker as VxeDatePickerConstructor,
774
- option,
775
- value,
776
- code
777
- }
778
- if (!clickMethod && code) {
779
- const gCommandOpts = commands.get(code)
780
- const dpCommandMethod = gCommandOpts ? gCommandOpts.datePickerCommandMethod : null
781
- if (dpCommandMethod) {
782
- dpCommandMethod(shortcutParams)
783
- } else {
784
- const dateValueFormat = $xeDatePicker.computeDateValueFormat
785
- const firstDayOfWeek = $xeDatePicker.computeFirstDayOfWeek
786
- switch (code) {
787
- case 'now':
788
- case 'prev':
789
- case 'next':
790
- case 'minus':
791
- case 'plus': {
792
- const restObj = getDateByCode(code, value, type, {
793
- valueFormat: dateValueFormat,
794
- firstDay: firstDayOfWeek
795
- })
796
- value = restObj.value
797
- shortcutParams.value = value
798
- $xeDatePicker.handleChange(value, $event)
799
- break
800
- }
801
- default:
802
- errLog('vxe.error.notCommands', [`[date-picker] ${code}`])
803
- break
804
- }
805
- }
806
- } else {
807
- const optClickMethod = clickMethod || shortcutOpts.clickMethod
808
- if (optClickMethod) {
809
- optClickMethod(shortcutParams)
810
- }
811
- }
812
- if (autoClose) {
813
- $xeDatePicker.hidePanel()
814
- }
815
- $xeDatePicker.dispatchEvent('shortcut-click', shortcutParams, $event)
816
- },
817
-
818
- setModelValue (value: string) {
819
- const $xeDatePicker = this
820
- const reactData = $xeDatePicker.reactData
821
-
822
- reactData.inputValue = value
823
- $xeDatePicker.emitModel(value)
824
- },
825
- setModelValueByEvent (evnt: Event, value: string) {
826
- const $xeDatePicker = this
827
-
828
- $xeDatePicker.handleChange(value || '', evnt)
829
- },
830
- focus () {
831
- const $xeDatePicker = this
832
- const reactData = $xeDatePicker.reactData
833
-
834
- const inputElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
835
- reactData.isActivated = true
836
- inputElem.focus()
837
- return $xeDatePicker.$nextTick()
838
- },
839
- blur () {
840
- const $xeDatePicker = this
841
- const reactData = $xeDatePicker.reactData
842
-
843
- const inputElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
844
- inputElem.blur()
845
- reactData.isActivated = false
846
- return $xeDatePicker.$nextTick()
847
- },
848
- select () {
849
- const $xeDatePicker = this
850
- const reactData = $xeDatePicker.reactData
851
-
852
- const inputElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
853
- inputElem.select()
854
- reactData.isActivated = false
855
- return $xeDatePicker.$nextTick()
856
- },
857
-
858
- //
859
- // Render
860
- //
861
- renderShortcutBtn (h: CreateElement, pos: 'top' | 'bottom' | 'left' | 'right' | 'header' | 'footer', isVertical?: boolean) {
862
- const $xeDatePicker = this
863
-
864
- const shortcutOpts = $xeDatePicker.computeShortcutOpts
865
- const { position, align, mode } = shortcutOpts
866
- const shortcutList = $xeDatePicker.computeShortcutList
867
- if (isEnableConf(shortcutOpts) && shortcutList.length && (position || 'left') === pos) {
868
- return h('div', {
869
- class: `vxe-date-picker--layout-${pos}-wrapper`
870
- }, [
871
- h(VxeButtonGroupComponent, {
872
- props: {
873
- options: shortcutList,
874
- mode,
875
- align,
876
- vertical: isVertical
877
- },
878
- on: {
879
- click: $xeDatePicker.handleShortcutEvent
880
- }
881
- })
882
- ])
883
- }
884
- return renderEmptyElement($xeDatePicker)
885
- },
886
- renderPanel (h: CreateElement) {
887
- const $xeDatePicker = this
888
- const props = $xeDatePicker
889
- const slots = $xeDatePicker.$scopedSlots
890
- const reactData = $xeDatePicker.reactData
891
-
892
- const { type, multiple, showClearButton, showConfirmButton } = props
893
- const { initialized, isAniVisible, visiblePanel, panelPlacement, panelStyle, inputValue } = reactData
894
- const vSize = $xeDatePicker.computeSize
895
- const btnTransfer = $xeDatePicker.computeBtnTransfer
896
- const shortcutOpts = $xeDatePicker.computeShortcutOpts
897
- const isClearable = $xeDatePicker.computeIsClearable
898
- const isDateTimeType = $xeDatePicker.computeIsDateTimeType
899
- const shortcutList = $xeDatePicker.computeShortcutList
900
- const timeOpts = $xeDatePicker.computeTimeOpts
901
- const popupOpts = $xeDatePicker.computePopupOpts
902
- const { position } = shortcutOpts
903
- const headerSlot = slots.header
904
- const footerSlot = slots.footer
905
- const topSlot = slots.top
906
- const bottomSlot = slots.bottom
907
- const leftSlot = slots.left
908
- const rightSlot = slots.right
909
- const ppClassName = popupOpts.className
910
- const hasShortcutBtn = shortcutList.length > 0
911
- const showConfirmBtn = (showConfirmButton === null ? (isDateTimeType || multiple) : showConfirmButton)
912
- const showClearBtn = (showClearButton === null ? (isClearable && showConfirmBtn && type !== 'time') : showClearButton)
913
- return h('div', {
914
- ref: 'refInputPanel',
915
- class: ['vxe-table--ignore-clear vxe-date-picker--panel', `type--${type}`, {
916
- [`size--${vSize}`]: vSize,
917
- 'is--transfer': btnTransfer,
918
- 'ani--leave': isAniVisible,
919
- 'ani--enter': visiblePanel,
920
- 'show--top': !!(topSlot || headerSlot || (hasShortcutBtn && (position === 'top' || position === 'header'))),
921
- 'show--bottom': !!(bottomSlot || footerSlot || (hasShortcutBtn && (position === 'bottom' || position === 'footer'))),
922
- 'show--left': !!(leftSlot || (hasShortcutBtn && position === 'left')),
923
- 'show--right': !!(rightSlot || (hasShortcutBtn && position === 'right'))
924
- }],
925
- attrs: {
926
- placement: panelPlacement
927
- },
928
- style: panelStyle
929
- }, initialized && (visiblePanel || isAniVisible)
930
- ? [
931
- h('div', {
932
- ref: 'refPanelWrapper',
933
- class: ['vxe-date-picker--layout-all-wrapper', `type--${type}`, ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $datePicker: $xeDatePicker }) : ppClassName) : '', {
934
- [`size--${vSize}`]: vSize
935
- }]
936
- }, [
937
- topSlot
938
- ? h('div', {
939
- class: 'vxe-date-picker--layout-top-wrapper'
940
- }, topSlot({}))
941
- : $xeDatePicker.renderShortcutBtn(h, 'top'),
942
- h('div', {
943
- class: 'vxe-date-picker--layout-body-layout-wrapper'
944
- }, [
945
- leftSlot
946
- ? h('div', {
947
- class: 'vxe-date-picker--layout-left-wrapper'
948
- }, leftSlot({}))
949
- : $xeDatePicker.renderShortcutBtn(h, 'left', true),
950
- h('div', {
951
- class: 'vxe-date-picker--layout-body-content-wrapper'
952
- }, [
953
- headerSlot
954
- ? h('div', {
955
- class: 'vxe-date-picker--layout-header-wrapper'
956
- }, headerSlot({}))
957
- : $xeDatePicker.renderShortcutBtn(h, 'header'),
958
- h('div', {
959
- class: 'vxe-date-picker--layout-body-wrapper'
960
- }, [
961
- h(VxeDatePanelComponent, {
962
- ref: 'refDatePanel',
963
- props: {
964
- value: reactData.inputValue,
965
- type: props.type,
966
- className: props.className,
967
- multiple: props.multiple,
968
- limitCount: props.limitCount,
969
- startDate: props.startDate,
970
- endDate: props.endDate,
971
- defaultDate: props.defaultDate,
972
- defaultTime: props.defaultTime,
973
- minDate: props.minDate,
974
- maxDate: props.maxDate,
975
- startDay: props.startDay,
976
- labelFormat: props.labelFormat,
977
- valueFormat: props.valueFormat,
978
- timeFormat: props.timeFormat,
979
- timeConfig: timeOpts,
980
- festivalMethod: props.festivalMethod,
981
- disabledMethod: props.disabledMethod,
982
- selectDay: props.selectDay
983
- },
984
- on: {
985
- change: $xeDatePicker.panelChangeEvent,
986
- confirm: $xeDatePicker.panelConfirmEvent
987
- }
988
- })
989
- ]),
990
- h('div', {
991
- class: 'vxe-date-picker--layout-footer-wrapper'
992
- }, [
993
- h('div', {
994
- class: 'vxe-date-picker--layout-footer-custom'
995
- }, footerSlot ? footerSlot({}) : [$xeDatePicker.renderShortcutBtn(h, 'footer')]),
996
- showClearBtn || showConfirmBtn
997
- ? h('div', {
998
- class: 'vxe-date-picker--layout-footer-btns'
999
- }, [
1000
- showClearBtn
1001
- ? h(VxeButtonComponent, {
1002
- props: {
1003
- size: 'mini',
1004
- disabled: inputValue === '' || XEUtils.eqNull(inputValue),
1005
- content: getI18n('vxe.button.clear')
1006
- },
1007
- on: {
1008
- click: $xeDatePicker.clearValueEvent
1009
- }
1010
- })
1011
- : renderEmptyElement($xeDatePicker),
1012
- showConfirmBtn
1013
- ? h(VxeButtonComponent, {
1014
- props: {
1015
- size: 'mini',
1016
- status: 'primary',
1017
- content: getI18n('vxe.button.confirm')
1018
- },
1019
- on: {
1020
- click: $xeDatePicker.confirmEvent
1021
- }
1022
- })
1023
- : renderEmptyElement($xeDatePicker)
1024
- ])
1025
- : renderEmptyElement($xeDatePicker)
1026
- ])
1027
- ]),
1028
- rightSlot
1029
- ? h('div', {
1030
- class: 'vxe-date-picker--layout-right-wrapper'
1031
- }, rightSlot({}))
1032
- : $xeDatePicker.renderShortcutBtn(h, 'right', true)
1033
- ]),
1034
- bottomSlot
1035
- ? h('div', {
1036
- class: 'vxe-date-picker--layout-bottom-wrapper'
1037
- }, bottomSlot({}))
1038
- : $xeDatePicker.renderShortcutBtn(h, 'bottom')
1039
- ])
1040
- ]
1041
- : [])
1042
- },
1043
- renderPrefixIcon (h: CreateElement) {
1044
- const $xeDatePicker = this
1045
- const props = $xeDatePicker
1046
- const slots = $xeDatePicker.$scopedSlots
1047
-
1048
- const { prefixIcon } = props
1049
- const prefixSlot = slots.prefix
1050
- return prefixSlot || prefixIcon
1051
- ? h('div', {
1052
- class: 'vxe-date-picker--prefix',
1053
- on: {
1054
- click: $xeDatePicker.clickPrefixEvent
1055
- }
1056
- }, [
1057
- h('div', {
1058
- class: 'vxe-date-picker--prefix-icon'
1059
- }, prefixSlot
1060
- ? getSlotVNs(prefixSlot({}))
1061
- : [
1062
- h('i', {
1063
- class: prefixIcon
1064
- })
1065
- ])
1066
- ])
1067
- : null
1068
- },
1069
- renderSuffixIcon (h: CreateElement) {
1070
- const $xeDatePicker = this
1071
- const props = $xeDatePicker
1072
- const slots = $xeDatePicker.$scopedSlots
1073
- const reactData = $xeDatePicker.reactData
1074
-
1075
- const { suffixIcon } = props
1076
- const { inputValue } = reactData
1077
- const suffixSlot = slots.suffix
1078
- const isDisabled = $xeDatePicker.computeIsDisabled
1079
- const isClearable = $xeDatePicker.computeIsClearable
1080
- return h('div', {
1081
- class: ['vxe-date-picker--suffix', {
1082
- 'is--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
1083
- }]
1084
- }, [
1085
- isClearable
1086
- ? h('div', {
1087
- class: 'vxe-date-picker--clear-icon',
1088
- on: {
1089
- click: $xeDatePicker.clearValueEvent
1090
- }
1091
- }, [
1092
- h('i', {
1093
- class: getIcon().INPUT_CLEAR
1094
- })
1095
- ])
1096
- : renderEmptyElement($xeDatePicker),
1097
- $xeDatePicker.renderExtraSuffixIcon(h),
1098
- suffixSlot || suffixIcon
1099
- ? h('div', {
1100
- class: 'vxe-date-picker--suffix-icon',
1101
- on: {
1102
- click: $xeDatePicker.clickSuffixEvent
1103
- }
1104
- }, suffixSlot
1105
- ? getSlotVNs(suffixSlot({}))
1106
- : [
1107
- h('i', {
1108
- class: suffixIcon
1109
- })
1110
- ])
1111
- : renderEmptyElement($xeDatePicker)
1112
- ])
1113
- },
1114
- renderExtraSuffixIcon (h: CreateElement) {
1115
- const $xeDatePicker = this
1116
-
1117
- return h('div', {
1118
- class: 'vxe-date-picker--control-icon',
1119
- on: {
1120
- click: $xeDatePicker.datePickerOpenEvent
1121
- }
1122
- }, [
1123
- h('i', {
1124
- class: ['vxe-date-picker--date-picker-icon', getIcon().DATE_PICKER_DATE]
1125
- })
1126
- ])
1127
- },
1128
- renderVN (h: CreateElement) {
1129
- const $xeDatePicker = this
1130
- const props = $xeDatePicker
1131
- const reactData = $xeDatePicker.reactData
1132
-
1133
- const { className, type, name, autoComplete } = props
1134
- const { inputValue, inputLabel, visiblePanel, isActivated } = reactData
1135
- const vSize = $xeDatePicker.computeSize
1136
- const isDisabled = $xeDatePicker.computeIsDisabled
1137
- const formReadonly = $xeDatePicker.computeFormReadonly
1138
- const panelLabel = $xeDatePicker.computePanelLabel
1139
- if (formReadonly) {
1140
- return h('div', {
1141
- ref: 'refElem',
1142
- class: ['vxe-date-picker--readonly', `type--${type}`, className]
1143
- }, panelLabel)
1144
- }
1145
- const inputReadonly = $xeDatePicker.computeInputReadonly
1146
- const inpPlaceholder = $xeDatePicker.computeInpPlaceholder
1147
- const isClearable = $xeDatePicker.computeIsClearable
1148
- const prefix = $xeDatePicker.renderPrefixIcon(h)
1149
- const suffix = $xeDatePicker.renderSuffixIcon(h)
1150
- return h('div', {
1151
- ref: 'refElem',
1152
- class: ['vxe-date-picker', `type--${type}`, className, {
1153
- [`size--${vSize}`]: vSize,
1154
- 'is--prefix': !!prefix,
1155
- 'is--suffix': !!suffix,
1156
- 'is--visible': visiblePanel,
1157
- 'is--disabled': isDisabled,
1158
- 'is--active': isActivated,
1159
- 'show--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
1160
- }],
1161
- attrs: {
1162
- spellcheck: false
1163
- }
1164
- }, [
1165
- prefix || renderEmptyElement($xeDatePicker),
1166
- h('div', {
1167
- class: 'vxe-date-picker--wrapper'
1168
- }, [
1169
- h('input', {
1170
- ref: 'refInputTarget',
1171
- class: 'vxe-date-picker--inner',
1172
- domProps: {
1173
- value: inputLabel
1174
- },
1175
- attrs: {
1176
- name,
1177
- type: 'text',
1178
- placeholder: inpPlaceholder,
1179
- readonly: inputReadonly,
1180
- disabled: isDisabled,
1181
- autocomplete: autoComplete
1182
- },
1183
- on: {
1184
- keydown: $xeDatePicker.keydownEvent,
1185
- keyup: $xeDatePicker.keyupEvent,
1186
- click: $xeDatePicker.clickEvent,
1187
- input: $xeDatePicker.inputEvent,
1188
- change: $xeDatePicker.changeEvent,
1189
- focus: $xeDatePicker.focusEvent,
1190
- blur: $xeDatePicker.blurEvent
1191
- }
1192
- })
1193
- ]),
1194
- suffix || renderEmptyElement($xeDatePicker),
1195
- // 下拉面板
1196
- $xeDatePicker.renderPanel(h)
1197
- ])
1198
- }
1199
- },
1200
- watch: {
1201
- computePanelLabel (val) {
1202
- const $xeDatePicker = this
1203
- const reactData = $xeDatePicker.reactData
1204
-
1205
- reactData.inputLabel = val
1206
- },
1207
- value () {
1208
- const $xeDatePicker = this
1209
-
1210
- $xeDatePicker.updateModelValue()
1211
- }
1212
- },
1213
- created () {
1214
- const $xeDatePicker = this
1215
-
1216
- $xeDatePicker.updateModelValue()
1217
- globalEvents.on($xeDatePicker, 'mousewheel', $xeDatePicker.handleGlobalMousewheelEvent)
1218
- globalEvents.on($xeDatePicker, 'mousedown', $xeDatePicker.handleGlobalMousedownEvent)
1219
- globalEvents.on($xeDatePicker, 'keydown', $xeDatePicker.handleGlobalKeydownEvent)
1220
- globalEvents.on($xeDatePicker, 'blur', $xeDatePicker.handleGlobalBlurEvent)
1221
- globalEvents.on($xeDatePicker, 'resize', $xeDatePicker.handleGlobalResizeEvent)
1222
- },
1223
- beforeDestroy () {
1224
- const $xeDatePicker = this
1225
-
1226
- const panelElem = $xeDatePicker.$refs.refInputPanel as HTMLElement | undefined
1227
- if (panelElem && panelElem.parentNode) {
1228
- panelElem.parentNode.removeChild(panelElem)
1229
- }
1230
- globalEvents.off($xeDatePicker, 'mousewheel')
1231
- globalEvents.off($xeDatePicker, 'mousedown')
1232
- globalEvents.off($xeDatePicker, 'blur')
1233
- globalEvents.off($xeDatePicker, 'resize')
1234
- },
1235
- render (this: any, h) {
1236
- return this.renderVN(h)
1237
- }
1238
- }) /* define-vxe-component end */
1
+ import { PropType, CreateElement } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { getConfig, getIcon, getI18n, commands, createEvent, globalEvents, GLOBAL_EVENT_KEYS, globalMixins, renderEmptyElement } from '../../ui'
5
+ import { getFuncText, getLastZIndex, nextZIndex, isEnableConf } from '../../ui/src/utils'
6
+ import { updatePanelPlacement, getEventTargetNode } from '../../ui/src/dom'
7
+ import { getSlotVNs } from '../../ui/src/vn'
8
+ import { parseDateObj, parseDateValue, getDateByCode, handleValueFormat, hasDateValueType, hasTimestampValueType } from '../../date-panel/src/util'
9
+ import { errLog } from '../../ui/src/log'
10
+ import VxeDatePanelComponent from '../../date-panel/src/date-panel'
11
+ import VxeButtonComponent from '../../button/src/button'
12
+ import VxeButtonGroupComponent from '../../button/src/button-group'
13
+
14
+ import type { VxeDatePickerConstructor, VxeDatePickerEmits, DatePickerInternalData, DatePickerReactData, VxeButtonGroupDefines, VxeComponentSizeType, VxeDatePickerPropTypes, VxeFormConstructor, VxeFormPrivateMethods, VxeFormDefines, ValueOf, VxeModalConstructor, VxeDrawerConstructor, VxeModalMethods, VxeDrawerMethods, VxeDatePickerDefines, VxeDatePanelConstructor } from '../../../types'
15
+ import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
16
+
17
+ export default /* define-vxe-component start */ defineVxeComponent({
18
+ name: 'VxeDatePicker',
19
+ mixins: [
20
+ globalMixins.sizeMixin
21
+ ],
22
+ model: {
23
+ prop: 'value',
24
+ event: 'modelValue'
25
+ },
26
+ props: {
27
+ value: [String, Number, Date] as PropType<VxeDatePickerPropTypes.ModelValue>,
28
+ immediate: {
29
+ type: Boolean as PropType<VxeDatePickerPropTypes.Immediate>,
30
+ default: true
31
+ },
32
+ name: String as PropType<VxeDatePickerPropTypes.Name>,
33
+ type: {
34
+ type: String as PropType<VxeDatePickerPropTypes.Type>,
35
+ default: 'date' as VxeDatePickerPropTypes.Type
36
+ },
37
+ clearable: {
38
+ type: Boolean as PropType<VxeDatePickerPropTypes.Clearable>,
39
+ default: () => getConfig().datePicker.clearable
40
+ },
41
+ readonly: {
42
+ type: Boolean as PropType<VxeDatePickerPropTypes.Readonly>,
43
+ default: null
44
+ },
45
+ disabled: {
46
+ type: Boolean as PropType<VxeDatePickerPropTypes.Disabled>,
47
+ default: null
48
+ },
49
+ placeholder: String as PropType<VxeDatePickerPropTypes.Placeholder>,
50
+ autoComplete: {
51
+ type: String as PropType<VxeDatePickerPropTypes.AutoComplete>,
52
+ default: 'off'
53
+ },
54
+ form: String as PropType<VxeDatePickerPropTypes.Form>,
55
+ className: String as PropType<VxeDatePickerPropTypes.ClassName>,
56
+ zIndex: Number as PropType<VxeDatePickerPropTypes.ZIndex>,
57
+ size: {
58
+ type: String as PropType<VxeDatePickerPropTypes.Size>,
59
+ default: () => getConfig().datePicker.size || getConfig().size
60
+ },
61
+ multiple: Boolean as PropType<VxeDatePickerPropTypes.Multiple>,
62
+ limitCount: {
63
+ type: [String, Number] as PropType<VxeDatePickerPropTypes.LimitCount>,
64
+ default: () => getConfig().datePicker.limitCount
65
+ },
66
+
67
+ // date、week、month、quarter、year
68
+ startDate: {
69
+ type: [String, Number, Date] as PropType<VxeDatePickerPropTypes.StartDate>,
70
+ default: () => getConfig().datePicker.startDate
71
+ },
72
+ endDate: {
73
+ type: [String, Number, Date] as PropType<VxeDatePickerPropTypes.EndDate>,
74
+ default: () => getConfig().datePicker.endDate
75
+ },
76
+ defaultDate: [String, Number, Date] as PropType<VxeDatePickerPropTypes.DefaultDate>,
77
+ defaultTime: [String, Number, Date] as PropType<VxeDatePickerPropTypes.DefaultTime>,
78
+ minDate: [String, Number, Date] as PropType<VxeDatePickerPropTypes.MinDate>,
79
+ maxDate: [String, Number, Date] as PropType<VxeDatePickerPropTypes.MaxDate>,
80
+ startDay: {
81
+ type: [String, Number] as PropType<VxeDatePickerPropTypes.StartDay>,
82
+ default: () => getConfig().datePicker.startDay
83
+ },
84
+ labelFormat: String as PropType<VxeDatePickerPropTypes.LabelFormat>,
85
+ valueFormat: String as PropType<VxeDatePickerPropTypes.ValueFormat>,
86
+ timeFormat: String as PropType<VxeDatePickerPropTypes.TimeFormat>,
87
+ editable: {
88
+ type: Boolean as PropType<VxeDatePickerPropTypes.Editable>,
89
+ default: true
90
+ },
91
+ festivalMethod: {
92
+ type: Function as PropType<VxeDatePickerPropTypes.FestivalMethod>,
93
+ default: () => getConfig().datePicker.festivalMethod
94
+ },
95
+ disabledMethod: {
96
+ type: Function as PropType<VxeDatePickerPropTypes.DisabledMethod>,
97
+ default: () => getConfig().datePicker.disabledMethod
98
+ },
99
+
100
+ // week
101
+ selectDay: {
102
+ type: [String, Number] as PropType<VxeDatePickerPropTypes.SelectDay>,
103
+ default: () => getConfig().datePicker.selectDay
104
+ },
105
+ showClearButton: {
106
+ type: Boolean as PropType<VxeDatePickerPropTypes.ShowClearButton>,
107
+ default: () => getConfig().datePicker.showClearButton
108
+ },
109
+ showConfirmButton: {
110
+ type: Boolean as PropType<VxeDatePickerPropTypes.ShowConfirmButton>,
111
+ default: () => getConfig().datePicker.showConfirmButton
112
+ },
113
+ autoClose: {
114
+ type: Boolean as PropType<VxeDatePickerPropTypes.AutoClose>,
115
+ default: () => getConfig().datePicker.autoClose
116
+ },
117
+
118
+ prefixIcon: String as PropType<VxeDatePickerPropTypes.PrefixIcon>,
119
+ suffixIcon: String as PropType<VxeDatePickerPropTypes.SuffixIcon>,
120
+ placement: String as PropType<VxeDatePickerPropTypes.Placement>,
121
+ transfer: {
122
+ type: Boolean as PropType<VxeDatePickerPropTypes.Transfer>,
123
+ default: null
124
+ },
125
+
126
+ timeConfig: Object as PropType<VxeDatePickerPropTypes.TimeConfig>,
127
+ popupConfig: Object as PropType<VxeDatePickerPropTypes.PopupConfig>,
128
+ shortcutConfig: Object as PropType<VxeDatePickerPropTypes.ShortcutConfig>,
129
+
130
+ // 已废弃 startWeek,被 startDay 替换
131
+ startWeek: Number as PropType<VxeDatePickerPropTypes.StartDay>
132
+ },
133
+ inject: {
134
+ $xeModal: {
135
+ default: null
136
+ },
137
+ $xeDrawer: {
138
+ default: null
139
+ },
140
+ $xeTable: {
141
+ default: null
142
+ },
143
+ $xeForm: {
144
+ default: null
145
+ },
146
+ formItemInfo: {
147
+ from: 'xeFormItemInfo',
148
+ default: null
149
+ }
150
+ },
151
+ provide () {
152
+ const $xeDatePicker = this
153
+
154
+ return {
155
+ $xeDatePicker
156
+ }
157
+ },
158
+ data () {
159
+ const xID = XEUtils.uniqueId()
160
+
161
+ const reactData: DatePickerReactData = {
162
+ initialized: false,
163
+ panelIndex: 0,
164
+ visiblePanel: false,
165
+ isAniVisible: false,
166
+ panelStyle: {},
167
+ panelPlacement: '',
168
+ isActivated: false,
169
+ inputValue: '',
170
+ inputLabel: ''
171
+ }
172
+
173
+ const internalData: DatePickerInternalData = {
174
+ hpTimeout: undefined
175
+ }
176
+
177
+ return {
178
+ xID,
179
+ reactData,
180
+ internalData
181
+ }
182
+ },
183
+ computed: {
184
+ ...({} as {
185
+ computeSize(): VxeComponentSizeType
186
+ $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
187
+ $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
188
+ $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
189
+ $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
190
+ formItemInfo(): VxeFormDefines.ProvideItemInfo | null
191
+ }),
192
+ computeBtnTransfer () {
193
+ const $xeDatePicker = this
194
+ const props = $xeDatePicker
195
+ const $xeTable = $xeDatePicker.$xeTable
196
+ const $xeModal = $xeDatePicker.$xeModal
197
+ const $xeDrawer = $xeDatePicker.$xeDrawer
198
+ const $xeForm = $xeDatePicker.$xeForm
199
+
200
+ const { transfer } = props
201
+ const popupOpts = $xeDatePicker.computePopupOpts as VxeDatePickerPropTypes.PopupConfig
202
+ if (XEUtils.isBoolean(popupOpts.transfer)) {
203
+ return popupOpts.transfer
204
+ }
205
+ if (transfer === null) {
206
+ const globalTransfer = getConfig().datePicker.transfer
207
+ if (XEUtils.isBoolean(globalTransfer)) {
208
+ return globalTransfer
209
+ }
210
+ if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
211
+ return true
212
+ }
213
+ }
214
+ return transfer
215
+ },
216
+ computeFormReadonly () {
217
+ const $xeDatePicker = this
218
+ const props = $xeDatePicker
219
+ const $xeForm = $xeDatePicker.$xeForm
220
+
221
+ const { readonly } = props
222
+ if (readonly === null) {
223
+ if ($xeForm) {
224
+ return $xeForm.readonly
225
+ }
226
+ return false
227
+ }
228
+ return readonly
229
+ },
230
+ computeIsDisabled () {
231
+ const $xeDatePicker = this
232
+ const props = $xeDatePicker
233
+ const $xeForm = $xeDatePicker.$xeForm
234
+
235
+ const { disabled } = props
236
+ if (disabled === null) {
237
+ if ($xeForm) {
238
+ return $xeForm.disabled
239
+ }
240
+ return false
241
+ }
242
+ return disabled
243
+ },
244
+ computeIsDateTimeType () {
245
+ const $xeDatePicker = this
246
+ const props = $xeDatePicker
247
+
248
+ const { type } = props
249
+ return type === 'time' || type === 'datetime'
250
+ },
251
+ computeIsDatePickerType () {
252
+ const $xeDatePicker = this
253
+ const props = $xeDatePicker
254
+
255
+ const isDateTimeType = $xeDatePicker.computeIsDateTimeType
256
+ return isDateTimeType || ['date', 'week', 'month', 'quarter', 'year'].indexOf(props.type) > -1
257
+ },
258
+ computeIsClearable () {
259
+ const $xeDatePicker = this
260
+ const props = $xeDatePicker
261
+
262
+ return props.clearable
263
+ },
264
+ computeInputReadonly () {
265
+ const $xeDatePicker = this
266
+ const props = $xeDatePicker
267
+
268
+ const { type, editable, multiple } = props
269
+ const formReadonly = $xeDatePicker.computeFormReadonly
270
+ return formReadonly || multiple || !editable || type === 'week' || type === 'quarter'
271
+ },
272
+ computeInpPlaceholder () {
273
+ const $xeDatePicker = this
274
+ const props = $xeDatePicker
275
+
276
+ const { placeholder } = props
277
+ if (placeholder) {
278
+ return getFuncText(placeholder)
279
+ }
280
+ const globalPlaceholder = getConfig().datePicker.placeholder
281
+ if (globalPlaceholder) {
282
+ return getFuncText(globalPlaceholder)
283
+ }
284
+ return getI18n('vxe.base.pleaseSelect')
285
+ },
286
+ computeInpImmediate () {
287
+ const $xeDatePicker = this
288
+ const props = $xeDatePicker
289
+
290
+ const { immediate } = props
291
+ return immediate
292
+ },
293
+ computeTimeOpts () {
294
+ const $xeDatePicker = this
295
+ const props = $xeDatePicker
296
+
297
+ return Object.assign({}, getConfig().datePicker.timeConfig, props.timeConfig)
298
+ },
299
+ computePopupOpts () {
300
+ const $xeDatePicker = this
301
+ const props = $xeDatePicker
302
+
303
+ return Object.assign({}, getConfig().datePicker.popupConfig, props.popupConfig)
304
+ },
305
+ computeShortcutOpts () {
306
+ const $xeDatePicker = this
307
+ const props = $xeDatePicker
308
+
309
+ return Object.assign({}, getConfig().datePicker.shortcutConfig, props.shortcutConfig)
310
+ },
311
+ computeShortcutList () {
312
+ const $xeDatePicker = this
313
+
314
+ const shortcutOpts = $xeDatePicker.computeShortcutOpts as VxeDatePickerPropTypes.ShortcutConfig
315
+ const { options } = shortcutOpts
316
+ if (options) {
317
+ return options.map((option, index) => {
318
+ return Object.assign({
319
+ name: `${option.name || option.code || index}`
320
+ }, option)
321
+ })
322
+ }
323
+ return []
324
+ },
325
+ computeDateLabelFormat () {
326
+ const $xeDatePicker = this
327
+ const props = $xeDatePicker
328
+
329
+ const { labelFormat } = props
330
+ return labelFormat || getI18n(`vxe.input.date.labelFormat.${props.type}`)
331
+ },
332
+ computeDateValueFormat () {
333
+ const $xeDatePicker = this
334
+ const props = $xeDatePicker
335
+
336
+ const { type, valueFormat } = props
337
+ return handleValueFormat(type, valueFormat)
338
+ },
339
+ computeFirstDayOfWeek () {
340
+ const $xeDatePicker = this
341
+ const props = $xeDatePicker
342
+
343
+ const { startDay } = props
344
+ return XEUtils.toNumber(startDay) as VxeDatePickerPropTypes.StartDay
345
+ },
346
+ computePanelLabel () {
347
+ const $xeDatePicker = this
348
+ const props = $xeDatePicker
349
+ const reactData = $xeDatePicker.reactData
350
+
351
+ const { type, multiple } = props
352
+ const { inputValue } = reactData
353
+ const dateLabelFormat = $xeDatePicker.computeDateLabelFormat
354
+ const dateValueFormat = $xeDatePicker.computeDateValueFormat
355
+ const firstDayOfWeek = $xeDatePicker.computeFirstDayOfWeek
356
+ const vals: string[] = inputValue ? (multiple ? inputValue.split(',') : [inputValue]) : []
357
+ return vals.map(val => {
358
+ const dateObj = parseDateObj(val, type, {
359
+ valueFormat: dateValueFormat,
360
+ labelFormat: dateLabelFormat,
361
+ firstDay: firstDayOfWeek
362
+ })
363
+ return dateObj.label
364
+ }).join(', ')
365
+ }
366
+ },
367
+ methods: {
368
+
369
+ //
370
+ // Method
371
+ //
372
+ dispatchEvent (type: ValueOf<VxeDatePickerEmits>, params: Record<string, any>, evnt: Event | null) {
373
+ const $xeDatePicker = this
374
+ $xeDatePicker.$emit(type, createEvent(evnt, { $datePicker: $xeDatePicker }, params))
375
+ },
376
+ emitModel (value: any) {
377
+ const $xeDatePicker = this
378
+
379
+ const { _events } = $xeDatePicker as any
380
+ if (_events && _events.modelValue) {
381
+ $xeDatePicker.$emit('modelValue', value)
382
+ } else {
383
+ $xeDatePicker.$emit('model-value', value)
384
+ }
385
+ },
386
+ updateModelValue () {
387
+ const $xeDatePicker = this
388
+ const props = $xeDatePicker
389
+ const reactData = $xeDatePicker.reactData
390
+
391
+ const { value: modelValue } = props
392
+ let val: any = ''
393
+ if (modelValue) {
394
+ if (XEUtils.isNumber(modelValue) && /^[0-9]{11,15}$/.test(`${modelValue}`)) {
395
+ val = new Date(modelValue)
396
+ } else {
397
+ val = modelValue
398
+ }
399
+ }
400
+ reactData.inputValue = val
401
+ },
402
+ triggerEvent (evnt: Event & { type: 'input' | 'change' | 'keydown' | 'keyup' | 'click' | 'focus' | 'blur' }) {
403
+ const $xeDatePicker = this
404
+ const reactData = $xeDatePicker.reactData
405
+
406
+ const { inputValue } = reactData
407
+ $xeDatePicker.dispatchEvent(evnt.type, { value: inputValue }, evnt)
408
+ },
409
+ handleChange (value: string | number | Date, evnt: Event | { type: string }) {
410
+ const $xeDatePicker = this
411
+ const props = $xeDatePicker
412
+ const reactData = $xeDatePicker.reactData
413
+ const $xeForm = $xeDatePicker.$xeForm
414
+ const formItemInfo = $xeDatePicker.formItemInfo
415
+
416
+ const { type, value: modelValue, valueFormat } = props
417
+ const dateValueFormat = $xeDatePicker.computeDateValueFormat
418
+ reactData.inputValue = value
419
+ if (hasTimestampValueType(valueFormat)) {
420
+ const dateVal = parseDateValue(value, type, { valueFormat: dateValueFormat })
421
+ const timeNum = dateVal ? dateVal.getTime() : null
422
+ $xeDatePicker.emitModel(timeNum)
423
+ if (modelValue !== timeNum) {
424
+ $xeDatePicker.dispatchEvent('change', { value: timeNum }, evnt as Event)
425
+ // 自动更新校验状态
426
+ if ($xeForm && formItemInfo) {
427
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, timeNum)
428
+ }
429
+ }
430
+ } else if (hasDateValueType(valueFormat)) {
431
+ const dateVal = parseDateValue(value, type, { valueFormat: dateValueFormat })
432
+ $xeDatePicker.emitModel(dateVal)
433
+ if (modelValue && dateVal ? XEUtils.toStringDate(modelValue).getTime() !== dateVal.getTime() : modelValue !== dateVal) {
434
+ $xeDatePicker.dispatchEvent('change', { value: dateVal }, evnt as Event)
435
+ // 自动更新校验状态
436
+ if ($xeForm && formItemInfo) {
437
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, dateVal)
438
+ }
439
+ }
440
+ } else {
441
+ $xeDatePicker.emitModel(value)
442
+ if (XEUtils.toValueString(modelValue) !== value) {
443
+ $xeDatePicker.dispatchEvent('change', { value }, evnt as Event)
444
+ // 自动更新校验状态
445
+ if ($xeForm && formItemInfo) {
446
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
447
+ }
448
+ }
449
+ }
450
+ },
451
+ inputEvent (evnt: Event & { type: 'input' }) {
452
+ const $xeDatePicker = this
453
+ const reactData = $xeDatePicker.reactData
454
+
455
+ const inputElem = evnt.target as HTMLInputElement
456
+ const value = inputElem.value
457
+ reactData.inputLabel = value
458
+ $xeDatePicker.dispatchEvent('input', { value }, evnt)
459
+ },
460
+ changeEvent (evnt: Event & { type: 'change' }) {
461
+ const $xeDatePicker = this
462
+
463
+ const inpImmediate = $xeDatePicker.computeInpImmediate
464
+ if (!inpImmediate) {
465
+ $xeDatePicker.triggerEvent(evnt)
466
+ }
467
+ },
468
+ focusEvent (evnt: Event & { type: 'focus' }) {
469
+ const $xeDatePicker = this
470
+ const reactData = $xeDatePicker.reactData
471
+
472
+ reactData.isActivated = true
473
+ const isDatePickerType = $xeDatePicker.computeIsDatePickerType
474
+ if (isDatePickerType) {
475
+ $xeDatePicker.datePickerOpenEvent(evnt)
476
+ }
477
+ $xeDatePicker.triggerEvent(evnt)
478
+ },
479
+ clickPrefixEvent (evnt: Event) {
480
+ const $xeDatePicker = this
481
+ const reactData = $xeDatePicker.reactData
482
+
483
+ const isDisabled = $xeDatePicker.computeIsDisabled
484
+ if (!isDisabled) {
485
+ const { inputValue } = reactData
486
+ $xeDatePicker.dispatchEvent('prefix-click', { value: inputValue }, evnt)
487
+ }
488
+ },
489
+ hidePanel () {
490
+ const $xeDatePicker = this
491
+ const reactData = $xeDatePicker.reactData
492
+ const internalData = $xeDatePicker.internalData
493
+
494
+ return new Promise<void>(resolve => {
495
+ reactData.visiblePanel = false
496
+ internalData.hpTimeout = setTimeout(() => {
497
+ reactData.isAniVisible = false
498
+ resolve()
499
+ }, 350)
500
+ })
501
+ },
502
+ clearValueEvent (evnt: Event, value: VxeDatePickerPropTypes.ModelValue) {
503
+ const $xeDatePicker = this
504
+
505
+ const isDatePickerType = $xeDatePicker.computeIsDatePickerType
506
+ if (isDatePickerType) {
507
+ $xeDatePicker.hidePanel()
508
+ }
509
+ $xeDatePicker.handleChange('', evnt)
510
+ $xeDatePicker.dispatchEvent('clear', { value }, evnt)
511
+ },
512
+ clickSuffixEvent (evnt: Event) {
513
+ const $xeDatePicker = this
514
+ const reactData = $xeDatePicker.reactData
515
+
516
+ const isDisabled = $xeDatePicker.computeIsDisabled
517
+ if (!isDisabled) {
518
+ const { inputValue } = reactData
519
+ $xeDatePicker.dispatchEvent('suffix-click', { value: inputValue }, evnt)
520
+ }
521
+ },
522
+ blurEvent (evnt: Event & { type: 'blur' }) {
523
+ const $xeDatePicker = this
524
+ const reactData = $xeDatePicker.reactData
525
+ const $xeForm = $xeDatePicker.$xeForm
526
+ const formItemInfo = $xeDatePicker.formItemInfo
527
+
528
+ const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
529
+ const { inputValue } = reactData
530
+ const inpImmediate = $xeDatePicker.computeInpImmediate
531
+ const value = inputValue
532
+ if (!inpImmediate) {
533
+ $xeDatePicker.handleChange(value, evnt)
534
+ }
535
+ if (!reactData.visiblePanel) {
536
+ reactData.isActivated = false
537
+ // 未打开面板时才校验
538
+ if ($datePanel) {
539
+ $datePanel.checkValue(reactData.inputLabel)
540
+ }
541
+ }
542
+ $xeDatePicker.dispatchEvent('blur', { value }, evnt)
543
+ // 自动更新校验状态
544
+ if ($xeForm && formItemInfo) {
545
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
546
+ }
547
+ },
548
+ keydownEvent (evnt: KeyboardEvent & { type: 'keydown' }) {
549
+ const $xeDatePicker = this
550
+
551
+ $xeDatePicker.triggerEvent(evnt)
552
+ },
553
+ keyupEvent (evnt: KeyboardEvent & { type: 'keyup' }) {
554
+ const $xeDatePicker = this
555
+
556
+ $xeDatePicker.triggerEvent(evnt)
557
+ },
558
+ confirmEvent (evnt: MouseEvent) {
559
+ const $xeDatePicker = this
560
+
561
+ const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
562
+ if ($datePanel) {
563
+ $datePanel.confirmByEvent(evnt)
564
+ }
565
+ $xeDatePicker.hidePanel()
566
+ },
567
+ panelChangeEvent (params: VxeDatePickerDefines.ChangeEventParams) {
568
+ const $xeDatePicker = this
569
+ const props = $xeDatePicker
570
+
571
+ const { multiple, autoClose } = props
572
+ const { value, $event } = params
573
+ const isDateTimeType = $xeDatePicker.computeIsDateTimeType
574
+ $xeDatePicker.handleChange(value, $event)
575
+ if (!multiple && !isDateTimeType) {
576
+ if (autoClose) {
577
+ $xeDatePicker.hidePanel()
578
+ }
579
+ }
580
+ },
581
+ panelConfirmEvent (params: VxeDatePickerDefines.ConfirmEventParams) {
582
+ const $xeDatePicker = this
583
+
584
+ $xeDatePicker.dispatchEvent('confirm', params, params.$event)
585
+ },
586
+ // 全局事件
587
+ handleGlobalMousedownEvent (evnt: Event) {
588
+ const $xeDatePicker = this
589
+ const reactData = $xeDatePicker.reactData
590
+
591
+ const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
592
+ const { visiblePanel, isActivated } = reactData
593
+ const el = $xeDatePicker.$refs.refElem as HTMLDivElement
594
+ const panelWrapperElem = $xeDatePicker.$refs.refPanelWrapper as HTMLDivElement
595
+ const isDisabled = $xeDatePicker.computeIsDisabled
596
+ if (!isDisabled && isActivated) {
597
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelWrapperElem).flag
598
+ if (!reactData.isActivated) {
599
+ if (visiblePanel) {
600
+ $xeDatePicker.hidePanel()
601
+ if ($datePanel) {
602
+ $datePanel.checkValue(reactData.inputLabel)
603
+ }
604
+ }
605
+ }
606
+ }
607
+ },
608
+ handleGlobalKeydownEvent (evnt: KeyboardEvent) {
609
+ const $xeDatePicker = this
610
+ const reactData = $xeDatePicker.reactData
611
+
612
+ const { visiblePanel } = reactData
613
+ const isDisabled = $xeDatePicker.computeIsDisabled
614
+ if (!isDisabled) {
615
+ const isTab = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.TAB)
616
+ const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE)
617
+ if (isTab) {
618
+ reactData.isActivated = false
619
+ }
620
+ if (visiblePanel) {
621
+ if (isEsc || isTab) {
622
+ $xeDatePicker.hidePanel()
623
+ }
624
+ }
625
+ }
626
+ },
627
+ handleGlobalMousewheelEvent (evnt: Event) {
628
+ const $xeDatePicker = this
629
+ const reactData = $xeDatePicker.reactData
630
+
631
+ const { visiblePanel } = reactData
632
+ const isDisabled = $xeDatePicker.computeIsDisabled
633
+ if (!isDisabled) {
634
+ if (visiblePanel) {
635
+ const panelWrapperElem = $xeDatePicker.$refs.refPanelWrapper as HTMLDivElement
636
+ if (getEventTargetNode(evnt, panelWrapperElem).flag) {
637
+ $xeDatePicker.updatePlacement()
638
+ } else {
639
+ $xeDatePicker.hidePanel()
640
+ }
641
+ }
642
+ }
643
+ },
644
+ handleGlobalBlurEvent () {
645
+ const $xeDatePicker = this
646
+ const reactData = $xeDatePicker.reactData
647
+
648
+ const $datePanel = $xeDatePicker.$refs.refDatePanel as VxeDatePanelConstructor
649
+ const { isActivated, visiblePanel } = reactData
650
+ if (visiblePanel) {
651
+ $xeDatePicker.hidePanel()
652
+ }
653
+ if (isActivated) {
654
+ reactData.isActivated = false
655
+ }
656
+ if (visiblePanel || isActivated) {
657
+ if ($datePanel) {
658
+ $datePanel.checkValue(reactData.inputLabel)
659
+ }
660
+ const targetElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
661
+ if (targetElem) {
662
+ targetElem.blur()
663
+ }
664
+ }
665
+ },
666
+ handleGlobalResizeEvent () {
667
+ const $xeDatePicker = this
668
+ const reactData = $xeDatePicker.reactData
669
+
670
+ const { visiblePanel } = reactData
671
+ if (visiblePanel) {
672
+ $xeDatePicker.updatePlacement()
673
+ }
674
+ },
675
+ // 弹出面板
676
+ updateZindex () {
677
+ const $xeDatePicker = this
678
+ const props = $xeDatePicker
679
+ const reactData = $xeDatePicker.reactData
680
+
681
+ const popupOpts = $xeDatePicker.computePopupOpts
682
+ const customZIndex = popupOpts.zIndex || props.zIndex
683
+ if (customZIndex) {
684
+ reactData.panelIndex = XEUtils.toNumber(customZIndex)
685
+ } else if (reactData.panelIndex < getLastZIndex()) {
686
+ reactData.panelIndex = nextZIndex()
687
+ }
688
+ },
689
+ updatePlacement () {
690
+ const $xeDatePicker = this
691
+ const props = $xeDatePicker
692
+ const reactData = $xeDatePicker.reactData
693
+
694
+ const { placement } = props
695
+ const { panelIndex } = reactData
696
+ const targetElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
697
+ const panelElem = $xeDatePicker.$refs.refInputPanel as HTMLDivElement
698
+ const btnTransfer = $xeDatePicker.computeBtnTransfer
699
+ const popupOpts = $xeDatePicker.computePopupOpts
700
+ const handleStyle = () => {
701
+ const ppObj = updatePanelPlacement(targetElem, panelElem, {
702
+ placement: popupOpts.placement || placement,
703
+ teleportTo: btnTransfer
704
+ })
705
+ const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
706
+ zIndex: panelIndex
707
+ })
708
+ reactData.panelStyle = panelStyle
709
+ reactData.panelPlacement = ppObj.placement
710
+ }
711
+ handleStyle()
712
+ return $xeDatePicker.$nextTick().then(handleStyle)
713
+ },
714
+ showPanel () {
715
+ const $xeDatePicker = this
716
+ const reactData = $xeDatePicker.reactData
717
+ const internalData = $xeDatePicker.internalData
718
+
719
+ const { visiblePanel } = reactData
720
+ const isDisabled = $xeDatePicker.computeIsDisabled
721
+ const btnTransfer = $xeDatePicker.computeBtnTransfer
722
+ const panelElem = $xeDatePicker.$refs.refInputPanel as HTMLElement
723
+ if (!isDisabled && !visiblePanel) {
724
+ if (!reactData.initialized) {
725
+ reactData.initialized = true
726
+ if (btnTransfer) {
727
+ if (panelElem) {
728
+ document.body.appendChild(panelElem)
729
+ }
730
+ }
731
+ }
732
+ if (internalData.hpTimeout) {
733
+ clearTimeout(internalData.hpTimeout)
734
+ internalData.hpTimeout = undefined
735
+ }
736
+ reactData.isActivated = true
737
+ reactData.isAniVisible = true
738
+ setTimeout(() => {
739
+ reactData.visiblePanel = true
740
+ $xeDatePicker.updatePlacement()
741
+ }, 10)
742
+ $xeDatePicker.updateZindex()
743
+ return $xeDatePicker.updatePlacement()
744
+ }
745
+ return $xeDatePicker.$nextTick()
746
+ },
747
+ datePickerOpenEvent (evnt: Event) {
748
+ const $xeDatePicker = this
749
+
750
+ const formReadonly = $xeDatePicker.computeFormReadonly
751
+ if (!formReadonly) {
752
+ evnt.preventDefault()
753
+ $xeDatePicker.showPanel()
754
+ }
755
+ },
756
+ clickEvent (evnt: Event & { type: 'click' }) {
757
+ const $xeDatePicker = this
758
+
759
+ $xeDatePicker.triggerEvent(evnt)
760
+ },
761
+ handleShortcutEvent ({ option, $event }: VxeButtonGroupDefines.ClickEventParams) {
762
+ const $xeDatePicker = this
763
+ const props = $xeDatePicker
764
+ const reactData = $xeDatePicker.reactData
765
+
766
+ const { type } = props
767
+ const { inputValue } = reactData
768
+ const shortcutOpts = $xeDatePicker.computeShortcutOpts
769
+ const { autoClose } = shortcutOpts
770
+ const { code, clickMethod } = option as VxeDatePickerDefines.ShortcutOption
771
+ let value = inputValue
772
+ const shortcutParams = {
773
+ $datePicker: $xeDatePicker as VxeDatePickerConstructor,
774
+ option,
775
+ value,
776
+ code
777
+ }
778
+ if (!clickMethod && code) {
779
+ const gCommandOpts = commands.get(code)
780
+ const dpCommandMethod = gCommandOpts ? gCommandOpts.datePickerCommandMethod : null
781
+ if (dpCommandMethod) {
782
+ dpCommandMethod(shortcutParams)
783
+ } else {
784
+ const dateValueFormat = $xeDatePicker.computeDateValueFormat
785
+ const firstDayOfWeek = $xeDatePicker.computeFirstDayOfWeek
786
+ switch (code) {
787
+ case 'now':
788
+ case 'prev':
789
+ case 'next':
790
+ case 'minus':
791
+ case 'plus': {
792
+ const restObj = getDateByCode(code, value, type, {
793
+ valueFormat: dateValueFormat,
794
+ firstDay: firstDayOfWeek
795
+ })
796
+ value = restObj.value
797
+ shortcutParams.value = value
798
+ $xeDatePicker.handleChange(value, $event)
799
+ break
800
+ }
801
+ default:
802
+ errLog('vxe.error.notCommands', [`[date-picker] ${code}`])
803
+ break
804
+ }
805
+ }
806
+ } else {
807
+ const optClickMethod = clickMethod || shortcutOpts.clickMethod
808
+ if (optClickMethod) {
809
+ optClickMethod(shortcutParams)
810
+ }
811
+ }
812
+ if (autoClose) {
813
+ $xeDatePicker.hidePanel()
814
+ }
815
+ $xeDatePicker.dispatchEvent('shortcut-click', shortcutParams, $event)
816
+ },
817
+
818
+ setModelValue (value: string) {
819
+ const $xeDatePicker = this
820
+ const reactData = $xeDatePicker.reactData
821
+
822
+ reactData.inputValue = value
823
+ $xeDatePicker.emitModel(value)
824
+ },
825
+ setModelValueByEvent (evnt: Event, value: string) {
826
+ const $xeDatePicker = this
827
+
828
+ $xeDatePicker.handleChange(value || '', evnt)
829
+ },
830
+ focus () {
831
+ const $xeDatePicker = this
832
+ const reactData = $xeDatePicker.reactData
833
+
834
+ const inputElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
835
+ reactData.isActivated = true
836
+ inputElem.focus()
837
+ return $xeDatePicker.$nextTick()
838
+ },
839
+ blur () {
840
+ const $xeDatePicker = this
841
+ const reactData = $xeDatePicker.reactData
842
+
843
+ const inputElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
844
+ inputElem.blur()
845
+ reactData.isActivated = false
846
+ return $xeDatePicker.$nextTick()
847
+ },
848
+ select () {
849
+ const $xeDatePicker = this
850
+ const reactData = $xeDatePicker.reactData
851
+
852
+ const inputElem = $xeDatePicker.$refs.refInputTarget as HTMLInputElement
853
+ inputElem.select()
854
+ reactData.isActivated = false
855
+ return $xeDatePicker.$nextTick()
856
+ },
857
+
858
+ //
859
+ // Render
860
+ //
861
+ renderShortcutBtn (h: CreateElement, pos: 'top' | 'bottom' | 'left' | 'right' | 'header' | 'footer', isVertical?: boolean) {
862
+ const $xeDatePicker = this
863
+
864
+ const shortcutOpts = $xeDatePicker.computeShortcutOpts
865
+ const { position, align, mode } = shortcutOpts
866
+ const shortcutList = $xeDatePicker.computeShortcutList
867
+ if (isEnableConf(shortcutOpts) && shortcutList.length && (position || 'left') === pos) {
868
+ return h('div', {
869
+ class: `vxe-date-picker--layout-${pos}-wrapper`
870
+ }, [
871
+ h(VxeButtonGroupComponent, {
872
+ props: {
873
+ options: shortcutList,
874
+ mode,
875
+ align,
876
+ vertical: isVertical
877
+ },
878
+ on: {
879
+ click: $xeDatePicker.handleShortcutEvent
880
+ }
881
+ })
882
+ ])
883
+ }
884
+ return renderEmptyElement($xeDatePicker)
885
+ },
886
+ renderPanel (h: CreateElement) {
887
+ const $xeDatePicker = this
888
+ const props = $xeDatePicker
889
+ const slots = $xeDatePicker.$scopedSlots
890
+ const reactData = $xeDatePicker.reactData
891
+
892
+ const { type, multiple, showClearButton, showConfirmButton } = props
893
+ const { initialized, isAniVisible, visiblePanel, panelPlacement, panelStyle, inputValue } = reactData
894
+ const vSize = $xeDatePicker.computeSize
895
+ const btnTransfer = $xeDatePicker.computeBtnTransfer
896
+ const shortcutOpts = $xeDatePicker.computeShortcutOpts
897
+ const isClearable = $xeDatePicker.computeIsClearable
898
+ const isDateTimeType = $xeDatePicker.computeIsDateTimeType
899
+ const shortcutList = $xeDatePicker.computeShortcutList
900
+ const timeOpts = $xeDatePicker.computeTimeOpts
901
+ const popupOpts = $xeDatePicker.computePopupOpts
902
+ const { position } = shortcutOpts
903
+ const headerSlot = slots.header
904
+ const footerSlot = slots.footer
905
+ const topSlot = slots.top
906
+ const bottomSlot = slots.bottom
907
+ const leftSlot = slots.left
908
+ const rightSlot = slots.right
909
+ const ppClassName = popupOpts.className
910
+ const hasShortcutBtn = shortcutList.length > 0
911
+ const showConfirmBtn = (showConfirmButton === null ? (isDateTimeType || multiple) : showConfirmButton)
912
+ const showClearBtn = (showClearButton === null ? (isClearable && showConfirmBtn && type !== 'time') : showClearButton)
913
+ return h('div', {
914
+ ref: 'refInputPanel',
915
+ class: ['vxe-table--ignore-clear vxe-date-picker--panel', `type--${type}`, {
916
+ [`size--${vSize}`]: vSize,
917
+ 'is--transfer': btnTransfer,
918
+ 'ani--leave': isAniVisible,
919
+ 'ani--enter': visiblePanel,
920
+ 'show--top': !!(topSlot || headerSlot || (hasShortcutBtn && (position === 'top' || position === 'header'))),
921
+ 'show--bottom': !!(bottomSlot || footerSlot || (hasShortcutBtn && (position === 'bottom' || position === 'footer'))),
922
+ 'show--left': !!(leftSlot || (hasShortcutBtn && position === 'left')),
923
+ 'show--right': !!(rightSlot || (hasShortcutBtn && position === 'right'))
924
+ }],
925
+ attrs: {
926
+ placement: panelPlacement
927
+ },
928
+ style: panelStyle
929
+ }, initialized && (visiblePanel || isAniVisible)
930
+ ? [
931
+ h('div', {
932
+ ref: 'refPanelWrapper',
933
+ class: ['vxe-date-picker--layout-all-wrapper', `type--${type}`, ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $datePicker: $xeDatePicker }) : ppClassName) : '', {
934
+ [`size--${vSize}`]: vSize
935
+ }]
936
+ }, [
937
+ topSlot
938
+ ? h('div', {
939
+ class: 'vxe-date-picker--layout-top-wrapper'
940
+ }, topSlot({}))
941
+ : $xeDatePicker.renderShortcutBtn(h, 'top'),
942
+ h('div', {
943
+ class: 'vxe-date-picker--layout-body-layout-wrapper'
944
+ }, [
945
+ leftSlot
946
+ ? h('div', {
947
+ class: 'vxe-date-picker--layout-left-wrapper'
948
+ }, leftSlot({}))
949
+ : $xeDatePicker.renderShortcutBtn(h, 'left', true),
950
+ h('div', {
951
+ class: 'vxe-date-picker--layout-body-content-wrapper'
952
+ }, [
953
+ headerSlot
954
+ ? h('div', {
955
+ class: 'vxe-date-picker--layout-header-wrapper'
956
+ }, headerSlot({}))
957
+ : $xeDatePicker.renderShortcutBtn(h, 'header'),
958
+ h('div', {
959
+ class: 'vxe-date-picker--layout-body-wrapper'
960
+ }, [
961
+ h(VxeDatePanelComponent, {
962
+ ref: 'refDatePanel',
963
+ props: {
964
+ value: reactData.inputValue,
965
+ type: props.type,
966
+ className: props.className,
967
+ multiple: props.multiple,
968
+ limitCount: props.limitCount,
969
+ startDate: props.startDate,
970
+ endDate: props.endDate,
971
+ defaultDate: props.defaultDate,
972
+ defaultTime: props.defaultTime,
973
+ minDate: props.minDate,
974
+ maxDate: props.maxDate,
975
+ startDay: props.startDay,
976
+ labelFormat: props.labelFormat,
977
+ valueFormat: props.valueFormat,
978
+ timeFormat: props.timeFormat,
979
+ timeConfig: timeOpts,
980
+ festivalMethod: props.festivalMethod,
981
+ disabledMethod: props.disabledMethod,
982
+ selectDay: props.selectDay
983
+ },
984
+ on: {
985
+ change: $xeDatePicker.panelChangeEvent,
986
+ confirm: $xeDatePicker.panelConfirmEvent
987
+ }
988
+ })
989
+ ]),
990
+ h('div', {
991
+ class: 'vxe-date-picker--layout-footer-wrapper'
992
+ }, [
993
+ h('div', {
994
+ class: 'vxe-date-picker--layout-footer-custom'
995
+ }, footerSlot ? footerSlot({}) : [$xeDatePicker.renderShortcutBtn(h, 'footer')]),
996
+ showClearBtn || showConfirmBtn
997
+ ? h('div', {
998
+ class: 'vxe-date-picker--layout-footer-btns'
999
+ }, [
1000
+ showClearBtn
1001
+ ? h(VxeButtonComponent, {
1002
+ props: {
1003
+ size: 'mini',
1004
+ disabled: inputValue === '' || XEUtils.eqNull(inputValue),
1005
+ content: getI18n('vxe.button.clear')
1006
+ },
1007
+ on: {
1008
+ click: $xeDatePicker.clearValueEvent
1009
+ }
1010
+ })
1011
+ : renderEmptyElement($xeDatePicker),
1012
+ showConfirmBtn
1013
+ ? h(VxeButtonComponent, {
1014
+ props: {
1015
+ size: 'mini',
1016
+ status: 'primary',
1017
+ content: getI18n('vxe.button.confirm')
1018
+ },
1019
+ on: {
1020
+ click: $xeDatePicker.confirmEvent
1021
+ }
1022
+ })
1023
+ : renderEmptyElement($xeDatePicker)
1024
+ ])
1025
+ : renderEmptyElement($xeDatePicker)
1026
+ ])
1027
+ ]),
1028
+ rightSlot
1029
+ ? h('div', {
1030
+ class: 'vxe-date-picker--layout-right-wrapper'
1031
+ }, rightSlot({}))
1032
+ : $xeDatePicker.renderShortcutBtn(h, 'right', true)
1033
+ ]),
1034
+ bottomSlot
1035
+ ? h('div', {
1036
+ class: 'vxe-date-picker--layout-bottom-wrapper'
1037
+ }, bottomSlot({}))
1038
+ : $xeDatePicker.renderShortcutBtn(h, 'bottom')
1039
+ ])
1040
+ ]
1041
+ : [])
1042
+ },
1043
+ renderPrefixIcon (h: CreateElement) {
1044
+ const $xeDatePicker = this
1045
+ const props = $xeDatePicker
1046
+ const slots = $xeDatePicker.$scopedSlots
1047
+
1048
+ const { prefixIcon } = props
1049
+ const prefixSlot = slots.prefix
1050
+ return prefixSlot || prefixIcon
1051
+ ? h('div', {
1052
+ class: 'vxe-date-picker--prefix',
1053
+ on: {
1054
+ click: $xeDatePicker.clickPrefixEvent
1055
+ }
1056
+ }, [
1057
+ h('div', {
1058
+ class: 'vxe-date-picker--prefix-icon'
1059
+ }, prefixSlot
1060
+ ? getSlotVNs(prefixSlot({}))
1061
+ : [
1062
+ h('i', {
1063
+ class: prefixIcon
1064
+ })
1065
+ ])
1066
+ ])
1067
+ : null
1068
+ },
1069
+ renderSuffixIcon (h: CreateElement) {
1070
+ const $xeDatePicker = this
1071
+ const props = $xeDatePicker
1072
+ const slots = $xeDatePicker.$scopedSlots
1073
+ const reactData = $xeDatePicker.reactData
1074
+
1075
+ const { suffixIcon } = props
1076
+ const { inputValue } = reactData
1077
+ const suffixSlot = slots.suffix
1078
+ const isDisabled = $xeDatePicker.computeIsDisabled
1079
+ const isClearable = $xeDatePicker.computeIsClearable
1080
+ return h('div', {
1081
+ class: ['vxe-date-picker--suffix', {
1082
+ 'is--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
1083
+ }]
1084
+ }, [
1085
+ isClearable
1086
+ ? h('div', {
1087
+ class: 'vxe-date-picker--clear-icon',
1088
+ on: {
1089
+ click: $xeDatePicker.clearValueEvent
1090
+ }
1091
+ }, [
1092
+ h('i', {
1093
+ class: getIcon().INPUT_CLEAR
1094
+ })
1095
+ ])
1096
+ : renderEmptyElement($xeDatePicker),
1097
+ $xeDatePicker.renderExtraSuffixIcon(h),
1098
+ suffixSlot || suffixIcon
1099
+ ? h('div', {
1100
+ class: 'vxe-date-picker--suffix-icon',
1101
+ on: {
1102
+ click: $xeDatePicker.clickSuffixEvent
1103
+ }
1104
+ }, suffixSlot
1105
+ ? getSlotVNs(suffixSlot({}))
1106
+ : [
1107
+ h('i', {
1108
+ class: suffixIcon
1109
+ })
1110
+ ])
1111
+ : renderEmptyElement($xeDatePicker)
1112
+ ])
1113
+ },
1114
+ renderExtraSuffixIcon (h: CreateElement) {
1115
+ const $xeDatePicker = this
1116
+
1117
+ return h('div', {
1118
+ class: 'vxe-date-picker--control-icon',
1119
+ on: {
1120
+ click: $xeDatePicker.datePickerOpenEvent
1121
+ }
1122
+ }, [
1123
+ h('i', {
1124
+ class: ['vxe-date-picker--date-picker-icon', getIcon().DATE_PICKER_DATE]
1125
+ })
1126
+ ])
1127
+ },
1128
+ renderVN (h: CreateElement) {
1129
+ const $xeDatePicker = this
1130
+ const props = $xeDatePicker
1131
+ const reactData = $xeDatePicker.reactData
1132
+
1133
+ const { className, type, name, autoComplete } = props
1134
+ const { inputValue, inputLabel, visiblePanel, isActivated } = reactData
1135
+ const vSize = $xeDatePicker.computeSize
1136
+ const isDisabled = $xeDatePicker.computeIsDisabled
1137
+ const formReadonly = $xeDatePicker.computeFormReadonly
1138
+ const panelLabel = $xeDatePicker.computePanelLabel
1139
+ if (formReadonly) {
1140
+ return h('div', {
1141
+ ref: 'refElem',
1142
+ class: ['vxe-date-picker--readonly', `type--${type}`, className]
1143
+ }, panelLabel)
1144
+ }
1145
+ const inputReadonly = $xeDatePicker.computeInputReadonly
1146
+ const inpPlaceholder = $xeDatePicker.computeInpPlaceholder
1147
+ const isClearable = $xeDatePicker.computeIsClearable
1148
+ const prefix = $xeDatePicker.renderPrefixIcon(h)
1149
+ const suffix = $xeDatePicker.renderSuffixIcon(h)
1150
+ return h('div', {
1151
+ ref: 'refElem',
1152
+ class: ['vxe-date-picker', `type--${type}`, className, {
1153
+ [`size--${vSize}`]: vSize,
1154
+ 'is--prefix': !!prefix,
1155
+ 'is--suffix': !!suffix,
1156
+ 'is--visible': visiblePanel,
1157
+ 'is--disabled': isDisabled,
1158
+ 'is--active': isActivated,
1159
+ 'show--clear': isClearable && !isDisabled && !(inputValue === '' || XEUtils.eqNull(inputValue))
1160
+ }],
1161
+ attrs: {
1162
+ spellcheck: false
1163
+ }
1164
+ }, [
1165
+ prefix || renderEmptyElement($xeDatePicker),
1166
+ h('div', {
1167
+ class: 'vxe-date-picker--wrapper'
1168
+ }, [
1169
+ h('input', {
1170
+ ref: 'refInputTarget',
1171
+ class: 'vxe-date-picker--inner',
1172
+ domProps: {
1173
+ value: inputLabel
1174
+ },
1175
+ attrs: {
1176
+ name,
1177
+ type: 'text',
1178
+ placeholder: inpPlaceholder,
1179
+ readonly: inputReadonly,
1180
+ disabled: isDisabled,
1181
+ autocomplete: autoComplete
1182
+ },
1183
+ on: {
1184
+ keydown: $xeDatePicker.keydownEvent,
1185
+ keyup: $xeDatePicker.keyupEvent,
1186
+ click: $xeDatePicker.clickEvent,
1187
+ input: $xeDatePicker.inputEvent,
1188
+ change: $xeDatePicker.changeEvent,
1189
+ focus: $xeDatePicker.focusEvent,
1190
+ blur: $xeDatePicker.blurEvent
1191
+ }
1192
+ })
1193
+ ]),
1194
+ suffix || renderEmptyElement($xeDatePicker),
1195
+ // 下拉面板
1196
+ $xeDatePicker.renderPanel(h)
1197
+ ])
1198
+ }
1199
+ },
1200
+ watch: {
1201
+ computePanelLabel (val) {
1202
+ const $xeDatePicker = this
1203
+ const reactData = $xeDatePicker.reactData
1204
+
1205
+ reactData.inputLabel = val
1206
+ },
1207
+ value () {
1208
+ const $xeDatePicker = this
1209
+
1210
+ $xeDatePicker.updateModelValue()
1211
+ }
1212
+ },
1213
+ created () {
1214
+ const $xeDatePicker = this
1215
+
1216
+ $xeDatePicker.updateModelValue()
1217
+ globalEvents.on($xeDatePicker, 'mousewheel', $xeDatePicker.handleGlobalMousewheelEvent)
1218
+ globalEvents.on($xeDatePicker, 'mousedown', $xeDatePicker.handleGlobalMousedownEvent)
1219
+ globalEvents.on($xeDatePicker, 'keydown', $xeDatePicker.handleGlobalKeydownEvent)
1220
+ globalEvents.on($xeDatePicker, 'blur', $xeDatePicker.handleGlobalBlurEvent)
1221
+ globalEvents.on($xeDatePicker, 'resize', $xeDatePicker.handleGlobalResizeEvent)
1222
+ },
1223
+ beforeDestroy () {
1224
+ const $xeDatePicker = this
1225
+
1226
+ const panelElem = $xeDatePicker.$refs.refInputPanel as HTMLElement | undefined
1227
+ if (panelElem && panelElem.parentNode) {
1228
+ panelElem.parentNode.removeChild(panelElem)
1229
+ }
1230
+ globalEvents.off($xeDatePicker, 'mousewheel')
1231
+ globalEvents.off($xeDatePicker, 'mousedown')
1232
+ globalEvents.off($xeDatePicker, 'blur')
1233
+ globalEvents.off($xeDatePicker, 'resize')
1234
+ },
1235
+ render (this: any, h) {
1236
+ return this.renderVN(h)
1237
+ }
1238
+ }) /* define-vxe-component end */