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,913 +1,913 @@
1
- import { CreateElement, PropType, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getIcon, getConfig, getI18n, globalEvents, GLOBAL_EVENT_KEYS, createEvent, globalMixins } from '../../ui'
5
- import { warnLog, errLog } from '../../ui/src/log'
6
- import VxeSelectComponent from '../../select/src/select'
7
- import VxeNumberInputComponent from '../../number-input/src/number-input'
8
-
9
- import type { VxePagerPropTypes, VxePagerEmits, VxeInputDefines, VxeSelectDefines, ValueOf, VxeComponentSizeType, PagerReactData } from '../../../types'
10
- import type { VxeGridConstructor, VxeGridPrivateMethods } from '../../../types/components/grid'
11
-
12
- export default /* define-vxe-component start */ defineVxeComponent({
13
- name: 'VxePager',
14
- mixins: [
15
- globalMixins.sizeMixin
16
- ],
17
- props: {
18
- size: {
19
- type: String as PropType<VxePagerPropTypes.Size>,
20
- default: () => getConfig().pager.size || getConfig().size
21
- },
22
- // 自定义布局
23
- layouts: {
24
- type: Array as PropType<VxePagerPropTypes.Layouts>,
25
- default: () => getConfig().pager.layouts || ['PrevJump', 'PrevPage', 'Jump', 'PageCount', 'NextPage', 'NextJump', 'Sizes', 'Total']
26
- },
27
- // 当前页
28
- currentPage: {
29
- type: Number as PropType<VxePagerPropTypes.CurrentPage>,
30
- default: 1
31
- },
32
- // 加载中
33
- loading: Boolean as PropType<VxePagerPropTypes.Loading>,
34
- // 每页大小
35
- pageSize: {
36
- type: Number as PropType<VxePagerPropTypes.PageSize>,
37
- default: () => getConfig().pager.pageSize || 10
38
- },
39
- // 总条数
40
- total: { type: Number as PropType<VxePagerPropTypes.Total>, default: 0 },
41
- // 显示页码按钮的数量
42
- pagerCount: {
43
- type: Number as PropType<VxePagerPropTypes.PagerCount>,
44
- default: () => getConfig().pager.pagerCount || 7
45
- },
46
- // 每页大小选项列表
47
- pageSizes: {
48
- type: Array as PropType<VxePagerPropTypes.PageSizes>,
49
- default: () => getConfig().pager.pageSizes || [10, 15, 20, 50, 100]
50
- },
51
- // 列对齐方式
52
- align: {
53
- type: String as PropType<VxePagerPropTypes.Align>,
54
- default: () => getConfig().pager.align
55
- },
56
- // 带边框
57
- border: {
58
- type: Boolean as PropType<VxePagerPropTypes.Border>,
59
- default: () => getConfig().pager.border
60
- },
61
- // 带背景颜色
62
- background: {
63
- type: Boolean as PropType<VxePagerPropTypes.Background>,
64
- default: () => getConfig().pager.background
65
- },
66
- // 配套的样式
67
- perfect: {
68
- type: Boolean as PropType<VxePagerPropTypes.Perfect>,
69
- default: () => getConfig().pager.perfect
70
- },
71
- // 当只有一页时隐藏
72
- autoHidden: {
73
- type: Boolean as PropType<VxePagerPropTypes.AutoHidden>,
74
- default: () => getConfig().pager.autoHidden
75
- },
76
- transfer: {
77
- type: Boolean as PropType<VxePagerPropTypes.Transfer>,
78
- default: () => getConfig().pager.transfer
79
- },
80
- className: [String, Function] as PropType<VxePagerPropTypes.ClassName>,
81
- pageSizePlacement: {
82
- type: String as PropType<VxePagerPropTypes.PageSizePlacement>,
83
- default: () => getConfig().pager.pageSizePlacement
84
- },
85
- // 自定义图标
86
- iconPrevPage: String as PropType<VxePagerPropTypes.IconPrevPage>,
87
- iconJumpPrev: String as PropType<VxePagerPropTypes.IconJumpPrev>,
88
- iconJumpNext: String as PropType<VxePagerPropTypes.IconJumpNext>,
89
- iconNextPage: String as PropType<VxePagerPropTypes.IconNextPage>,
90
- iconJumpMore: String as PropType<VxePagerPropTypes.IconJumpMore>,
91
- iconHomePage: String as PropType<VxePagerPropTypes.IconHomePage>,
92
- iconEndPage: String as PropType<VxePagerPropTypes.IconEndPage>
93
- },
94
- inject: {
95
- $xeGrid: {
96
- default: null
97
- }
98
- },
99
- data () {
100
- const xID = XEUtils.uniqueId()
101
- const reactData: PagerReactData = {
102
- inpCurrPage: 1
103
- }
104
- return {
105
- xID,
106
- reactData
107
- }
108
- },
109
- computed: {
110
- ...({} as {
111
- computeSize(): VxeComponentSizeType
112
- $xeGrid(): (VxeGridConstructor & VxeGridPrivateMethods) | null
113
- }),
114
- computePageCount (this: any) {
115
- const $xePager = this
116
- const props = $xePager
117
-
118
- return $xePager.getPageCount(props.total, props.pageSize)
119
- },
120
- computeNumList () {
121
- const $xePager = this
122
- const props = $xePager
123
-
124
- const { pagerCount } = props
125
- const pageCount = $xePager.computePageCount
126
- const len = pageCount > pagerCount ? pagerCount - 2 : pagerCount
127
- const rest = []
128
- for (let index = 0; index < len; index++) {
129
- rest.push(index)
130
- }
131
- return rest
132
- },
133
- computeOffsetNumber () {
134
- const $xePager = this
135
- const props = $xePager
136
-
137
- return Math.floor((props.pagerCount - 2) / 2)
138
- },
139
- computeSizeList () {
140
- const $xePager = this
141
- const props = $xePager
142
-
143
- return props.pageSizes.map((item) => {
144
- if (XEUtils.isNumber(item)) {
145
- return {
146
- value: item,
147
- label: `${getI18n('vxe.pager.pagesize', [item])}`
148
- }
149
- }
150
- return { value: '', label: '', ...item }
151
- })
152
- }
153
- },
154
- methods: {
155
- //
156
- // Method
157
- //
158
- dispatchEvent (type: ValueOf<VxePagerEmits>, params: Record<string, any>, evnt: Event | null) {
159
- const $xePager = this
160
- $xePager.$emit(type, createEvent(evnt, { $pager: $xePager }, params))
161
- },
162
- setPageSize (num: number) {
163
- const $xePager = this
164
-
165
- $xePager.pageSizeEvent({ value: num } as VxeSelectDefines.ChangeEventParams)
166
- return $xePager.$nextTick()
167
- },
168
- setPageSizeByEvent (evnt: Event, num: number) {
169
- const $xePager = this
170
-
171
- $xePager.pageSizeEvent({ value: num, $event: evnt } as VxeSelectDefines.ChangeEventParams)
172
- },
173
- homePage () {
174
- const $xePager = this
175
-
176
- $xePager.handleHomePage()
177
- return $xePager.$nextTick()
178
- },
179
- homePageByEvent (evnt: Event) {
180
- const $xePager = this
181
-
182
- $xePager.handleHomePage(evnt)
183
- },
184
- endPage () {
185
- const $xePager = this
186
-
187
- $xePager.handleEndPage()
188
- return $xePager.$nextTick()
189
- },
190
- endPageByEvent (evnt: Event) {
191
- const $xePager = this
192
-
193
- $xePager.handleEndPage(evnt)
194
- },
195
- prevPage () {
196
- const $xePager = this
197
-
198
- $xePager.handlePrevPage()
199
- return $xePager.$nextTick()
200
- },
201
- prevPageByEvent (evnt: Event) {
202
- const $xePager = this
203
-
204
- $xePager.handlePrevPage(evnt)
205
- },
206
- nextPage () {
207
- const $xePager = this
208
-
209
- $xePager.handleNextPage()
210
- return $xePager.$nextTick()
211
- },
212
- nextPageByEvent (evnt: Event) {
213
- const $xePager = this
214
-
215
- $xePager.handleNextPage(evnt)
216
- },
217
- prevJump () {
218
- const $xePager = this
219
-
220
- $xePager.handlePrevJump()
221
- return $xePager.$nextTick()
222
- },
223
- prevJumpByEvent (evnt: Event) {
224
- const $xePager = this
225
-
226
- $xePager.handlePrevJump(evnt)
227
- },
228
- nextJump () {
229
- const $xePager = this
230
-
231
- $xePager.handleNextJump()
232
- return $xePager.$nextTick()
233
- },
234
- nextJumpByEvent (evnt: Event) {
235
- const $xePager = this
236
-
237
- $xePager.handleNextJump(evnt)
238
- },
239
- setCurrentPage (currentPage: number) {
240
- const $xePager = this
241
- const reactData = $xePager.reactData
242
-
243
- const current = XEUtils.toNumber(currentPage) || 1
244
- reactData.inpCurrPage = current
245
- $xePager.handleChangeCurrentPage(current)
246
- return $xePager.$nextTick()
247
- },
248
- setCurrentPageByEvent (evnt: Event, currentPage: number) {
249
- const $xePager = this
250
- const reactData = $xePager.reactData
251
-
252
- const current = XEUtils.toNumber(currentPage) || 1
253
- reactData.inpCurrPage = current
254
- $xePager.handleChangeCurrentPage(current, evnt)
255
- },
256
- /**
257
- * 已废弃,被 setCurrentPage 替换
258
- * @deprecated
259
- */
260
- jumpPage (currentPage: number) {
261
- const $xePager = this
262
-
263
- warnLog('vxe.error.delFunc', ['[pager] jumpPage', 'setCurrentPage'])
264
- return $xePager.setCurrentPage(currentPage)
265
- },
266
- getPageCount (total: number, size: number) {
267
- return Math.max(Math.ceil(total / size), 1)
268
- },
269
- handleJumpPageEvent (evnt: Event, currentPage: number) {
270
- const $xePager = this
271
- const props = $xePager
272
-
273
- $xePager.$emit('update:currentPage', currentPage)
274
- if (evnt && currentPage !== props.currentPage) {
275
- $xePager.dispatchEvent('page-change', { type: 'current', pageSize: props.pageSize, currentPage }, evnt)
276
- }
277
- },
278
- handleChangeCurrentPage (currentPage: number, evnt?: Event) {
279
- const $xePager = this
280
- const props = $xePager
281
-
282
- $xePager.$emit('update:currentPage', currentPage)
283
- if (evnt && currentPage !== props.currentPage) {
284
- $xePager.dispatchEvent('page-change', { type: 'current', pageSize: props.pageSize, currentPage }, evnt)
285
- }
286
- },
287
- triggerJumpEvent (params: VxeInputDefines.BlurEventParams) {
288
- const $xePager = this
289
- const reactData = $xePager.reactData
290
-
291
- const { $event } = params
292
- const inputElem: HTMLInputElement = $event.target as HTMLInputElement
293
- const inpValue = XEUtils.toInteger(inputElem.value)
294
- const pageCount = $xePager.computePageCount.value
295
- const current = inpValue <= 0 ? 1 : inpValue >= pageCount ? pageCount : inpValue
296
- const currPage = XEUtils.toValueString(current)
297
- inputElem.value = currPage
298
- reactData.inpCurrPage = currPage
299
- $xePager.handleChangeCurrentPage(current, $event)
300
- },
301
- handleHomePage (evnt?: Event) {
302
- const $xePager = this
303
- const props = $xePager
304
-
305
- const { currentPage } = props
306
- if (currentPage > 1) {
307
- $xePager.handleChangeCurrentPage(1, evnt)
308
- }
309
- },
310
- handleEndPage (evnt?: Event) {
311
- const $xePager = this
312
- const props = $xePager
313
-
314
- const { currentPage } = props
315
- const pageCount = $xePager.computePageCount
316
- if (currentPage < pageCount) {
317
- $xePager.handleChangeCurrentPage(pageCount, evnt)
318
- }
319
- },
320
- handlePrevPage (evnt?: Event) {
321
- const $xePager = this
322
- const props = $xePager
323
-
324
- const { currentPage } = props
325
- const pageCount = $xePager.computePageCount
326
- if (currentPage > 1) {
327
- $xePager.handleChangeCurrentPage(Math.min(pageCount, Math.max(currentPage - 1, 1)), evnt)
328
- }
329
- },
330
- handleNextPage (evnt?: Event) {
331
- const $xePager = this
332
- const props = $xePager
333
-
334
- const { currentPage } = props
335
- const pageCount = $xePager.computePageCount
336
- if (currentPage < pageCount) {
337
- $xePager.handleChangeCurrentPage(Math.min(pageCount, currentPage + 1), evnt)
338
- }
339
- },
340
- handlePrevJump (evnt?: Event) {
341
- const $xePager = this
342
- const props = $xePager
343
-
344
- const numList = $xePager.computeNumList
345
- $xePager.handleChangeCurrentPage(Math.max(props.currentPage - numList.length, 1), evnt)
346
- },
347
- handleNextJump (evnt?: Event) {
348
- const $xePager = this
349
- const props = $xePager
350
-
351
- const pageCount = $xePager.computePageCount
352
- const numList = $xePager.computeNumList
353
- $xePager.handleChangeCurrentPage(Math.min(props.currentPage + numList.length, pageCount), evnt)
354
- },
355
- pageSizeEvent (params: VxeSelectDefines.ChangeEventParams) {
356
- const $xePager = this
357
- const props = $xePager
358
-
359
- const { value, $event } = params
360
- const pageSize = XEUtils.toNumber(value)
361
- const pageCount = $xePager.getPageCount(props.total, pageSize)
362
- let currentPage = props.currentPage
363
- if (currentPage > pageCount) {
364
- currentPage = pageCount
365
- $xePager.$emit('update:currentPage', pageCount)
366
- }
367
- $xePager.$emit('update:pageSize', pageSize)
368
- if ($event) {
369
- $xePager.dispatchEvent('page-change', { type: 'size', pageSize, currentPage }, $event)
370
- }
371
- },
372
- jumpKeydownEvent (params: VxeInputDefines.KeydownEventParams) {
373
- const $xePager = this
374
-
375
- const { $event } = params
376
- if (globalEvents.hasKey($event, GLOBAL_EVENT_KEYS.ENTER)) {
377
- $xePager.triggerJumpEvent(params)
378
- } else if (globalEvents.hasKey($event, GLOBAL_EVENT_KEYS.ARROW_UP)) {
379
- $event.preventDefault()
380
- $xePager.handleNextPage($event)
381
- } else if (globalEvents.hasKey($event, GLOBAL_EVENT_KEYS.ARROW_DOWN)) {
382
- $event.preventDefault()
383
- $xePager.handlePrevPage($event)
384
- }
385
- },
386
-
387
- //
388
- // Render
389
- //
390
- // 第一页
391
- renderHomePage (h: CreateElement) {
392
- const $xePager = this
393
- const props = $xePager
394
- const slots = $xePager.$scopedSlots
395
-
396
- const { currentPage, total } = props
397
- const homeSlot = slots.home
398
- const pageCount = $xePager.computePageCount
399
- if (homeSlot) {
400
- return h('span', {
401
- class: 'vxe-pager--custom-home-btn'
402
- }, homeSlot({ $pager: $xePager, total, currentPage, pageCount }))
403
- }
404
- return h('button', {
405
- class: ['vxe-pager--home-btn', {
406
- 'is--disabled': currentPage <= 1
407
- }],
408
- attrs: {
409
- type: 'button',
410
- title: getI18n('vxe.pager.homePageTitle')
411
- },
412
- on: {
413
- click: $xePager.handleHomePage
414
- }
415
- }, [
416
- h('i', {
417
- class: ['vxe-pager--btn-icon', props.iconHomePage || getIcon().PAGER_HOME]
418
- })
419
- ])
420
- },
421
- // 上一页
422
- renderPrevPage (h: CreateElement) {
423
- const $xePager = this
424
- const props = $xePager
425
- const slots = $xePager.$scopedSlots
426
-
427
- const { currentPage, total } = props
428
- const prevPageSlot = slots.prevPage || slots['prev-page']
429
- const pageCount = $xePager.computePageCount
430
- if (prevPageSlot) {
431
- return h('span', {
432
- class: 'vxe-pager--custom-prev-btn'
433
- }, prevPageSlot({ $pager: $xePager, total, currentPage, pageCount }))
434
- }
435
- return h('button', {
436
- class: ['vxe-pager--prev-btn', {
437
- 'is--disabled': currentPage <= 1
438
- }],
439
- attrs: {
440
- type: 'button',
441
- title: getI18n('vxe.pager.prevPageTitle')
442
- },
443
- on: {
444
- click: $xePager.handlePrevPage
445
- }
446
- }, [
447
- h('i', {
448
- class: ['vxe-pager--btn-icon', props.iconPrevPage || getIcon().PAGER_PREV_PAGE]
449
- })
450
- ])
451
- },
452
- // 向上翻页
453
- renderPrevJump (h: CreateElement, tagName?: string) {
454
- const $xePager = this
455
- const props = $xePager
456
- const slots = $xePager.$scopedSlots
457
-
458
- const { currentPage, total } = props
459
- const prevJumpSlot = slots.prevJump || slots['prev-jump']
460
- const pageCount = $xePager.computePageCount
461
- if (prevJumpSlot) {
462
- return h('span', {
463
- class: 'vxe-pager--custom-jump-prev'
464
- }, prevJumpSlot({ $pager: $xePager, total, currentPage, pageCount }))
465
- }
466
- return h(tagName || 'button', {
467
- class: ['vxe-pager--jump-prev', {
468
- 'is--fixed': !tagName,
469
- 'is--disabled': currentPage <= 1
470
- }],
471
- attrs: {
472
- type: 'button',
473
- title: getI18n('vxe.pager.prevJumpTitle')
474
- },
475
- on: {
476
- click: $xePager.handlePrevJump
477
- }
478
- }, [
479
- tagName
480
- ? h('i', {
481
- class: ['vxe-pager--jump-more-icon', props.iconJumpMore || getIcon().PAGER_JUMP_MORE]
482
- })
483
- : null,
484
- h('i', {
485
- class: ['vxe-pager--jump-icon', props.iconJumpPrev || getIcon().PAGER_JUMP_PREV]
486
- })
487
- ])
488
- },
489
- // 向下翻页
490
- renderNextJump (h: CreateElement, tagName?: string) {
491
- const $xePager = this
492
- const props = $xePager
493
- const slots = $xePager.$scopedSlots
494
-
495
- const { currentPage, total } = props
496
- const nextJumpSlot = slots.nextJump || slots['next-jump']
497
- const pageCount = $xePager.computePageCount
498
- if (nextJumpSlot) {
499
- return h('span', {
500
- class: 'vxe-pager--custom-jump-next'
501
- }, nextJumpSlot({ $pager: $xePager, total, currentPage, pageCount }))
502
- }
503
- return h(tagName || 'button', {
504
- class: ['vxe-pager--jump-next', {
505
- 'is--fixed': !tagName,
506
- 'is--disabled': currentPage >= pageCount
507
- }],
508
- attrs: {
509
- type: 'button',
510
- title: getI18n('vxe.pager.nextJumpTitle')
511
- },
512
- on: {
513
- click: $xePager.handleNextJump
514
- }
515
- }, [
516
- tagName
517
- ? h('i', {
518
- class: ['vxe-pager--jump-more-icon', props.iconJumpMore || getIcon().PAGER_JUMP_MORE]
519
- })
520
- : null,
521
- h('i', {
522
- class: ['vxe-pager--jump-icon', props.iconJumpNext || getIcon().PAGER_JUMP_NEXT]
523
- })
524
- ])
525
- },
526
- // 下一页
527
- renderNextPage (h: CreateElement) {
528
- const $xePager = this
529
- const props = $xePager
530
- const slots = $xePager.$scopedSlots
531
-
532
- const { currentPage, total } = props
533
- const nextPageSlot = slots.nextPage || slots['next-page']
534
- const pageCount = $xePager.computePageCount
535
- if (nextPageSlot) {
536
- return h('span', {
537
- class: 'vxe-pager--custom-next-btn'
538
- }, nextPageSlot({ $pager: $xePager, total, currentPage, pageCount }))
539
- }
540
- return h('button', {
541
- class: ['vxe-pager--next-btn', {
542
- 'is--disabled': currentPage >= pageCount
543
- }],
544
- attrs: {
545
- type: 'button',
546
- title: getI18n('vxe.pager.nextPageTitle')
547
- },
548
- on: {
549
- click: $xePager.handleNextPage
550
- }
551
- }, [
552
- h('i', {
553
- class: ['vxe-pager--btn-icon', props.iconNextPage || getIcon().PAGER_NEXT_PAGE]
554
- })
555
- ])
556
- },
557
- // 最后一页
558
- renderEndPage (h: CreateElement) {
559
- const $xePager = this
560
- const props = $xePager
561
- const slots = $xePager.$scopedSlots
562
-
563
- const { currentPage, total } = props
564
- const endSlot = slots.end
565
- const pageCount = $xePager.computePageCount
566
- if (endSlot) {
567
- return h('span', {
568
- class: 'vxe-pager--custom-end-btn'
569
- }, endSlot({ $pager: $xePager, total, currentPage, pageCount }))
570
- }
571
- return h('button', {
572
- class: ['vxe-pager--end-btn', {
573
- 'is--disabled': currentPage >= pageCount
574
- }],
575
- attrs: {
576
- type: 'button',
577
- title: getI18n('vxe.pager.endPageTitle')
578
- },
579
- on: {
580
- click: $xePager.handleEndPage
581
- }
582
- }, [
583
- h('i', {
584
- class: ['vxe-pager--btn-icon', props.iconEndPage || getIcon().PAGER_END]
585
- })
586
- ])
587
- },
588
- // 页数
589
- renderNumber (h: CreateElement, showJump?: boolean) {
590
- const $xePager = this
591
- const props = $xePager
592
- const slots = $xePager.$scopedSlots
593
-
594
- const { currentPage, total, pagerCount } = props
595
- const numberSlot = showJump ? (slots.numberJump || slots['number-jump']) : slots.number
596
- const nums = []
597
- const pageCount = $xePager.computePageCount
598
- const numList = $xePager.computeNumList
599
- const offsetNumber = $xePager.computeOffsetNumber
600
- const isOv = pageCount > pagerCount
601
- const isLt = isOv && currentPage > offsetNumber + 1
602
- const isGt = isOv && currentPage < pageCount - offsetNumber
603
- const restList: number[] = []
604
- let startNumber = 1
605
-
606
- if (isOv) {
607
- if (currentPage >= pageCount - offsetNumber) {
608
- startNumber = Math.max(pageCount - numList.length + 1, 1)
609
- } else {
610
- startNumber = Math.max(currentPage - offsetNumber, 1)
611
- }
612
- }
613
-
614
- if (showJump && isLt) {
615
- restList.push(1)
616
- nums.push(
617
- h('button', {
618
- class: 'vxe-pager--num-btn',
619
- attrs: {
620
- type: 'button'
621
- },
622
- on: {
623
- click: (evnt: Event) => $xePager.handleJumpPageEvent(evnt, 1)
624
- }
625
- }, '1'),
626
- $xePager.renderPrevJump(h, 'span')
627
- )
628
- }
629
- numList.forEach((item, index) => {
630
- const number = startNumber + index
631
- if (number <= pageCount) {
632
- restList.push(number)
633
- nums.push(
634
- h('button', {
635
- key: number,
636
- class: ['vxe-pager--num-btn', {
637
- 'is--active': currentPage === number
638
- }],
639
- attrs: {
640
- type: 'button'
641
- },
642
- on: {
643
- click: (evnt: Event) => $xePager.handleJumpPageEvent(evnt, number)
644
- }
645
- }, `${number}`)
646
- )
647
- }
648
- })
649
- if (showJump && isGt) {
650
- restList.push(pageCount)
651
- nums.push(
652
- $xePager.renderNextJump(h, 'button'),
653
- h('button', {
654
- class: 'vxe-pager--num-btn',
655
- attrs: {
656
- type: 'button'
657
- },
658
- on: {
659
- click: (evnt: Event) => $xePager.handleJumpPageEvent(evnt, pageCount)
660
- }
661
- }, pageCount)
662
- )
663
- }
664
- if (numberSlot) {
665
- return h('span', {
666
- class: 'vxe-pager--custom-btn-wrapper'
667
- }, numberSlot({ $pager: $xePager, total, numList: restList, currentPage, pageCount }))
668
- }
669
- return h('span', {
670
- class: 'vxe-pager--btn-wrapper'
671
- }, nums)
672
- },
673
- // jumpNumber
674
- renderJumpNumber (h: CreateElement) {
675
- const $xePager = this
676
-
677
- return $xePager.renderNumber(h, true)
678
- },
679
- // sizes
680
- renderSizes (h: CreateElement) {
681
- const $xePager = this
682
- const props = $xePager
683
- const slots = $xePager.$scopedSlots
684
-
685
- const { currentPage, total, pageSize, pageSizePlacement, transfer } = props
686
- const sizesSlot = slots.sizes
687
- const sizeList = $xePager.computeSizeList
688
- const pageCount = $xePager.computePageCount
689
- if (sizesSlot) {
690
- return h('span', {
691
- class: 'vxe-pager--custom-sizes'
692
- }, sizesSlot({ $pager: $xePager, total, currentPage, pageCount, pageSize, options: sizeList }))
693
- }
694
- return h(VxeSelectComponent, {
695
- class: 'vxe-pager--sizes',
696
- props: {
697
- value: pageSize,
698
- placement: pageSizePlacement,
699
- transfer: transfer,
700
- options: sizeList
701
- },
702
- on: {
703
- change: $xePager.pageSizeEvent
704
- }
705
- })
706
- },
707
- // Jump
708
- renderJump (h: CreateElement, isFull?: boolean) {
709
- const $xePager = this
710
- const props = $xePager
711
- const reactData = $xePager.reactData
712
- const slots = $xePager.$scopedSlots
713
-
714
- const { total } = props
715
- const { inpCurrPage } = reactData
716
- const jumpSlot = isFull ? (slots.fullJump || slots['full-jump']) : slots.jump
717
- const pageCount = $xePager.computePageCount
718
- if (jumpSlot) {
719
- return h('span', {
720
- class: 'vxe-pager--custom-jump'
721
- }, jumpSlot({ $pager: $xePager, total, currentPage: inpCurrPage, pageCount }))
722
- }
723
- return h('span', {
724
- class: 'vxe-pager--jump'
725
- }, [
726
- isFull
727
- ? h('span', {
728
- class: 'vxe-pager--goto-text'
729
- }, getI18n('vxe.pager.goto'))
730
- : null,
731
- h(VxeNumberInputComponent, {
732
- class: 'vxe-pager--goto',
733
- props: {
734
- value: inpCurrPage,
735
- placeholder: getI18n('vxe.pager.gotoTitle'),
736
- align: 'center',
737
- type: 'integer',
738
- max: pageCount,
739
- min: 1,
740
- controls: false
741
- },
742
- on: {
743
- keydown: $xePager.jumpKeydownEvent,
744
- blur: $xePager.triggerJumpEvent,
745
- 'modelValue' (val: string) {
746
- reactData.inpCurrPage = val
747
- }
748
- }
749
- }),
750
- isFull
751
- ? h('span', {
752
- class: 'vxe-pager--classifier-text'
753
- }, getI18n('vxe.pager.pageClassifier'))
754
- : null
755
- ])
756
- },
757
- // FullJump
758
- renderFullJump (h: CreateElement) {
759
- const $xePager = this
760
-
761
- return $xePager.renderJump(h, true)
762
- },
763
- // PageCount
764
- renderPageCount (h: CreateElement) {
765
- const $xePager = this
766
- const props = $xePager
767
- const slots = $xePager.$scopedSlots
768
-
769
- const { currentPage, total } = props
770
- const pageCountSlot = slots.pageCount || slots['page-count']
771
- const pageCount = $xePager.computePageCount
772
- if (pageCountSlot) {
773
- return h('span', {
774
- class: 'vxe-pager--custom-count'
775
- }, pageCountSlot({ $pager: $xePager, total, currentPage, pageCount }))
776
- }
777
- return h('span', {
778
- class: 'vxe-pager--count'
779
- }, [
780
- h('span', {
781
- class: 'vxe-pager--separator'
782
- }),
783
- h('span', pageCount)
784
- ])
785
- },
786
- // total
787
- renderTotal (h: CreateElement) {
788
- const $xePager = this
789
- const props = $xePager
790
- const slots = $xePager.$scopedSlots
791
-
792
- const { total, currentPage } = props
793
- const totalSlot = slots.total
794
- const pageCount = $xePager.computePageCount
795
- if (totalSlot) {
796
- return h('span', {
797
- class: 'vxe-pager--custom-total'
798
- }, totalSlot({ $pager: $xePager, total, currentPage, pageCount }))
799
- }
800
- return h('span', {
801
- class: 'vxe-pager--total'
802
- }, getI18n('vxe.pager.total', [total]))
803
- },
804
- renderVN (h: CreateElement): VNode {
805
- const $xePager = this
806
- const props = $xePager
807
- const slots = $xePager.$scopedSlots
808
- const $xeGrid = $xePager.$xeGrid
809
-
810
- const { align, layouts, className } = props
811
- const childNodes = []
812
- const vSize = $xePager.computeSize
813
- const pageCount = $xePager.computePageCount
814
- if (slots.left) {
815
- childNodes.push(
816
- h('span', {
817
- class: 'vxe-pager--left-wrapper'
818
- }, slots.left({ $grid: $xeGrid }))
819
- )
820
- }
821
- layouts.forEach((name) => {
822
- let renderFn: (h: CreateElement) => VNode
823
- switch (name) {
824
- case 'Home':
825
- renderFn = $xePager.renderHomePage
826
- break
827
- case 'PrevJump':
828
- renderFn = $xePager.renderPrevJump
829
- break
830
- case 'PrevPage':
831
- renderFn = $xePager.renderPrevPage
832
- break
833
- case 'Number':
834
- renderFn = $xePager.renderNumber
835
- break
836
- case 'JumpNumber':
837
- renderFn = $xePager.renderJumpNumber
838
- break
839
- case 'NextPage':
840
- renderFn = $xePager.renderNextPage
841
- break
842
- case 'NextJump':
843
- renderFn = $xePager.renderNextJump
844
- break
845
- case 'End':
846
- renderFn = $xePager.renderEndPage
847
- break
848
- case 'Sizes':
849
- renderFn = $xePager.renderSizes
850
- break
851
- case 'FullJump':
852
- renderFn = $xePager.renderFullJump
853
- break
854
- case 'Jump':
855
- renderFn = $xePager.renderJump
856
- break
857
- case 'PageCount':
858
- renderFn = $xePager.renderPageCount
859
- break
860
- case 'Total':
861
- renderFn = $xePager.renderTotal
862
- break
863
- }
864
- if (renderFn) {
865
- childNodes.push(renderFn(h))
866
- } else {
867
- errLog('vxe.error.notProp', [`[pager] layouts -> ${name}`])
868
- }
869
- })
870
- if (slots.right) {
871
- childNodes.push(
872
- h('span', {
873
- class: 'vxe-pager--right-wrapper'
874
- }, slots.right({ $grid: $xeGrid }))
875
- )
876
- }
877
- return h('div', {
878
- ref: 'refElem',
879
- class: ['vxe-pager', className ? (XEUtils.isFunction(className) ? className({ $pager: $xePager }) : className) : '', {
880
- [`size--${vSize}`]: vSize,
881
- [`align--${align}`]: align,
882
- 'is--border': props.border,
883
- 'is--background': props.background,
884
- 'is--perfect': props.perfect,
885
- 'is--hidden': props.autoHidden && pageCount === 1,
886
- 'is--loading': props.loading
887
- }]
888
- }, [
889
- h('div', {
890
- class: 'vxe-pager--wrapper'
891
- }, childNodes)
892
- ])
893
- }
894
- },
895
- watch: {
896
- currentPage (val) {
897
- const $xePager = this
898
- const reactData = $xePager.reactData
899
-
900
- reactData.inpCurrPage = val
901
- }
902
- },
903
- created () {
904
- const $xePager = this
905
- const props = $xePager
906
- const reactData = $xePager.reactData
907
-
908
- reactData.inpCurrPage = props.currentPage
909
- },
910
- render (this: any, h) {
911
- return this.renderVN(h)
912
- }
913
- }) /* define-vxe-component end */
1
+ import { CreateElement, PropType, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { getIcon, getConfig, getI18n, globalEvents, GLOBAL_EVENT_KEYS, createEvent, globalMixins } from '../../ui'
5
+ import { warnLog, errLog } from '../../ui/src/log'
6
+ import VxeSelectComponent from '../../select/src/select'
7
+ import VxeNumberInputComponent from '../../number-input/src/number-input'
8
+
9
+ import type { VxePagerPropTypes, VxePagerEmits, VxeInputDefines, VxeSelectDefines, ValueOf, VxeComponentSizeType, PagerReactData } from '../../../types'
10
+ import type { VxeGridConstructor, VxeGridPrivateMethods } from '../../../types/components/grid'
11
+
12
+ export default /* define-vxe-component start */ defineVxeComponent({
13
+ name: 'VxePager',
14
+ mixins: [
15
+ globalMixins.sizeMixin
16
+ ],
17
+ props: {
18
+ size: {
19
+ type: String as PropType<VxePagerPropTypes.Size>,
20
+ default: () => getConfig().pager.size || getConfig().size
21
+ },
22
+ // 自定义布局
23
+ layouts: {
24
+ type: Array as PropType<VxePagerPropTypes.Layouts>,
25
+ default: () => getConfig().pager.layouts || ['PrevJump', 'PrevPage', 'Jump', 'PageCount', 'NextPage', 'NextJump', 'Sizes', 'Total']
26
+ },
27
+ // 当前页
28
+ currentPage: {
29
+ type: Number as PropType<VxePagerPropTypes.CurrentPage>,
30
+ default: 1
31
+ },
32
+ // 加载中
33
+ loading: Boolean as PropType<VxePagerPropTypes.Loading>,
34
+ // 每页大小
35
+ pageSize: {
36
+ type: Number as PropType<VxePagerPropTypes.PageSize>,
37
+ default: () => getConfig().pager.pageSize || 10
38
+ },
39
+ // 总条数
40
+ total: { type: Number as PropType<VxePagerPropTypes.Total>, default: 0 },
41
+ // 显示页码按钮的数量
42
+ pagerCount: {
43
+ type: Number as PropType<VxePagerPropTypes.PagerCount>,
44
+ default: () => getConfig().pager.pagerCount || 7
45
+ },
46
+ // 每页大小选项列表
47
+ pageSizes: {
48
+ type: Array as PropType<VxePagerPropTypes.PageSizes>,
49
+ default: () => getConfig().pager.pageSizes || [10, 15, 20, 50, 100]
50
+ },
51
+ // 列对齐方式
52
+ align: {
53
+ type: String as PropType<VxePagerPropTypes.Align>,
54
+ default: () => getConfig().pager.align
55
+ },
56
+ // 带边框
57
+ border: {
58
+ type: Boolean as PropType<VxePagerPropTypes.Border>,
59
+ default: () => getConfig().pager.border
60
+ },
61
+ // 带背景颜色
62
+ background: {
63
+ type: Boolean as PropType<VxePagerPropTypes.Background>,
64
+ default: () => getConfig().pager.background
65
+ },
66
+ // 配套的样式
67
+ perfect: {
68
+ type: Boolean as PropType<VxePagerPropTypes.Perfect>,
69
+ default: () => getConfig().pager.perfect
70
+ },
71
+ // 当只有一页时隐藏
72
+ autoHidden: {
73
+ type: Boolean as PropType<VxePagerPropTypes.AutoHidden>,
74
+ default: () => getConfig().pager.autoHidden
75
+ },
76
+ transfer: {
77
+ type: Boolean as PropType<VxePagerPropTypes.Transfer>,
78
+ default: () => getConfig().pager.transfer
79
+ },
80
+ className: [String, Function] as PropType<VxePagerPropTypes.ClassName>,
81
+ pageSizePlacement: {
82
+ type: String as PropType<VxePagerPropTypes.PageSizePlacement>,
83
+ default: () => getConfig().pager.pageSizePlacement
84
+ },
85
+ // 自定义图标
86
+ iconPrevPage: String as PropType<VxePagerPropTypes.IconPrevPage>,
87
+ iconJumpPrev: String as PropType<VxePagerPropTypes.IconJumpPrev>,
88
+ iconJumpNext: String as PropType<VxePagerPropTypes.IconJumpNext>,
89
+ iconNextPage: String as PropType<VxePagerPropTypes.IconNextPage>,
90
+ iconJumpMore: String as PropType<VxePagerPropTypes.IconJumpMore>,
91
+ iconHomePage: String as PropType<VxePagerPropTypes.IconHomePage>,
92
+ iconEndPage: String as PropType<VxePagerPropTypes.IconEndPage>
93
+ },
94
+ inject: {
95
+ $xeGrid: {
96
+ default: null
97
+ }
98
+ },
99
+ data () {
100
+ const xID = XEUtils.uniqueId()
101
+ const reactData: PagerReactData = {
102
+ inpCurrPage: 1
103
+ }
104
+ return {
105
+ xID,
106
+ reactData
107
+ }
108
+ },
109
+ computed: {
110
+ ...({} as {
111
+ computeSize(): VxeComponentSizeType
112
+ $xeGrid(): (VxeGridConstructor & VxeGridPrivateMethods) | null
113
+ }),
114
+ computePageCount (this: any) {
115
+ const $xePager = this
116
+ const props = $xePager
117
+
118
+ return $xePager.getPageCount(props.total, props.pageSize)
119
+ },
120
+ computeNumList () {
121
+ const $xePager = this
122
+ const props = $xePager
123
+
124
+ const { pagerCount } = props
125
+ const pageCount = $xePager.computePageCount
126
+ const len = pageCount > pagerCount ? pagerCount - 2 : pagerCount
127
+ const rest = []
128
+ for (let index = 0; index < len; index++) {
129
+ rest.push(index)
130
+ }
131
+ return rest
132
+ },
133
+ computeOffsetNumber () {
134
+ const $xePager = this
135
+ const props = $xePager
136
+
137
+ return Math.floor((props.pagerCount - 2) / 2)
138
+ },
139
+ computeSizeList () {
140
+ const $xePager = this
141
+ const props = $xePager
142
+
143
+ return props.pageSizes.map((item) => {
144
+ if (XEUtils.isNumber(item)) {
145
+ return {
146
+ value: item,
147
+ label: `${getI18n('vxe.pager.pagesize', [item])}`
148
+ }
149
+ }
150
+ return { value: '', label: '', ...item }
151
+ })
152
+ }
153
+ },
154
+ methods: {
155
+ //
156
+ // Method
157
+ //
158
+ dispatchEvent (type: ValueOf<VxePagerEmits>, params: Record<string, any>, evnt: Event | null) {
159
+ const $xePager = this
160
+ $xePager.$emit(type, createEvent(evnt, { $pager: $xePager }, params))
161
+ },
162
+ setPageSize (num: number) {
163
+ const $xePager = this
164
+
165
+ $xePager.pageSizeEvent({ value: num } as VxeSelectDefines.ChangeEventParams)
166
+ return $xePager.$nextTick()
167
+ },
168
+ setPageSizeByEvent (evnt: Event, num: number) {
169
+ const $xePager = this
170
+
171
+ $xePager.pageSizeEvent({ value: num, $event: evnt } as VxeSelectDefines.ChangeEventParams)
172
+ },
173
+ homePage () {
174
+ const $xePager = this
175
+
176
+ $xePager.handleHomePage()
177
+ return $xePager.$nextTick()
178
+ },
179
+ homePageByEvent (evnt: Event) {
180
+ const $xePager = this
181
+
182
+ $xePager.handleHomePage(evnt)
183
+ },
184
+ endPage () {
185
+ const $xePager = this
186
+
187
+ $xePager.handleEndPage()
188
+ return $xePager.$nextTick()
189
+ },
190
+ endPageByEvent (evnt: Event) {
191
+ const $xePager = this
192
+
193
+ $xePager.handleEndPage(evnt)
194
+ },
195
+ prevPage () {
196
+ const $xePager = this
197
+
198
+ $xePager.handlePrevPage()
199
+ return $xePager.$nextTick()
200
+ },
201
+ prevPageByEvent (evnt: Event) {
202
+ const $xePager = this
203
+
204
+ $xePager.handlePrevPage(evnt)
205
+ },
206
+ nextPage () {
207
+ const $xePager = this
208
+
209
+ $xePager.handleNextPage()
210
+ return $xePager.$nextTick()
211
+ },
212
+ nextPageByEvent (evnt: Event) {
213
+ const $xePager = this
214
+
215
+ $xePager.handleNextPage(evnt)
216
+ },
217
+ prevJump () {
218
+ const $xePager = this
219
+
220
+ $xePager.handlePrevJump()
221
+ return $xePager.$nextTick()
222
+ },
223
+ prevJumpByEvent (evnt: Event) {
224
+ const $xePager = this
225
+
226
+ $xePager.handlePrevJump(evnt)
227
+ },
228
+ nextJump () {
229
+ const $xePager = this
230
+
231
+ $xePager.handleNextJump()
232
+ return $xePager.$nextTick()
233
+ },
234
+ nextJumpByEvent (evnt: Event) {
235
+ const $xePager = this
236
+
237
+ $xePager.handleNextJump(evnt)
238
+ },
239
+ setCurrentPage (currentPage: number) {
240
+ const $xePager = this
241
+ const reactData = $xePager.reactData
242
+
243
+ const current = XEUtils.toNumber(currentPage) || 1
244
+ reactData.inpCurrPage = current
245
+ $xePager.handleChangeCurrentPage(current)
246
+ return $xePager.$nextTick()
247
+ },
248
+ setCurrentPageByEvent (evnt: Event, currentPage: number) {
249
+ const $xePager = this
250
+ const reactData = $xePager.reactData
251
+
252
+ const current = XEUtils.toNumber(currentPage) || 1
253
+ reactData.inpCurrPage = current
254
+ $xePager.handleChangeCurrentPage(current, evnt)
255
+ },
256
+ /**
257
+ * 已废弃,被 setCurrentPage 替换
258
+ * @deprecated
259
+ */
260
+ jumpPage (currentPage: number) {
261
+ const $xePager = this
262
+
263
+ warnLog('vxe.error.delFunc', ['[pager] jumpPage', 'setCurrentPage'])
264
+ return $xePager.setCurrentPage(currentPage)
265
+ },
266
+ getPageCount (total: number, size: number) {
267
+ return Math.max(Math.ceil(total / size), 1)
268
+ },
269
+ handleJumpPageEvent (evnt: Event, currentPage: number) {
270
+ const $xePager = this
271
+ const props = $xePager
272
+
273
+ $xePager.$emit('update:currentPage', currentPage)
274
+ if (evnt && currentPage !== props.currentPage) {
275
+ $xePager.dispatchEvent('page-change', { type: 'current', pageSize: props.pageSize, currentPage }, evnt)
276
+ }
277
+ },
278
+ handleChangeCurrentPage (currentPage: number, evnt?: Event) {
279
+ const $xePager = this
280
+ const props = $xePager
281
+
282
+ $xePager.$emit('update:currentPage', currentPage)
283
+ if (evnt && currentPage !== props.currentPage) {
284
+ $xePager.dispatchEvent('page-change', { type: 'current', pageSize: props.pageSize, currentPage }, evnt)
285
+ }
286
+ },
287
+ triggerJumpEvent (params: VxeInputDefines.BlurEventParams) {
288
+ const $xePager = this
289
+ const reactData = $xePager.reactData
290
+
291
+ const { $event } = params
292
+ const inputElem: HTMLInputElement = $event.target as HTMLInputElement
293
+ const inpValue = XEUtils.toInteger(inputElem.value)
294
+ const pageCount = $xePager.computePageCount.value
295
+ const current = inpValue <= 0 ? 1 : inpValue >= pageCount ? pageCount : inpValue
296
+ const currPage = XEUtils.toValueString(current)
297
+ inputElem.value = currPage
298
+ reactData.inpCurrPage = currPage
299
+ $xePager.handleChangeCurrentPage(current, $event)
300
+ },
301
+ handleHomePage (evnt?: Event) {
302
+ const $xePager = this
303
+ const props = $xePager
304
+
305
+ const { currentPage } = props
306
+ if (currentPage > 1) {
307
+ $xePager.handleChangeCurrentPage(1, evnt)
308
+ }
309
+ },
310
+ handleEndPage (evnt?: Event) {
311
+ const $xePager = this
312
+ const props = $xePager
313
+
314
+ const { currentPage } = props
315
+ const pageCount = $xePager.computePageCount
316
+ if (currentPage < pageCount) {
317
+ $xePager.handleChangeCurrentPage(pageCount, evnt)
318
+ }
319
+ },
320
+ handlePrevPage (evnt?: Event) {
321
+ const $xePager = this
322
+ const props = $xePager
323
+
324
+ const { currentPage } = props
325
+ const pageCount = $xePager.computePageCount
326
+ if (currentPage > 1) {
327
+ $xePager.handleChangeCurrentPage(Math.min(pageCount, Math.max(currentPage - 1, 1)), evnt)
328
+ }
329
+ },
330
+ handleNextPage (evnt?: Event) {
331
+ const $xePager = this
332
+ const props = $xePager
333
+
334
+ const { currentPage } = props
335
+ const pageCount = $xePager.computePageCount
336
+ if (currentPage < pageCount) {
337
+ $xePager.handleChangeCurrentPage(Math.min(pageCount, currentPage + 1), evnt)
338
+ }
339
+ },
340
+ handlePrevJump (evnt?: Event) {
341
+ const $xePager = this
342
+ const props = $xePager
343
+
344
+ const numList = $xePager.computeNumList
345
+ $xePager.handleChangeCurrentPage(Math.max(props.currentPage - numList.length, 1), evnt)
346
+ },
347
+ handleNextJump (evnt?: Event) {
348
+ const $xePager = this
349
+ const props = $xePager
350
+
351
+ const pageCount = $xePager.computePageCount
352
+ const numList = $xePager.computeNumList
353
+ $xePager.handleChangeCurrentPage(Math.min(props.currentPage + numList.length, pageCount), evnt)
354
+ },
355
+ pageSizeEvent (params: VxeSelectDefines.ChangeEventParams) {
356
+ const $xePager = this
357
+ const props = $xePager
358
+
359
+ const { value, $event } = params
360
+ const pageSize = XEUtils.toNumber(value)
361
+ const pageCount = $xePager.getPageCount(props.total, pageSize)
362
+ let currentPage = props.currentPage
363
+ if (currentPage > pageCount) {
364
+ currentPage = pageCount
365
+ $xePager.$emit('update:currentPage', pageCount)
366
+ }
367
+ $xePager.$emit('update:pageSize', pageSize)
368
+ if ($event) {
369
+ $xePager.dispatchEvent('page-change', { type: 'size', pageSize, currentPage }, $event)
370
+ }
371
+ },
372
+ jumpKeydownEvent (params: VxeInputDefines.KeydownEventParams) {
373
+ const $xePager = this
374
+
375
+ const { $event } = params
376
+ if (globalEvents.hasKey($event, GLOBAL_EVENT_KEYS.ENTER)) {
377
+ $xePager.triggerJumpEvent(params)
378
+ } else if (globalEvents.hasKey($event, GLOBAL_EVENT_KEYS.ARROW_UP)) {
379
+ $event.preventDefault()
380
+ $xePager.handleNextPage($event)
381
+ } else if (globalEvents.hasKey($event, GLOBAL_EVENT_KEYS.ARROW_DOWN)) {
382
+ $event.preventDefault()
383
+ $xePager.handlePrevPage($event)
384
+ }
385
+ },
386
+
387
+ //
388
+ // Render
389
+ //
390
+ // 第一页
391
+ renderHomePage (h: CreateElement) {
392
+ const $xePager = this
393
+ const props = $xePager
394
+ const slots = $xePager.$scopedSlots
395
+
396
+ const { currentPage, total } = props
397
+ const homeSlot = slots.home
398
+ const pageCount = $xePager.computePageCount
399
+ if (homeSlot) {
400
+ return h('span', {
401
+ class: 'vxe-pager--custom-home-btn'
402
+ }, homeSlot({ $pager: $xePager, total, currentPage, pageCount }))
403
+ }
404
+ return h('button', {
405
+ class: ['vxe-pager--home-btn', {
406
+ 'is--disabled': currentPage <= 1
407
+ }],
408
+ attrs: {
409
+ type: 'button',
410
+ title: getI18n('vxe.pager.homePageTitle')
411
+ },
412
+ on: {
413
+ click: $xePager.handleHomePage
414
+ }
415
+ }, [
416
+ h('i', {
417
+ class: ['vxe-pager--btn-icon', props.iconHomePage || getIcon().PAGER_HOME]
418
+ })
419
+ ])
420
+ },
421
+ // 上一页
422
+ renderPrevPage (h: CreateElement) {
423
+ const $xePager = this
424
+ const props = $xePager
425
+ const slots = $xePager.$scopedSlots
426
+
427
+ const { currentPage, total } = props
428
+ const prevPageSlot = slots.prevPage || slots['prev-page']
429
+ const pageCount = $xePager.computePageCount
430
+ if (prevPageSlot) {
431
+ return h('span', {
432
+ class: 'vxe-pager--custom-prev-btn'
433
+ }, prevPageSlot({ $pager: $xePager, total, currentPage, pageCount }))
434
+ }
435
+ return h('button', {
436
+ class: ['vxe-pager--prev-btn', {
437
+ 'is--disabled': currentPage <= 1
438
+ }],
439
+ attrs: {
440
+ type: 'button',
441
+ title: getI18n('vxe.pager.prevPageTitle')
442
+ },
443
+ on: {
444
+ click: $xePager.handlePrevPage
445
+ }
446
+ }, [
447
+ h('i', {
448
+ class: ['vxe-pager--btn-icon', props.iconPrevPage || getIcon().PAGER_PREV_PAGE]
449
+ })
450
+ ])
451
+ },
452
+ // 向上翻页
453
+ renderPrevJump (h: CreateElement, tagName?: string) {
454
+ const $xePager = this
455
+ const props = $xePager
456
+ const slots = $xePager.$scopedSlots
457
+
458
+ const { currentPage, total } = props
459
+ const prevJumpSlot = slots.prevJump || slots['prev-jump']
460
+ const pageCount = $xePager.computePageCount
461
+ if (prevJumpSlot) {
462
+ return h('span', {
463
+ class: 'vxe-pager--custom-jump-prev'
464
+ }, prevJumpSlot({ $pager: $xePager, total, currentPage, pageCount }))
465
+ }
466
+ return h(tagName || 'button', {
467
+ class: ['vxe-pager--jump-prev', {
468
+ 'is--fixed': !tagName,
469
+ 'is--disabled': currentPage <= 1
470
+ }],
471
+ attrs: {
472
+ type: 'button',
473
+ title: getI18n('vxe.pager.prevJumpTitle')
474
+ },
475
+ on: {
476
+ click: $xePager.handlePrevJump
477
+ }
478
+ }, [
479
+ tagName
480
+ ? h('i', {
481
+ class: ['vxe-pager--jump-more-icon', props.iconJumpMore || getIcon().PAGER_JUMP_MORE]
482
+ })
483
+ : null,
484
+ h('i', {
485
+ class: ['vxe-pager--jump-icon', props.iconJumpPrev || getIcon().PAGER_JUMP_PREV]
486
+ })
487
+ ])
488
+ },
489
+ // 向下翻页
490
+ renderNextJump (h: CreateElement, tagName?: string) {
491
+ const $xePager = this
492
+ const props = $xePager
493
+ const slots = $xePager.$scopedSlots
494
+
495
+ const { currentPage, total } = props
496
+ const nextJumpSlot = slots.nextJump || slots['next-jump']
497
+ const pageCount = $xePager.computePageCount
498
+ if (nextJumpSlot) {
499
+ return h('span', {
500
+ class: 'vxe-pager--custom-jump-next'
501
+ }, nextJumpSlot({ $pager: $xePager, total, currentPage, pageCount }))
502
+ }
503
+ return h(tagName || 'button', {
504
+ class: ['vxe-pager--jump-next', {
505
+ 'is--fixed': !tagName,
506
+ 'is--disabled': currentPage >= pageCount
507
+ }],
508
+ attrs: {
509
+ type: 'button',
510
+ title: getI18n('vxe.pager.nextJumpTitle')
511
+ },
512
+ on: {
513
+ click: $xePager.handleNextJump
514
+ }
515
+ }, [
516
+ tagName
517
+ ? h('i', {
518
+ class: ['vxe-pager--jump-more-icon', props.iconJumpMore || getIcon().PAGER_JUMP_MORE]
519
+ })
520
+ : null,
521
+ h('i', {
522
+ class: ['vxe-pager--jump-icon', props.iconJumpNext || getIcon().PAGER_JUMP_NEXT]
523
+ })
524
+ ])
525
+ },
526
+ // 下一页
527
+ renderNextPage (h: CreateElement) {
528
+ const $xePager = this
529
+ const props = $xePager
530
+ const slots = $xePager.$scopedSlots
531
+
532
+ const { currentPage, total } = props
533
+ const nextPageSlot = slots.nextPage || slots['next-page']
534
+ const pageCount = $xePager.computePageCount
535
+ if (nextPageSlot) {
536
+ return h('span', {
537
+ class: 'vxe-pager--custom-next-btn'
538
+ }, nextPageSlot({ $pager: $xePager, total, currentPage, pageCount }))
539
+ }
540
+ return h('button', {
541
+ class: ['vxe-pager--next-btn', {
542
+ 'is--disabled': currentPage >= pageCount
543
+ }],
544
+ attrs: {
545
+ type: 'button',
546
+ title: getI18n('vxe.pager.nextPageTitle')
547
+ },
548
+ on: {
549
+ click: $xePager.handleNextPage
550
+ }
551
+ }, [
552
+ h('i', {
553
+ class: ['vxe-pager--btn-icon', props.iconNextPage || getIcon().PAGER_NEXT_PAGE]
554
+ })
555
+ ])
556
+ },
557
+ // 最后一页
558
+ renderEndPage (h: CreateElement) {
559
+ const $xePager = this
560
+ const props = $xePager
561
+ const slots = $xePager.$scopedSlots
562
+
563
+ const { currentPage, total } = props
564
+ const endSlot = slots.end
565
+ const pageCount = $xePager.computePageCount
566
+ if (endSlot) {
567
+ return h('span', {
568
+ class: 'vxe-pager--custom-end-btn'
569
+ }, endSlot({ $pager: $xePager, total, currentPage, pageCount }))
570
+ }
571
+ return h('button', {
572
+ class: ['vxe-pager--end-btn', {
573
+ 'is--disabled': currentPage >= pageCount
574
+ }],
575
+ attrs: {
576
+ type: 'button',
577
+ title: getI18n('vxe.pager.endPageTitle')
578
+ },
579
+ on: {
580
+ click: $xePager.handleEndPage
581
+ }
582
+ }, [
583
+ h('i', {
584
+ class: ['vxe-pager--btn-icon', props.iconEndPage || getIcon().PAGER_END]
585
+ })
586
+ ])
587
+ },
588
+ // 页数
589
+ renderNumber (h: CreateElement, showJump?: boolean) {
590
+ const $xePager = this
591
+ const props = $xePager
592
+ const slots = $xePager.$scopedSlots
593
+
594
+ const { currentPage, total, pagerCount } = props
595
+ const numberSlot = showJump ? (slots.numberJump || slots['number-jump']) : slots.number
596
+ const nums = []
597
+ const pageCount = $xePager.computePageCount
598
+ const numList = $xePager.computeNumList
599
+ const offsetNumber = $xePager.computeOffsetNumber
600
+ const isOv = pageCount > pagerCount
601
+ const isLt = isOv && currentPage > offsetNumber + 1
602
+ const isGt = isOv && currentPage < pageCount - offsetNumber
603
+ const restList: number[] = []
604
+ let startNumber = 1
605
+
606
+ if (isOv) {
607
+ if (currentPage >= pageCount - offsetNumber) {
608
+ startNumber = Math.max(pageCount - numList.length + 1, 1)
609
+ } else {
610
+ startNumber = Math.max(currentPage - offsetNumber, 1)
611
+ }
612
+ }
613
+
614
+ if (showJump && isLt) {
615
+ restList.push(1)
616
+ nums.push(
617
+ h('button', {
618
+ class: 'vxe-pager--num-btn',
619
+ attrs: {
620
+ type: 'button'
621
+ },
622
+ on: {
623
+ click: (evnt: Event) => $xePager.handleJumpPageEvent(evnt, 1)
624
+ }
625
+ }, '1'),
626
+ $xePager.renderPrevJump(h, 'span')
627
+ )
628
+ }
629
+ numList.forEach((item, index) => {
630
+ const number = startNumber + index
631
+ if (number <= pageCount) {
632
+ restList.push(number)
633
+ nums.push(
634
+ h('button', {
635
+ key: number,
636
+ class: ['vxe-pager--num-btn', {
637
+ 'is--active': currentPage === number
638
+ }],
639
+ attrs: {
640
+ type: 'button'
641
+ },
642
+ on: {
643
+ click: (evnt: Event) => $xePager.handleJumpPageEvent(evnt, number)
644
+ }
645
+ }, `${number}`)
646
+ )
647
+ }
648
+ })
649
+ if (showJump && isGt) {
650
+ restList.push(pageCount)
651
+ nums.push(
652
+ $xePager.renderNextJump(h, 'button'),
653
+ h('button', {
654
+ class: 'vxe-pager--num-btn',
655
+ attrs: {
656
+ type: 'button'
657
+ },
658
+ on: {
659
+ click: (evnt: Event) => $xePager.handleJumpPageEvent(evnt, pageCount)
660
+ }
661
+ }, pageCount)
662
+ )
663
+ }
664
+ if (numberSlot) {
665
+ return h('span', {
666
+ class: 'vxe-pager--custom-btn-wrapper'
667
+ }, numberSlot({ $pager: $xePager, total, numList: restList, currentPage, pageCount }))
668
+ }
669
+ return h('span', {
670
+ class: 'vxe-pager--btn-wrapper'
671
+ }, nums)
672
+ },
673
+ // jumpNumber
674
+ renderJumpNumber (h: CreateElement) {
675
+ const $xePager = this
676
+
677
+ return $xePager.renderNumber(h, true)
678
+ },
679
+ // sizes
680
+ renderSizes (h: CreateElement) {
681
+ const $xePager = this
682
+ const props = $xePager
683
+ const slots = $xePager.$scopedSlots
684
+
685
+ const { currentPage, total, pageSize, pageSizePlacement, transfer } = props
686
+ const sizesSlot = slots.sizes
687
+ const sizeList = $xePager.computeSizeList
688
+ const pageCount = $xePager.computePageCount
689
+ if (sizesSlot) {
690
+ return h('span', {
691
+ class: 'vxe-pager--custom-sizes'
692
+ }, sizesSlot({ $pager: $xePager, total, currentPage, pageCount, pageSize, options: sizeList }))
693
+ }
694
+ return h(VxeSelectComponent, {
695
+ class: 'vxe-pager--sizes',
696
+ props: {
697
+ value: pageSize,
698
+ placement: pageSizePlacement,
699
+ transfer: transfer,
700
+ options: sizeList
701
+ },
702
+ on: {
703
+ change: $xePager.pageSizeEvent
704
+ }
705
+ })
706
+ },
707
+ // Jump
708
+ renderJump (h: CreateElement, isFull?: boolean) {
709
+ const $xePager = this
710
+ const props = $xePager
711
+ const reactData = $xePager.reactData
712
+ const slots = $xePager.$scopedSlots
713
+
714
+ const { total } = props
715
+ const { inpCurrPage } = reactData
716
+ const jumpSlot = isFull ? (slots.fullJump || slots['full-jump']) : slots.jump
717
+ const pageCount = $xePager.computePageCount
718
+ if (jumpSlot) {
719
+ return h('span', {
720
+ class: 'vxe-pager--custom-jump'
721
+ }, jumpSlot({ $pager: $xePager, total, currentPage: inpCurrPage, pageCount }))
722
+ }
723
+ return h('span', {
724
+ class: 'vxe-pager--jump'
725
+ }, [
726
+ isFull
727
+ ? h('span', {
728
+ class: 'vxe-pager--goto-text'
729
+ }, getI18n('vxe.pager.goto'))
730
+ : null,
731
+ h(VxeNumberInputComponent, {
732
+ class: 'vxe-pager--goto',
733
+ props: {
734
+ value: inpCurrPage,
735
+ placeholder: getI18n('vxe.pager.gotoTitle'),
736
+ align: 'center',
737
+ type: 'integer',
738
+ max: pageCount,
739
+ min: 1,
740
+ controls: false
741
+ },
742
+ on: {
743
+ keydown: $xePager.jumpKeydownEvent,
744
+ blur: $xePager.triggerJumpEvent,
745
+ 'modelValue' (val: string) {
746
+ reactData.inpCurrPage = val
747
+ }
748
+ }
749
+ }),
750
+ isFull
751
+ ? h('span', {
752
+ class: 'vxe-pager--classifier-text'
753
+ }, getI18n('vxe.pager.pageClassifier'))
754
+ : null
755
+ ])
756
+ },
757
+ // FullJump
758
+ renderFullJump (h: CreateElement) {
759
+ const $xePager = this
760
+
761
+ return $xePager.renderJump(h, true)
762
+ },
763
+ // PageCount
764
+ renderPageCount (h: CreateElement) {
765
+ const $xePager = this
766
+ const props = $xePager
767
+ const slots = $xePager.$scopedSlots
768
+
769
+ const { currentPage, total } = props
770
+ const pageCountSlot = slots.pageCount || slots['page-count']
771
+ const pageCount = $xePager.computePageCount
772
+ if (pageCountSlot) {
773
+ return h('span', {
774
+ class: 'vxe-pager--custom-count'
775
+ }, pageCountSlot({ $pager: $xePager, total, currentPage, pageCount }))
776
+ }
777
+ return h('span', {
778
+ class: 'vxe-pager--count'
779
+ }, [
780
+ h('span', {
781
+ class: 'vxe-pager--separator'
782
+ }),
783
+ h('span', pageCount)
784
+ ])
785
+ },
786
+ // total
787
+ renderTotal (h: CreateElement) {
788
+ const $xePager = this
789
+ const props = $xePager
790
+ const slots = $xePager.$scopedSlots
791
+
792
+ const { total, currentPage } = props
793
+ const totalSlot = slots.total
794
+ const pageCount = $xePager.computePageCount
795
+ if (totalSlot) {
796
+ return h('span', {
797
+ class: 'vxe-pager--custom-total'
798
+ }, totalSlot({ $pager: $xePager, total, currentPage, pageCount }))
799
+ }
800
+ return h('span', {
801
+ class: 'vxe-pager--total'
802
+ }, getI18n('vxe.pager.total', [total]))
803
+ },
804
+ renderVN (h: CreateElement): VNode {
805
+ const $xePager = this
806
+ const props = $xePager
807
+ const slots = $xePager.$scopedSlots
808
+ const $xeGrid = $xePager.$xeGrid
809
+
810
+ const { align, layouts, className } = props
811
+ const childNodes = []
812
+ const vSize = $xePager.computeSize
813
+ const pageCount = $xePager.computePageCount
814
+ if (slots.left) {
815
+ childNodes.push(
816
+ h('span', {
817
+ class: 'vxe-pager--left-wrapper'
818
+ }, slots.left({ $grid: $xeGrid }))
819
+ )
820
+ }
821
+ layouts.forEach((name) => {
822
+ let renderFn: (h: CreateElement) => VNode
823
+ switch (name) {
824
+ case 'Home':
825
+ renderFn = $xePager.renderHomePage
826
+ break
827
+ case 'PrevJump':
828
+ renderFn = $xePager.renderPrevJump
829
+ break
830
+ case 'PrevPage':
831
+ renderFn = $xePager.renderPrevPage
832
+ break
833
+ case 'Number':
834
+ renderFn = $xePager.renderNumber
835
+ break
836
+ case 'JumpNumber':
837
+ renderFn = $xePager.renderJumpNumber
838
+ break
839
+ case 'NextPage':
840
+ renderFn = $xePager.renderNextPage
841
+ break
842
+ case 'NextJump':
843
+ renderFn = $xePager.renderNextJump
844
+ break
845
+ case 'End':
846
+ renderFn = $xePager.renderEndPage
847
+ break
848
+ case 'Sizes':
849
+ renderFn = $xePager.renderSizes
850
+ break
851
+ case 'FullJump':
852
+ renderFn = $xePager.renderFullJump
853
+ break
854
+ case 'Jump':
855
+ renderFn = $xePager.renderJump
856
+ break
857
+ case 'PageCount':
858
+ renderFn = $xePager.renderPageCount
859
+ break
860
+ case 'Total':
861
+ renderFn = $xePager.renderTotal
862
+ break
863
+ }
864
+ if (renderFn) {
865
+ childNodes.push(renderFn(h))
866
+ } else {
867
+ errLog('vxe.error.notProp', [`[pager] layouts -> ${name}`])
868
+ }
869
+ })
870
+ if (slots.right) {
871
+ childNodes.push(
872
+ h('span', {
873
+ class: 'vxe-pager--right-wrapper'
874
+ }, slots.right({ $grid: $xeGrid }))
875
+ )
876
+ }
877
+ return h('div', {
878
+ ref: 'refElem',
879
+ class: ['vxe-pager', className ? (XEUtils.isFunction(className) ? className({ $pager: $xePager }) : className) : '', {
880
+ [`size--${vSize}`]: vSize,
881
+ [`align--${align}`]: align,
882
+ 'is--border': props.border,
883
+ 'is--background': props.background,
884
+ 'is--perfect': props.perfect,
885
+ 'is--hidden': props.autoHidden && pageCount === 1,
886
+ 'is--loading': props.loading
887
+ }]
888
+ }, [
889
+ h('div', {
890
+ class: 'vxe-pager--wrapper'
891
+ }, childNodes)
892
+ ])
893
+ }
894
+ },
895
+ watch: {
896
+ currentPage (val) {
897
+ const $xePager = this
898
+ const reactData = $xePager.reactData
899
+
900
+ reactData.inpCurrPage = val
901
+ }
902
+ },
903
+ created () {
904
+ const $xePager = this
905
+ const props = $xePager
906
+ const reactData = $xePager.reactData
907
+
908
+ reactData.inpCurrPage = props.currentPage
909
+ },
910
+ render (this: any, h) {
911
+ return this.renderVN(h)
912
+ }
913
+ }) /* define-vxe-component end */