@fecp/designer 5.4.106 → 5.4.108

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 (331) hide show
  1. package/es/_virtual/index2.mjs +2 -5
  2. package/es/designer/package.json.mjs +1 -1
  3. package/es/designer/src/packages/dialog/useDialogDialog.mjs +1 -1
  4. package/es/designer/src/packages/dialogGlobal/useDialogGlobalDialog.mjs +1 -1
  5. package/es/designer/src/packages/form/property/widgets.vue.mjs +2 -2
  6. package/es/designer.css +2 -2
  7. package/es/node_modules/@vxe-ui/core/es/index.esm.mjs +1 -2
  8. package/es/node_modules/@vxe-ui/core/es/src/clipboard.mjs +1 -2
  9. package/es/node_modules/@vxe-ui/core/es/src/commands.mjs +1 -2
  10. package/es/node_modules/@vxe-ui/core/es/src/config.mjs +1 -2
  11. package/es/node_modules/@vxe-ui/core/es/src/event.mjs +1 -2
  12. package/es/node_modules/@vxe-ui/core/es/src/formats.mjs +1 -2
  13. package/es/node_modules/@vxe-ui/core/es/src/i18n.mjs +1 -2
  14. package/es/node_modules/@vxe-ui/core/es/src/icon.mjs +1 -2
  15. package/es/node_modules/@vxe-ui/core/es/src/interceptor.mjs +1 -2
  16. package/es/node_modules/@vxe-ui/core/es/src/menus.mjs +1 -2
  17. package/es/node_modules/@vxe-ui/core/es/src/permission.mjs +1 -2
  18. package/es/node_modules/@vxe-ui/core/es/src/renderer.mjs +1 -2
  19. package/es/node_modules/@vxe-ui/core/es/src/resize.mjs +1 -2
  20. package/es/node_modules/@vxe-ui/core/es/src/store.mjs +1 -2
  21. package/es/node_modules/@vxe-ui/core/es/src/vm.mjs +1 -2
  22. package/es/node_modules/crypto-js/index.mjs +1 -1
  23. package/es/node_modules/vxe-pc-ui/es/alert/src/alert.mjs +1 -1
  24. package/es/node_modules/vxe-pc-ui/es/anchor/src/anchor-link.mjs +1 -1
  25. package/es/node_modules/vxe-pc-ui/es/anchor/src/anchor.mjs +1 -1
  26. package/es/node_modules/vxe-pc-ui/es/anchor/src/util.mjs +1 -1
  27. package/es/node_modules/vxe-pc-ui/es/avatar/src/avatar.mjs +1 -1
  28. package/es/node_modules/vxe-pc-ui/es/backtop/src/backtop.mjs +1 -1
  29. package/es/node_modules/vxe-pc-ui/es/badge/src/badge.mjs +1 -1
  30. package/es/node_modules/vxe-pc-ui/es/breadcrumb/src/breadcrumb-item.mjs +1 -1
  31. package/es/node_modules/vxe-pc-ui/es/breadcrumb/src/breadcrumb.mjs +1 -1
  32. package/es/node_modules/vxe-pc-ui/es/button/src/button-group.mjs +1 -1
  33. package/es/node_modules/vxe-pc-ui/es/button/src/button.mjs +1 -1
  34. package/es/node_modules/vxe-pc-ui/es/calendar/src/calendar.mjs +1 -1
  35. package/es/node_modules/vxe-pc-ui/es/card/src/card.mjs +1 -1
  36. package/es/node_modules/vxe-pc-ui/es/carousel/src/carousel-item.mjs +1 -1
  37. package/es/node_modules/vxe-pc-ui/es/carousel/src/carousel.mjs +1 -1
  38. package/es/node_modules/vxe-pc-ui/es/carousel/src/util.mjs +1 -1
  39. package/es/node_modules/vxe-pc-ui/es/cascader/src/cascader.mjs +1 -1
  40. package/es/node_modules/vxe-pc-ui/es/checkbox/src/button.mjs +1 -1
  41. package/es/node_modules/vxe-pc-ui/es/checkbox/src/checkbox.mjs +1 -1
  42. package/es/node_modules/vxe-pc-ui/es/checkbox/src/group.mjs +1 -1
  43. package/es/node_modules/vxe-pc-ui/es/collapse/src/collapse-pane.mjs +1 -1
  44. package/es/node_modules/vxe-pc-ui/es/collapse/src/collapse.mjs +1 -1
  45. package/es/node_modules/vxe-pc-ui/es/collapse/src/util.mjs +1 -1
  46. package/es/node_modules/vxe-pc-ui/es/color-picker/src/color-picker.mjs +1 -1
  47. package/es/node_modules/vxe-pc-ui/es/color-picker/src/util.mjs +1 -1
  48. package/es/node_modules/vxe-pc-ui/es/context-menu/src/context-menu.mjs +1 -1
  49. package/es/node_modules/vxe-pc-ui/es/countdown/src/countdown.mjs +1 -1
  50. package/es/node_modules/vxe-pc-ui/es/date-panel/src/date-panel.mjs +1 -1
  51. package/es/node_modules/vxe-pc-ui/es/date-panel/src/util.mjs +1 -1
  52. package/es/node_modules/vxe-pc-ui/es/date-picker/src/date-picker.mjs +1 -1
  53. package/es/node_modules/vxe-pc-ui/es/date-range-picker/src/date-range-picker.mjs +1 -1
  54. package/es/node_modules/vxe-pc-ui/es/drawer/index.mjs +1 -1
  55. package/es/node_modules/vxe-pc-ui/es/drawer/src/drawer.mjs +1 -1
  56. package/es/node_modules/vxe-pc-ui/es/empty/src/empty.mjs +1 -1
  57. package/es/node_modules/vxe-pc-ui/es/form/render/index.mjs +1 -1
  58. package/es/node_modules/vxe-pc-ui/es/form/src/form-config-item.mjs +1 -1
  59. package/es/node_modules/vxe-pc-ui/es/form/src/form-group.mjs +1 -1
  60. package/es/node_modules/vxe-pc-ui/es/form/src/form-item.mjs +1 -1
  61. package/es/node_modules/vxe-pc-ui/es/form/src/form.mjs +1 -1
  62. package/es/node_modules/vxe-pc-ui/es/form/src/itemInfo.mjs +1 -1
  63. package/es/node_modules/vxe-pc-ui/es/form/src/render.mjs +1 -1
  64. package/es/node_modules/vxe-pc-ui/es/form/src/util.mjs +1 -1
  65. package/es/node_modules/vxe-pc-ui/es/icon/src/icon.mjs +1 -1
  66. package/es/node_modules/vxe-pc-ui/es/icon-picker/src/icon-picker.mjs +1 -1
  67. package/es/node_modules/vxe-pc-ui/es/image/src/group.mjs +1 -1
  68. package/es/node_modules/vxe-pc-ui/es/image/src/image.mjs +1 -1
  69. package/es/node_modules/vxe-pc-ui/es/image/src/preview.mjs +1 -1
  70. package/es/node_modules/vxe-pc-ui/es/image/src/util.mjs +1 -1
  71. package/es/node_modules/vxe-pc-ui/es/input/src/input.mjs +1 -1
  72. package/es/node_modules/vxe-pc-ui/es/layout-aside/src/layout-aside.mjs +1 -1
  73. package/es/node_modules/vxe-pc-ui/es/layout-body/src/layout-body.mjs +1 -1
  74. package/es/node_modules/vxe-pc-ui/es/layout-container/src/layout-container.mjs +1 -1
  75. package/es/node_modules/vxe-pc-ui/es/layout-footer/src/layout-footer.mjs +1 -1
  76. package/es/node_modules/vxe-pc-ui/es/layout-header/src/layout-header.mjs +1 -1
  77. package/es/node_modules/vxe-pc-ui/es/link/src/link.mjs +1 -1
  78. package/es/node_modules/vxe-pc-ui/es/list/src/list.mjs +1 -1
  79. package/es/node_modules/vxe-pc-ui/es/loading/src/loading.mjs +1 -1
  80. package/es/node_modules/vxe-pc-ui/es/menu/src/menu.mjs +1 -1
  81. package/es/node_modules/vxe-pc-ui/es/modal/index.mjs +1 -1
  82. package/es/node_modules/vxe-pc-ui/es/modal/src/modal.mjs +1 -1
  83. package/es/node_modules/vxe-pc-ui/es/notice-bar/src/notice-bar.mjs +1 -1
  84. package/es/node_modules/vxe-pc-ui/es/number-input/src/number-input.mjs +1 -1
  85. package/es/node_modules/vxe-pc-ui/es/number-input/src/util.mjs +1 -1
  86. package/es/node_modules/vxe-pc-ui/es/pager/src/pager.mjs +1 -1
  87. package/es/node_modules/vxe-pc-ui/es/password-input/src/password-input.mjs +1 -1
  88. package/es/node_modules/vxe-pc-ui/es/print/src/page-break.mjs +1 -1
  89. package/es/node_modules/vxe-pc-ui/es/print/src/print.mjs +1 -1
  90. package/es/node_modules/vxe-pc-ui/es/print/src/util.mjs +1 -1
  91. package/es/node_modules/vxe-pc-ui/es/pulldown/src/pulldown.mjs +1 -1
  92. package/es/node_modules/vxe-pc-ui/es/radio/src/button.mjs +1 -1
  93. package/es/node_modules/vxe-pc-ui/es/radio/src/group.mjs +1 -1
  94. package/es/node_modules/vxe-pc-ui/es/radio/src/radio.mjs +1 -1
  95. package/es/node_modules/vxe-pc-ui/es/rate/src/rate.mjs +1 -1
  96. package/es/node_modules/vxe-pc-ui/es/result/src/result.mjs +1 -1
  97. package/es/node_modules/vxe-pc-ui/es/row/src/col.mjs +1 -1
  98. package/es/node_modules/vxe-pc-ui/es/row/src/row.mjs +1 -1
  99. package/es/node_modules/vxe-pc-ui/es/segmented/src/segmented.mjs +1 -1
  100. package/es/node_modules/vxe-pc-ui/es/select/src/option-info.mjs +1 -1
  101. package/es/node_modules/vxe-pc-ui/es/select/src/select.mjs +1 -1
  102. package/es/node_modules/vxe-pc-ui/es/select/src/util.mjs +1 -1
  103. package/es/node_modules/vxe-pc-ui/es/slider/src/slider.mjs +1 -1
  104. package/es/node_modules/vxe-pc-ui/es/splitter/src/splitter-panel.mjs +1 -1
  105. package/es/node_modules/vxe-pc-ui/es/splitter/src/splitter.mjs +1 -1
  106. package/es/node_modules/vxe-pc-ui/es/splitter/src/util.mjs +1 -1
  107. package/es/node_modules/vxe-pc-ui/es/steps/src/steps.mjs +1 -1
  108. package/es/node_modules/vxe-pc-ui/es/switch/src/switch.mjs +1 -1
  109. package/es/node_modules/vxe-pc-ui/es/table-select/src/table-select.mjs +1 -1
  110. package/es/node_modules/vxe-pc-ui/es/tabs/src/tab-pane.mjs +1 -1
  111. package/es/node_modules/vxe-pc-ui/es/tabs/src/tabs.mjs +1 -1
  112. package/es/node_modules/vxe-pc-ui/es/tabs/src/util.mjs +1 -1
  113. package/es/node_modules/vxe-pc-ui/es/tag/src/tag.mjs +1 -1
  114. package/es/node_modules/vxe-pc-ui/es/text/src/text.mjs +1 -1
  115. package/es/node_modules/vxe-pc-ui/es/text-ellipsis/src/text-ellipsis.mjs +1 -1
  116. package/es/node_modules/vxe-pc-ui/es/textarea/src/textarea.mjs +1 -1
  117. package/es/node_modules/vxe-pc-ui/es/timeline/src/timeline-item.mjs +1 -1
  118. package/es/node_modules/vxe-pc-ui/es/timeline/src/timeline.mjs +1 -1
  119. package/es/node_modules/vxe-pc-ui/es/tip/src/tip.mjs +1 -1
  120. package/es/node_modules/vxe-pc-ui/es/tooltip/src/tooltip.mjs +1 -1
  121. package/es/node_modules/vxe-pc-ui/es/tour/src/tour.mjs +1 -1
  122. package/es/node_modules/vxe-pc-ui/es/tree/src/tree.mjs +1 -1
  123. package/es/node_modules/vxe-pc-ui/es/tree/src/util.mjs +1 -1
  124. package/es/node_modules/vxe-pc-ui/es/tree-select/src/tree-select.mjs +1 -1
  125. package/es/node_modules/vxe-pc-ui/es/ui/src/anime.mjs +1 -1
  126. package/es/node_modules/vxe-pc-ui/es/ui/src/dom.mjs +1 -1
  127. package/es/node_modules/vxe-pc-ui/es/ui/src/utils.mjs +1 -1
  128. package/es/node_modules/vxe-pc-ui/es/ui/src/vn.mjs +1 -1
  129. package/es/node_modules/vxe-pc-ui/es/upload/src/upload.mjs +1 -1
  130. package/es/node_modules/vxe-pc-ui/es/upload/src/util.mjs +1 -1
  131. package/es/node_modules/vxe-pc-ui/es/watermark/src/util.mjs +1 -1
  132. package/es/node_modules/vxe-pc-ui/es/watermark/src/watermark.mjs +1 -1
  133. package/es/node_modules/vxe-table/es/components.mjs +2 -1
  134. package/es/node_modules/vxe-table/es/grid/index.mjs +5 -1
  135. package/es/node_modules/vxe-table/es/grid/src/grid.mjs +20 -24
  136. package/es/node_modules/vxe-table/es/locale/lang/zh-CN.mjs +0 -6
  137. package/es/node_modules/vxe-table/es/table/module/custom/hook.mjs +8 -25
  138. package/es/node_modules/vxe-table/es/table/module/custom/panel.mjs +9 -14
  139. package/es/node_modules/vxe-table/es/table/module/export/export-panel.mjs +5 -11
  140. package/es/node_modules/vxe-table/es/table/module/export/import-panel.mjs +4 -11
  141. package/es/node_modules/vxe-table/es/table/module/filter/hook.mjs +19 -63
  142. package/es/node_modules/vxe-table/es/table/module/keyboard/hook.mjs +7 -18
  143. package/es/node_modules/vxe-table/es/table/module/menu/hook.mjs +2 -2
  144. package/es/node_modules/vxe-table/es/table/module/validator/hook.mjs +19 -19
  145. package/es/node_modules/vxe-table/es/table/src/body.mjs +17 -28
  146. package/es/node_modules/vxe-table/es/table/src/column.mjs +1 -1
  147. package/es/node_modules/vxe-table/es/table/src/columnInfo.mjs +0 -2
  148. package/es/node_modules/vxe-table/es/table/src/emits.mjs +0 -1
  149. package/es/node_modules/vxe-table/es/table/src/footer.mjs +2 -2
  150. package/es/node_modules/vxe-table/es/table/src/group.mjs +1 -2
  151. package/es/node_modules/vxe-table/es/table/src/props.mjs +0 -4
  152. package/es/node_modules/vxe-table/es/table/src/table.mjs +496 -619
  153. package/es/node_modules/vxe-table/es/table/src/util.mjs +22 -286
  154. package/es/node_modules/vxe-table/es/toolbar/src/toolbar.mjs +7 -11
  155. package/es/node_modules/vxe-table/es/ui/index.mjs +4 -12
  156. package/es/node_modules/vxe-table/es/ui/src/dom.mjs +1 -24
  157. package/es/node_modules/vxe-table/es/ui/src/log.mjs +1 -1
  158. package/es/packages/mobile/src/components/dataDisplay/table/Table.vue.mjs +2 -3
  159. package/es/packages/mobile/src/components/form/field/Field.vue.mjs +1 -1
  160. package/es/packages/mobile/src/utils/formatterUtil.mjs +1 -1
  161. package/es/packages/mobile/src/utils/optionUtil.mjs +1 -1
  162. package/es/packages/vue/src/components/table/CustomButtons.vue.mjs +1 -2
  163. package/es/packages/vue/src/components/table/DynamicQuery.vue.mjs +1 -2
  164. package/es/packages/vue/src/components/table/Table.vue.mjs +2 -3
  165. package/es/packages/vue/src/components/table/TableColumn.vue.mjs +1 -2
  166. package/lib/_virtual/index2.js +3 -6
  167. package/lib/designer/package.json.js +1 -1
  168. package/lib/designer/src/packages/dialog/useDialogDialog.js +1 -1
  169. package/lib/designer/src/packages/dialogGlobal/useDialogGlobalDialog.js +1 -1
  170. package/lib/designer/src/packages/form/property/widgets.vue.js +2 -2
  171. package/lib/designer.css +2 -2
  172. package/lib/node_modules/@vxe-ui/core/es/index.esm.js +4 -5
  173. package/lib/node_modules/@vxe-ui/core/es/src/clipboard.js +2 -3
  174. package/lib/node_modules/@vxe-ui/core/es/src/commands.js +7 -8
  175. package/lib/node_modules/@vxe-ui/core/es/src/config.js +3 -4
  176. package/lib/node_modules/@vxe-ui/core/es/src/event.js +6 -7
  177. package/lib/node_modules/@vxe-ui/core/es/src/formats.js +7 -8
  178. package/lib/node_modules/@vxe-ui/core/es/src/i18n.js +2 -3
  179. package/lib/node_modules/@vxe-ui/core/es/src/icon.js +3 -4
  180. package/lib/node_modules/@vxe-ui/core/es/src/interceptor.js +5 -6
  181. package/lib/node_modules/@vxe-ui/core/es/src/menus.js +7 -8
  182. package/lib/node_modules/@vxe-ui/core/es/src/permission.js +2 -3
  183. package/lib/node_modules/@vxe-ui/core/es/src/renderer.js +5 -6
  184. package/lib/node_modules/@vxe-ui/core/es/src/resize.js +3 -4
  185. package/lib/node_modules/@vxe-ui/core/es/src/store.js +6 -7
  186. package/lib/node_modules/@vxe-ui/core/es/src/vm.js +2 -3
  187. package/lib/node_modules/crypto-js/index.js +1 -1
  188. package/lib/node_modules/vxe-pc-ui/es/alert/src/alert.js +4 -4
  189. package/lib/node_modules/vxe-pc-ui/es/anchor/src/anchor-link.js +3 -3
  190. package/lib/node_modules/vxe-pc-ui/es/anchor/src/anchor.js +6 -6
  191. package/lib/node_modules/vxe-pc-ui/es/anchor/src/util.js +3 -3
  192. package/lib/node_modules/vxe-pc-ui/es/avatar/src/avatar.js +3 -3
  193. package/lib/node_modules/vxe-pc-ui/es/backtop/src/backtop.js +9 -9
  194. package/lib/node_modules/vxe-pc-ui/es/badge/src/badge.js +3 -3
  195. package/lib/node_modules/vxe-pc-ui/es/breadcrumb/src/breadcrumb-item.js +2 -2
  196. package/lib/node_modules/vxe-pc-ui/es/breadcrumb/src/breadcrumb.js +2 -2
  197. package/lib/node_modules/vxe-pc-ui/es/button/src/button-group.js +5 -5
  198. package/lib/node_modules/vxe-pc-ui/es/button/src/button.js +15 -15
  199. package/lib/node_modules/vxe-pc-ui/es/calendar/src/calendar.js +80 -80
  200. package/lib/node_modules/vxe-pc-ui/es/card/src/card.js +2 -2
  201. package/lib/node_modules/vxe-pc-ui/es/carousel/src/carousel-item.js +2 -2
  202. package/lib/node_modules/vxe-pc-ui/es/carousel/src/carousel.js +12 -12
  203. package/lib/node_modules/vxe-pc-ui/es/carousel/src/util.js +5 -5
  204. package/lib/node_modules/vxe-pc-ui/es/cascader/src/cascader.js +16 -16
  205. package/lib/node_modules/vxe-pc-ui/es/checkbox/src/button.js +3 -3
  206. package/lib/node_modules/vxe-pc-ui/es/checkbox/src/checkbox.js +3 -3
  207. package/lib/node_modules/vxe-pc-ui/es/checkbox/src/group.js +7 -7
  208. package/lib/node_modules/vxe-pc-ui/es/collapse/src/collapse-pane.js +2 -2
  209. package/lib/node_modules/vxe-pc-ui/es/collapse/src/collapse.js +4 -4
  210. package/lib/node_modules/vxe-pc-ui/es/collapse/src/util.js +3 -3
  211. package/lib/node_modules/vxe-pc-ui/es/color-picker/src/color-picker.js +15 -15
  212. package/lib/node_modules/vxe-pc-ui/es/color-picker/src/util.js +4 -4
  213. package/lib/node_modules/vxe-pc-ui/es/context-menu/src/context-menu.js +13 -13
  214. package/lib/node_modules/vxe-pc-ui/es/countdown/src/countdown.js +9 -9
  215. package/lib/node_modules/vxe-pc-ui/es/date-panel/src/date-panel.js +120 -120
  216. package/lib/node_modules/vxe-pc-ui/es/date-panel/src/util.js +29 -29
  217. package/lib/node_modules/vxe-pc-ui/es/date-picker/src/date-picker.js +15 -15
  218. package/lib/node_modules/vxe-pc-ui/es/date-range-picker/src/date-range-picker.js +17 -17
  219. package/lib/node_modules/vxe-pc-ui/es/drawer/index.js +3 -3
  220. package/lib/node_modules/vxe-pc-ui/es/drawer/src/drawer.js +8 -8
  221. package/lib/node_modules/vxe-pc-ui/es/empty/src/empty.js +2 -2
  222. package/lib/node_modules/vxe-pc-ui/es/form/render/index.js +31 -31
  223. package/lib/node_modules/vxe-pc-ui/es/form/src/form-config-item.js +3 -3
  224. package/lib/node_modules/vxe-pc-ui/es/form/src/form-group.js +4 -4
  225. package/lib/node_modules/vxe-pc-ui/es/form/src/form-item.js +4 -4
  226. package/lib/node_modules/vxe-pc-ui/es/form/src/form.js +43 -43
  227. package/lib/node_modules/vxe-pc-ui/es/form/src/itemInfo.js +4 -4
  228. package/lib/node_modules/vxe-pc-ui/es/form/src/render.js +25 -25
  229. package/lib/node_modules/vxe-pc-ui/es/form/src/util.js +6 -6
  230. package/lib/node_modules/vxe-pc-ui/es/icon/src/icon.js +2 -2
  231. package/lib/node_modules/vxe-pc-ui/es/icon-picker/src/icon-picker.js +8 -8
  232. package/lib/node_modules/vxe-pc-ui/es/image/src/group.js +7 -7
  233. package/lib/node_modules/vxe-pc-ui/es/image/src/image.js +7 -7
  234. package/lib/node_modules/vxe-pc-ui/es/image/src/preview.js +9 -9
  235. package/lib/node_modules/vxe-pc-ui/es/image/src/util.js +2 -2
  236. package/lib/node_modules/vxe-pc-ui/es/input/src/input.js +146 -146
  237. package/lib/node_modules/vxe-pc-ui/es/layout-aside/src/layout-aside.js +2 -2
  238. package/lib/node_modules/vxe-pc-ui/es/layout-body/src/layout-body.js +6 -6
  239. package/lib/node_modules/vxe-pc-ui/es/layout-container/src/layout-container.js +2 -2
  240. package/lib/node_modules/vxe-pc-ui/es/layout-footer/src/layout-footer.js +2 -2
  241. package/lib/node_modules/vxe-pc-ui/es/layout-header/src/layout-header.js +2 -2
  242. package/lib/node_modules/vxe-pc-ui/es/link/src/link.js +3 -3
  243. package/lib/node_modules/vxe-pc-ui/es/list/src/list.js +12 -12
  244. package/lib/node_modules/vxe-pc-ui/es/loading/src/loading.js +3 -3
  245. package/lib/node_modules/vxe-pc-ui/es/menu/src/menu.js +10 -10
  246. package/lib/node_modules/vxe-pc-ui/es/modal/index.js +5 -5
  247. package/lib/node_modules/vxe-pc-ui/es/modal/src/modal.js +36 -36
  248. package/lib/node_modules/vxe-pc-ui/es/notice-bar/src/notice-bar.js +2 -2
  249. package/lib/node_modules/vxe-pc-ui/es/number-input/src/number-input.js +30 -30
  250. package/lib/node_modules/vxe-pc-ui/es/number-input/src/util.js +4 -4
  251. package/lib/node_modules/vxe-pc-ui/es/pager/src/pager.js +13 -13
  252. package/lib/node_modules/vxe-pc-ui/es/password-input/src/password-input.js +5 -5
  253. package/lib/node_modules/vxe-pc-ui/es/print/src/page-break.js +2 -2
  254. package/lib/node_modules/vxe-pc-ui/es/print/src/print.js +13 -13
  255. package/lib/node_modules/vxe-pc-ui/es/print/src/util.js +11 -11
  256. package/lib/node_modules/vxe-pc-ui/es/pulldown/src/pulldown.js +7 -7
  257. package/lib/node_modules/vxe-pc-ui/es/radio/src/button.js +6 -6
  258. package/lib/node_modules/vxe-pc-ui/es/radio/src/group.js +7 -7
  259. package/lib/node_modules/vxe-pc-ui/es/radio/src/radio.js +6 -6
  260. package/lib/node_modules/vxe-pc-ui/es/rate/src/rate.js +3 -3
  261. package/lib/node_modules/vxe-pc-ui/es/result/src/result.js +2 -2
  262. package/lib/node_modules/vxe-pc-ui/es/row/src/col.js +5 -5
  263. package/lib/node_modules/vxe-pc-ui/es/row/src/row.js +5 -5
  264. package/lib/node_modules/vxe-pc-ui/es/segmented/src/segmented.js +6 -6
  265. package/lib/node_modules/vxe-pc-ui/es/select/src/option-info.js +2 -2
  266. package/lib/node_modules/vxe-pc-ui/es/select/src/select.js +27 -27
  267. package/lib/node_modules/vxe-pc-ui/es/select/src/util.js +3 -3
  268. package/lib/node_modules/vxe-pc-ui/es/slider/src/slider.js +14 -14
  269. package/lib/node_modules/vxe-pc-ui/es/splitter/src/splitter-panel.js +2 -2
  270. package/lib/node_modules/vxe-pc-ui/es/splitter/src/splitter.js +28 -28
  271. package/lib/node_modules/vxe-pc-ui/es/splitter/src/util.js +5 -5
  272. package/lib/node_modules/vxe-pc-ui/es/steps/src/steps.js +2 -2
  273. package/lib/node_modules/vxe-pc-ui/es/switch/src/switch.js +2 -2
  274. package/lib/node_modules/vxe-pc-ui/es/table-select/src/table-select.js +18 -18
  275. package/lib/node_modules/vxe-pc-ui/es/tabs/src/tab-pane.js +2 -2
  276. package/lib/node_modules/vxe-pc-ui/es/tabs/src/tabs.js +22 -22
  277. package/lib/node_modules/vxe-pc-ui/es/tabs/src/util.js +3 -3
  278. package/lib/node_modules/vxe-pc-ui/es/tag/src/tag.js +3 -3
  279. package/lib/node_modules/vxe-pc-ui/es/text/src/text.js +3 -3
  280. package/lib/node_modules/vxe-pc-ui/es/text-ellipsis/src/text-ellipsis.js +7 -7
  281. package/lib/node_modules/vxe-pc-ui/es/textarea/src/textarea.js +12 -12
  282. package/lib/node_modules/vxe-pc-ui/es/timeline/src/timeline-item.js +2 -2
  283. package/lib/node_modules/vxe-pc-ui/es/timeline/src/timeline.js +2 -2
  284. package/lib/node_modules/vxe-pc-ui/es/tip/src/tip.js +4 -4
  285. package/lib/node_modules/vxe-pc-ui/es/tooltip/src/tooltip.js +9 -9
  286. package/lib/node_modules/vxe-pc-ui/es/tour/src/tour.js +2 -2
  287. package/lib/node_modules/vxe-pc-ui/es/tree/src/tree.js +61 -61
  288. package/lib/node_modules/vxe-pc-ui/es/tree/src/util.js +4 -4
  289. package/lib/node_modules/vxe-pc-ui/es/tree-select/src/tree-select.js +27 -27
  290. package/lib/node_modules/vxe-pc-ui/es/ui/src/anime.js +4 -4
  291. package/lib/node_modules/vxe-pc-ui/es/ui/src/dom.js +9 -9
  292. package/lib/node_modules/vxe-pc-ui/es/ui/src/utils.js +4 -4
  293. package/lib/node_modules/vxe-pc-ui/es/ui/src/vn.js +2 -2
  294. package/lib/node_modules/vxe-pc-ui/es/upload/src/upload.js +63 -63
  295. package/lib/node_modules/vxe-pc-ui/es/upload/src/util.js +4 -4
  296. package/lib/node_modules/vxe-pc-ui/es/watermark/src/util.js +11 -11
  297. package/lib/node_modules/vxe-pc-ui/es/watermark/src/watermark.js +5 -5
  298. package/lib/node_modules/vxe-table/es/components.js +4 -3
  299. package/lib/node_modules/vxe-table/es/grid/index.js +4 -1
  300. package/lib/node_modules/vxe-table/es/grid/src/grid.js +19 -23
  301. package/lib/node_modules/vxe-table/es/locale/lang/zh-CN.js +0 -6
  302. package/lib/node_modules/vxe-table/es/table/module/custom/hook.js +8 -25
  303. package/lib/node_modules/vxe-table/es/table/module/custom/panel.js +8 -13
  304. package/lib/node_modules/vxe-table/es/table/module/export/export-panel.js +5 -11
  305. package/lib/node_modules/vxe-table/es/table/module/export/import-panel.js +4 -11
  306. package/lib/node_modules/vxe-table/es/table/module/filter/hook.js +19 -63
  307. package/lib/node_modules/vxe-table/es/table/module/keyboard/hook.js +7 -18
  308. package/lib/node_modules/vxe-table/es/table/module/menu/hook.js +2 -2
  309. package/lib/node_modules/vxe-table/es/table/module/validator/hook.js +19 -19
  310. package/lib/node_modules/vxe-table/es/table/src/body.js +17 -28
  311. package/lib/node_modules/vxe-table/es/table/src/column.js +1 -1
  312. package/lib/node_modules/vxe-table/es/table/src/columnInfo.js +0 -2
  313. package/lib/node_modules/vxe-table/es/table/src/emits.js +0 -1
  314. package/lib/node_modules/vxe-table/es/table/src/footer.js +2 -2
  315. package/lib/node_modules/vxe-table/es/table/src/group.js +1 -2
  316. package/lib/node_modules/vxe-table/es/table/src/props.js +0 -4
  317. package/lib/node_modules/vxe-table/es/table/src/table.js +494 -617
  318. package/lib/node_modules/vxe-table/es/table/src/util.js +22 -286
  319. package/lib/node_modules/vxe-table/es/toolbar/src/toolbar.js +6 -10
  320. package/lib/node_modules/vxe-table/es/ui/index.js +4 -12
  321. package/lib/node_modules/vxe-table/es/ui/src/dom.js +0 -23
  322. package/lib/node_modules/vxe-table/es/ui/src/log.js +1 -1
  323. package/lib/packages/mobile/src/components/dataDisplay/table/Table.vue.js +3 -4
  324. package/lib/packages/mobile/src/components/form/field/Field.vue.js +1 -1
  325. package/lib/packages/mobile/src/utils/formatterUtil.js +21 -21
  326. package/lib/packages/mobile/src/utils/optionUtil.js +5 -5
  327. package/lib/packages/vue/src/components/table/CustomButtons.vue.js +4 -5
  328. package/lib/packages/vue/src/components/table/DynamicQuery.vue.js +26 -27
  329. package/lib/packages/vue/src/components/table/Table.vue.js +8 -9
  330. package/lib/packages/vue/src/components/table/TableColumn.vue.js +16 -17
  331. package/package.json +1 -1
@@ -55,7 +55,246 @@ const VxeTableComponent = comp.defineVxeComponent({
55
55
  const $xeGGWrapper = $xeGrid || $xeGantt;
56
56
  const { computeSize } = useFns.useSize(props$1);
57
57
  const crossTableDragRowInfo = store.getCrossTableDragRowInfo();
58
- const reactData = vue.reactive(util.createReactData());
58
+ const reactData = vue.reactive({
59
+ // 低性能的静态列
60
+ staticColumns: [],
61
+ // 渲染的列分组
62
+ tableGroupColumn: [],
63
+ // 可视区渲染的列
64
+ tableColumn: [],
65
+ // 渲染中的数据
66
+ tableData: [],
67
+ // 是否启用了横向 X 可视渲染方式加载
68
+ scrollXLoad: false,
69
+ // 是否启用了纵向 Y 可视渲染方式加载
70
+ scrollYLoad: false,
71
+ // 是否存在纵向滚动条
72
+ overflowY: true,
73
+ // 是否存在横向滚动条
74
+ overflowX: false,
75
+ // 纵向滚动条的宽度
76
+ scrollbarWidth: 0,
77
+ // 横向滚动条的高度
78
+ scrollbarHeight: 0,
79
+ // 最后滚动时间戳
80
+ lastScrollTime: 0,
81
+ // 行高
82
+ rowHeight: 0,
83
+ // 表格父容器的高度
84
+ parentHeight: 0,
85
+ // 是否使用分组表头
86
+ isGroup: false,
87
+ isAllOverflow: false,
88
+ // 复选框属性,是否全选
89
+ isAllSelected: false,
90
+ // 复选框属性,有选中且非全选状态
91
+ isIndeterminate: false,
92
+ // 当前行
93
+ currentRow: null,
94
+ // 单选框属性,选中列
95
+ currentColumn: null,
96
+ // 单选框属性,选中行
97
+ selectRadioRow: null,
98
+ // 表尾合计数据
99
+ footerTableData: [],
100
+ // 行分组列信息
101
+ rowGroupColumn: null,
102
+ // 展开列信息
103
+ expandColumn: null,
104
+ checkboxColumn: null,
105
+ radioColumn: null,
106
+ // 树节点列信息
107
+ treeNodeColumn: null,
108
+ hasFixedColumn: false,
109
+ // 刷新列标识,当列筛选被改变时,触发表格刷新数据
110
+ upDataFlag: 0,
111
+ // 刷新列标识,当列的特定属性被改变时,触发表格刷新列
112
+ reColumnFlag: 0,
113
+ // 初始化标识
114
+ initStore: {
115
+ filter: false,
116
+ import: false,
117
+ export: false,
118
+ custom: false
119
+ },
120
+ // 自定义列相关的信息
121
+ customStore: {
122
+ btnEl: null,
123
+ isAll: false,
124
+ isIndeterminate: false,
125
+ activeBtn: false,
126
+ activeWrapper: false,
127
+ visible: false,
128
+ maxHeight: 0,
129
+ oldSortMaps: {},
130
+ oldFixedMaps: {},
131
+ oldVisibleMaps: {}
132
+ },
133
+ customColumnList: [],
134
+ // 当前选中的筛选列
135
+ filterStore: {
136
+ isAllSelected: false,
137
+ isIndeterminate: false,
138
+ style: null,
139
+ column: null,
140
+ visible: false,
141
+ maxHeight: null
142
+ },
143
+ // 存放列相关的信息
144
+ columnStore: {
145
+ leftList: [],
146
+ centerList: [],
147
+ rightList: [],
148
+ resizeList: [],
149
+ pxList: [],
150
+ pxMinList: [],
151
+ autoMinList: [],
152
+ scaleList: [],
153
+ scaleMinList: [],
154
+ autoList: [],
155
+ remainList: []
156
+ },
157
+ // 存放快捷菜单的信息
158
+ ctxMenuStore: {
159
+ selected: null,
160
+ visible: false,
161
+ showChild: false,
162
+ selectChild: null,
163
+ list: [],
164
+ style: null
165
+ },
166
+ // 存放可编辑相关信息
167
+ editStore: {
168
+ indexs: {
169
+ columns: []
170
+ },
171
+ titles: {
172
+ columns: []
173
+ },
174
+ // 选中源
175
+ selected: {
176
+ row: null,
177
+ column: null
178
+ },
179
+ // 已复制源
180
+ copyed: {
181
+ cut: false,
182
+ rows: [],
183
+ columns: []
184
+ },
185
+ // 激活
186
+ actived: {
187
+ row: null,
188
+ column: null
189
+ },
190
+ // 当前被强制聚焦单元格,只会在鼠标点击后算聚焦
191
+ focused: {
192
+ row: null,
193
+ column: null
194
+ }
195
+ },
196
+ // 存放 tooltip 相关信息
197
+ tooltipStore: {
198
+ row: null,
199
+ column: null,
200
+ content: null,
201
+ visible: false,
202
+ type: null,
203
+ currOpts: {}
204
+ },
205
+ // 存放数据校验相关信息
206
+ validStore: {
207
+ visible: false
208
+ },
209
+ validErrorMaps: {},
210
+ // 导入相关信息
211
+ importStore: {
212
+ inited: false,
213
+ file: null,
214
+ type: "",
215
+ modeList: [],
216
+ typeList: [],
217
+ filename: "",
218
+ visible: false
219
+ },
220
+ importParams: {
221
+ mode: "",
222
+ types: null,
223
+ message: true
224
+ },
225
+ // 导出相关信息
226
+ exportStore: {
227
+ inited: false,
228
+ name: "",
229
+ modeList: [],
230
+ typeList: [],
231
+ columns: [],
232
+ isPrint: false,
233
+ hasFooter: false,
234
+ hasMerge: false,
235
+ hasTree: false,
236
+ hasColgroup: false,
237
+ visible: false
238
+ },
239
+ exportParams: {
240
+ filename: "",
241
+ sheetName: "",
242
+ mode: "",
243
+ type: "",
244
+ isColgroup: false,
245
+ isMerge: false,
246
+ isAllExpand: false,
247
+ useStyle: false,
248
+ original: false,
249
+ message: true,
250
+ isHeader: false,
251
+ isTitle: false,
252
+ isFooter: false
253
+ },
254
+ visiblwRowsFlag: 1,
255
+ isRowGroupStatus: false,
256
+ rowGroupList: [],
257
+ aggHandleFields: [],
258
+ aggHandleAggColumns: [],
259
+ rowGroupExpandedFlag: 1,
260
+ rowExpandedFlag: 1,
261
+ treeExpandedFlag: 1,
262
+ updateCheckboxFlag: 1,
263
+ pendingRowFlag: 1,
264
+ insertRowFlag: 1,
265
+ removeRowFlag: 1,
266
+ mergeHeadFlag: 1,
267
+ mergeBodyFlag: 1,
268
+ mergeFootFlag: 1,
269
+ rowHeightStore: {
270
+ large: 52,
271
+ default: 48,
272
+ medium: 44,
273
+ small: 40,
274
+ mini: 36
275
+ },
276
+ scrollVMLoading: false,
277
+ scrollYHeight: 0,
278
+ scrollYTop: 0,
279
+ isScrollYBig: false,
280
+ scrollXLeft: 0,
281
+ scrollXWidth: 0,
282
+ isScrollXBig: false,
283
+ lazScrollLoading: false,
284
+ rowExpandHeightFlag: 1,
285
+ calcCellHeightFlag: 1,
286
+ resizeHeightFlag: 1,
287
+ resizeWidthFlag: 1,
288
+ isCustomStatus: false,
289
+ isCrossDragRow: false,
290
+ dragRow: null,
291
+ isCrossDragCol: false,
292
+ dragCol: null,
293
+ dragTipText: "",
294
+ isDragResize: false,
295
+ isRowLoading: false,
296
+ isColLoading: false
297
+ });
59
298
  const internalData = util.createInternalData();
60
299
  let tableMethods = {};
61
300
  let tablePrivateMethods = {};
@@ -117,11 +356,7 @@ const VxeTableComponent = comp.defineVxeComponent({
117
356
  return `${props$1.rowId || rowOpts.keyField || "_X_ROW_KEY"}`;
118
357
  });
119
358
  const computeValidOpts = vue.computed(() => {
120
- const opts = Object.assign({}, getConfig().table.validConfig, props$1.validConfig);
121
- if (index.default.isBoolean(opts.showMessage)) {
122
- opts.showErrorMessage = opts.showMessage;
123
- }
124
- return opts;
359
+ return Object.assign({}, getConfig().table.validConfig, props$1.validConfig);
125
360
  });
126
361
  const computeSXOpts = vue.computed(() => {
127
362
  const virtualXOpts = computeVirtualXOpts.value;
@@ -250,9 +485,6 @@ const VxeTableComponent = comp.defineVxeComponent({
250
485
  const computeRowGroupOpts = vue.computed(() => {
251
486
  return computeAggregateOpts.value;
252
487
  });
253
- const computeAggregateAccuracyOpts = vue.computed(() => {
254
- return Object.assign({}, getConfig().table.aggregateAccuracyConfig, props$1.aggregateAccuracyConfig);
255
- });
256
488
  const computeCurrentRowOpts = vue.computed(() => {
257
489
  return Object.assign({}, getConfig().table.currentRowConfig, props$1.currentRowConfig);
258
490
  });
@@ -298,9 +530,6 @@ const VxeTableComponent = comp.defineVxeComponent({
298
530
  const computeEditOpts = vue.computed(() => {
299
531
  return Object.assign({}, getConfig().table.editConfig, props$1.editConfig);
300
532
  });
301
- const computeEditDirtyOpts = vue.computed(() => {
302
- return Object.assign({}, getConfig().table.editDirtyConfig, props$1.editDirtyConfig);
303
- });
304
533
  const computeSortOpts = vue.computed(() => {
305
534
  return Object.assign({ orders: ["asc", "desc", null] }, getConfig().table.sortConfig, props$1.sortConfig);
306
535
  });
@@ -364,9 +593,7 @@ const VxeTableComponent = comp.defineVxeComponent({
364
593
  const lecIndex = leftList.length;
365
594
  for (let i = 0; i < mergeBodyList.length; i++) {
366
595
  const { col, colspan } = mergeBodyList[i];
367
- if (col < lecIndex && col + colspan > lecIndex) {
368
- return true;
369
- } else if (col < rscIndex && col + colspan > rscIndex) {
596
+ if (col < lecIndex || col + colspan > rscIndex) {
370
597
  return true;
371
598
  }
372
599
  }
@@ -477,38 +704,6 @@ const VxeTableComponent = comp.defineVxeComponent({
477
704
  const computeCustomOpts = vue.computed(() => {
478
705
  return Object.assign({}, getConfig().table.customConfig, props$1.customConfig);
479
706
  });
480
- const computeCustomSimpleMode = vue.computed(() => {
481
- const { minHeight, height } = props$1;
482
- const customOpts = computeCustomOpts.value;
483
- const { mode, popupOptions, placement } = customOpts;
484
- if (!placement || placement === "top-left" || placement === "top-right") {
485
- if (!(mode === "modal" || mode === "drawer")) {
486
- const { mode: mode2 } = popupOptions || {};
487
- if (!mode2 || mode2 === "auto") {
488
- if (height || minHeight) {
489
- return "inside";
490
- }
491
- return "outside";
492
- }
493
- if (mode2) {
494
- return mode2;
495
- }
496
- }
497
- }
498
- return "";
499
- });
500
- const computeTableStyle = vue.computed(() => {
501
- const scrollbarOpts = computeScrollbarOpts.value;
502
- const { width, height } = scrollbarOpts;
503
- const tStys = {};
504
- if (width) {
505
- tStys["--vxe-ui-table-view-scrollbar-width"] = dom.toCssUnit(width);
506
- }
507
- if (height) {
508
- tStys["--vxe-ui-table-view-scrollbar-height"] = dom.toCssUnit(height);
509
- }
510
- return tStys;
511
- });
512
707
  const computeTableRowExpandedList = vue.computed(() => {
513
708
  const { tableData, rowExpandedFlag, expandColumn, rowGroupExpandedFlag, treeExpandedFlag } = reactData;
514
709
  const { visibleDataRowIdData, rowExpandedMaps } = internalData;
@@ -549,32 +744,6 @@ const VxeTableComponent = comp.defineVxeComponent({
549
744
  }
550
745
  return false;
551
746
  });
552
- const computeKeepFields = vue.computed(() => {
553
- const { tableFullColumn } = internalData;
554
- const { updateColFlag } = reactData;
555
- const editDirtyOpts = computeEditDirtyOpts.value;
556
- const { includeFields, excludeFields } = editDirtyOpts;
557
- const kpFields = [];
558
- if (updateColFlag) {
559
- if (includeFields && includeFields.length) {
560
- return includeFields;
561
- }
562
- const exfMaps = {};
563
- if (excludeFields && excludeFields.length) {
564
- excludeFields.forEach((field) => {
565
- exfMaps[field] = 1;
566
- });
567
- }
568
- for (let i = 0; i < tableFullColumn.length; i++) {
569
- const column = tableFullColumn[i];
570
- const { field, type, editRender, cellRender } = column;
571
- if (field && !type && (editRender || cellRender) && !exfMaps[field]) {
572
- kpFields.push(field);
573
- }
574
- }
575
- }
576
- return kpFields;
577
- });
578
747
  const computeTableBorder = vue.computed(() => {
579
748
  const { border } = props$1;
580
749
  if (border === true) {
@@ -682,7 +851,6 @@ const VxeTableComponent = comp.defineVxeComponent({
682
851
  computeFooterCellOpts,
683
852
  computeRowOpts,
684
853
  computeAggregateOpts,
685
- computeAggregateAccuracyOpts,
686
854
  computeRowGroupOpts,
687
855
  computeCurrentRowOpts,
688
856
  computeRowDragOpts,
@@ -696,7 +864,6 @@ const VxeTableComponent = comp.defineVxeComponent({
696
864
  computeHeaderTooltipOpts,
697
865
  computeFooterTooltipOpts,
698
866
  computeEditOpts,
699
- computeEditDirtyOpts,
700
867
  computeSortOpts,
701
868
  computeFilterOpts,
702
869
  computeFloatingFilterOpts,
@@ -721,13 +888,11 @@ const VxeTableComponent = comp.defineVxeComponent({
721
888
  computeLoadingOpts,
722
889
  computeCellOffsetWidth,
723
890
  computeCustomOpts,
724
- computeCustomSimpleMode,
725
891
  computeLeftFixedWidth,
726
892
  computeRightFixedWidth,
727
893
  computeBodyMergeCoverFixed,
728
894
  computeFixedColumnSize,
729
895
  computeIsMaxFixedColumn,
730
- computeKeepFields,
731
896
  computeIsAllCheckboxDisabled,
732
897
  computeIsHeaderRenderOptimize,
733
898
  computeIsBodyRenderOptimize,
@@ -939,44 +1104,32 @@ const VxeTableComponent = comp.defineVxeComponent({
939
1104
  }
940
1105
  return { toVisibleIndex: 0, visibleSize: 6 };
941
1106
  };
942
- const calculateMergerOffsetIndex = (list, mergeMaps, offsetItem, type) => {
943
- const mKey = `${offsetItem.startIndex}:${offsetItem.endIndex}`;
944
- const mObj = mergeMaps[mKey];
945
- if (mObj) {
946
- offsetItem.startIndex = mObj.startIndex;
947
- offsetItem.endIndex = mObj.endIndex;
948
- } else {
949
- for (let mcIndex = 0, len = list.length; mcIndex < len; mcIndex++) {
950
- const mergeItem = list[mcIndex];
951
- const { startIndex, endIndex } = offsetItem;
952
- const mergeStartIndex = mergeItem[type];
953
- const mergeSpanNumber = mergeItem[type + "span"];
954
- const mergeEndIndex = mergeStartIndex + mergeSpanNumber;
955
- if (mergeStartIndex < startIndex && startIndex < mergeEndIndex) {
956
- offsetItem.startIndex = mergeStartIndex;
957
- }
958
- if (mergeStartIndex < endIndex && endIndex < mergeEndIndex) {
959
- offsetItem.endIndex = mergeEndIndex;
960
- }
961
- if (offsetItem.startIndex !== startIndex || offsetItem.endIndex !== endIndex) {
962
- mcIndex = -1;
963
- }
1107
+ const calculateMergerOffsetIndex = (list, offsetItem, type) => {
1108
+ for (let mcIndex = 0, len = list.length; mcIndex < len; mcIndex++) {
1109
+ const mergeItem = list[mcIndex];
1110
+ const { startIndex, endIndex } = offsetItem;
1111
+ const mergeStartIndex = mergeItem[type];
1112
+ const mergeSpanNumber = mergeItem[type + "span"];
1113
+ const mergeEndIndex = mergeStartIndex + mergeSpanNumber;
1114
+ if (mergeStartIndex < startIndex && startIndex < mergeEndIndex) {
1115
+ offsetItem.startIndex = mergeStartIndex;
1116
+ }
1117
+ if (mergeStartIndex < endIndex && endIndex < mergeEndIndex) {
1118
+ offsetItem.endIndex = mergeEndIndex;
1119
+ }
1120
+ if (offsetItem.startIndex !== startIndex || offsetItem.endIndex !== endIndex) {
1121
+ mcIndex = -1;
964
1122
  }
965
- mergeMaps[mKey] = offsetItem;
966
1123
  }
967
1124
  };
968
1125
  function buildMergeData(mergeConfigs) {
969
1126
  const mergeMaps = {};
970
- const mergeRowMaps = {};
971
- const mergeColMaps = {};
972
1127
  if (mergeConfigs && mergeConfigs.length) {
973
1128
  for (let mIndex = 0; mIndex < mergeConfigs.length; mIndex++) {
974
1129
  const { row: _rowIndex, col: _columnIndex, rowspan: mergeRowspan, colspan: mergeColspan } = mergeConfigs[mIndex];
975
1130
  for (let i = 0; i < mergeRowspan; i++) {
976
- const currRIndex = _rowIndex + i;
977
1131
  for (let j = 0; j < mergeColspan; j++) {
978
- const currCIndex = _columnIndex + j;
979
- mergeMaps[`${currRIndex}:${currCIndex}`] = !i && !j ? {
1132
+ mergeMaps[`${_rowIndex + i}:${_columnIndex + j}`] = !i && !j ? {
980
1133
  rowspan: mergeRowspan,
981
1134
  colspan: mergeColspan
982
1135
  } : {
@@ -987,14 +1140,12 @@ const VxeTableComponent = comp.defineVxeComponent({
987
1140
  }
988
1141
  }
989
1142
  }
990
- return { mergeMaps, mergeRowMaps, mergeColMaps };
1143
+ return mergeMaps;
991
1144
  }
992
1145
  const handleUpdateMergeBodyCells = (merges) => {
993
1146
  internalData.mergeBodyList = [];
994
1147
  internalData.mergeBodyMaps = {};
995
1148
  internalData.mergeBodyCellMaps = {};
996
- internalData.mergeBodyRowMaps = {};
997
- internalData.mergeBodyColMaps = {};
998
1149
  $xeTable.setMergeCells(merges);
999
1150
  };
1000
1151
  const handleBodyMerge = (merges) => {
@@ -1106,8 +1257,6 @@ const VxeTableComponent = comp.defineVxeComponent({
1106
1257
  internalData.mergeHeaderList = [];
1107
1258
  internalData.mergeHeaderMaps = {};
1108
1259
  internalData.mergeHeaderCellMaps = {};
1109
- internalData.mergeHeaderRowMaps = {};
1110
- internalData.mergeBodyColMaps = {};
1111
1260
  $xeTable.setMergeHeaderCells(merges);
1112
1261
  };
1113
1262
  const handleHeaderMerge = (merges) => {
@@ -1206,8 +1355,6 @@ const VxeTableComponent = comp.defineVxeComponent({
1206
1355
  internalData.mergeFooterList = [];
1207
1356
  internalData.mergeFooterMaps = {};
1208
1357
  internalData.mergeFooterCellMaps = {};
1209
- internalData.mergeFooterRowMaps = {};
1210
- internalData.mergeFooterColMaps = {};
1211
1358
  $xeTable.setMergeFooterCells(merges);
1212
1359
  };
1213
1360
  const handleFooterMerge = (merges) => {
@@ -1478,7 +1625,6 @@ const VxeTableComponent = comp.defineVxeComponent({
1478
1625
  const newCollectCols = index.default.toArrayTree(index.default.orderBy(allCols, "renderSortNumber"), { key: "id", parentKey: "parentId", children: "children" });
1479
1626
  internalData.collectColumn = newCollectCols;
1480
1627
  internalData.tableFullColumn = util.getColumnList(newCollectCols);
1481
- reactData.updateColFlag++;
1482
1628
  }
1483
1629
  reactData.isCustomStatus = true;
1484
1630
  } else {
@@ -1516,26 +1662,6 @@ const VxeTableComponent = comp.defineVxeComponent({
1516
1662
  }
1517
1663
  }
1518
1664
  };
1519
- const updateColumnAllOverflow = () => {
1520
- const { showOverflow } = props$1;
1521
- const { isGroup } = reactData;
1522
- const { fullAllDataRowIdData, tableFullColumn, collectColumn } = internalData;
1523
- let isAllOverflow = !!showOverflow;
1524
- const handleFunc = (column) => {
1525
- if (isAllOverflow && column.showOverflow === false) {
1526
- isAllOverflow = false;
1527
- }
1528
- };
1529
- if (isGroup) {
1530
- index.default.eachTree(collectColumn, handleFunc);
1531
- } else {
1532
- tableFullColumn.forEach(handleFunc);
1533
- }
1534
- index.default.each(fullAllDataRowIdData, (rowRest) => {
1535
- rowRest.height = 0;
1536
- });
1537
- reactData.isAllOverflow = isAllOverflow;
1538
- };
1539
1665
  const cacheColumnMap = () => {
1540
1666
  const { treeConfig, showOverflow } = props$1;
1541
1667
  const { tableFullColumn, collectColumn } = internalData;
@@ -1875,7 +2001,7 @@ const VxeTableComponent = comp.defineVxeComponent({
1875
2001
  if (sortBy) {
1876
2002
  cellValue = index.default.isFunction(sortBy) ? sortBy({ row, column }) : index.default.get(row, sortBy);
1877
2003
  } else {
1878
- cellValue = $xeTable.getCellLabel(row, column);
2004
+ cellValue = tableMethods.getCellLabel(row, column);
1879
2005
  }
1880
2006
  if (!sortType || sortType === "auto") {
1881
2007
  return isNaN(cellValue) ? cellValue : index.default.toNumber(cellValue);
@@ -1890,7 +2016,7 @@ const VxeTableComponent = comp.defineVxeComponent({
1890
2016
  if (sortBy) {
1891
2017
  cellValue = index.default.isFunction(sortBy) ? sortBy({ row, column }) : index.default.get(row, sortBy);
1892
2018
  } else {
1893
- cellValue = $xeTable.getCellLabel(row, column);
2019
+ cellValue = tableMethods.getCellLabel(row, column);
1894
2020
  }
1895
2021
  if (!sortType || sortType === "auto") {
1896
2022
  return isNaN(cellValue) ? cellValue : index.default.toNumber(cellValue);
@@ -2025,8 +2151,8 @@ const VxeTableComponent = comp.defineVxeComponent({
2025
2151
  const treeOpts = computeTreeOpts.value;
2026
2152
  const childrenField = treeOpts.children || treeOpts.childrenField;
2027
2153
  const { transform, rowField, parentField, mapChildrenField } = treeOpts;
2028
- const { isEvery, remote: allRemoteFilter, filterMethod: allFilterMethod, isDeep: isFilterDeep } = filterOpts;
2029
- const { remote: allRemoteSort, sortMethod: allSortMethod, multiple: sortMultiple, chronological, isDeep: isSortDeep } = sortOpts;
2154
+ const { isEvery, remote: allRemoteFilter, filterMethod: allFilterMethod } = filterOpts;
2155
+ const { remote: allRemoteSort, sortMethod: allSortMethod, multiple: sortMultiple, chronological } = sortOpts;
2030
2156
  let tableData = [];
2031
2157
  let tableTree = [];
2032
2158
  if (!allRemoteFilter || !allRemoteSort) {
@@ -2082,7 +2208,7 @@ const VxeTableComponent = comp.defineVxeComponent({
2082
2208
  mapChildren: aggregateOpts.childrenField
2083
2209
  });
2084
2210
  tableData = tableTree;
2085
- } else if (treeConfig && transform && isFilterDeep !== false) {
2211
+ } else if (treeConfig && transform) {
2086
2212
  tableTree = index.default.searchTree(tableFullTreeData, handleFilter, {
2087
2213
  original: true,
2088
2214
  isEvery,
@@ -2103,7 +2229,7 @@ const VxeTableComponent = comp.defineVxeComponent({
2103
2229
  mapChildren: aggregateOpts.childrenField
2104
2230
  });
2105
2231
  tableData = tableTree;
2106
- } else if (treeConfig && transform && isFilterDeep !== false) {
2232
+ } else if (treeConfig && transform) {
2107
2233
  tableTree = index.default.searchTree(tableFullTreeData, () => true, {
2108
2234
  original: true,
2109
2235
  isEvery,
@@ -2135,7 +2261,7 @@ const VxeTableComponent = comp.defineVxeComponent({
2135
2261
  });
2136
2262
  }
2137
2263
  tableData = tableTree;
2138
- } else if (treeConfig && transform && isSortDeep !== false) {
2264
+ } else if (treeConfig && transform) {
2139
2265
  if (allSortMethod) {
2140
2266
  const sortRests = allSortMethod({ data: tableTree, sortList: orderColumns, $table: $xeTable });
2141
2267
  tableTree = index.default.isArray(sortRests) ? sortRests : tableTree;
@@ -2170,7 +2296,7 @@ const VxeTableComponent = comp.defineVxeComponent({
2170
2296
  mapChildren: aggregateOpts.childrenField
2171
2297
  });
2172
2298
  tableData = tableTree;
2173
- } else if (treeConfig && transform && isSortDeep !== false) {
2299
+ } else if (treeConfig && transform) {
2174
2300
  tableTree = index.default.searchTree(tableFullTreeData, () => true, {
2175
2301
  original: true,
2176
2302
  isEvery,
@@ -3165,7 +3291,6 @@ const VxeTableComponent = comp.defineVxeComponent({
3165
3291
  if (rowGroups) {
3166
3292
  const aggregateOpts = computeAggregateOpts.value;
3167
3293
  const { rowField, parentField, childrenField, mapChildrenField } = aggregateOpts;
3168
- const rowOpts = computeRowOpts.value;
3169
3294
  const checkboxOpts = computeCheckboxOpts.value;
3170
3295
  const { checkField } = checkboxOpts;
3171
3296
  const indeterminateField = checkboxOpts.indeterminateField || checkboxOpts.halfField;
@@ -3201,10 +3326,10 @@ const VxeTableComponent = comp.defineVxeComponent({
3201
3326
  childCount: 0,
3202
3327
  [rowField]: util.getRowUniqueId(),
3203
3328
  [parentField]: null,
3329
+ [rowkey]: util.getRowUniqueId(),
3204
3330
  [childrenField]: childTreeData,
3205
3331
  [mapChildrenField]: childTreeData
3206
3332
  };
3207
- aggRow[rowkey] = util.createRowId(rowOpts, aggRow, rowkey);
3208
3333
  if (checkField) {
3209
3334
  aggRow[checkField] = false;
3210
3335
  }
@@ -3350,7 +3475,7 @@ const VxeTableComponent = comp.defineVxeComponent({
3350
3475
  if (reactData.expandColumn && expandOpts.mode !== "fixed") {
3351
3476
  log.errLog("vxe.error.notConflictProp", ['column.type="expand', 'expand-config.mode="fixed"']);
3352
3477
  }
3353
- if (virtualYOpts.mode === "scroll" && reactData.expandColumn && expandOpts.mode === "fixed") {
3478
+ if (virtualYOpts.mode === "scroll" && expandOpts.mode === "fixed") {
3354
3479
  log.warnLog("vxe.error.notConflictProp", ["virtual-y-config.mode=scroll", "expand-config.mode=inside"]);
3355
3480
  }
3356
3481
  if (!(props$1.height || props$1.maxHeight)) {
@@ -3453,14 +3578,13 @@ const VxeTableComponent = comp.defineVxeComponent({
3453
3578
  const handleUpdateColumn = () => {
3454
3579
  const columnList = index.default.orderBy(internalData.collectColumn, "renderSortNumber");
3455
3580
  internalData.collectColumn = columnList;
3456
- const tFullColumn = util.getColumnList(columnList);
3457
- internalData.tableFullColumn = tFullColumn;
3458
- reactData.updateColFlag++;
3581
+ const tableFullColumn = util.getColumnList(columnList);
3582
+ internalData.tableFullColumn = tableFullColumn;
3459
3583
  cacheColumnMap();
3460
3584
  };
3461
3585
  const loadScrollXData = () => {
3462
3586
  const { isScrollXBig } = reactData;
3463
- const { mergeBodyList, mergeFooterList, mergeBodyRowMaps, scrollXStore } = internalData;
3587
+ const { mergeBodyList, mergeFooterList, scrollXStore } = internalData;
3464
3588
  const { preloadSize, startIndex, endIndex, offsetSize } = scrollXStore;
3465
3589
  const { toVisibleIndex, visibleSize } = handleVirtualXVisible();
3466
3590
  const offsetItem = {
@@ -3469,7 +3593,7 @@ const VxeTableComponent = comp.defineVxeComponent({
3469
3593
  };
3470
3594
  scrollXStore.visibleStartIndex = toVisibleIndex - 1;
3471
3595
  scrollXStore.visibleEndIndex = toVisibleIndex + visibleSize + 1;
3472
- calculateMergerOffsetIndex(mergeBodyList.concat(mergeFooterList), mergeBodyRowMaps, offsetItem, "col");
3596
+ calculateMergerOffsetIndex(mergeBodyList.concat(mergeFooterList), offsetItem, "col");
3473
3597
  const { startIndex: offsetStartIndex, endIndex: offsetEndIndex } = offsetItem;
3474
3598
  if (toVisibleIndex <= startIndex || toVisibleIndex >= endIndex - visibleSize - 1) {
3475
3599
  if (startIndex !== offsetStartIndex || endIndex !== offsetEndIndex) {
@@ -3609,9 +3733,8 @@ const VxeTableComponent = comp.defineVxeComponent({
3609
3733
  const handleInitColumn = (collectColumn) => {
3610
3734
  const expandOpts = computeExpandOpts.value;
3611
3735
  internalData.collectColumn = collectColumn;
3612
- const tFullColumn = util.getColumnList(collectColumn);
3613
- internalData.tableFullColumn = tFullColumn;
3614
- reactData.updateColFlag++;
3736
+ const tableFullColumn = util.getColumnList(collectColumn);
3737
+ internalData.tableFullColumn = tableFullColumn;
3615
3738
  reactData.isColLoading = true;
3616
3739
  initColumnHierarchy();
3617
3740
  return Promise.resolve(restoreCustomStorage()).then(() => {
@@ -3828,7 +3951,7 @@ const VxeTableComponent = comp.defineVxeComponent({
3828
3951
  };
3829
3952
  const loadScrollYData = () => {
3830
3953
  const { isAllOverflow, isScrollYBig } = reactData;
3831
- const { mergeBodyList, mergeBodyColMaps, scrollYStore } = internalData;
3954
+ const { mergeBodyList, scrollYStore } = internalData;
3832
3955
  const { preloadSize, startIndex, endIndex, offsetSize } = scrollYStore;
3833
3956
  const autoOffsetYSize = isAllOverflow ? offsetSize : offsetSize + 1;
3834
3957
  const { toVisibleIndex, visibleSize } = handleVirtualYVisible();
@@ -3838,7 +3961,7 @@ const VxeTableComponent = comp.defineVxeComponent({
3838
3961
  };
3839
3962
  scrollYStore.visibleStartIndex = toVisibleIndex - 1;
3840
3963
  scrollYStore.visibleEndIndex = toVisibleIndex + visibleSize + 1;
3841
- calculateMergerOffsetIndex(mergeBodyList, mergeBodyColMaps, offsetItem, "row");
3964
+ calculateMergerOffsetIndex(mergeBodyList, offsetItem, "row");
3842
3965
  const { startIndex: offsetStartIndex, endIndex: offsetEndIndex } = offsetItem;
3843
3966
  if (toVisibleIndex <= startIndex || toVisibleIndex >= endIndex - visibleSize - 1) {
3844
3967
  if (startIndex !== offsetStartIndex || endIndex !== offsetEndIndex) {
@@ -3941,7 +4064,7 @@ const VxeTableComponent = comp.defineVxeComponent({
3941
4064
  return Promise.all([
3942
4065
  xRest,
3943
4066
  yRest,
3944
- scrollXLoad || scrollYLoad ? $xeTable.updateCellAreas() : null
4067
+ $xeTable.updateCellAreas()
3945
4068
  ]);
3946
4069
  };
3947
4070
  const checkLastSyncScroll = (isRollX, isRollY) => {
@@ -3981,6 +4104,32 @@ const VxeTableComponent = comp.defineVxeComponent({
3981
4104
  }
3982
4105
  return multiple;
3983
4106
  };
4107
+ const wheelScrollLeftTo = (scrollLeft, cb) => {
4108
+ requestAnimationFrame(() => {
4109
+ cb(scrollLeft);
4110
+ });
4111
+ };
4112
+ const wheelScrollTopTo = (diffNum, cb) => {
4113
+ const duration = Math.abs(diffNum);
4114
+ const startTime = performance.now();
4115
+ let countTop = 0;
4116
+ const step = (timestamp) => {
4117
+ let progress = (timestamp - startTime) / duration;
4118
+ if (progress < 0) {
4119
+ progress = 0;
4120
+ } else if (progress > 1) {
4121
+ progress = 1;
4122
+ }
4123
+ const easedProgress = Math.pow(progress, 2);
4124
+ const offsetTop = Math.floor(diffNum * easedProgress) - countTop;
4125
+ countTop += offsetTop;
4126
+ cb(offsetTop);
4127
+ if (progress < 1) {
4128
+ requestAnimationFrame(step);
4129
+ }
4130
+ };
4131
+ requestAnimationFrame(step);
4132
+ };
3984
4133
  const syncGanttScrollTop = (scrollTop) => {
3985
4134
  const $xeGanttView = internalData.xeGanttView;
3986
4135
  if ($xeGanttView) {
@@ -3995,11 +4144,11 @@ const VxeTableComponent = comp.defineVxeComponent({
3995
4144
  const dispatchEvent = (type, params, evnt) => {
3996
4145
  emit(type, createEvent(evnt, { $table: $xeTable, $grid: $xeGrid, $gantt: $xeGantt }, params));
3997
4146
  };
3998
- const handleScrollToRowColumn = (fieldOrColumn, row, options) => {
4147
+ const handleScrollToRowColumn = (fieldOrColumn, row) => {
3999
4148
  const { fullColumnIdData } = internalData;
4000
4149
  const column = util.handleFieldOrColumn($xeTable, fieldOrColumn);
4001
4150
  if (column && fullColumnIdData[column.id]) {
4002
- return util.colToVisible($xeTable, options ? options.colAlign !== false : true, column, row);
4151
+ return util.colToVisible($xeTable, column, row);
4003
4152
  }
4004
4153
  return vue.nextTick();
4005
4154
  };
@@ -4086,7 +4235,7 @@ const VxeTableComponent = comp.defineVxeComponent({
4086
4235
  const rowid = expandEl.getAttribute("rowid") || "";
4087
4236
  const rowRest = fullAllDataRowIdData[rowid];
4088
4237
  if (rowRest) {
4089
- const expandHeight = expandEl.offsetHeight;
4238
+ const expandHeight = expandEl.offsetHeight + 1;
4090
4239
  const trEl = bodyScrollElem.querySelector(`.vxe-body--row[rowid="${rowid}"]`);
4091
4240
  let offsetTop = 0;
4092
4241
  if (scrollYLoad) {
@@ -4383,7 +4532,7 @@ const VxeTableComponent = comp.defineVxeComponent({
4383
4532
  const childrenField = treeOpts.children || treeOpts.childrenField;
4384
4533
  const parentRest = fullAllDataRowIdData[util.getRowid($xeTable, row)];
4385
4534
  const parentLevel = parentRest ? parentRest.level : 0;
4386
- return $xeTable.createData(childRecords).then((rows) => {
4535
+ return tableMethods.createData(childRecords).then((rows) => {
4387
4536
  if (keepSource) {
4388
4537
  const rowid = util.getRowid($xeTable, row);
4389
4538
  const matchObj = index.default.findTree(tableSourceData, (item) => rowid === util.getRowid($xeTable, item), { children: childrenField });
@@ -4438,8 +4587,8 @@ const VxeTableComponent = comp.defineVxeComponent({
4438
4587
  * @param {ColumnInfo} columns 列配置
4439
4588
  */
4440
4589
  reloadColumn(columns) {
4441
- return $xeTable.clearAll().then(() => {
4442
- return $xeTable.loadColumn(columns);
4590
+ return tableMethods.clearAll().then(() => {
4591
+ return tableMethods.loadColumn(columns);
4443
4592
  });
4444
4593
  },
4445
4594
  /**
@@ -4530,7 +4679,7 @@ const VxeTableComponent = comp.defineVxeComponent({
4530
4679
  */
4531
4680
  createData(records) {
4532
4681
  return vue.nextTick().then(() => {
4533
- return vue.reactive($xeTable.defineField(records));
4682
+ return vue.reactive(tablePrivateMethods.defineField(records));
4534
4683
  });
4535
4684
  },
4536
4685
  /**
@@ -4543,7 +4692,7 @@ const VxeTableComponent = comp.defineVxeComponent({
4543
4692
  if (!isArr) {
4544
4693
  records = [records || {}];
4545
4694
  }
4546
- return $xeTable.createData(records).then((rows) => isArr ? rows : rows[0]);
4695
+ return tableMethods.createData(records).then((rows) => isArr ? rows : rows[0]);
4547
4696
  },
4548
4697
  /**
4549
4698
  * 还原数据
@@ -4727,7 +4876,7 @@ const VxeTableComponent = comp.defineVxeComponent({
4727
4876
  const tcFormatMethod = gFormatOpts ? gFormatOpts.tableCellFormatMethod || gFormatOpts.cellFormatMethod : null;
4728
4877
  cellLabel = tcFormatMethod ? tcFormatMethod(formatParams, ...formatter.slice(1)) : "";
4729
4878
  } else {
4730
- cellLabel = formatter(formatParams);
4879
+ cellLabel = `${formatter(formatParams)}`;
4731
4880
  }
4732
4881
  } else if (renderOpts && tcFormatter) {
4733
4882
  cellLabel = tcFormatter(renderOpts, formatParams);
@@ -4738,43 +4887,6 @@ const VxeTableComponent = comp.defineVxeComponent({
4738
4887
  }
4739
4888
  return cellLabel;
4740
4889
  },
4741
- updateCellLabel(row, fieldOrColumn) {
4742
- const column = util.handleFieldOrColumn($xeTable, fieldOrColumn);
4743
- if (!column) {
4744
- return null;
4745
- }
4746
- const { fullAllDataRowIdData } = internalData;
4747
- const rowid = util.getRowid($xeTable, row);
4748
- if (rowid) {
4749
- const colid = column.id;
4750
- const rowid2 = util.getRowid($xeTable, row);
4751
- const rowRest = fullAllDataRowIdData[rowid2];
4752
- if (rowRest) {
4753
- const formatData = rowRest.formatData;
4754
- if (formatData) {
4755
- delete formatData[colid];
4756
- }
4757
- }
4758
- }
4759
- return $xeTable.getFooterCellLabel(row, column);
4760
- },
4761
- clearFormatterCache(isUpdate) {
4762
- const { tableData, tableColumn } = reactData;
4763
- const { fullAllDataRowIdData } = internalData;
4764
- index.default.each(fullAllDataRowIdData, (rowRest) => {
4765
- if (rowRest.formatData) {
4766
- rowRest.formatData = void 0;
4767
- }
4768
- });
4769
- if (isUpdate) {
4770
- tableData.forEach((row) => {
4771
- tableColumn.forEach((column) => {
4772
- $xeTable.getCellLabel(row, column);
4773
- });
4774
- });
4775
- }
4776
- return vue.nextTick();
4777
- },
4778
4890
  getFooterCellLabel(row, fieldOrColumn) {
4779
4891
  const column = util.handleFieldOrColumn($xeTable, fieldOrColumn);
4780
4892
  if (!column) {
@@ -4839,41 +4951,6 @@ const VxeTableComponent = comp.defineVxeComponent({
4839
4951
  }
4840
4952
  return cellLabel;
4841
4953
  },
4842
- updateFooterCellLabel(row, fieldOrColumn) {
4843
- const column = util.handleFieldOrColumn($xeTable, fieldOrColumn);
4844
- if (!column) {
4845
- return null;
4846
- }
4847
- const { footerTableData } = reactData;
4848
- const { footerFullDataRowData } = internalData;
4849
- const colid = column.id;
4850
- const $rowIndex = footerTableData.indexOf(row);
4851
- const rowRest = footerFullDataRowData[$rowIndex];
4852
- if (rowRest) {
4853
- const formatData = rowRest.formatData;
4854
- if (formatData) {
4855
- delete formatData[colid];
4856
- }
4857
- }
4858
- return $xeTable.getFooterCellLabel(row, column);
4859
- },
4860
- clearFooterFormatterCache(isUpdate) {
4861
- const { tableData, tableColumn } = reactData;
4862
- const { footerFullDataRowData } = internalData;
4863
- index.default.each(footerFullDataRowData, (rowRest) => {
4864
- if (rowRest.formatData) {
4865
- rowRest.formatData = void 0;
4866
- }
4867
- });
4868
- if (isUpdate) {
4869
- tableData.forEach((row) => {
4870
- tableColumn.forEach((column) => {
4871
- $xeTable.getFooterCellLabel(row, column);
4872
- });
4873
- });
4874
- }
4875
- return vue.nextTick();
4876
- },
4877
4954
  /**
4878
4955
  * 检查是否为临时行数据
4879
4956
  */
@@ -4897,8 +4974,7 @@ const VxeTableComponent = comp.defineVxeComponent({
4897
4974
  */
4898
4975
  isUpdateByRow(rowidOrRow, field) {
4899
4976
  const { keepSource } = props$1;
4900
- const { fullDataRowIdData, sourceDataRowIdData } = internalData;
4901
- const keepFields = computeKeepFields.value;
4977
+ const { tableFullColumn, fullDataRowIdData, sourceDataRowIdData } = internalData;
4902
4978
  if (keepSource) {
4903
4979
  const rowid = index.default.isString(rowidOrRow) || index.default.isNumber(rowidOrRow) ? rowidOrRow : util.getRowid($xeTable, rowidOrRow);
4904
4980
  const rowRest = fullDataRowIdData[rowid];
@@ -4911,8 +4987,9 @@ const VxeTableComponent = comp.defineVxeComponent({
4911
4987
  if (arguments.length > 1) {
4912
4988
  return !eqCellValue(oRow, row, field);
4913
4989
  }
4914
- for (let i = 0; i < keepFields.length; i++) {
4915
- if (!eqCellValue(oRow, row, keepFields[i])) {
4990
+ for (let index2 = 0, len = tableFullColumn.length; index2 < len; index2++) {
4991
+ const property = tableFullColumn[index2].field;
4992
+ if (property && !eqCellValue(oRow, row, property)) {
4916
4993
  return true;
4917
4994
  }
4918
4995
  }
@@ -5244,14 +5321,14 @@ const VxeTableComponent = comp.defineVxeComponent({
5244
5321
  column2.fixed = fixed;
5245
5322
  column2.renderFixed = fixed;
5246
5323
  });
5247
- $xeTable.saveCustomStore("update:fixed");
5324
+ tablePrivateMethods.saveCustomStore("update:fixed");
5248
5325
  if (!status) {
5249
5326
  status = true;
5250
5327
  }
5251
5328
  }
5252
5329
  }
5253
5330
  if (status) {
5254
- return $xeTable.refreshColumn();
5331
+ return tableMethods.refreshColumn();
5255
5332
  }
5256
5333
  return vue.nextTick();
5257
5334
  },
@@ -5269,14 +5346,14 @@ const VxeTableComponent = comp.defineVxeComponent({
5269
5346
  column2.fixed = null;
5270
5347
  column2.renderFixed = null;
5271
5348
  });
5272
- $xeTable.saveCustomStore("update:fixed");
5349
+ tablePrivateMethods.saveCustomStore("update:fixed");
5273
5350
  if (!status) {
5274
5351
  status = true;
5275
5352
  }
5276
5353
  }
5277
5354
  });
5278
5355
  if (status) {
5279
- return $xeTable.refreshColumn();
5356
+ return tableMethods.refreshColumn();
5280
5357
  }
5281
5358
  return vue.nextTick();
5282
5359
  },
@@ -5632,8 +5709,8 @@ const VxeTableComponent = comp.defineVxeComponent({
5632
5709
  const checkboxOpts = computeCheckboxOpts.value;
5633
5710
  const { checkField } = checkboxOpts;
5634
5711
  const checked = checkField ? !index.default.get(row, checkField) : !selectCheckboxMaps[util.getRowid($xeTable, row)];
5635
- $xeTable.handleBatchSelectRows([row], checked, true);
5636
- $xeTable.checkSelectionStatus();
5712
+ tablePrivateMethods.handleBatchSelectRows([row], checked, true);
5713
+ tablePrivateMethods.checkSelectionStatus();
5637
5714
  return vue.nextTick();
5638
5715
  },
5639
5716
  /**
@@ -5770,7 +5847,7 @@ const VxeTableComponent = comp.defineVxeComponent({
5770
5847
  const $xeGanttView = internalData.xeGanttView;
5771
5848
  const rowOpts = computeRowOpts.value;
5772
5849
  const el = refElem.value;
5773
- $xeTable.clearCurrentRow();
5850
+ tableMethods.clearCurrentRow();
5774
5851
  reactData.currentRow = row;
5775
5852
  if (rowOpts.isCurrent || props$1.highlightCurrentRow) {
5776
5853
  if (el) {
@@ -5952,7 +6029,7 @@ const VxeTableComponent = comp.defineVxeComponent({
5952
6029
  return vue.nextTick();
5953
6030
  },
5954
6031
  hasPendingByRow(row) {
5955
- return $xeTable.isPendingByRow(row);
6032
+ return tableMethods.isPendingByRow(row);
5956
6033
  },
5957
6034
  isPendingByRow(row) {
5958
6035
  const { pendingRowMaps } = internalData;
@@ -5995,7 +6072,7 @@ const VxeTableComponent = comp.defineVxeComponent({
5995
6072
  let { field, order } = confs;
5996
6073
  let column = field;
5997
6074
  if (index.default.isString(field)) {
5998
- column = $xeTable.getColumnByField(field);
6075
+ column = tableMethods.getColumnByField(field);
5999
6076
  }
6000
6077
  if (column && column.sortable) {
6001
6078
  if (orders && orders.indexOf(order) === -1) {
@@ -6008,11 +6085,11 @@ const VxeTableComponent = comp.defineVxeComponent({
6008
6085
  }
6009
6086
  });
6010
6087
  if (!remote) {
6011
- $xeTable.handleTableData(true);
6088
+ tablePrivateMethods.handleTableData(true);
6012
6089
  }
6013
6090
  return vue.nextTick().then(() => {
6014
6091
  updateRowOffsetTop();
6015
- $xeTable.updateCellAreas();
6092
+ tableMethods.updateCellAreas();
6016
6093
  return updateStyle();
6017
6094
  });
6018
6095
  }
@@ -6091,7 +6168,7 @@ const VxeTableComponent = comp.defineVxeComponent({
6091
6168
  const column = util.handleFieldOrColumn($xeTable, fieldOrColumn);
6092
6169
  return column ? column.sortable && !!column.order : false;
6093
6170
  }
6094
- return $xeTable.getSortColumns().length > 0;
6171
+ return tableMethods.getSortColumns().length > 0;
6095
6172
  },
6096
6173
  getSortColumns() {
6097
6174
  const sortOpts = computeSortOpts.value;
@@ -6151,7 +6228,7 @@ const VxeTableComponent = comp.defineVxeComponent({
6151
6228
  return $xeTable.getCheckedFilters().length > 0;
6152
6229
  },
6153
6230
  isFilter(fieldOrColumn) {
6154
- return $xeTable.isActiveFilterByColumn(fieldOrColumn);
6231
+ return tableMethods.isActiveFilterByColumn(fieldOrColumn);
6155
6232
  },
6156
6233
  clearFilterByEvent(evnt, fieldOrColumn) {
6157
6234
  const { filterStore } = reactData;
@@ -6282,7 +6359,7 @@ const VxeTableComponent = comp.defineVxeComponent({
6282
6359
  } else {
6283
6360
  expandedRows = tableFullData;
6284
6361
  }
6285
- return $xeTable.setRowExpand(expandedRows, expanded);
6362
+ return tableMethods.setRowExpand(expandedRows, expanded);
6286
6363
  },
6287
6364
  /**
6288
6365
  * 设置展开行,二个参数设置这一行展开与否
@@ -6355,7 +6432,7 @@ const VxeTableComponent = comp.defineVxeComponent({
6355
6432
  },
6356
6433
  isExpandByRow(row) {
6357
6434
  log.warnLog("vxe.error.delFunc", ["isExpandByRow", "isRowExpandByRow"]);
6358
- return $xeTable.isRowExpandByRow(row);
6435
+ return tableMethods.isRowExpandByRow(row);
6359
6436
  },
6360
6437
  /**
6361
6438
  * 手动清空展开行状态,数据会恢复成未展开的状态
@@ -6777,45 +6854,37 @@ const VxeTableComponent = comp.defineVxeComponent({
6777
6854
  dom.setScrollLeft(bodyScrollElem, scrollLeft);
6778
6855
  dom.setScrollLeft(headerScrollElem, scrollLeft);
6779
6856
  dom.setScrollLeft(footerScrollElem, scrollLeft);
6780
- if (reactData.scrollXLoad) {
6781
- loadScrollXData();
6782
- }
6857
+ loadScrollXData();
6783
6858
  }
6784
6859
  if (index.default.isNumber(scrollTop)) {
6785
6860
  dom.setScrollTop(yHandleEl, scrollTop);
6786
6861
  dom.setScrollTop(bodyScrollElem, scrollTop);
6787
6862
  dom.setScrollTop(leftScrollElem, scrollTop);
6788
6863
  dom.setScrollTop(rightScrollElem, scrollTop);
6789
- if (reactData.scrollYLoad) {
6790
- loadScrollYData();
6791
- }
6864
+ loadScrollYData();
6792
6865
  }
6793
- return new Promise((resolve) => {
6794
- setTimeout(() => {
6795
- vue.nextTick(() => {
6796
- internalData.intoRunScroll = false;
6797
- resolve();
6798
- });
6799
- }, reactData.scrollXLoad || reactData.scrollYLoad ? 30 : 0);
6866
+ if (reactData.scrollXLoad || reactData.scrollYLoad) {
6867
+ return new Promise((resolve) => {
6868
+ setTimeout(() => {
6869
+ vue.nextTick(() => {
6870
+ internalData.intoRunScroll = false;
6871
+ resolve();
6872
+ });
6873
+ }, 30);
6874
+ });
6875
+ }
6876
+ return vue.nextTick().then(() => {
6877
+ internalData.intoRunScroll = false;
6800
6878
  });
6801
6879
  },
6802
6880
  /**
6803
6881
  * 如果有滚动条,则滚动到对应的行
6882
+ * @param {Row} row 行对象
6883
+ * @param {ColumnInfo} fieldOrColumn 列配置
6804
6884
  */
6805
- scrollToRow(rowOrRowid, fieldOrColumn, options) {
6885
+ scrollToRow(row, fieldOrColumn) {
6806
6886
  const { isAllOverflow, scrollYLoad, scrollXLoad } = reactData;
6807
- const { fullAllDataRowIdData, _sToTime } = internalData;
6808
6887
  const rest = [];
6809
- let row;
6810
- if (index.default.isString(rowOrRowid) || index.default.isNumber(rowOrRowid)) {
6811
- const rowid = rowOrRowid;
6812
- const rowRest = rowid ? fullAllDataRowIdData[rowid] : null;
6813
- if (rowRest) {
6814
- row = rowRest.row;
6815
- }
6816
- } else {
6817
- row = rowOrRowid;
6818
- }
6819
6888
  if (row) {
6820
6889
  if (props$1.treeConfig) {
6821
6890
  rest.push($xeTable.scrollToTreeRow(row));
@@ -6824,29 +6893,13 @@ const VxeTableComponent = comp.defineVxeComponent({
6824
6893
  }
6825
6894
  }
6826
6895
  if (fieldOrColumn) {
6827
- rest.push(handleScrollToRowColumn(fieldOrColumn, row, options));
6828
- }
6829
- if (_sToTime) {
6830
- clearTimeout(_sToTime);
6896
+ rest.push(handleScrollToRowColumn(fieldOrColumn, row));
6831
6897
  }
6832
6898
  return Promise.all(rest).then(() => {
6833
6899
  if (row) {
6834
6900
  if (!isAllOverflow && (scrollYLoad || scrollXLoad)) {
6835
6901
  calcCellHeight();
6836
6902
  calcCellWidth();
6837
- internalData._sToTime = setTimeout(() => {
6838
- internalData._sToTime = void 0;
6839
- if (scrollYLoad) {
6840
- if (props$1.treeConfig) {
6841
- $xeTable.scrollToTreeRow(row);
6842
- } else {
6843
- util.rowToVisible($xeTable, row);
6844
- }
6845
- }
6846
- if (scrollXLoad && fieldOrColumn) {
6847
- handleScrollToRowColumn(fieldOrColumn, row, options);
6848
- }
6849
- }, 350);
6850
6903
  }
6851
6904
  return vue.nextTick();
6852
6905
  }
@@ -6855,36 +6908,41 @@ const VxeTableComponent = comp.defineVxeComponent({
6855
6908
  /**
6856
6909
  * 如果有滚动条,则滚动到第一行
6857
6910
  */
6858
- scrollToStartRow(fieldOrColumn, options) {
6911
+ scrollToStartRow(fieldOrColumn) {
6859
6912
  const { afterFullData } = internalData;
6860
- return $xeTable.scrollToRow(afterFullData[0], fieldOrColumn, options);
6913
+ return $xeTable.scrollToRow(afterFullData[0], fieldOrColumn);
6861
6914
  },
6862
6915
  /**
6863
6916
  * 如果有滚动条,则滚动到最后一行
6864
6917
  */
6865
- scrollToEndRow(fieldOrColumn, options) {
6918
+ scrollToEndRow(fieldOrColumn) {
6866
6919
  const { afterFullData } = internalData;
6867
- return $xeTable.scrollToRow(afterFullData[afterFullData.length - 1], fieldOrColumn, options);
6920
+ return $xeTable.scrollToRow(afterFullData[afterFullData.length - 1], fieldOrColumn);
6868
6921
  },
6869
6922
  /**
6870
6923
  * 如果有滚动条,则滚动到对应的列
6871
6924
  */
6872
- scrollToColumn(fieldOrColumn, options) {
6873
- return handleScrollToRowColumn(fieldOrColumn, null, options);
6925
+ scrollToColumn(fieldOrColumn) {
6926
+ const { fullColumnIdData } = internalData;
6927
+ const column = util.handleFieldOrColumn($xeTable, fieldOrColumn);
6928
+ if (column && fullColumnIdData[column.id]) {
6929
+ return util.colToVisible($xeTable, column);
6930
+ }
6931
+ return vue.nextTick();
6874
6932
  },
6875
6933
  /**
6876
6934
  * 如果有滚动条,则滚动到第一列
6877
6935
  */
6878
- scrollToStartColumn(options) {
6936
+ scrollToStartColumn() {
6879
6937
  const { visibleColumn } = internalData;
6880
- return $xeTable.scrollToColumn(visibleColumn[0], options);
6938
+ return $xeTable.scrollToColumn(visibleColumn[0]);
6881
6939
  },
6882
6940
  /**
6883
6941
  * 如果有滚动条,则滚动到最后一列
6884
6942
  */
6885
- scrollToEndColumn(options) {
6943
+ scrollToEndColumn() {
6886
6944
  const { visibleColumn } = internalData;
6887
- return $xeTable.scrollToColumn(visibleColumn[visibleColumn.length - 1], options);
6945
+ return $xeTable.scrollToColumn(visibleColumn[visibleColumn.length - 1]);
6888
6946
  },
6889
6947
  /**
6890
6948
  * 手动清除滚动相关信息,还原到初始状态
@@ -6949,8 +7007,7 @@ const VxeTableComponent = comp.defineVxeComponent({
6949
7007
  updateStatus(slotParams, cellValue) {
6950
7008
  return vue.nextTick().then(() => {
6951
7009
  const { editRules } = props$1;
6952
- const { isActivated } = internalData;
6953
- if (isActivated && slotParams && editRules) {
7010
+ if (slotParams && editRules) {
6954
7011
  return $xeTable.handleCellRuleUpdateStatus("change", slotParams, cellValue);
6955
7012
  }
6956
7013
  });
@@ -7002,8 +7059,6 @@ const VxeTableComponent = comp.defineVxeComponent({
7002
7059
  internalData.mergeBodyList = [];
7003
7060
  internalData.mergeBodyMaps = {};
7004
7061
  internalData.mergeBodyCellMaps = {};
7005
- internalData.mergeBodyRowMaps = {};
7006
- internalData.mergeBodyColMaps = {};
7007
7062
  reactData.mergeBodyFlag++;
7008
7063
  return vue.nextTick().then(() => {
7009
7064
  return updateStyle();
@@ -7040,8 +7095,6 @@ const VxeTableComponent = comp.defineVxeComponent({
7040
7095
  internalData.mergeHeaderList = [];
7041
7096
  internalData.mergeHeaderMaps = {};
7042
7097
  internalData.mergeHeaderCellMaps = {};
7043
- internalData.mergeHeaderRowMaps = {};
7044
- internalData.mergeBodyColMaps = {};
7045
7098
  reactData.mergeHeadFlag++;
7046
7099
  return vue.nextTick().then(() => {
7047
7100
  return updateStyle();
@@ -7090,8 +7143,6 @@ const VxeTableComponent = comp.defineVxeComponent({
7090
7143
  internalData.mergeFooterList = [];
7091
7144
  internalData.mergeFooterMaps = {};
7092
7145
  internalData.mergeFooterCellMaps = {};
7093
- internalData.mergeFooterRowMaps = {};
7094
- internalData.mergeFooterColMaps = {};
7095
7146
  reactData.mergeFootFlag++;
7096
7147
  return vue.nextTick().then(() => {
7097
7148
  return updateStyle();
@@ -7270,7 +7321,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7270
7321
  else if (dom.getEventTargetNode(evnt, tableFilter.getRefMaps().refElem.value).flag) ;
7271
7322
  else {
7272
7323
  if (!dom.getEventTargetNode(evnt, document.body, "vxe-table--ignore-clear").flag) {
7273
- $xeTable.preventEvent(evnt, "event.clearFilter", internalData._currFilterParams, $xeTable.closeFilter);
7324
+ tablePrivateMethods.preventEvent(evnt, "event.clearFilter", internalData._currFilterParams, tableMethods.closeFilter);
7274
7325
  }
7275
7326
  }
7276
7327
  }
@@ -7280,7 +7331,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7280
7331
  else {
7281
7332
  if (!dom.getEventTargetNode(evnt, document.body, "vxe-table--ignore-clear").flag) {
7282
7333
  if (customStore.visible && $xeTable.closeCustom) {
7283
- $xeTable.preventEvent(evnt, "event.clearCustom", {}, () => {
7334
+ tablePrivateMethods.preventEvent(evnt, "event.clearCustom", {}, () => {
7284
7335
  $xeTable.closeCustom();
7285
7336
  $xeTable.dispatchEvent("custom", { type: "close" }, evnt);
7286
7337
  });
@@ -7295,11 +7346,11 @@ const VxeTableComponent = comp.defineVxeComponent({
7295
7346
  if ($validTooltip && dom.getEventTargetNode(evnt, $validTooltip.$el).flag) ;
7296
7347
  else if (!internalData._lastCallTime || internalData._lastCallTime + 50 < Date.now()) {
7297
7348
  if (!dom.getEventTargetNode(evnt, document.body, "vxe-table--ignore-clear").flag) {
7298
- $xeTable.preventEvent(evnt, "event.clearEdit", actived.args, () => {
7349
+ tablePrivateMethods.preventEvent(evnt, "event.clearEdit", actived.args, () => {
7299
7350
  let isClear;
7300
7351
  if (editOpts.mode === "row") {
7301
7352
  const rowTargetNode = dom.getEventTargetNode(evnt, el, "vxe-body--row");
7302
- const rowNodeRest = rowTargetNode.flag ? $xeTable.getRowNode(rowTargetNode.targetElem) : null;
7353
+ const rowNodeRest = rowTargetNode.flag ? tableMethods.getRowNode(rowTargetNode.targetElem) : null;
7303
7354
  isClear = rowNodeRest ? !$xeTable.eqRow(rowNodeRest.item, actived.args.row) : false;
7304
7355
  } else {
7305
7356
  isClear = !dom.getEventTargetNode(evnt, el, "col--edit").flag;
@@ -7340,7 +7391,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7340
7391
  if ($xeTable.getCellAreas) {
7341
7392
  const cellAreas = $xeTable.getCellAreas();
7342
7393
  if (cellAreas && cellAreas.length && !dom.getEventTargetNode(evnt, document.body, "vxe-table--ignore-areas-clear").flag) {
7343
- $xeTable.preventEvent(evnt, "event.clearAreas", {}, () => {
7394
+ tablePrivateMethods.preventEvent(evnt, "event.clearAreas", {}, () => {
7344
7395
  $xeTable.clearCellAreas();
7345
7396
  $xeTable.clearCopyCellArea();
7346
7397
  dispatchEvent("clear-cell-area-selection", { cellAreas }, evnt);
@@ -7355,22 +7406,20 @@ const VxeTableComponent = comp.defineVxeComponent({
7355
7406
  $xeTable.closeMenu();
7356
7407
  }
7357
7408
  }
7358
- if (!(actived.row && dom.getEventTargetNode(evnt, document.body, "vxe-table--ignore-clear").flag)) {
7359
- const isActivated = dom.getEventTargetNode(evnt, $xeGGWrapper ? $xeGGWrapper.getRefMaps().refElem.value : el).flag;
7360
- if (!isActivated && editRules && validOpts.autoClear) {
7361
- reactData.validErrorMaps = {};
7362
- }
7363
- internalData.isActivated = isActivated;
7409
+ const isActivated = dom.getEventTargetNode(evnt, $xeGGWrapper ? $xeGGWrapper.getRefMaps().refElem.value : el).flag;
7410
+ if (!isActivated && editRules && validOpts.autoClear) {
7411
+ reactData.validErrorMaps = {};
7364
7412
  }
7413
+ internalData.isActivated = isActivated;
7365
7414
  };
7366
7415
  const handleGlobalBlurEvent = () => {
7367
- $xeTable.closeFilter();
7416
+ tableMethods.closeFilter();
7368
7417
  if ($xeTable.closeMenu) {
7369
7418
  $xeTable.closeMenu();
7370
7419
  }
7371
7420
  };
7372
7421
  const handleGlobalMousewheelEvent = () => {
7373
- $xeTable.closeTooltip();
7422
+ tableMethods.closeTooltip();
7374
7423
  if ($xeTable.closeMenu) {
7375
7424
  $xeTable.closeMenu();
7376
7425
  }
@@ -7383,7 +7432,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7383
7432
  const { actived } = editStore;
7384
7433
  const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE);
7385
7434
  if (isEsc) {
7386
- $xeTable.preventEvent(evnt, "event.keydown", null, () => {
7435
+ tablePrivateMethods.preventEvent(evnt, "event.keydown", null, () => {
7387
7436
  dispatchEvent("keydown-start", {}, evnt);
7388
7437
  if (keyboardConfig && mouseConfig && mouseOpts.area && $xeTable.handleKeyboardCellAreaEvent) {
7389
7438
  $xeTable.handleKeyboardCellAreaEvent(evnt);
@@ -7392,7 +7441,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7392
7441
  if ($xeTable.closeMenu) {
7393
7442
  $xeTable.closeMenu();
7394
7443
  }
7395
- $xeTable.closeFilter();
7444
+ tableMethods.closeFilter();
7396
7445
  if (keyboardConfig && keyboardOpts.isEsc) {
7397
7446
  if (actived.row) {
7398
7447
  const params = actived.args;
@@ -7416,7 +7465,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7416
7465
  $xeTable.preventEvent(evnt, "event.keydown", null, () => {
7417
7466
  const { mouseConfig, keyboardConfig, treeConfig, editConfig, highlightCurrentRow, highlightCurrentColumn } = props$1;
7418
7467
  const { ctxMenuStore, editStore, currentRow } = reactData;
7419
- const { afterFullData, visibleColumn } = internalData;
7468
+ const { afterFullData } = internalData;
7420
7469
  const isContentMenu = computeIsContentMenu.value;
7421
7470
  const bodyMenu = computeBodyMenu.value;
7422
7471
  const keyboardOpts = computeKeyboardOpts.value;
@@ -7426,7 +7475,6 @@ const VxeTableComponent = comp.defineVxeComponent({
7426
7475
  const menuList = computeMenuList.value;
7427
7476
  const rowOpts = computeRowOpts.value;
7428
7477
  const columnOpts = computeColumnOpts.value;
7429
- const { isLastEnterAppendRow, beforeEnterMethod, enterMethod, isLastTabAppendRow, beforeTabMethod, tabMethod } = keyboardOpts;
7430
7478
  const { selected, actived } = editStore;
7431
7479
  const childrenField = treeOpts.children || treeOpts.childrenField;
7432
7480
  const keyCode = evnt.keyCode;
@@ -7475,9 +7523,9 @@ const VxeTableComponent = comp.defineVxeComponent({
7475
7523
  } else if (isSpacebar && keyboardConfig && keyboardOpts.isChecked && selected.row && selected.column && (selected.column.type === "checkbox" || selected.column.type === "radio")) {
7476
7524
  evnt.preventDefault();
7477
7525
  if (selected.column.type === "checkbox") {
7478
- $xeTable.handleToggleCheckRowEvent(evnt, selected.args);
7526
+ tablePrivateMethods.handleToggleCheckRowEvent(evnt, selected.args);
7479
7527
  } else {
7480
- $xeTable.triggerRadioRowEvent(evnt, selected.args);
7528
+ tablePrivateMethods.triggerRadioRowEvent(evnt, selected.args);
7481
7529
  }
7482
7530
  } else if (isF2 && utils.isEnableConf(editConfig)) {
7483
7531
  if (!isEditStatus) {
@@ -7493,6 +7541,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7493
7541
  internalData._keyCtx = false;
7494
7542
  }, 1e3);
7495
7543
  } else if (isEnter && !isAltKey && keyboardConfig && keyboardOpts.isEnter && (selected.row || actived.row || treeConfig && (rowOpts.isCurrent || highlightCurrentRow) && currentRow)) {
7544
+ const { isLastEnterAppendRow, beforeEnterMethod, enterMethod } = keyboardOpts;
7496
7545
  if (isControlKey) {
7497
7546
  if (actived.row) {
7498
7547
  const params = actived.args;
@@ -7505,8 +7554,6 @@ const VxeTableComponent = comp.defineVxeComponent({
7505
7554
  }
7506
7555
  } else {
7507
7556
  if (selected.row || actived.row) {
7508
- const activeRow = selected.row || actived.row;
7509
- const activeColumn = selected.column || actived.column;
7510
7557
  const activeParams = selected.row ? selected.args : actived.args;
7511
7558
  if (hasShiftKey) {
7512
7559
  if (keyboardOpts.enterToTab) {
@@ -7515,43 +7562,12 @@ const VxeTableComponent = comp.defineVxeComponent({
7515
7562
  $xeTable.moveEnterSelected(activeParams, isLeftArrow, true, isRightArrow, false, evnt);
7516
7563
  }
7517
7564
  } else {
7518
- const _rowIndex = $xeTable.getVTRowIndex(activeRow);
7519
- const _columnIndex = $xeTable.getVTColumnIndex(activeColumn);
7520
7565
  if (keyboardOpts.enterToTab) {
7521
- const ttrParams = {
7522
- row: activeRow,
7523
- rowIndex: $xeTable.getRowIndex(activeRow),
7524
- $rowIndex: $xeTable.getVMRowIndex(activeRow),
7525
- _rowIndex,
7526
- column: activeColumn,
7527
- columnIndex: $xeTable.getColumnIndex(activeColumn),
7528
- $columnIndex: $xeTable.getVMColumnIndex(activeColumn),
7529
- _columnIndex,
7530
- $table: $xeTable
7531
- };
7532
- if (!beforeTabMethod || beforeTabMethod(ttrParams) !== false) {
7533
- evnt.preventDefault();
7534
- if (isLastTabAppendRow) {
7535
- const newColumn = visibleColumn[0];
7536
- if (_rowIndex >= afterFullData.length - 1 && _columnIndex >= visibleColumn.length - 1) {
7537
- if (actived.row) {
7538
- $xeTable.handleClearEdit(evnt);
7539
- }
7540
- $xeTable.insertAt({}, -1).then(({ row: newRow }) => {
7541
- $xeTable.scrollToRow(newRow, newColumn);
7542
- $xeTable.handleSelected(Object.assign(Object.assign({}, activeParams), { row: newRow, column: newColumn }), evnt);
7543
- });
7544
- $xeTable.dispatchEvent("tab-append-row", ttrParams, evnt);
7545
- return;
7546
- }
7547
- }
7548
- if (tabMethod) {
7549
- tabMethod(ttrParams);
7550
- } else {
7551
- $xeTable.moveTabSelected(activeParams, hasShiftKey, evnt);
7552
- }
7553
- }
7566
+ $xeTable.moveTabSelected(activeParams, hasShiftKey, evnt);
7554
7567
  } else {
7568
+ const activeRow = selected.row || actived.row;
7569
+ const activeColumn = selected.column || actived.column;
7570
+ const _rowIndex = $xeTable.getVTRowIndex(activeRow);
7555
7571
  const etrParams = {
7556
7572
  row: activeRow,
7557
7573
  rowIndex: $xeTable.getRowIndex(activeRow),
@@ -7560,11 +7576,10 @@ const VxeTableComponent = comp.defineVxeComponent({
7560
7576
  column: activeColumn,
7561
7577
  columnIndex: $xeTable.getColumnIndex(activeColumn),
7562
7578
  $columnIndex: $xeTable.getVMColumnIndex(activeColumn),
7563
- _columnIndex,
7579
+ _columnIndex: $xeTable.getVTColumnIndex(activeColumn),
7564
7580
  $table: $xeTable
7565
7581
  };
7566
7582
  if (!beforeEnterMethod || beforeEnterMethod(etrParams) !== false) {
7567
- evnt.preventDefault();
7568
7583
  if (isLastEnterAppendRow) {
7569
7584
  if (_rowIndex >= afterFullData.length - 1) {
7570
7585
  $xeTable.insertAt({}, -1).then(({ row: newRow }) => {
@@ -7575,13 +7590,9 @@ const VxeTableComponent = comp.defineVxeComponent({
7575
7590
  return;
7576
7591
  }
7577
7592
  }
7593
+ $xeTable.moveEnterSelected(activeParams, isLeftArrow, false, isRightArrow, true, evnt);
7578
7594
  if (enterMethod) {
7579
7595
  enterMethod(etrParams);
7580
- } else {
7581
- if (actived.row) {
7582
- $xeTable.handleClearEdit(evnt);
7583
- }
7584
- $xeTable.moveEnterSelected(activeParams, isLeftArrow, false, isRightArrow, true, evnt);
7585
7596
  }
7586
7597
  }
7587
7598
  }
@@ -7615,57 +7626,19 @@ const VxeTableComponent = comp.defineVxeComponent({
7615
7626
  }
7616
7627
  }
7617
7628
  } else if (isTab && keyboardConfig && keyboardOpts.isTab) {
7618
- if (selected.row || actived.row) {
7619
- const activeRow = selected.row || actived.row;
7620
- const activeColumn = selected.column || actived.column;
7621
- const activeParams = selected.row ? selected.args : actived.args;
7622
- const _rowIndex = $xeTable.getVTRowIndex(activeRow);
7623
- const _columnIndex = $xeTable.getVTColumnIndex(activeColumn);
7624
- const ttrParams = {
7625
- row: activeRow,
7626
- rowIndex: $xeTable.getRowIndex(activeRow),
7627
- $rowIndex: $xeTable.getVMRowIndex(activeRow),
7628
- _rowIndex,
7629
- column: activeColumn,
7630
- columnIndex: $xeTable.getColumnIndex(activeColumn),
7631
- $columnIndex: $xeTable.getVMColumnIndex(activeColumn),
7632
- _columnIndex,
7633
- $table: $xeTable
7634
- };
7635
- if (!beforeTabMethod || beforeTabMethod(ttrParams) !== false) {
7636
- evnt.preventDefault();
7637
- if (isLastTabAppendRow) {
7638
- const newColumn = visibleColumn[0];
7639
- if (_rowIndex >= afterFullData.length - 1 && _columnIndex >= visibleColumn.length - 1) {
7640
- if (actived.row) {
7641
- $xeTable.handleClearEdit(evnt);
7642
- }
7643
- $xeTable.insertAt({}, -1).then(({ row: newRow }) => {
7644
- $xeTable.scrollToRow(newRow, newColumn);
7645
- $xeTable.handleSelected(Object.assign(Object.assign({}, activeParams), { row: newRow, column: newColumn }), evnt);
7646
- });
7647
- $xeTable.dispatchEvent("tab-append-row", ttrParams, evnt);
7648
- return;
7649
- }
7650
- }
7651
- if (tabMethod) {
7652
- tabMethod(ttrParams);
7653
- } else {
7654
- if (actived.row) {
7655
- $xeTable.handleClearEdit(evnt);
7656
- }
7657
- $xeTable.moveTabSelected(activeParams, hasShiftKey, evnt);
7658
- }
7659
- }
7629
+ if (selected.row || selected.column) {
7630
+ $xeTable.moveTabSelected(selected.args, hasShiftKey, evnt);
7631
+ } else if (actived.row || actived.column) {
7632
+ $xeTable.moveTabSelected(actived.args, hasShiftKey, evnt);
7660
7633
  }
7661
7634
  } else if (keyboardConfig && keyboardOpts.isDel && hasDeleteKey && utils.isEnableConf(editConfig) && (selected.row || selected.column)) {
7662
7635
  if (!isEditStatus) {
7663
7636
  const { delMethod } = keyboardOpts;
7664
7637
  const params = {
7665
7638
  row: selected.row,
7666
- rowIndex: $xeTable.getRowIndex(selected.row),
7639
+ rowIndex: tableMethods.getRowIndex(selected.row),
7667
7640
  column: selected.column,
7668
- columnIndex: $xeTable.getColumnIndex(selected.column),
7641
+ columnIndex: tableMethods.getColumnIndex(selected.column),
7669
7642
  $table: $xeTable,
7670
7643
  $grid: $xeGrid,
7671
7644
  $gantt: $xeGantt
@@ -7676,7 +7649,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7676
7649
  } else {
7677
7650
  util.setCellValue(selected.row, selected.column, null);
7678
7651
  }
7679
- $xeTable.updateFooter();
7652
+ tableMethods.updateFooter();
7680
7653
  dispatchEvent("cell-delete-value", params, evnt);
7681
7654
  }
7682
7655
  }
@@ -7756,8 +7729,8 @@ const VxeTableComponent = comp.defineVxeComponent({
7756
7729
  const { actived } = editStore;
7757
7730
  if (isActivated && !filterStore.visible) {
7758
7731
  if (!(actived.row || actived.column)) {
7759
- if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handlePeClAreaEvent) {
7760
- $xeTable.handlePeClAreaEvent(evnt);
7732
+ if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handlePasteCellAreaEvent) {
7733
+ $xeTable.handlePasteCellAreaEvent(evnt);
7761
7734
  }
7762
7735
  }
7763
7736
  dispatchEvent("paste", {}, evnt);
@@ -7772,8 +7745,8 @@ const VxeTableComponent = comp.defineVxeComponent({
7772
7745
  const { actived } = editStore;
7773
7746
  if (isActivated && !filterStore.visible) {
7774
7747
  if (!(actived.row || actived.column)) {
7775
- if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handleCyClAreaEvent) {
7776
- $xeTable.handleCyClAreaEvent(evnt);
7748
+ if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handleCopyCellAreaEvent) {
7749
+ $xeTable.handleCopyCellAreaEvent(evnt);
7777
7750
  }
7778
7751
  }
7779
7752
  dispatchEvent("copy", {}, evnt);
@@ -7810,7 +7783,7 @@ const VxeTableComponent = comp.defineVxeComponent({
7810
7783
  const $tooltip = refTooltip.value;
7811
7784
  clearTimeout(internalData.tooltipTimeout);
7812
7785
  if (isClear) {
7813
- $xeTable.closeTooltip();
7786
+ tableMethods.closeTooltip();
7814
7787
  } else {
7815
7788
  if ($tooltip && $tooltip.setActived) {
7816
7789
  $tooltip.setActived(true);
@@ -8148,7 +8121,6 @@ const VxeTableComponent = comp.defineVxeComponent({
8148
8121
  const expandOpts = computeExpandOpts.value;
8149
8122
  const treeOpts = computeTreeOpts.value;
8150
8123
  const radioOpts = computeRadioOpts.value;
8151
- const rowOpts = computeRowOpts.value;
8152
8124
  const checkboxOpts = computeCheckboxOpts.value;
8153
8125
  const childrenField = treeOpts.children || treeOpts.childrenField;
8154
8126
  const rowkey = util.getRowkey($xeTable);
@@ -8181,7 +8153,7 @@ const VxeTableComponent = comp.defineVxeComponent({
8181
8153
  record[childrenField] = null;
8182
8154
  }
8183
8155
  if (utils.eqEmptyValue(index.default.get(record, rowkey))) {
8184
- index.default.set(record, rowkey, util.createRowId(rowOpts, record, rowkey));
8156
+ index.default.set(record, rowkey, util.getRowUniqueId());
8185
8157
  }
8186
8158
  return record;
8187
8159
  });
@@ -8194,12 +8166,6 @@ const VxeTableComponent = comp.defineVxeComponent({
8194
8166
  if (force) {
8195
8167
  updateAfterFullData();
8196
8168
  fullList = handleVirtualTreeToList();
8197
- internalData.mergeHeaderRowMaps = {};
8198
- internalData.mergeHeaderColMaps = {};
8199
- internalData.mergeBodyRowMaps = {};
8200
- internalData.mergeBodyColMaps = {};
8201
- internalData.mergeFooterRowMaps = {};
8202
- internalData.mergeFooterColMaps = {};
8203
8169
  }
8204
8170
  const tableData = scrollYLoad ? fullList.slice(scrollYStore.startIndex, scrollYStore.endIndex) : fullList.slice(0);
8205
8171
  const visibleDataRowIdMaps = {};
@@ -8715,7 +8681,7 @@ const VxeTableComponent = comp.defineVxeComponent({
8715
8681
  fixedData: {},
8716
8682
  aggGroupData: {},
8717
8683
  aggFuncData: {}
8718
- } : $xeTable.getCustomStoreData();
8684
+ } : tableMethods.getCustomStoreData();
8719
8685
  if (updateStore) {
8720
8686
  return updateStore({
8721
8687
  $table: $xeTable,
@@ -8740,8 +8706,8 @@ const VxeTableComponent = comp.defineVxeComponent({
8740
8706
  $xeTable.clearCopyCellArea();
8741
8707
  }
8742
8708
  }
8743
- $xeTable.analyColumnWidth();
8744
- return $xeTable.refreshColumn(true);
8709
+ tablePrivateMethods.analyColumnWidth();
8710
+ return tableMethods.refreshColumn(true);
8745
8711
  },
8746
8712
  handleUpdateDataQueue() {
8747
8713
  reactData.upDataFlag++;
@@ -9090,31 +9056,22 @@ const VxeTableComponent = comp.defineVxeComponent({
9090
9056
  handleSelectRow({ row }, checked, isForce) {
9091
9057
  $xeTable.handleBatchSelectRows([row], checked, isForce);
9092
9058
  },
9093
- handleUpdateHeaderMerge() {
9094
- const { mergeHeaderList } = internalData;
9095
- const { mergeMaps, mergeRowMaps, mergeColMaps } = buildMergeData(mergeHeaderList);
9096
- internalData.mergeHeaderCellMaps = mergeMaps;
9097
- internalData.mergeHeaderRowMaps = mergeRowMaps;
9098
- internalData.mergeHeaderColMaps = mergeColMaps;
9099
- reactData.mergeHeadFlag++;
9100
- },
9101
9059
  /**
9102
9060
  * 处理合并
9103
9061
  */
9104
9062
  handleUpdateBodyMerge() {
9105
9063
  const { mergeBodyList } = internalData;
9106
- const { mergeMaps, mergeRowMaps, mergeColMaps } = buildMergeData(mergeBodyList);
9107
- internalData.mergeBodyCellMaps = mergeMaps;
9108
- internalData.mergeBodyRowMaps = mergeRowMaps;
9109
- internalData.mergeBodyColMaps = mergeColMaps;
9064
+ internalData.mergeBodyCellMaps = buildMergeData(mergeBodyList);
9110
9065
  reactData.mergeBodyFlag++;
9111
9066
  },
9067
+ handleUpdateHeaderMerge() {
9068
+ const { mergeHeaderList } = internalData;
9069
+ internalData.mergeHeaderCellMaps = buildMergeData(mergeHeaderList);
9070
+ reactData.mergeHeadFlag++;
9071
+ },
9112
9072
  handleUpdateFooterMerge() {
9113
9073
  const { mergeFooterList } = internalData;
9114
- const { mergeMaps, mergeRowMaps, mergeColMaps } = buildMergeData(mergeFooterList);
9115
- internalData.mergeFooterCellMaps = mergeMaps;
9116
- internalData.mergeFooterRowMaps = mergeRowMaps;
9117
- internalData.mergeFooterColMaps = mergeColMaps;
9074
+ internalData.mergeFooterCellMaps = buildMergeData(mergeFooterList);
9118
9075
  reactData.mergeFootFlag++;
9119
9076
  },
9120
9077
  handleAggregateSummaryData() {
@@ -9254,10 +9211,6 @@ const VxeTableComponent = comp.defineVxeComponent({
9254
9211
  if (sortOpts.trigger === "cell" && !(triggerResizable || triggerSort || triggerFilter)) {
9255
9212
  $xeTable.triggerSortEvent(evnt, column, getNextSortOrder(column));
9256
9213
  }
9257
- if ($xeGantt) {
9258
- const ganttReactData = $xeGantt.reactData;
9259
- ganttReactData.activeBarRowid = null;
9260
- }
9261
9214
  dispatchEvent("header-cell-click", Object.assign({ triggerResizable, triggerSort, triggerFilter, cell: cell2 }, params), evnt);
9262
9215
  if ((columnOpts.isCurrent || props$1.highlightCurrentColumn) && (!currentColumnOpts.trigger || ["header", "default"].includes(currentColumnOpts.trigger))) {
9263
9216
  $xeTable.triggerCurrentColumnEvent(evnt, params);
@@ -9363,10 +9316,6 @@ const VxeTableComponent = comp.defineVxeComponent({
9363
9316
  }
9364
9317
  }
9365
9318
  }
9366
- if ($xeGantt) {
9367
- const ganttReactData = $xeGantt.reactData;
9368
- ganttReactData.activeBarRowid = null;
9369
- }
9370
9319
  dispatchEvent("cell-click", params, evnt);
9371
9320
  },
9372
9321
  /**
@@ -9396,20 +9345,6 @@ const VxeTableComponent = comp.defineVxeComponent({
9396
9345
  }
9397
9346
  dispatchEvent("cell-dblclick", params, evnt);
9398
9347
  },
9399
- triggerFooterCellClickEvent(evnt, params) {
9400
- const cell2 = evnt.currentTarget;
9401
- params = Object.assign({ cell: cell2 }, params);
9402
- if ($xeGantt) {
9403
- const ganttReactData = $xeGantt.reactData;
9404
- ganttReactData.activeBarRowid = null;
9405
- }
9406
- $xeTable.dispatchEvent("footer-cell-click", params, evnt);
9407
- },
9408
- triggerFooterCellDblclickEvent(evnt, params) {
9409
- const cell2 = evnt.currentTarget;
9410
- params = Object.assign({ cell: cell2 }, params);
9411
- $xeTable.dispatchEvent("footer-cell-dblclick", params, evnt);
9412
- },
9413
9348
  handleToggleCheckRowEvent(evnt, params) {
9414
9349
  const { selectCheckboxMaps } = internalData;
9415
9350
  const checkboxOpts = computeCheckboxOpts.value;
@@ -9491,7 +9426,7 @@ const VxeTableComponent = comp.defineVxeComponent({
9491
9426
  const { selectRadioRow: oldValue } = reactData;
9492
9427
  const { row } = params;
9493
9428
  const radioOpts = computeRadioOpts.value;
9494
- const { trigger, strict, checkMethod } = radioOpts;
9429
+ const { trigger, checkMethod } = radioOpts;
9495
9430
  if (trigger === "manual") {
9496
9431
  return;
9497
9432
  }
@@ -9499,22 +9434,17 @@ const VxeTableComponent = comp.defineVxeComponent({
9499
9434
  if (!checkMethod || checkMethod({ $table: $xeTable, row })) {
9500
9435
  let newValue = row;
9501
9436
  let isChange = oldValue !== newValue;
9502
- if (strict) {
9437
+ if (isChange) {
9503
9438
  handleCheckedRadioRow(newValue);
9504
- } else {
9505
- if (oldValue === newValue) {
9506
- newValue = null;
9507
- }
9508
- isChange = oldValue !== newValue;
9509
- if (isChange && newValue) {
9510
- handleCheckedRadioRow(newValue);
9511
- } else {
9439
+ } else if (!radioOpts.strict) {
9440
+ isChange = oldValue === newValue;
9441
+ if (isChange) {
9512
9442
  newValue = null;
9513
9443
  $xeTable.clearRadioRow();
9514
9444
  }
9515
9445
  }
9516
9446
  if (isChange) {
9517
- dispatchEvent("radio-change", Object.assign({ oldValue, newValue, selected: !!newValue }, params), evnt);
9447
+ dispatchEvent("radio-change", Object.assign({ oldValue, newValue }, params), evnt);
9518
9448
  }
9519
9449
  }
9520
9450
  },
@@ -9523,29 +9453,16 @@ const VxeTableComponent = comp.defineVxeComponent({
9523
9453
  const columnOpts = computeColumnOpts.value;
9524
9454
  const currentColumnOpts = computeCurrentColumnOpts.value;
9525
9455
  const beforeRowMethod = currentColumnOpts.beforeSelectMethod || columnOpts.currentMethod;
9526
- let newValue = params.column;
9527
- const { trigger, strict } = currentColumnOpts;
9456
+ const { column: newValue } = params;
9457
+ const { trigger } = currentColumnOpts;
9528
9458
  if (trigger === "manual") {
9529
9459
  return;
9530
9460
  }
9531
- let isChange = oldValue !== newValue;
9461
+ const isChange = oldValue !== newValue;
9532
9462
  if (!beforeRowMethod || beforeRowMethod({ column: newValue, $table: $xeTable })) {
9533
- if (strict) {
9534
- $xeTable.setCurrentColumn(newValue);
9535
- } else {
9536
- if (oldValue === newValue) {
9537
- newValue = null;
9538
- }
9539
- isChange = oldValue !== newValue;
9540
- if (isChange && newValue) {
9541
- $xeTable.setCurrentColumn(newValue);
9542
- } else {
9543
- newValue = null;
9544
- $xeTable.clearCurrentColumn();
9545
- }
9546
- }
9463
+ $xeTable.setCurrentColumn(newValue);
9547
9464
  if (isChange) {
9548
- dispatchEvent("current-column-change", Object.assign({ oldValue, newValue, selected: !!newValue }, params), evnt);
9465
+ dispatchEvent("current-column-change", Object.assign({ oldValue, newValue }, params), evnt);
9549
9466
  }
9550
9467
  } else {
9551
9468
  dispatchEvent("current-column-disabled", params, evnt);
@@ -9556,29 +9473,16 @@ const VxeTableComponent = comp.defineVxeComponent({
9556
9473
  const rowOpts = computeRowOpts.value;
9557
9474
  const currentRowOpts = computeCurrentRowOpts.value;
9558
9475
  const beforeRowMethod = currentRowOpts.beforeSelectMethod || rowOpts.currentMethod;
9559
- let { row: newValue } = params;
9560
- const { trigger, strict } = currentRowOpts;
9476
+ const { row: newValue } = params;
9477
+ const { trigger } = currentRowOpts;
9561
9478
  if (trigger === "manual") {
9562
9479
  return;
9563
9480
  }
9564
- let isChange = oldValue !== newValue;
9481
+ const isChange = oldValue !== newValue;
9565
9482
  if (!beforeRowMethod || beforeRowMethod({ row: newValue, $table: $xeTable })) {
9566
- if (strict) {
9567
- $xeTable.setCurrentRow(newValue);
9568
- } else {
9569
- if (oldValue === newValue) {
9570
- newValue = null;
9571
- }
9572
- isChange = oldValue !== newValue;
9573
- if (isChange && newValue) {
9574
- $xeTable.setCurrentRow(newValue);
9575
- } else {
9576
- newValue = null;
9577
- $xeTable.clearCurrentRow();
9578
- }
9579
- }
9483
+ $xeTable.setCurrentRow(newValue);
9580
9484
  if (isChange) {
9581
- dispatchEvent("current-row-change", Object.assign({ oldValue, newValue, selected: !!newValue }, params), evnt);
9485
+ dispatchEvent("current-row-change", Object.assign({ oldValue, newValue }, params), evnt);
9582
9486
  dispatchEvent("current-change", Object.assign({ oldValue, newValue }, params), evnt);
9583
9487
  }
9584
9488
  } else {
@@ -9670,7 +9574,7 @@ const VxeTableComponent = comp.defineVxeComponent({
9670
9574
  const mouseOpts = computeMouseOpts.value;
9671
9575
  const { field, sortable, order } = column;
9672
9576
  if (sortable) {
9673
- const params = { $table: $xeTable, $event: evnt, column, field, property: field, order, sortList: $xeTable.getSortColumns(), sortTime: column.sortTime };
9577
+ const params = { $table: $xeTable, $event: evnt, column, field, property: field, order, sortList: tableMethods.getSortColumns(), sortTime: column.sortTime };
9674
9578
  if (mouseConfig && mouseOpts.area && $xeTable.handleSortEvent) {
9675
9579
  $xeTable.handleSortEvent(evnt, params);
9676
9580
  }
@@ -9921,7 +9825,6 @@ const VxeTableComponent = comp.defineVxeComponent({
9921
9825
  if (transform) {
9922
9826
  if (oldRest && newRest) {
9923
9827
  const fullList = index.default.toTreeArray(internalData.afterTreeFullData, {
9924
- updated: false,
9925
9828
  key: rowField,
9926
9829
  parentKey: parentField,
9927
9830
  children: mapChildrenField
@@ -10854,7 +10757,7 @@ const VxeTableComponent = comp.defineVxeComponent({
10854
10757
  }
10855
10758
  internalData.lastScrollTop = scrollTop;
10856
10759
  }
10857
- internalData.lastSTime = Date.now();
10760
+ reactData.lastScrollTime = Date.now();
10858
10761
  const evntParams = Object.assign({
10859
10762
  source: sourceType,
10860
10763
  scrollTop,
@@ -11093,7 +10996,7 @@ const VxeTableComponent = comp.defineVxeComponent({
11093
10996
  if (!bodyScrollElem) {
11094
10997
  return;
11095
10998
  }
11096
- const wheelSpeed = getWheelSpeed(internalData.lastSTime);
10999
+ const wheelSpeed = getWheelSpeed(reactData.lastScrollTime);
11097
11000
  const deltaTop = shiftKey ? 0 : deltaY * wheelSpeed;
11098
11001
  const deltaLeft = (shiftKey ? deltaX || deltaY : deltaX) * wheelSpeed;
11099
11002
  const currScrollTop = bodyScrollElem.scrollTop;
@@ -11141,9 +11044,8 @@ const VxeTableComponent = comp.defineVxeComponent({
11141
11044
  if (isRollX) {
11142
11045
  evnt.preventDefault();
11143
11046
  internalData.inWheelScroll = true;
11144
- dom.wheelScrollLeftTo(scrollLeft, (offsetLeft) => {
11145
- internalData.inWheelScroll = true;
11146
- const currLeftNum = offsetLeft;
11047
+ if (browseObj.firefox || browseObj.safari) {
11048
+ const currLeftNum = scrollLeft;
11147
11049
  dom.setScrollLeft(xHandleEl, currLeftNum);
11148
11050
  dom.setScrollLeft(bodyScrollElem, currLeftNum);
11149
11051
  dom.setScrollLeft(headerScrollElem, currLeftNum);
@@ -11155,14 +11057,29 @@ const VxeTableComponent = comp.defineVxeComponent({
11155
11057
  type: "table",
11156
11058
  fixed: ""
11157
11059
  });
11158
- });
11060
+ } else {
11061
+ wheelScrollLeftTo(scrollLeft, (offsetLeft) => {
11062
+ internalData.inWheelScroll = true;
11063
+ const currLeftNum = offsetLeft;
11064
+ dom.setScrollLeft(xHandleEl, currLeftNum);
11065
+ dom.setScrollLeft(bodyScrollElem, currLeftNum);
11066
+ dom.setScrollLeft(headerScrollElem, currLeftNum);
11067
+ dom.setScrollLeft(footerScrollElem, currLeftNum);
11068
+ if (scrollXLoad) {
11069
+ $xeTable.triggerScrollXEvent(evnt);
11070
+ }
11071
+ $xeTable.handleScrollEvent(evnt, isRollY, isRollX, bodyScrollElem.scrollTop, currLeftNum, {
11072
+ type: "table",
11073
+ fixed: ""
11074
+ });
11075
+ });
11076
+ }
11159
11077
  }
11160
11078
  if (isRollY) {
11161
11079
  evnt.preventDefault();
11162
11080
  internalData.inWheelScroll = true;
11163
- dom.wheelScrollTopTo(scrollTop, (offsetTop) => {
11164
- internalData.inWheelScroll = true;
11165
- const currTopNum = offsetTop;
11081
+ if (browseObj.firefox || browseObj.safari) {
11082
+ const currTopNum = scrollTop;
11166
11083
  dom.setScrollTop(yHandleEl, currTopNum);
11167
11084
  dom.setScrollTop(bodyScrollElem, currTopNum);
11168
11085
  dom.setScrollTop(leftScrollElem, currTopNum);
@@ -11172,11 +11089,29 @@ const VxeTableComponent = comp.defineVxeComponent({
11172
11089
  if (scrollYLoad) {
11173
11090
  $xeTable.triggerScrollYEvent(evnt);
11174
11091
  }
11175
- $xeTable.handleScrollEvent(evnt, isRollY, isRollX, offsetTop, bodyScrollElem.scrollLeft, {
11092
+ $xeTable.handleScrollEvent(evnt, isRollY, isRollX, currTopNum, bodyScrollElem.scrollLeft, {
11176
11093
  type: "table",
11177
11094
  fixed: ""
11178
11095
  });
11179
- });
11096
+ } else {
11097
+ wheelScrollTopTo(scrollTop - currScrollTop, (offsetTop) => {
11098
+ internalData.inWheelScroll = true;
11099
+ const currTopNum = bodyScrollElem.scrollTop + offsetTop;
11100
+ dom.setScrollTop(yHandleEl, currTopNum);
11101
+ dom.setScrollTop(bodyScrollElem, currTopNum);
11102
+ dom.setScrollTop(leftScrollElem, currTopNum);
11103
+ dom.setScrollTop(rightScrollElem, currTopNum);
11104
+ dom.setScrollTop(rowExpandEl, currTopNum);
11105
+ syncGanttScrollTop(currTopNum);
11106
+ if (scrollYLoad) {
11107
+ $xeTable.triggerScrollYEvent(evnt);
11108
+ }
11109
+ $xeTable.handleScrollEvent(evnt, isRollY, isRollX, currTopNum, bodyScrollElem.scrollLeft, {
11110
+ type: "table",
11111
+ fixed: ""
11112
+ });
11113
+ });
11114
+ }
11180
11115
  }
11181
11116
  },
11182
11117
  triggerVirtualScrollXEvent(evnt) {
@@ -11552,13 +11487,13 @@ const VxeTableComponent = comp.defineVxeComponent({
11552
11487
  * 行 hover 事件
11553
11488
  */
11554
11489
  triggerHoverEvent(evnt, { row }) {
11555
- $xeTable.setHoverRow(row);
11490
+ tablePrivateMethods.setHoverRow(row);
11556
11491
  },
11557
11492
  setHoverRow(row) {
11558
11493
  const $xeGanttView = internalData.xeGanttView;
11559
11494
  const rowid = util.getRowid($xeTable, row);
11560
11495
  const el = refElem.value;
11561
- $xeTable.clearHoverRow();
11496
+ tablePrivateMethods.clearHoverRow();
11562
11497
  if (el) {
11563
11498
  index.default.arrayEach(el.querySelectorAll(`.vxe-body--row[rowid="${rowid}"]`), (elem) => dom.addClass(elem, "row--hover"));
11564
11499
  }
@@ -11583,7 +11518,7 @@ const VxeTableComponent = comp.defineVxeComponent({
11583
11518
  * @deprecated
11584
11519
  */
11585
11520
  getCell(row, column) {
11586
- return $xeTable.getCellElement(row, column);
11521
+ return tableMethods.getCellElement(row, column);
11587
11522
  },
11588
11523
  findRowIndexOf(list, row) {
11589
11524
  return row ? index.default.findIndexOf(list, (item) => $xeTable.eqRow(item, row)) : -1;
@@ -11825,11 +11760,7 @@ const VxeTableComponent = comp.defineVxeComponent({
11825
11760
  }],
11826
11761
  rowid,
11827
11762
  style: cellStyle
11828
- }, [
11829
- vue.h("div", {
11830
- class: "vxe-body--row-expanded-content"
11831
- }, expandColumn.renderData(expandParams))
11832
- ]));
11763
+ }, expandColumn.renderData(expandParams)));
11833
11764
  });
11834
11765
  }
11835
11766
  return vue.h("div", {
@@ -11984,7 +11915,6 @@ const VxeTableComponent = comp.defineVxeComponent({
11984
11915
  footer: slots.footerTooltip || slots["footer-tooltip"]
11985
11916
  };
11986
11917
  const currTooltipSlot = tooltipStore.visible && tooltipStore.type ? tipSlots[tooltipStore.type] : null;
11987
- const tableStyle = computeTableStyle.value;
11988
11918
  const rowDragOpts = computeRowDragOpts.value;
11989
11919
  const tableTipConfig = computeTableTipConfig.value;
11990
11920
  const validTipConfig = computeValidTipConfig.value;
@@ -12005,8 +11935,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12005
11935
  const columnDragOpts = computeColumnDragOpts.value;
12006
11936
  const scrollbarXToTop = computeScrollbarXToTop.value;
12007
11937
  const scrollbarYToLeft = computeScrollbarYToLeft.value;
12008
- const customSimpleMode = computeCustomSimpleMode.value;
12009
- const showCustomSimpleOutside = customSimpleMode === "outside";
12010
11938
  const { isCrossTableDrag } = rowDragOpts;
12011
11939
  const tbOns = {
12012
11940
  onKeydown: keydownEvent,
@@ -12049,7 +11977,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12049
11977
  "not--scroll-x": !overflowX,
12050
11978
  "is--virtual-x": scrollXLoad,
12051
11979
  "is--virtual-y": scrollYLoad
12052
- }], style: tableStyle, spellcheck: false }, tbOns), [
11980
+ }], spellcheck: false }, tbOns), [
12053
11981
  /**
12054
11982
  * 隐藏列
12055
11983
  */
@@ -12144,7 +12072,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12144
12072
  /**
12145
12073
  * 自定义列
12146
12074
  */
12147
- !showCustomSimpleOutside && initStore.custom ? vue.h(panel.default, {
12075
+ initStore.custom ? vue.h(panel.default, {
12148
12076
  key: "cs",
12149
12077
  ref: refTableCustom,
12150
12078
  customStore
@@ -12182,14 +12110,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12182
12110
  vue.h("div", {
12183
12111
  ref: refPopupWrapperElem
12184
12112
  }, [
12185
- /**
12186
- * 自定义列
12187
- */
12188
- showCustomSimpleOutside && initStore.custom ? vue.h(panel.default, {
12189
- key: "cs",
12190
- ref: refTableCustom,
12191
- customStore
12192
- }) : renderEmptyElement($xeTable),
12193
12113
  /**
12194
12114
  * 筛选
12195
12115
  */
@@ -12253,10 +12173,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12253
12173
  minWidth: tableTipConfig.minWidth,
12254
12174
  minHeight: tableTipConfig.minHeight,
12255
12175
  maxWidth: tableTipConfig.maxWidth,
12256
- maxHeight: tableTipConfig.maxHeight,
12257
- placement: tableTipConfig.placement,
12258
- defaultPlacement: tableTipConfig.defaultPlacement,
12259
- popupClassName: tableTipConfig.popupClassName
12176
+ maxHeight: tableTipConfig.maxHeight
12260
12177
  }, currTooltipSlot ? {
12261
12178
  content: () => {
12262
12179
  const { type, row, column, content: tooltipContent } = tooltipStore;
@@ -12283,7 +12200,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12283
12200
  /**
12284
12201
  * 校验提示
12285
12202
  */
12286
- props$1.editRules && validOpts.showErrorMessage && (validOpts.message === "default" ? !height : validOpts.message === "tooltip") ? vue.h(VxeUITooltipComponent, {
12203
+ props$1.editRules && validOpts.showMessage && (validOpts.message === "default" ? !height : validOpts.message === "tooltip") ? vue.h(VxeUITooltipComponent, {
12287
12204
  key: "vtp",
12288
12205
  ref: refValidTooltip,
12289
12206
  class: [{
@@ -12321,7 +12238,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12321
12238
  if ((scrollXLoad || scrollYLoad) && (expandColumn && expandOpts.mode !== "fixed")) {
12322
12239
  log.warnLog("vxe.error.scrollErrProp", ["column.type=expand"]);
12323
12240
  }
12324
- return $xeTable.recalculate();
12241
+ return tableMethods.recalculate();
12325
12242
  });
12326
12243
  });
12327
12244
  const staticColumnFlag = vue.ref(0);
@@ -12342,16 +12259,16 @@ const VxeTableComponent = comp.defineVxeComponent({
12342
12259
  tableColumnFlag.value++;
12343
12260
  });
12344
12261
  vue.watch(tableColumnFlag, () => {
12345
- $xeTable.analyColumnWidth();
12262
+ tablePrivateMethods.analyColumnWidth();
12346
12263
  });
12347
12264
  vue.watch(() => reactData.upDataFlag, () => {
12348
12265
  vue.nextTick(() => {
12349
- $xeTable.updateData();
12266
+ tableMethods.updateData();
12350
12267
  });
12351
12268
  });
12352
12269
  vue.watch(() => reactData.reColumnFlag, () => {
12353
12270
  vue.nextTick(() => {
12354
- $xeTable.refreshColumn();
12271
+ tableMethods.refreshColumn();
12355
12272
  });
12356
12273
  });
12357
12274
  const reLayoutFlag = vue.ref(0);
@@ -12364,16 +12281,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12364
12281
  vue.watch(() => props$1.showFooter, () => {
12365
12282
  reLayoutFlag.value++;
12366
12283
  });
12367
- vue.watch(() => props$1.showHeaderOverflow, () => {
12368
- reLayoutFlag.value++;
12369
- });
12370
- vue.watch(() => props$1.showOverflow, () => {
12371
- updateColumnAllOverflow();
12372
- reLayoutFlag.value++;
12373
- });
12374
- vue.watch(() => props$1.showFooterOverflow, () => {
12375
- reLayoutFlag.value++;
12376
- });
12377
12284
  vue.watch(() => reactData.overflowX, () => {
12378
12285
  reLayoutFlag.value++;
12379
12286
  });
@@ -12480,21 +12387,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12480
12387
  });
12481
12388
  }
12482
12389
  });
12483
- const kfFlag = vue.ref(0);
12484
- vue.watch(() => reactData.updateColFlag, () => {
12485
- kfFlag.value++;
12486
- });
12487
- vue.watch(computeKeepFields, () => {
12488
- kfFlag.value++;
12489
- });
12490
- vue.watch(kfFlag, () => {
12491
- const keepFields = computeKeepFields.value;
12492
- const kpfMaps = {};
12493
- keepFields.forEach((field) => {
12494
- kpfMaps[field] = 1;
12495
- });
12496
- internalData.keepUpdateFieldMaps = kpfMaps;
12497
- });
12498
12390
  if ($xeTabs) {
12499
12391
  vue.watch(() => $xeTabs ? $xeTabs.reactData.resizeFlag : null, () => {
12500
12392
  handleGlobalResizeEvent();
@@ -12510,11 +12402,11 @@ const VxeTableComponent = comp.defineVxeComponent({
12510
12402
  }
12511
12403
  }
12512
12404
  });
12513
- $xeTable.preventEvent(null, "created", { $table: $xeTable });
12405
+ tablePrivateMethods.preventEvent(null, "created", { $table: $xeTable });
12514
12406
  let resizeObserver;
12515
12407
  vue.onActivated(() => {
12516
- $xeTable.recalculate().then(() => $xeTable.refreshScroll());
12517
- $xeTable.preventEvent(null, "activated", { $table: $xeTable });
12408
+ tableMethods.recalculate().then(() => tableMethods.refreshScroll());
12409
+ tablePrivateMethods.preventEvent(null, "activated", { $table: $xeTable });
12518
12410
  });
12519
12411
  vue.onDeactivated(() => {
12520
12412
  const { filterStore } = reactData;
@@ -12523,7 +12415,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12523
12415
  }
12524
12416
  $xeTable.closeTooltip();
12525
12417
  internalData.isActivated = false;
12526
- $xeTable.preventEvent(null, "deactivated", { $table: $xeTable });
12418
+ tablePrivateMethods.preventEvent(null, "deactivated", { $table: $xeTable });
12527
12419
  });
12528
12420
  vue.onMounted(() => {
12529
12421
  const { exportConfig, importConfig, treeConfig, minHeight } = props$1;
@@ -12544,8 +12436,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12544
12436
  const importOpts = computeImportOpts.value;
12545
12437
  const rowDragOpts = computeRowDragOpts.value;
12546
12438
  const areaOpts = computeAreaOpts.value;
12547
- const sortOpts = computeSortOpts.value;
12548
- const filterOpts = computeFilterOpts.value;
12549
12439
  const { groupFields } = aggregateOpts;
12550
12440
  if ($xeGantt) {
12551
12441
  const { refClassifyWrapperElem } = $xeGantt.getRefMaps();
@@ -12582,14 +12472,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12582
12472
  if (treeConfig && !treeOpts.transform && props$1.stripe) {
12583
12473
  log.warnLog("vxe.error.noTree", ["stripe"]);
12584
12474
  }
12585
- if (treeConfig && !treeOpts.transform) {
12586
- if (sortOpts.isDeep) {
12587
- log.warnLog("vxe.error.reqSupportProp", ["transform=false", "sort-config.isDeep=false"]);
12588
- }
12589
- if (filterOpts.isDeep) {
12590
- log.warnLog("vxe.error.reqSupportProp", ["transform=false", "filter-config.isDeep=false"]);
12591
- }
12592
- }
12593
12475
  if (props$1.showFooter && !(props$1.footerMethod || props$1.footerData)) {
12594
12476
  log.warnLog("vxe.error.reqProp", ["footer-data | footer-method"]);
12595
12477
  }
@@ -12631,7 +12513,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12631
12513
  if (rowOpts.height && !props$1.showOverflow) {
12632
12514
  log.warnLog("vxe.error.notProp", ["table.show-overflow"]);
12633
12515
  }
12634
- if (!$xeTable.triggerClAreaModnEvent) {
12516
+ if (!$xeTable.triggerCellAreaModnEvent) {
12635
12517
  if (props$1.areaConfig) {
12636
12518
  log.warnLog("vxe.error.notProp", ["area-config"]);
12637
12519
  }
@@ -12733,7 +12615,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12733
12615
  vue.nextTick(() => {
12734
12616
  if (props$1.autoResize) {
12735
12617
  const el = refElem.value;
12736
- const parentEl = $xeTable.getParentElem();
12618
+ const parentEl = tablePrivateMethods.getParentElem();
12737
12619
  resizeObserver = globalResize.create(() => {
12738
12620
  if (props$1.autoResize) {
12739
12621
  handleResizeEvent();
@@ -12765,10 +12647,6 @@ const VxeTableComponent = comp.defineVxeComponent({
12765
12647
  $xeTable.preventEvent(null, "mounted", { $table: $xeTable });
12766
12648
  });
12767
12649
  vue.onBeforeUnmount(() => {
12768
- const { _sToTime } = internalData;
12769
- if (_sToTime) {
12770
- clearTimeout(_sToTime);
12771
- }
12772
12650
  const tableViewportEl = refTableViewportElem.value;
12773
12651
  if (tableViewportEl) {
12774
12652
  tableViewportEl.removeEventListener("wheel", $xeTable.triggerBodyWheelEvent);
@@ -12780,7 +12658,7 @@ const VxeTableComponent = comp.defineVxeComponent({
12780
12658
  resizeObserver.disconnect();
12781
12659
  }
12782
12660
  $xeTable.closeTooltip();
12783
- $xeTable.closeFilter();
12661
+ tableMethods.closeFilter();
12784
12662
  if ($xeTable.closeMenu) {
12785
12663
  $xeTable.closeMenu();
12786
12664
  }
@@ -12793,12 +12671,11 @@ const VxeTableComponent = comp.defineVxeComponent({
12793
12671
  globalEvents.off($xeTable, "keydown");
12794
12672
  globalEvents.off($xeTable, "resize");
12795
12673
  globalEvents.off($xeTable, "contextmenu");
12796
- $xeTable.preventEvent(null, "beforeUnmount", { $table: $xeTable });
12797
- index.default.assign(reactData, util.createReactData());
12798
- index.default.assign(internalData, util.createInternalData());
12674
+ tablePrivateMethods.preventEvent(null, "beforeUnmount", { $table: $xeTable });
12799
12675
  });
12800
12676
  vue.onUnmounted(() => {
12801
- $xeTable.preventEvent(null, "unmounted", { $table: $xeTable });
12677
+ tablePrivateMethods.preventEvent(null, "unmounted", { $table: $xeTable });
12678
+ index.default.assign(internalData, util.createInternalData());
12802
12679
  });
12803
12680
  vue.nextTick(() => {
12804
12681
  if (props$1.loading) {